libcaes-20240413/0000755000175000017500000000000014606477654014236 5ustar00lordyestalordyestalibcaes-20240413/COPYING0000644000175000017500000010451514606473411015262 0ustar00lordyestalordyesta GNU GENERAL PUBLIC LICENSE Version 3, 29 June 2007 Copyright (C) 2007 Free Software Foundation, Inc. Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. Preamble The GNU General Public License is a free, copyleft license for software and other kinds of works. The licenses for most software and other practical works are designed to take away your freedom to share and change the works. By contrast, the GNU General Public License is intended to guarantee your freedom to share and change all versions of a program--to make sure it remains free software for all its users. We, the Free Software Foundation, use the GNU General Public License for most of our software; it applies also to any other work released this way by its authors. You can apply it to your programs, too. When we speak of free software, we are referring to freedom, not price. Our General Public Licenses are designed to make sure that you have the freedom to distribute copies of free software (and charge for them if you wish), that you receive source code or can get it if you want it, that you can change the software or use pieces of it in new free programs, and that you know you can do these things. To protect your rights, we need to prevent others from denying you these rights or asking you to surrender the rights. Therefore, you have certain responsibilities if you distribute copies of the software, or if you modify it: responsibilities to respect the freedom of others. For example, if you distribute copies of such a program, whether gratis or for a fee, you must pass on to the recipients the same freedoms that you received. You must make sure that they, too, receive or can get the source code. And you must show them these terms so they know their rights. Developers that use the GNU GPL protect your rights with two steps: (1) assert copyright on the software, and (2) offer you this License giving you legal permission to copy, distribute and/or modify it. For the developers' and authors' protection, the GPL clearly explains that there is no warranty for this free software. For both users' and authors' sake, the GPL requires that modified versions be marked as changed, so that their problems will not be attributed erroneously to authors of previous versions. Some devices are designed to deny users access to install or run modified versions of the software inside them, although the manufacturer can do so. This is fundamentally incompatible with the aim of protecting users' freedom to change the software. The systematic pattern of such abuse occurs in the area of products for individuals to use, which is precisely where it is most unacceptable. Therefore, we have designed this version of the GPL to prohibit the practice for those products. If such problems arise substantially in other domains, we stand ready to extend this provision to those domains in future versions of the GPL, as needed to protect the freedom of users. Finally, every program is threatened constantly by software patents. States should not allow patents to restrict development and use of software on general-purpose computers, but in those that do, we wish to avoid the special danger that patents applied to a free program could make it effectively proprietary. To prevent this, the GPL assures that patents cannot be used to render the program non-free. The precise terms and conditions for copying, distribution and modification follow. TERMS AND CONDITIONS 0. Definitions. "This License" refers to version 3 of the GNU General Public License. "Copyright" also means copyright-like laws that apply to other kinds of works, such as semiconductor masks. "The Program" refers to any copyrightable work licensed under this License. Each licensee is addressed as "you". "Licensees" and "recipients" may be individuals or organizations. To "modify" a work means to copy from or adapt all or part of the work in a fashion requiring copyright permission, other than the making of an exact copy. The resulting work is called a "modified version" of the earlier work or a work "based on" the earlier work. A "covered work" means either the unmodified Program or a work based on the Program. To "propagate" a work means to do anything with it that, without permission, would make you directly or secondarily liable for infringement under applicable copyright law, except executing it on a computer or modifying a private copy. Propagation includes copying, distribution (with or without modification), making available to the public, and in some countries other activities as well. To "convey" a work means any kind of propagation that enables other parties to make or receive copies. Mere interaction with a user through a computer network, with no transfer of a copy, is not conveying. An interactive user interface displays "Appropriate Legal Notices" to the extent that it includes a convenient and prominently visible feature that (1) displays an appropriate copyright notice, and (2) tells the user that there is no warranty for the work (except to the extent that warranties are provided), that licensees may convey the work under this License, and how to view a copy of this License. If the interface presents a list of user commands or options, such as a menu, a prominent item in the list meets this criterion. 1. Source Code. The "source code" for a work means the preferred form of the work for making modifications to it. "Object code" means any non-source form of a work. A "Standard Interface" means an interface that either is an official standard defined by a recognized standards body, or, in the case of interfaces specified for a particular programming language, one that is widely used among developers working in that language. The "System Libraries" of an executable work include anything, other than the work as a whole, that (a) is included in the normal form of packaging a Major Component, but which is not part of that Major Component, and (b) serves only to enable use of the work with that Major Component, or to implement a Standard Interface for which an implementation is available to the public in source code form. A "Major Component", in this context, means a major essential component (kernel, window system, and so on) of the specific operating system (if any) on which the executable work runs, or a compiler used to produce the work, or an object code interpreter used to run it. The "Corresponding Source" for a work in object code form means all the source code needed to generate, install, and (for an executable work) run the object code and to modify the work, including scripts to control those activities. However, it does not include the work's System Libraries, or general-purpose tools or generally available free programs which are used unmodified in performing those activities but which are not part of the work. For example, Corresponding Source includes interface definition files associated with source files for the work, and the source code for shared libraries and dynamically linked subprograms that the work is specifically designed to require, such as by intimate data communication or control flow between those subprograms and other parts of the work. The Corresponding Source need not include anything that users can regenerate automatically from other parts of the Corresponding Source. The Corresponding Source for a work in source code form is that same work. 2. Basic Permissions. All rights granted under this License are granted for the term of copyright on the Program, and are irrevocable provided the stated conditions are met. This License explicitly affirms your unlimited permission to run the unmodified Program. The output from running a covered work is covered by this License only if the output, given its content, constitutes a covered work. This License acknowledges your rights of fair use or other equivalent, as provided by copyright law. You may make, run and propagate covered works that you do not convey, without conditions so long as your license otherwise remains in force. You may convey covered works to others for the sole purpose of having them make modifications exclusively for you, or provide you with facilities for running those works, provided that you comply with the terms of this License in conveying all material for which you do not control copyright. Those thus making or running the covered works for you must do so exclusively on your behalf, under your direction and control, on terms that prohibit them from making any copies of your copyrighted material outside their relationship with you. Conveying under any other circumstances is permitted solely under the conditions stated below. Sublicensing is not allowed; section 10 makes it unnecessary. 3. Protecting Users' Legal Rights From Anti-Circumvention Law. No covered work shall be deemed part of an effective technological measure under any applicable law fulfilling obligations under article 11 of the WIPO copyright treaty adopted on 20 December 1996, or similar laws prohibiting or restricting circumvention of such measures. When you convey a covered work, you waive any legal power to forbid circumvention of technological measures to the extent such circumvention is effected by exercising rights under this License with respect to the covered work, and you disclaim any intention to limit operation or modification of the work as a means of enforcing, against the work's users, your or third parties' legal rights to forbid circumvention of technological measures. 4. Conveying Verbatim Copies. You may convey verbatim copies of the Program's source code as you receive it, in any medium, provided that you conspicuously and appropriately publish on each copy an appropriate copyright notice; keep intact all notices stating that this License and any non-permissive terms added in accord with section 7 apply to the code; keep intact all notices of the absence of any warranty; and give all recipients a copy of this License along with the Program. You may charge any price or no price for each copy that you convey, and you may offer support or warranty protection for a fee. 5. Conveying Modified Source Versions. You may convey a work based on the Program, or the modifications to produce it from the Program, in the form of source code under the terms of section 4, provided that you also meet all of these conditions: a) The work must carry prominent notices stating that you modified it, and giving a relevant date. b) The work must carry prominent notices stating that it is released under this License and any conditions added under section 7. This requirement modifies the requirement in section 4 to "keep intact all notices". c) You must license the entire work, as a whole, under this License to anyone who comes into possession of a copy. This License will therefore apply, along with any applicable section 7 additional terms, to the whole of the work, and all its parts, regardless of how they are packaged. This License gives no permission to license the work in any other way, but it does not invalidate such permission if you have separately received it. d) If the work has interactive user interfaces, each must display Appropriate Legal Notices; however, if the Program has interactive interfaces that do not display Appropriate Legal Notices, your work need not make them do so. A compilation of a covered work with other separate and independent works, which are not by their nature extensions of the covered work, and which are not combined with it such as to form a larger program, in or on a volume of a storage or distribution medium, is called an "aggregate" if the compilation and its resulting copyright are not used to limit the access or legal rights of the compilation's users beyond what the individual works permit. Inclusion of a covered work in an aggregate does not cause this License to apply to the other parts of the aggregate. 6. Conveying Non-Source Forms. You may convey a covered work in object code form under the terms of sections 4 and 5, provided that you also convey the machine-readable Corresponding Source under the terms of this License, in one of these ways: a) Convey the object code in, or embodied in, a physical product (including a physical distribution medium), accompanied by the Corresponding Source fixed on a durable physical medium customarily used for software interchange. b) Convey the object code in, or embodied in, a physical product (including a physical distribution medium), accompanied by a written offer, valid for at least three years and valid for as long as you offer spare parts or customer support for that product model, to give anyone who possesses the object code either (1) a copy of the Corresponding Source for all the software in the product that is covered by this License, on a durable physical medium customarily used for software interchange, for a price no more than your reasonable cost of physically performing this conveying of source, or (2) access to copy the Corresponding Source from a network server at no charge. c) Convey individual copies of the object code with a copy of the written offer to provide the Corresponding Source. This alternative is allowed only occasionally and noncommercially, and only if you received the object code with such an offer, in accord with subsection 6b. d) Convey the object code by offering access from a designated place (gratis or for a charge), and offer equivalent access to the Corresponding Source in the same way through the same place at no further charge. You need not require recipients to copy the Corresponding Source along with the object code. If the place to copy the object code is a network server, the Corresponding Source may be on a different server (operated by you or a third party) that supports equivalent copying facilities, provided you maintain clear directions next to the object code saying where to find the Corresponding Source. Regardless of what server hosts the Corresponding Source, you remain obligated to ensure that it is available for as long as needed to satisfy these requirements. e) Convey the object code using peer-to-peer transmission, provided you inform other peers where the object code and Corresponding Source of the work are being offered to the general public at no charge under subsection 6d. A separable portion of the object code, whose source code is excluded from the Corresponding Source as a System Library, need not be included in conveying the object code work. A "User Product" is either (1) a "consumer product", which means any tangible personal property which is normally used for personal, family, or household purposes, or (2) anything designed or sold for incorporation into a dwelling. In determining whether a product is a consumer product, doubtful cases shall be resolved in favor of coverage. For a particular product received by a particular user, "normally used" refers to a typical or common use of that class of product, regardless of the status of the particular user or of the way in which the particular user actually uses, or expects or is expected to use, the product. A product is a consumer product regardless of whether the product has substantial commercial, industrial or non-consumer uses, unless such uses represent the only significant mode of use of the product. "Installation Information" for a User Product means any methods, procedures, authorization keys, or other information required to install and execute modified versions of a covered work in that User Product from a modified version of its Corresponding Source. The information must suffice to ensure that the continued functioning of the modified object code is in no case prevented or interfered with solely because modification has been made. If you convey an object code work under this section in, or with, or specifically for use in, a User Product, and the conveying occurs as part of a transaction in which the right of possession and use of the User Product is transferred to the recipient in perpetuity or for a fixed term (regardless of how the transaction is characterized), the Corresponding Source conveyed under this section must be accompanied by the Installation Information. But this requirement does not apply if neither you nor any third party retains the ability to install modified object code on the User Product (for example, the work has been installed in ROM). The requirement to provide Installation Information does not include a requirement to continue to provide support service, warranty, or updates for a work that has been modified or installed by the recipient, or for the User Product in which it has been modified or installed. Access to a network may be denied when the modification itself materially and adversely affects the operation of the network or violates the rules and protocols for communication across the network. Corresponding Source conveyed, and Installation Information provided, in accord with this section must be in a format that is publicly documented (and with an implementation available to the public in source code form), and must require no special password or key for unpacking, reading or copying. 7. Additional Terms. "Additional permissions" are terms that supplement the terms of this License by making exceptions from one or more of its conditions. Additional permissions that are applicable to the entire Program shall be treated as though they were included in this License, to the extent that they are valid under applicable law. If additional permissions apply only to part of the Program, that part may be used separately under those permissions, but the entire Program remains governed by this License without regard to the additional permissions. When you convey a copy of a covered work, you may at your option remove any additional permissions from that copy, or from any part of it. (Additional permissions may be written to require their own removal in certain cases when you modify the work.) You may place additional permissions on material, added by you to a covered work, for which you have or can give appropriate copyright permission. Notwithstanding any other provision of this License, for material you add to a covered work, you may (if authorized by the copyright holders of that material) supplement the terms of this License with terms: a) Disclaiming warranty or limiting liability differently from the terms of sections 15 and 16 of this License; or b) Requiring preservation of specified reasonable legal notices or author attributions in that material or in the Appropriate Legal Notices displayed by works containing it; or c) Prohibiting misrepresentation of the origin of that material, or requiring that modified versions of such material be marked in reasonable ways as different from the original version; or d) Limiting the use for publicity purposes of names of licensors or authors of the material; or e) Declining to grant rights under trademark law for use of some trade names, trademarks, or service marks; or f) Requiring indemnification of licensors and authors of that material by anyone who conveys the material (or modified versions of it) with contractual assumptions of liability to the recipient, for any liability that these contractual assumptions directly impose on those licensors and authors. All other non-permissive additional terms are considered "further restrictions" within the meaning of section 10. If the Program as you received it, or any part of it, contains a notice stating that it is governed by this License along with a term that is a further restriction, you may remove that term. If a license document contains a further restriction but permits relicensing or conveying under this License, you may add to a covered work material governed by the terms of that license document, provided that the further restriction does not survive such relicensing or conveying. If you add terms to a covered work in accord with this section, you must place, in the relevant source files, a statement of the additional terms that apply to those files, or a notice indicating where to find the applicable terms. Additional terms, permissive or non-permissive, may be stated in the form of a separately written license, or stated as exceptions; the above requirements apply either way. 8. Termination. You may not propagate or modify a covered work except as expressly provided under this License. Any attempt otherwise to propagate or modify it is void, and will automatically terminate your rights under this License (including any patent licenses granted under the third paragraph of section 11). However, if you cease all violation of this License, then your license from a particular copyright holder is reinstated (a) provisionally, unless and until the copyright holder explicitly and finally terminates your license, and (b) permanently, if the copyright holder fails to notify you of the violation by some reasonable means prior to 60 days after the cessation. Moreover, your license from a particular copyright holder is reinstated permanently if the copyright holder notifies you of the violation by some reasonable means, this is the first time you have received notice of violation of this License (for any work) from that copyright holder, and you cure the violation prior to 30 days after your receipt of the notice. Termination of your rights under this section does not terminate the licenses of parties who have received copies or rights from you under this License. If your rights have been terminated and not permanently reinstated, you do not qualify to receive new licenses for the same material under section 10. 9. Acceptance Not Required for Having Copies. You are not required to accept this License in order to receive or run a copy of the Program. Ancillary propagation of a covered work occurring solely as a consequence of using peer-to-peer transmission to receive a copy likewise does not require acceptance. However, nothing other than this License grants you permission to propagate or modify any covered work. These actions infringe copyright if you do not accept this License. Therefore, by modifying or propagating a covered work, you indicate your acceptance of this License to do so. 10. Automatic Licensing of Downstream Recipients. Each time you convey a covered work, the recipient automatically receives a license from the original licensors, to run, modify and propagate that work, subject to this License. You are not responsible for enforcing compliance by third parties with this License. An "entity transaction" is a transaction transferring control of an organization, or substantially all assets of one, or subdividing an organization, or merging organizations. If propagation of a covered work results from an entity transaction, each party to that transaction who receives a copy of the work also receives whatever licenses to the work the party's predecessor in interest had or could give under the previous paragraph, plus a right to possession of the Corresponding Source of the work from the predecessor in interest, if the predecessor has it or can get it with reasonable efforts. You may not impose any further restrictions on the exercise of the rights granted or affirmed under this License. For example, you may not impose a license fee, royalty, or other charge for exercise of rights granted under this License, and you may not initiate litigation (including a cross-claim or counterclaim in a lawsuit) alleging that any patent claim is infringed by making, using, selling, offering for sale, or importing the Program or any portion of it. 11. Patents. A "contributor" is a copyright holder who authorizes use under this License of the Program or a work on which the Program is based. The work thus licensed is called the contributor's "contributor version". A contributor's "essential patent claims" are all patent claims owned or controlled by the contributor, whether already acquired or hereafter acquired, that would be infringed by some manner, permitted by this License, of making, using, or selling its contributor version, but do not include claims that would be infringed only as a consequence of further modification of the contributor version. For purposes of this definition, "control" includes the right to grant patent sublicenses in a manner consistent with the requirements of this License. Each contributor grants you a non-exclusive, worldwide, royalty-free patent license under the contributor's essential patent claims, to make, use, sell, offer for sale, import and otherwise run, modify and propagate the contents of its contributor version. In the following three paragraphs, a "patent license" is any express agreement or commitment, however denominated, not to enforce a patent (such as an express permission to practice a patent or covenant not to sue for patent infringement). To "grant" such a patent license to a party means to make such an agreement or commitment not to enforce a patent against the party. If you convey a covered work, knowingly relying on a patent license, and the Corresponding Source of the work is not available for anyone to copy, free of charge and under the terms of this License, through a publicly available network server or other readily accessible means, then you must either (1) cause the Corresponding Source to be so available, or (2) arrange to deprive yourself of the benefit of the patent license for this particular work, or (3) arrange, in a manner consistent with the requirements of this License, to extend the patent license to downstream recipients. "Knowingly relying" means you have actual knowledge that, but for the patent license, your conveying the covered work in a country, or your recipient's use of the covered work in a country, would infringe one or more identifiable patents in that country that you have reason to believe are valid. If, pursuant to or in connection with a single transaction or arrangement, you convey, or propagate by procuring conveyance of, a covered work, and grant a patent license to some of the parties receiving the covered work authorizing them to use, propagate, modify or convey a specific copy of the covered work, then the patent license you grant is automatically extended to all recipients of the covered work and works based on it. A patent license is "discriminatory" if it does not include within the scope of its coverage, prohibits the exercise of, or is conditioned on the non-exercise of one or more of the rights that are specifically granted under this License. You may not convey a covered work if you are a party to an arrangement with a third party that is in the business of distributing software, under which you make payment to the third party based on the extent of your activity of conveying the work, and under which the third party grants, to any of the parties who would receive the covered work from you, a discriminatory patent license (a) in connection with copies of the covered work conveyed by you (or copies made from those copies), or (b) primarily for and in connection with specific products or compilations that contain the covered work, unless you entered into that arrangement, or that patent license was granted, prior to 28 March 2007. Nothing in this License shall be construed as excluding or limiting any implied license or other defenses to infringement that may otherwise be available to you under applicable patent law. 12. No Surrender of Others' Freedom. If conditions are imposed on you (whether by court order, agreement or otherwise) that contradict the conditions of this License, they do not excuse you from the conditions of this License. If you cannot convey a covered work so as to satisfy simultaneously your obligations under this License and any other pertinent obligations, then as a consequence you may not convey it at all. For example, if you agree to terms that obligate you to collect a royalty for further conveying from those to whom you convey the Program, the only way you could satisfy both those terms and this License would be to refrain entirely from conveying the Program. 13. Use with the GNU Affero General Public License. Notwithstanding any other provision of this License, you have permission to link or combine any covered work with a work licensed under version 3 of the GNU Affero General Public License into a single combined work, and to convey the resulting work. The terms of this License will continue to apply to the part which is the covered work, but the special requirements of the GNU Affero General Public License, section 13, concerning interaction through a network will apply to the combination as such. 14. Revised Versions of this License. The Free Software Foundation may publish revised and/or new versions of the GNU General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. Each version is given a distinguishing version number. If the Program specifies that a certain numbered version of the GNU General Public License "or any later version" applies to it, you have the option of following the terms and conditions either of that numbered version or of any later version published by the Free Software Foundation. If the Program does not specify a version number of the GNU General Public License, you may choose any version ever published by the Free Software Foundation. If the Program specifies that a proxy can decide which future versions of the GNU General Public License can be used, that proxy's public statement of acceptance of a version permanently authorizes you to choose that version for the Program. Later license versions may give you additional or different permissions. However, no additional obligations are imposed on any author or copyright holder as a result of your choosing to follow a later version. 15. Disclaimer of Warranty. THERE IS NO WARRANTY FOR THE PROGRAM, TO THE EXTENT PERMITTED BY APPLICABLE LAW. EXCEPT WHEN OTHERWISE STATED IN WRITING THE COPYRIGHT HOLDERS AND/OR OTHER PARTIES PROVIDE THE PROGRAM "AS IS" WITHOUT WARRANTY OF ANY KIND, EITHER EXPRESSED OR IMPLIED, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. THE ENTIRE RISK AS TO THE QUALITY AND PERFORMANCE OF THE PROGRAM IS WITH YOU. SHOULD THE PROGRAM PROVE DEFECTIVE, YOU ASSUME THE COST OF ALL NECESSARY SERVICING, REPAIR OR CORRECTION. 16. Limitation of Liability. IN NO EVENT UNLESS REQUIRED BY APPLICABLE LAW OR AGREED TO IN WRITING WILL ANY COPYRIGHT HOLDER, OR ANY OTHER PARTY WHO MODIFIES AND/OR CONVEYS THE PROGRAM AS PERMITTED ABOVE, BE LIABLE TO YOU FOR DAMAGES, INCLUDING ANY GENERAL, SPECIAL, INCIDENTAL OR CONSEQUENTIAL DAMAGES ARISING OUT OF THE USE OR INABILITY TO USE THE PROGRAM (INCLUDING BUT NOT LIMITED TO LOSS OF DATA OR DATA BEING RENDERED INACCURATE OR LOSSES SUSTAINED BY YOU OR THIRD PARTIES OR A FAILURE OF THE PROGRAM TO OPERATE WITH ANY OTHER PROGRAMS), EVEN IF SUCH HOLDER OR OTHER PARTY HAS BEEN ADVISED OF THE POSSIBILITY OF SUCH DAMAGES. 17. Interpretation of Sections 15 and 16. If the disclaimer of warranty and limitation of liability provided above cannot be given local legal effect according to their terms, reviewing courts shall apply local law that most closely approximates an absolute waiver of all civil liability in connection with the Program, unless a warranty or assumption of liability accompanies a copy of the Program in return for a fee. END OF TERMS AND CONDITIONS How to Apply These Terms to Your New Programs If you develop a new program, and you want it to be of the greatest possible use to the public, the best way to achieve this is to make it free software which everyone can redistribute and change under these terms. To do so, attach the following notices to the program. It is safest to attach them to the start of each source file to most effectively state the exclusion of warranty; and each file should have at least the "copyright" line and a pointer to where the full notice is found. Copyright (C) This program 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 3 of the License, or (at your option) any later version. This program 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 this program. If not, see . Also add information on how to contact you by electronic and paper mail. If the program does terminal interaction, make it output a short notice like this when it starts in an interactive mode: Copyright (C) This program comes with ABSOLUTELY NO WARRANTY; for details type `show w'. This is free software, and you are welcome to redistribute it under certain conditions; type `show c' for details. The hypothetical commands `show w' and `show c' should show the appropriate parts of the General Public License. Of course, your program's commands might be different; for a GUI interface, you would use an "about box". You should also get your employer (if you work as a programmer) or school, if any, to sign a "copyright disclaimer" for the program, if necessary. For more information on this, and how to apply and follow the GNU GPL, see . The GNU General Public License does not permit incorporating your program into proprietary programs. If your program is a subroutine library, you may consider it more useful to permit linking proprietary applications with the library. If this is what you want to do, use the GNU Lesser General Public License instead of this License. But first, please read . libcaes-20240413/install-sh0000755000175000017500000003577614606477627016264 0ustar00lordyestalordyesta#!/bin/sh # install - install a program, script, or datafile scriptversion=2020-11-14.01; # UTC # This originates from X11R5 (mit/util/scripts/install.sh), which was # later released in X11R6 (xc/config/util/install.sh) with the # following copyright and license. # # Copyright (C) 1994 X Consortium # # Permission is hereby granted, free of charge, to any person obtaining a copy # of this software and associated documentation files (the "Software"), to # deal in the Software without restriction, including without limitation the # rights to use, copy, modify, merge, publish, distribute, sublicense, and/or # sell copies of the Software, and to permit persons to whom the Software is # furnished to do so, subject to the following conditions: # # The above copyright notice and this permission notice shall be included in # all copies or substantial portions of the Software. # # THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR # IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, # FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE # X CONSORTIUM BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN # AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNEC- # TION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. # # Except as contained in this notice, the name of the X Consortium shall not # be used in advertising or otherwise to promote the sale, use or other deal- # ings in this Software without prior written authorization from the X Consor- # tium. # # # FSF changes to this file are in the public domain. # # Calling this script install-sh is preferred over install.sh, to prevent # 'make' implicit rules from creating a file called install from it # when there is no Makefile. # # This script is compatible with the BSD install script, but was written # from scratch. tab=' ' nl=' ' IFS=" $tab$nl" # Set DOITPROG to "echo" to test this script. doit=${DOITPROG-} doit_exec=${doit:-exec} # Put in absolute file names if you don't have them in your path; # or use environment vars. chgrpprog=${CHGRPPROG-chgrp} chmodprog=${CHMODPROG-chmod} chownprog=${CHOWNPROG-chown} cmpprog=${CMPPROG-cmp} cpprog=${CPPROG-cp} mkdirprog=${MKDIRPROG-mkdir} mvprog=${MVPROG-mv} rmprog=${RMPROG-rm} stripprog=${STRIPPROG-strip} posix_mkdir= # Desired mode of installed file. mode=0755 # Create dirs (including intermediate dirs) using mode 755. # This is like GNU 'install' as of coreutils 8.32 (2020). mkdir_umask=22 backupsuffix= chgrpcmd= chmodcmd=$chmodprog chowncmd= mvcmd=$mvprog rmcmd="$rmprog -f" stripcmd= src= dst= dir_arg= dst_arg= copy_on_change=false is_target_a_directory=possibly usage="\ Usage: $0 [OPTION]... [-T] SRCFILE DSTFILE or: $0 [OPTION]... SRCFILES... DIRECTORY or: $0 [OPTION]... -t DIRECTORY SRCFILES... or: $0 [OPTION]... -d DIRECTORIES... In the 1st form, copy SRCFILE to DSTFILE. In the 2nd and 3rd, copy all SRCFILES to DIRECTORY. In the 4th, create DIRECTORIES. Options: --help display this help and exit. --version display version info and exit. -c (ignored) -C install only if different (preserve data modification time) -d create directories instead of installing files. -g GROUP $chgrpprog installed files to GROUP. -m MODE $chmodprog installed files to MODE. -o USER $chownprog installed files to USER. -p pass -p to $cpprog. -s $stripprog installed files. -S SUFFIX attempt to back up existing files, with suffix SUFFIX. -t DIRECTORY install into DIRECTORY. -T report an error if DSTFILE is a directory. Environment variables override the default commands: CHGRPPROG CHMODPROG CHOWNPROG CMPPROG CPPROG MKDIRPROG MVPROG RMPROG STRIPPROG By default, rm is invoked with -f; when overridden with RMPROG, it's up to you to specify -f if you want it. If -S is not specified, no backups are attempted. Email bug reports to bug-automake@gnu.org. Automake home page: https://www.gnu.org/software/automake/ " while test $# -ne 0; do case $1 in -c) ;; -C) copy_on_change=true;; -d) dir_arg=true;; -g) chgrpcmd="$chgrpprog $2" shift;; --help) echo "$usage"; exit $?;; -m) mode=$2 case $mode in *' '* | *"$tab"* | *"$nl"* | *'*'* | *'?'* | *'['*) echo "$0: invalid mode: $mode" >&2 exit 1;; esac shift;; -o) chowncmd="$chownprog $2" shift;; -p) cpprog="$cpprog -p";; -s) stripcmd=$stripprog;; -S) backupsuffix="$2" shift;; -t) is_target_a_directory=always dst_arg=$2 # Protect names problematic for 'test' and other utilities. case $dst_arg in -* | [=\(\)!]) dst_arg=./$dst_arg;; esac shift;; -T) is_target_a_directory=never;; --version) echo "$0 $scriptversion"; exit $?;; --) shift break;; -*) echo "$0: invalid option: $1" >&2 exit 1;; *) break;; esac shift done # We allow the use of options -d and -T together, by making -d # take the precedence; this is for compatibility with GNU install. if test -n "$dir_arg"; then if test -n "$dst_arg"; then echo "$0: target directory not allowed when installing a directory." >&2 exit 1 fi fi if test $# -ne 0 && test -z "$dir_arg$dst_arg"; then # When -d is used, all remaining arguments are directories to create. # When -t is used, the destination is already specified. # Otherwise, the last argument is the destination. Remove it from $@. for arg do if test -n "$dst_arg"; then # $@ is not empty: it contains at least $arg. set fnord "$@" "$dst_arg" shift # fnord fi shift # arg dst_arg=$arg # Protect names problematic for 'test' and other utilities. case $dst_arg in -* | [=\(\)!]) dst_arg=./$dst_arg;; esac done fi if test $# -eq 0; then if test -z "$dir_arg"; then echo "$0: no input file specified." >&2 exit 1 fi # It's OK to call 'install-sh -d' without argument. # This can happen when creating conditional directories. exit 0 fi if test -z "$dir_arg"; then if test $# -gt 1 || test "$is_target_a_directory" = always; then if test ! -d "$dst_arg"; then echo "$0: $dst_arg: Is not a directory." >&2 exit 1 fi fi fi if test -z "$dir_arg"; then do_exit='(exit $ret); exit $ret' trap "ret=129; $do_exit" 1 trap "ret=130; $do_exit" 2 trap "ret=141; $do_exit" 13 trap "ret=143; $do_exit" 15 # Set umask so as not to create temps with too-generous modes. # However, 'strip' requires both read and write access to temps. case $mode in # Optimize common cases. *644) cp_umask=133;; *755) cp_umask=22;; *[0-7]) if test -z "$stripcmd"; then u_plus_rw= else u_plus_rw='% 200' fi cp_umask=`expr '(' 777 - $mode % 1000 ')' $u_plus_rw`;; *) if test -z "$stripcmd"; then u_plus_rw= else u_plus_rw=,u+rw fi cp_umask=$mode$u_plus_rw;; esac fi for src do # Protect names problematic for 'test' and other utilities. case $src in -* | [=\(\)!]) src=./$src;; esac if test -n "$dir_arg"; then dst=$src dstdir=$dst test -d "$dstdir" dstdir_status=$? # Don't chown directories that already exist. if test $dstdir_status = 0; then chowncmd="" fi else # Waiting for this to be detected by the "$cpprog $src $dsttmp" command # might cause directories to be created, which would be especially bad # if $src (and thus $dsttmp) contains '*'. if test ! -f "$src" && test ! -d "$src"; then echo "$0: $src does not exist." >&2 exit 1 fi if test -z "$dst_arg"; then echo "$0: no destination specified." >&2 exit 1 fi dst=$dst_arg # If destination is a directory, append the input filename. if test -d "$dst"; then if test "$is_target_a_directory" = never; then echo "$0: $dst_arg: Is a directory" >&2 exit 1 fi dstdir=$dst dstbase=`basename "$src"` case $dst in */) dst=$dst$dstbase;; *) dst=$dst/$dstbase;; esac dstdir_status=0 else dstdir=`dirname "$dst"` test -d "$dstdir" dstdir_status=$? fi fi case $dstdir in */) dstdirslash=$dstdir;; *) dstdirslash=$dstdir/;; esac obsolete_mkdir_used=false if test $dstdir_status != 0; then case $posix_mkdir in '') # With -d, create the new directory with the user-specified mode. # Otherwise, rely on $mkdir_umask. if test -n "$dir_arg"; then mkdir_mode=-m$mode else mkdir_mode= fi posix_mkdir=false # The $RANDOM variable is not portable (e.g., dash). Use it # here however when possible just to lower collision chance. tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$ trap ' ret=$? rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" 2>/dev/null exit $ret ' 0 # Because "mkdir -p" follows existing symlinks and we likely work # directly in world-writeable /tmp, make sure that the '$tmpdir' # directory is successfully created first before we actually test # 'mkdir -p'. if (umask $mkdir_umask && $mkdirprog $mkdir_mode "$tmpdir" && exec $mkdirprog $mkdir_mode -p -- "$tmpdir/a/b") >/dev/null 2>&1 then if test -z "$dir_arg" || { # Check for POSIX incompatibilities with -m. # HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or # other-writable bit of parent directory when it shouldn't. # FreeBSD 6.1 mkdir -m -p sets mode of existing directory. test_tmpdir="$tmpdir/a" ls_ld_tmpdir=`ls -ld "$test_tmpdir"` case $ls_ld_tmpdir in d????-?r-*) different_mode=700;; d????-?--*) different_mode=755;; *) false;; esac && $mkdirprog -m$different_mode -p -- "$test_tmpdir" && { ls_ld_tmpdir_1=`ls -ld "$test_tmpdir"` test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1" } } then posix_mkdir=: fi rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" else # Remove any dirs left behind by ancient mkdir implementations. rmdir ./$mkdir_mode ./-p ./-- "$tmpdir" 2>/dev/null fi trap '' 0;; esac if $posix_mkdir && ( umask $mkdir_umask && $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir" ) then : else # mkdir does not conform to POSIX, # or it failed possibly due to a race condition. Create the # directory the slow way, step by step, checking for races as we go. case $dstdir in /*) prefix='/';; [-=\(\)!]*) prefix='./';; *) prefix='';; esac oIFS=$IFS IFS=/ set -f set fnord $dstdir shift set +f IFS=$oIFS prefixes= for d do test X"$d" = X && continue prefix=$prefix$d if test -d "$prefix"; then prefixes= else if $posix_mkdir; then (umask $mkdir_umask && $doit_exec $mkdirprog $mkdir_mode -p -- "$dstdir") && break # Don't fail if two instances are running concurrently. test -d "$prefix" || exit 1 else case $prefix in *\'*) qprefix=`echo "$prefix" | sed "s/'/'\\\\\\\\''/g"`;; *) qprefix=$prefix;; esac prefixes="$prefixes '$qprefix'" fi fi prefix=$prefix/ done if test -n "$prefixes"; then # Don't fail if two instances are running concurrently. (umask $mkdir_umask && eval "\$doit_exec \$mkdirprog $prefixes") || test -d "$dstdir" || exit 1 obsolete_mkdir_used=true fi fi fi if test -n "$dir_arg"; then { test -z "$chowncmd" || $doit $chowncmd "$dst"; } && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dst"; } && { test "$obsolete_mkdir_used$chowncmd$chgrpcmd" = false || test -z "$chmodcmd" || $doit $chmodcmd $mode "$dst"; } || exit 1 else # Make a couple of temp file names in the proper directory. dsttmp=${dstdirslash}_inst.$$_ rmtmp=${dstdirslash}_rm.$$_ # Trap to clean up those temp files at exit. trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0 # Copy the file name to the temp name. (umask $cp_umask && { test -z "$stripcmd" || { # Create $dsttmp read-write so that cp doesn't create it read-only, # which would cause strip to fail. if test -z "$doit"; then : >"$dsttmp" # No need to fork-exec 'touch'. else $doit touch "$dsttmp" fi } } && $doit_exec $cpprog "$src" "$dsttmp") && # and set any options; do chmod last to preserve setuid bits. # # If any of these fail, we abort the whole thing. If we want to # ignore errors from any of these, just make sure not to ignore # errors from the above "$doit $cpprog $src $dsttmp" command. # { test -z "$chowncmd" || $doit $chowncmd "$dsttmp"; } && { test -z "$chgrpcmd" || $doit $chgrpcmd "$dsttmp"; } && { test -z "$stripcmd" || $doit $stripcmd "$dsttmp"; } && { test -z "$chmodcmd" || $doit $chmodcmd $mode "$dsttmp"; } && # If -C, don't bother to copy if it wouldn't change the file. if $copy_on_change && old=`LC_ALL=C ls -dlL "$dst" 2>/dev/null` && new=`LC_ALL=C ls -dlL "$dsttmp" 2>/dev/null` && set -f && set X $old && old=:$2:$4:$5:$6 && set X $new && new=:$2:$4:$5:$6 && set +f && test "$old" = "$new" && $cmpprog "$dst" "$dsttmp" >/dev/null 2>&1 then rm -f "$dsttmp" else # If $backupsuffix is set, and the file being installed # already exists, attempt a backup. Don't worry if it fails, # e.g., if mv doesn't support -f. if test -n "$backupsuffix" && test -f "$dst"; then $doit $mvcmd -f "$dst" "$dst$backupsuffix" 2>/dev/null fi # Rename the file to the real destination. $doit $mvcmd -f "$dsttmp" "$dst" 2>/dev/null || # The rename failed, perhaps because mv can't rename something else # to itself, or perhaps because mv is so ancient that it does not # support -f. { # Now remove or move aside any old file at destination location. # We try this two ways since rm can't unlink itself on some # systems and the destination file might be busy for other # reasons. In this case, the final cleanup might fail but the new # file should still install successfully. { test ! -f "$dst" || $doit $rmcmd "$dst" 2>/dev/null || { $doit $mvcmd -f "$dst" "$rmtmp" 2>/dev/null && { $doit $rmcmd "$rmtmp" 2>/dev/null; :; } } || { echo "$0: cannot unlink or rename $dst" >&2 (exit 1); exit 1 } } && # Now rename the file to the real destination. $doit $mvcmd "$dsttmp" "$dst" } fi || exit 1 trap '' 0 fi done # Local variables: # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: libcaes-20240413/NEWS0000644000175000017500000000000014606473411014706 0ustar00lordyestalordyestalibcaes-20240413/depcomp0000755000175000017500000005602014606477627015616 0ustar00lordyestalordyesta#! /bin/sh # depcomp - compile a program generating dependencies as side-effects scriptversion=2018-03-07.03; # UTC # Copyright (C) 1999-2021 Free Software Foundation, Inc. # This program 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, or (at your option) # any later version. # This program 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 this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. # Originally written by Alexandre Oliva . case $1 in '') echo "$0: No command. Try '$0 --help' for more information." 1>&2 exit 1; ;; -h | --h*) cat <<\EOF Usage: depcomp [--help] [--version] PROGRAM [ARGS] Run PROGRAMS ARGS to compile a file, generating dependencies as side-effects. Environment variables: depmode Dependency tracking mode. source Source file read by 'PROGRAMS ARGS'. object Object file output by 'PROGRAMS ARGS'. DEPDIR directory where to store dependencies. depfile Dependency file to output. tmpdepfile Temporary file to use when outputting dependencies. libtool Whether libtool is used (yes/no). Report bugs to . EOF exit $? ;; -v | --v*) echo "depcomp $scriptversion" exit $? ;; esac # Get the directory component of the given path, and save it in the # global variables '$dir'. Note that this directory component will # be either empty or ending with a '/' character. This is deliberate. set_dir_from () { case $1 in */*) dir=`echo "$1" | sed -e 's|/[^/]*$|/|'`;; *) dir=;; esac } # Get the suffix-stripped basename of the given path, and save it the # global variable '$base'. set_base_from () { base=`echo "$1" | sed -e 's|^.*/||' -e 's/\.[^.]*$//'` } # If no dependency file was actually created by the compiler invocation, # we still have to create a dummy depfile, to avoid errors with the # Makefile "include basename.Plo" scheme. make_dummy_depfile () { echo "#dummy" > "$depfile" } # Factor out some common post-processing of the generated depfile. # Requires the auxiliary global variable '$tmpdepfile' to be set. aix_post_process_depfile () { # If the compiler actually managed to produce a dependency file, # post-process it. if test -f "$tmpdepfile"; then # Each line is of the form 'foo.o: dependency.h'. # Do two passes, one to just change these to # $object: dependency.h # and one to simply output # dependency.h: # which is needed to avoid the deleted-header problem. { sed -e "s,^.*\.[$lower]*:,$object:," < "$tmpdepfile" sed -e "s,^.*\.[$lower]*:[$tab ]*,," -e 's,$,:,' < "$tmpdepfile" } > "$depfile" rm -f "$tmpdepfile" else make_dummy_depfile fi } # A tabulation character. tab=' ' # A newline character. nl=' ' # Character ranges might be problematic outside the C locale. # These definitions help. upper=ABCDEFGHIJKLMNOPQRSTUVWXYZ lower=abcdefghijklmnopqrstuvwxyz digits=0123456789 alpha=${upper}${lower} if test -z "$depmode" || test -z "$source" || test -z "$object"; then echo "depcomp: Variables source, object and depmode must be set" 1>&2 exit 1 fi # Dependencies for sub/bar.o or sub/bar.obj go into sub/.deps/bar.Po. depfile=${depfile-`echo "$object" | sed 's|[^\\/]*$|'${DEPDIR-.deps}'/&|;s|\.\([^.]*\)$|.P\1|;s|Pobj$|Po|'`} tmpdepfile=${tmpdepfile-`echo "$depfile" | sed 's/\.\([^.]*\)$/.T\1/'`} rm -f "$tmpdepfile" # Avoid interferences from the environment. gccflag= dashmflag= # Some modes work just like other modes, but use different flags. We # parameterize here, but still list the modes in the big case below, # to make depend.m4 easier to write. Note that we *cannot* use a case # here, because this file can only contain one case statement. if test "$depmode" = hp; then # HP compiler uses -M and no extra arg. gccflag=-M depmode=gcc fi if test "$depmode" = dashXmstdout; then # This is just like dashmstdout with a different argument. dashmflag=-xM depmode=dashmstdout fi cygpath_u="cygpath -u -f -" if test "$depmode" = msvcmsys; then # This is just like msvisualcpp but w/o cygpath translation. # Just convert the backslash-escaped backslashes to single forward # slashes to satisfy depend.m4 cygpath_u='sed s,\\\\,/,g' depmode=msvisualcpp fi if test "$depmode" = msvc7msys; then # This is just like msvc7 but w/o cygpath translation. # Just convert the backslash-escaped backslashes to single forward # slashes to satisfy depend.m4 cygpath_u='sed s,\\\\,/,g' depmode=msvc7 fi if test "$depmode" = xlc; then # IBM C/C++ Compilers xlc/xlC can output gcc-like dependency information. gccflag=-qmakedep=gcc,-MF depmode=gcc fi case "$depmode" in gcc3) ## gcc 3 implements dependency tracking that does exactly what ## we want. Yay! Note: for some reason libtool 1.4 doesn't like ## it if -MD -MP comes after the -MF stuff. Hmm. ## Unfortunately, FreeBSD c89 acceptance of flags depends upon ## the command line argument order; so add the flags where they ## appear in depend2.am. Note that the slowdown incurred here ## affects only configure: in makefiles, %FASTDEP% shortcuts this. for arg do case $arg in -c) set fnord "$@" -MT "$object" -MD -MP -MF "$tmpdepfile" "$arg" ;; *) set fnord "$@" "$arg" ;; esac shift # fnord shift # $arg done "$@" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi mv "$tmpdepfile" "$depfile" ;; gcc) ## Note that this doesn't just cater to obsosete pre-3.x GCC compilers. ## but also to in-use compilers like IMB xlc/xlC and the HP C compiler. ## (see the conditional assignment to $gccflag above). ## There are various ways to get dependency output from gcc. Here's ## why we pick this rather obscure method: ## - Don't want to use -MD because we'd like the dependencies to end ## up in a subdir. Having to rename by hand is ugly. ## (We might end up doing this anyway to support other compilers.) ## - The DEPENDENCIES_OUTPUT environment variable makes gcc act like ## -MM, not -M (despite what the docs say). Also, it might not be ## supported by the other compilers which use the 'gcc' depmode. ## - Using -M directly means running the compiler twice (even worse ## than renaming). if test -z "$gccflag"; then gccflag=-MD, fi "$@" -Wp,"$gccflag$tmpdepfile" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" echo "$object : \\" > "$depfile" # The second -e expression handles DOS-style file names with drive # letters. sed -e 's/^[^:]*: / /' \ -e 's/^['$alpha']:\/[^:]*: / /' < "$tmpdepfile" >> "$depfile" ## This next piece of magic avoids the "deleted header file" problem. ## The problem is that when a header file which appears in a .P file ## is deleted, the dependency causes make to die (because there is ## typically no way to rebuild the header). We avoid this by adding ## dummy dependencies for each header file. Too bad gcc doesn't do ## this for us directly. ## Some versions of gcc put a space before the ':'. On the theory ## that the space means something, we add a space to the output as ## well. hp depmode also adds that space, but also prefixes the VPATH ## to the object. Take care to not repeat it in the output. ## Some versions of the HPUX 10.20 sed can't process this invocation ## correctly. Breaking it into two sed invocations is a workaround. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^\\$//' -e '/^$/d' -e "s|.*$object$||" -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; hp) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; sgi) if test "$libtool" = yes; then "$@" "-Wp,-MDupdate,$tmpdepfile" else "$@" -MDupdate "$tmpdepfile" fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" if test -f "$tmpdepfile"; then # yes, the sourcefile depend on other files echo "$object : \\" > "$depfile" # Clip off the initial element (the dependent). Don't try to be # clever and replace this with sed code, as IRIX sed won't handle # lines with more than a fixed number of characters (4096 in # IRIX 6.2 sed, 8192 in IRIX 6.5). We also remove comment lines; # the IRIX cc adds comments like '#:fec' to the end of the # dependency line. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' \ | tr "$nl" ' ' >> "$depfile" echo >> "$depfile" # The second pass generates a dummy entry for each header file. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^.*\.o://' -e 's/#.*$//' -e '/^$/ d' -e 's/$/:/' \ >> "$depfile" else make_dummy_depfile fi rm -f "$tmpdepfile" ;; xlc) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; aix) # The C for AIX Compiler uses -M and outputs the dependencies # in a .u file. In older versions, this file always lives in the # current directory. Also, the AIX compiler puts '$object:' at the # start of each line; $object doesn't have directory information. # Version 6 uses the directory in both cases. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then tmpdepfile1=$dir$base.u tmpdepfile2=$base.u tmpdepfile3=$dir.libs/$base.u "$@" -Wc,-M else tmpdepfile1=$dir$base.u tmpdepfile2=$dir$base.u tmpdepfile3=$dir$base.u "$@" -M fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" do test -f "$tmpdepfile" && break done aix_post_process_depfile ;; tcc) # tcc (Tiny C Compiler) understand '-MD -MF file' since version 0.9.26 # FIXME: That version still under development at the moment of writing. # Make that this statement remains true also for stable, released # versions. # It will wrap lines (doesn't matter whether long or short) with a # trailing '\', as in: # # foo.o : \ # foo.c \ # foo.h \ # # It will put a trailing '\' even on the last line, and will use leading # spaces rather than leading tabs (at least since its commit 0394caf7 # "Emit spaces for -MD"). "$@" -MD -MF "$tmpdepfile" stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" # Each non-empty line is of the form 'foo.o : \' or ' dep.h \'. # We have to change lines of the first kind to '$object: \'. sed -e "s|.*:|$object :|" < "$tmpdepfile" > "$depfile" # And for each line of the second kind, we have to emit a 'dep.h:' # dummy dependency, to avoid the deleted-header problem. sed -n -e 's|^ *\(.*\) *\\$|\1:|p' < "$tmpdepfile" >> "$depfile" rm -f "$tmpdepfile" ;; ## The order of this option in the case statement is important, since the ## shell code in configure will try each of these formats in the order ## listed in this file. A plain '-MD' option would be understood by many ## compilers, so we must ensure this comes after the gcc and icc options. pgcc) # Portland's C compiler understands '-MD'. # Will always output deps to 'file.d' where file is the root name of the # source file under compilation, even if file resides in a subdirectory. # The object file name does not affect the name of the '.d' file. # pgcc 10.2 will output # foo.o: sub/foo.c sub/foo.h # and will wrap long lines using '\' : # foo.o: sub/foo.c ... \ # sub/foo.h ... \ # ... set_dir_from "$object" # Use the source, not the object, to determine the base name, since # that's sadly what pgcc will do too. set_base_from "$source" tmpdepfile=$base.d # For projects that build the same source file twice into different object # files, the pgcc approach of using the *source* file root name can cause # problems in parallel builds. Use a locking strategy to avoid stomping on # the same $tmpdepfile. lockdir=$base.d-lock trap " echo '$0: caught signal, cleaning up...' >&2 rmdir '$lockdir' exit 1 " 1 2 13 15 numtries=100 i=$numtries while test $i -gt 0; do # mkdir is a portable test-and-set. if mkdir "$lockdir" 2>/dev/null; then # This process acquired the lock. "$@" -MD stat=$? # Release the lock. rmdir "$lockdir" break else # If the lock is being held by a different process, wait # until the winning process is done or we timeout. while test -d "$lockdir" && test $i -gt 0; do sleep 1 i=`expr $i - 1` done fi i=`expr $i - 1` done trap - 1 2 13 15 if test $i -le 0; then echo "$0: failed to acquire lock after $numtries attempts" >&2 echo "$0: check lockdir '$lockdir'" >&2 exit 1 fi if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" # Each line is of the form `foo.o: dependent.h', # or `foo.o: dep1.h dep2.h \', or ` dep3.h dep4.h \'. # Do two passes, one to just change these to # `$object: dependent.h' and one to simply `dependent.h:'. sed "s,^[^:]*:,$object :," < "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process this invocation # correctly. Breaking it into two sed invocations is a workaround. sed 's,^[^:]*: \(.*\)$,\1,;s/^\\$//;/^$/d;/:$/d' < "$tmpdepfile" \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; hp2) # The "hp" stanza above does not work with aCC (C++) and HP's ia64 # compilers, which have integrated preprocessors. The correct option # to use with these is +Maked; it writes dependencies to a file named # 'foo.d', which lands next to the object file, wherever that # happens to be. # Much of this is similar to the tru64 case; see comments there. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then tmpdepfile1=$dir$base.d tmpdepfile2=$dir.libs/$base.d "$@" -Wc,+Maked else tmpdepfile1=$dir$base.d tmpdepfile2=$dir$base.d "$@" +Maked fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" do test -f "$tmpdepfile" && break done if test -f "$tmpdepfile"; then sed -e "s,^.*\.[$lower]*:,$object:," "$tmpdepfile" > "$depfile" # Add 'dependent.h:' lines. sed -ne '2,${ s/^ *// s/ \\*$// s/$/:/ p }' "$tmpdepfile" >> "$depfile" else make_dummy_depfile fi rm -f "$tmpdepfile" "$tmpdepfile2" ;; tru64) # The Tru64 compiler uses -MD to generate dependencies as a side # effect. 'cc -MD -o foo.o ...' puts the dependencies into 'foo.o.d'. # At least on Alpha/Redhat 6.1, Compaq CCC V6.2-504 seems to put # dependencies in 'foo.d' instead, so we check for that too. # Subdirectories are respected. set_dir_from "$object" set_base_from "$object" if test "$libtool" = yes; then # Libtool generates 2 separate objects for the 2 libraries. These # two compilations output dependencies in $dir.libs/$base.o.d and # in $dir$base.o.d. We have to check for both files, because # one of the two compilations can be disabled. We should prefer # $dir$base.o.d over $dir.libs/$base.o.d because the latter is # automatically cleaned when .libs/ is deleted, while ignoring # the former would cause a distcleancheck panic. tmpdepfile1=$dir$base.o.d # libtool 1.5 tmpdepfile2=$dir.libs/$base.o.d # Likewise. tmpdepfile3=$dir.libs/$base.d # Compaq CCC V6.2-504 "$@" -Wc,-MD else tmpdepfile1=$dir$base.d tmpdepfile2=$dir$base.d tmpdepfile3=$dir$base.d "$@" -MD fi stat=$? if test $stat -ne 0; then rm -f "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" exit $stat fi for tmpdepfile in "$tmpdepfile1" "$tmpdepfile2" "$tmpdepfile3" do test -f "$tmpdepfile" && break done # Same post-processing that is required for AIX mode. aix_post_process_depfile ;; msvc7) if test "$libtool" = yes; then showIncludes=-Wc,-showIncludes else showIncludes=-showIncludes fi "$@" $showIncludes > "$tmpdepfile" stat=$? grep -v '^Note: including file: ' "$tmpdepfile" if test $stat -ne 0; then rm -f "$tmpdepfile" exit $stat fi rm -f "$depfile" echo "$object : \\" > "$depfile" # The first sed program below extracts the file names and escapes # backslashes for cygpath. The second sed program outputs the file # name when reading, but also accumulates all include files in the # hold buffer in order to output them again at the end. This only # works with sed implementations that can handle large buffers. sed < "$tmpdepfile" -n ' /^Note: including file: *\(.*\)/ { s//\1/ s/\\/\\\\/g p }' | $cygpath_u | sort -u | sed -n ' s/ /\\ /g s/\(.*\)/'"$tab"'\1 \\/p s/.\(.*\) \\/\1:/ H $ { s/.*/'"$tab"'/ G p }' >> "$depfile" echo >> "$depfile" # make sure the fragment doesn't end with a backslash rm -f "$tmpdepfile" ;; msvc7msys) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; #nosideeffect) # This comment above is used by automake to tell side-effect # dependency tracking mechanisms from slower ones. dashmstdout) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout, regardless of -o. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # Remove '-o $object'. IFS=" " for arg do case $arg in -o) shift ;; $object) shift ;; *) set fnord "$@" "$arg" shift # fnord shift # $arg ;; esac done test -z "$dashmflag" && dashmflag=-M # Require at least two characters before searching for ':' # in the target name. This is to cope with DOS-style filenames: # a dependency such as 'c:/foo/bar' could be seen as target 'c' otherwise. "$@" $dashmflag | sed "s|^[$tab ]*[^:$tab ][^:][^:]*:[$tab ]*|$object: |" > "$tmpdepfile" rm -f "$depfile" cat < "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process this sed invocation # correctly. Breaking it into two sed invocations is a workaround. tr ' ' "$nl" < "$tmpdepfile" \ | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; dashXmstdout) # This case only exists to satisfy depend.m4. It is never actually # run, as this mode is specially recognized in the preamble. exit 1 ;; makedepend) "$@" || exit $? # Remove any Libtool call if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # X makedepend shift cleared=no eat=no for arg do case $cleared in no) set ""; shift cleared=yes ;; esac if test $eat = yes; then eat=no continue fi case "$arg" in -D*|-I*) set fnord "$@" "$arg"; shift ;; # Strip any option that makedepend may not understand. Remove # the object too, otherwise makedepend will parse it as a source file. -arch) eat=yes ;; -*|$object) ;; *) set fnord "$@" "$arg"; shift ;; esac done obj_suffix=`echo "$object" | sed 's/^.*\././'` touch "$tmpdepfile" ${MAKEDEPEND-makedepend} -o"$obj_suffix" -f"$tmpdepfile" "$@" rm -f "$depfile" # makedepend may prepend the VPATH from the source file name to the object. # No need to regex-escape $object, excess matching of '.' is harmless. sed "s|^.*\($object *:\)|\1|" "$tmpdepfile" > "$depfile" # Some versions of the HPUX 10.20 sed can't process the last invocation # correctly. Breaking it into two sed invocations is a workaround. sed '1,2d' "$tmpdepfile" \ | tr ' ' "$nl" \ | sed -e 's/^\\$//' -e '/^$/d' -e '/:$/d' \ | sed -e 's/$/ :/' >> "$depfile" rm -f "$tmpdepfile" "$tmpdepfile".bak ;; cpp) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi # Remove '-o $object'. IFS=" " for arg do case $arg in -o) shift ;; $object) shift ;; *) set fnord "$@" "$arg" shift # fnord shift # $arg ;; esac done "$@" -E \ | sed -n -e '/^# [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ -e '/^#line [0-9][0-9]* "\([^"]*\)".*/ s:: \1 \\:p' \ | sed '$ s: \\$::' > "$tmpdepfile" rm -f "$depfile" echo "$object : \\" > "$depfile" cat < "$tmpdepfile" >> "$depfile" sed < "$tmpdepfile" '/^$/d;s/^ //;s/ \\$//;s/$/ :/' >> "$depfile" rm -f "$tmpdepfile" ;; msvisualcpp) # Important note: in order to support this mode, a compiler *must* # always write the preprocessed file to stdout. "$@" || exit $? # Remove the call to Libtool. if test "$libtool" = yes; then while test "X$1" != 'X--mode=compile'; do shift done shift fi IFS=" " for arg do case "$arg" in -o) shift ;; $object) shift ;; "-Gm"|"/Gm"|"-Gi"|"/Gi"|"-ZI"|"/ZI") set fnord "$@" shift shift ;; *) set fnord "$@" "$arg" shift shift ;; esac done "$@" -E 2>/dev/null | sed -n '/^#line [0-9][0-9]* "\([^"]*\)"/ s::\1:p' | $cygpath_u | sort -u > "$tmpdepfile" rm -f "$depfile" echo "$object : \\" > "$depfile" sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::'"$tab"'\1 \\:p' >> "$depfile" echo "$tab" >> "$depfile" sed < "$tmpdepfile" -n -e 's% %\\ %g' -e '/^\(.*\)$/ s::\1\::p' >> "$depfile" rm -f "$tmpdepfile" ;; msvcmsys) # This case exists only to let depend.m4 do its work. It works by # looking at the text of this script. This case will never be run, # since it is checked for above. exit 1 ;; none) exec "$@" ;; *) echo "Unknown depmode $depmode" 1>&2 exit 1 ;; esac exit 0 # Local Variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: libcaes-20240413/libcaes/0000755000175000017500000000000014606477653015637 5ustar00lordyestalordyestalibcaes-20240413/libcaes/libcaes_unused.h0000644000175000017500000000257014606473412020766 0ustar00lordyestalordyesta/* * Definitions to silence compiler warnings about unused function attributes/parameters. * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_UNUSED_H ) #define _LIBCAES_UNUSED_H #include #if !defined( LIBCAES_ATTRIBUTE_UNUSED ) #if defined( __GNUC__ ) && __GNUC__ >= 3 #define LIBCAES_ATTRIBUTE_UNUSED __attribute__ ((__unused__)) #else #define LIBCAES_ATTRIBUTE_UNUSED #endif #endif #if defined( _MSC_VER ) #define LIBCAES_UNREFERENCED_PARAMETER( parameter ) \ UNREFERENCED_PARAMETER( parameter ); #else #define LIBCAES_UNREFERENCED_PARAMETER( parameter ) \ /* parameter */ #endif #endif /* !defined( _LIBCAES_UNUSED_H ) */ libcaes-20240413/libcaes/libcaes.c0000644000175000017500000000343114606473412017373 0ustar00lordyestalordyesta/* * Library to support cross-platform AES encryption * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #if defined( WINAPI ) #include #endif #include "libcaes_unused.h" /* Define HAVE_LOCAL_LIBCAES for local use of libcaes */ #if !defined( HAVE_LOCAL_LIBCAES ) #if defined( WINAPI ) && defined( HAVE_DLLMAIN ) #if defined( _MANAGED ) #pragma managed( push, off ) #endif /* Defines the entry point for the DLL */ BOOL WINAPI DllMain( HINSTANCE hinstDLL, DWORD fdwReason, LPVOID lpvReserved ) { LIBCAES_UNREFERENCED_PARAMETER( lpvReserved ) switch( fdwReason ) { case DLL_PROCESS_ATTACH: DisableThreadLibraryCalls( hinstDLL ); break; case DLL_THREAD_ATTACH: break; case DLL_THREAD_DETACH: break; case DLL_PROCESS_DETACH: break; } return( TRUE ); } /* Function that indicates the library is a DLL * Returns 1 */ int libcaes_is_dll( void ) { return( 1 ); } #endif /* defined( WINAPI ) && defined( HAVE_DLLMAIN ) */ #endif /* !defined( HAVE_LOCAL_LIBCAES ) */ libcaes-20240413/libcaes/libcaes_tweaked_context.h0000644000175000017500000000550514606473412022654 0ustar00lordyestalordyesta/* * AES tweaked de/encryption context functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_TWEAKED_CONTEXT_H ) #define _LIBCAES_TWEAKED_CONTEXT_H #include #include #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) #include #endif #include "libcaes_extern.h" #include "libcaes_libcerror.h" #include "libcaes_types.h" #if defined( __cplusplus ) extern "C" { #endif typedef struct libcaes_internal_tweaked_context libcaes_internal_tweaked_context_t; struct libcaes_internal_tweaked_context { #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) /* The EVP cipher context */ #if defined( HAVE_EVP_CIPHER_CTX_INIT ) EVP_CIPHER_CTX internal_evp_cipher_context; #endif EVP_CIPHER_CTX *evp_cipher_context; /* The key */ uint8_t key[ 64 ]; /* The key bit size */ size_t key_bit_size; #else /* The main de/encryption context */ libcaes_context_t *main_context; /* The tweak encryption context */ libcaes_context_t *tweak_context; #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) */ }; LIBCAES_EXTERN \ int libcaes_tweaked_context_initialize( libcaes_tweaked_context_t **tweaked_context, libcerror_error_t **error ); LIBCAES_EXTERN \ int libcaes_tweaked_context_free( libcaes_tweaked_context_t **tweaked_context, libcerror_error_t **error ); LIBCAES_EXTERN \ int libcaes_tweaked_context_set_keys( libcaes_tweaked_context_t *tweaked_context, int mode, const uint8_t *key, size_t key_bit_size, const uint8_t *tweak_key, size_t tweak_key_bit_size, libcerror_error_t **error ); LIBCAES_EXTERN \ int libcaes_crypt_xts( libcaes_tweaked_context_t *tweaked_context, int mode, const uint8_t *tweak_value, size_t tweak_value_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ); #ifdef __cplusplus } #endif #endif /* !defined( _LIBCAES_TWEAKED_CONTEXT_H ) */ libcaes-20240413/libcaes/libcaes_context.h0000644000175000017500000001056014606473412021145 0ustar00lordyestalordyesta/* * AES de/encryption context functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_CONTEXT_H ) #define _LIBCAES_CONTEXT_H #include #include #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) #include #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) #include #endif #include "libcaes_extern.h" #include "libcaes_libcerror.h" #include "libcaes_types.h" #if defined( __cplusplus ) extern "C" { #endif typedef struct libcaes_internal_context libcaes_internal_context_t; struct libcaes_internal_context { #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_ECB_ENCRYPT ) ) /* The AES key */ AES_KEY key; #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && ( defined( HAVE_EVP_CRYPTO_AES_CBC ) || defined( HAVE_EVP_CRYPTO_AES_ECB ) ) /* The EVP cipher context */ #if defined( HAVE_EVP_CIPHER_CTX_INIT ) EVP_CIPHER_CTX internal_evp_cipher_context; #endif EVP_CIPHER_CTX *evp_cipher_context; /* The key */ uint8_t key[ 32 ]; /* The key bit size */ size_t key_bit_size; #else /* The number of round keys */ uint8_t number_of_round_keys; /* The round keys */ uint32_t *round_keys; /* The round keys data */ uint32_t round_keys_data[ 68 ]; #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_ECB_ENCRYPT ) ) */ }; LIBCAES_EXTERN \ int libcaes_context_initialize( libcaes_context_t **context, libcerror_error_t **error ); LIBCAES_EXTERN \ int libcaes_context_free( libcaes_context_t **context, libcerror_error_t **error ); LIBCAES_EXTERN \ int libcaes_context_set_key( libcaes_context_t *context, int mode, const uint8_t *key, size_t key_bit_size, libcerror_error_t **error ); #if !defined( LIBCAES_HAVE_AES_SUPPORT ) int libcaes_initialize_tables( libcerror_error_t **error ); int libcaes_internal_context_set_decryption_key( libcaes_internal_context_t *internal_context, const uint8_t *key, size_t key_bit_size, libcerror_error_t **error ); int libcaes_internal_context_set_encryption_key( libcaes_internal_context_t *internal_context, const uint8_t *key, size_t key_bit_size, libcerror_error_t **error ); #endif /* !defined( LIBCAES_HAVE_AES_SUPPORT ) */ LIBCAES_EXTERN \ int libcaes_crypt_cbc( libcaes_context_t *context, int mode, const uint8_t *initialization_vector, size_t initialization_vector_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ); LIBCAES_EXTERN \ int libcaes_crypt_ccm( libcaes_context_t *context, int mode, const uint8_t *nonce, size_t nonce_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ); LIBCAES_EXTERN \ int libcaes_crypt_cfb( libcaes_context_t *context, int mode, const uint8_t *initialization_vector, size_t initialization_vector_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ); LIBCAES_EXTERN \ int libcaes_crypt_ecb( libcaes_context_t *context, int mode, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ); #ifdef __cplusplus } #endif #endif /* !defined( _LIBCAES_CONTEXT_H ) */ libcaes-20240413/libcaes/libcaes_error.c0000644000175000017500000000552014606473412020605 0ustar00lordyestalordyesta/* * Error functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include #include "libcaes_error.h" #include "libcaes_libcerror.h" #if !defined( HAVE_LOCAL_LIBCAES ) /* Free an error and its elements */ void libcaes_error_free( libcaes_error_t **error ) { libcerror_error_free( (libcerror_error_t **) error ); } /* Prints a descriptive string of the error to the stream * Returns the number of printed characters if successful or -1 on error */ int libcaes_error_fprint( libcaes_error_t *error, FILE *stream ) { int print_count = 0; print_count = libcerror_error_fprint( (libcerror_error_t *) error, stream ); return( print_count ); } /* Prints a descriptive string of the error to the string * The end-of-string character is not included in the return value * Returns the number of printed characters if successful or -1 on error */ int libcaes_error_sprint( libcaes_error_t *error, char *string, size_t size ) { int print_count = 0; print_count = libcerror_error_sprint( (libcerror_error_t *) error, string, size ); return( print_count ); } /* Prints a backtrace of the error to the stream * Returns the number of printed characters if successful or -1 on error */ int libcaes_error_backtrace_fprint( libcaes_error_t *error, FILE *stream ) { int print_count = 0; print_count = libcerror_error_backtrace_fprint( (libcerror_error_t *) error, stream ); return( print_count ); } /* Prints a backtrace of the error to the string * The end-of-string character is not included in the return value * Returns the number of printed characters if successful or -1 on error */ int libcaes_error_backtrace_sprint( libcaes_error_t *error, char *string, size_t size ) { int print_count = 0; print_count = libcerror_error_backtrace_sprint( (libcerror_error_t *) error, string, size ); return( print_count ); } #endif /* !defined( HAVE_LOCAL_LIBCAES ) */ libcaes-20240413/libcaes/libcaes_context.c0000644000175000017500000024127014606473412021144 0ustar00lordyestalordyesta/* * AES de/encryption context functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include #include #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) #include #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) #include #include #endif #if defined( HAVE_EVP_CIPHERINIT_EX2 ) #include #endif #include "libcaes_context.h" #include "libcaes_definitions.h" #include "libcaes_libcerror.h" #include "libcaes_types.h" #if !defined( LIBCAES_HAVE_AES_SUPPORT ) /* FIPS-197 compliant AES encryption functions * * The AES block cipher was designed by Vincent Rijmen and Joan Daemen. * * http://csrc.nist.gov/encryption/aes/rijndael/Rijndael.pdf * http://csrc.nist.gov/publications/fips/fips197/fips-197.pdf */ #define libcaes_calculate_forward_substitution_value( value, index0, index1, index2, index3 ) \ value = libcaes_forward_substitution_box[ index3 ]; \ value <<= 8; \ value |= libcaes_forward_substitution_box[ index2 ]; \ value <<= 8; \ value |= libcaes_forward_substitution_box[ index1 ]; \ value <<= 8; \ value |= libcaes_forward_substitution_box[ index0 ]; #define libcaes_calculate_forward_table_value( value, index0, index1, index2, index3 ) \ value = libcaes_forward_table0[ index0 ]; \ value ^= libcaes_forward_table1[ index1 ]; \ value ^= libcaes_forward_table2[ index2 ]; \ value ^= libcaes_forward_table3[ index3 ]; #define libcaes_calculate_reverse_substitution_value( value, index0, index1, index2, index3 ) \ value = libcaes_reverse_substitution_box[ index3 ]; \ value <<= 8; \ value |= libcaes_reverse_substitution_box[ index2 ]; \ value <<= 8; \ value |= libcaes_reverse_substitution_box[ index1 ]; \ value <<= 8; \ value |= libcaes_reverse_substitution_box[ index0 ]; #define libcaes_calculate_reverse_table_value( value, index0, index1, index2, index3 ) \ value = libcaes_reverse_table0[ index0 ]; \ value ^= libcaes_reverse_table1[ index1 ]; \ value ^= libcaes_reverse_table2[ index2 ]; \ value ^= libcaes_reverse_table3[ index3 ]; #define libcaes_calculate_forward_substitution_round( round_keys, values_32bit, cipher_values_32bit, substitution_value ) \ libcaes_calculate_forward_substitution_value( \ substitution_value, \ ( cipher_values_32bit[ 0 ] & 0xff ), \ ( ( cipher_values_32bit[ 1 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 2 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 3 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 0 ] = round_keys[ 0 ] ^ substitution_value; \ \ libcaes_calculate_forward_substitution_value( \ substitution_value, \ ( cipher_values_32bit[ 1 ] & 0xff ), \ ( ( cipher_values_32bit[ 2 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 3 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 0 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 1 ] = round_keys[ 1 ] ^ substitution_value; \ \ libcaes_calculate_forward_substitution_value( \ substitution_value, \ ( cipher_values_32bit[ 2 ] & 0xff ), \ ( ( cipher_values_32bit[ 3 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 0 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 1 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 2 ] = round_keys[ 2 ] ^ substitution_value; \ \ libcaes_calculate_forward_substitution_value( \ substitution_value, \ ( cipher_values_32bit[ 3 ] & 0xff ), \ ( ( cipher_values_32bit[ 0 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 1 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 2 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 3 ] = round_keys[ 3 ] ^ substitution_value; #define libcaes_calculate_forward_table_round( round_keys, values_32bit, cipher_values_32bit, table_value ) \ libcaes_calculate_forward_table_value( \ table_value, \ ( cipher_values_32bit[ 0 ] & 0xff ), \ ( ( cipher_values_32bit[ 1 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 2 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 3 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 0 ] = round_keys[ 0 ] ^ table_value; \ \ libcaes_calculate_forward_table_value( \ table_value, \ ( cipher_values_32bit[ 1 ] & 0xff ), \ ( ( cipher_values_32bit[ 2 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 3 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 0 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 1 ] = round_keys[ 1 ] ^ table_value; \ \ libcaes_calculate_forward_table_value( \ table_value, \ ( cipher_values_32bit[ 2 ] & 0xff ), \ ( ( cipher_values_32bit[ 3 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 0 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 1 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 2 ] = round_keys[ 2 ] ^ table_value; \ \ libcaes_calculate_forward_table_value( \ table_value, \ ( cipher_values_32bit[ 3 ] & 0xff ), \ ( ( cipher_values_32bit[ 0 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 1 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 2 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 3 ] = round_keys[ 3 ] ^ table_value; #define libcaes_calculate_reverse_substitution_round( round_keys, values_32bit, cipher_values_32bit, substitution_value ) \ libcaes_calculate_reverse_substitution_value( \ substitution_value, \ ( cipher_values_32bit[ 0 ] & 0xff ), \ ( ( cipher_values_32bit[ 3 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 2 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 1 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 0 ] = round_keys[ 0 ] ^ substitution_value; \ \ libcaes_calculate_reverse_substitution_value( \ substitution_value, \ ( cipher_values_32bit[ 1 ] & 0xff ), \ ( ( cipher_values_32bit[ 0 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 3 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 2 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 1 ] = round_keys[ 1 ] ^ substitution_value; \ \ libcaes_calculate_reverse_substitution_value( \ substitution_value, \ ( cipher_values_32bit[ 2 ] & 0xff ), \ ( ( cipher_values_32bit[ 1 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 0 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 3 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 2 ] = round_keys[ 2 ] ^ substitution_value; \ \ libcaes_calculate_reverse_substitution_value( \ substitution_value, \ ( cipher_values_32bit[ 3 ] & 0xff ), \ ( ( cipher_values_32bit[ 2 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 1 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 0 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 3 ] = round_keys[ 3 ] ^ substitution_value; #define libcaes_calculate_reverse_table_round( round_keys, values_32bit, cipher_values_32bit, table_value ) \ libcaes_calculate_reverse_table_value( \ table_value, \ ( cipher_values_32bit[ 0 ] & 0xff ), \ ( ( cipher_values_32bit[ 3 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 2 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 1 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 0 ] = round_keys[ 0 ] ^ table_value; \ \ libcaes_calculate_reverse_table_value( \ table_value, \ ( cipher_values_32bit[ 1 ] & 0xff ), \ ( ( cipher_values_32bit[ 0 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 3 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 2 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 1 ] = round_keys[ 1 ] ^ table_value; \ \ libcaes_calculate_reverse_table_value( \ table_value, \ ( cipher_values_32bit[ 2 ] & 0xff ), \ ( ( cipher_values_32bit[ 1 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 0 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 3 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 2 ] = round_keys[ 2 ] ^ table_value; \ \ libcaes_calculate_reverse_table_value( \ table_value, \ ( cipher_values_32bit[ 3 ] & 0xff ), \ ( ( cipher_values_32bit[ 2 ] >> 8 ) & 0xff ), \ ( ( cipher_values_32bit[ 1 ] >> 16 ) & 0xff ), \ ( ( cipher_values_32bit[ 0 ] >> 24 ) & 0xff ) ); \ \ values_32bit[ 3 ] = round_keys[ 3 ] ^ table_value; /* Forward S-box & tables */ static uint8_t libcaes_forward_substitution_box[ 256 ]; static uint32_t libcaes_forward_table0[ 256 ]; static uint32_t libcaes_forward_table1[ 256 ]; static uint32_t libcaes_forward_table2[ 256 ]; static uint32_t libcaes_forward_table3[ 256 ]; /* Reverse S-box & tables */ static uint8_t libcaes_reverse_substitution_box[ 256 ]; static uint32_t libcaes_reverse_table0[ 256 ]; static uint32_t libcaes_reverse_table1[ 256 ]; static uint32_t libcaes_reverse_table2[ 256 ]; static uint32_t libcaes_reverse_table3[ 256 ]; /* Round constants */ static uint32_t libcaes_round_constants[ 10 ]; static int libcaes_tables_initialized = 0; #endif /* !defined( LIBCAES_HAVE_AES_SUPPORT ) */ /* Creates a context * Make sure the value context is referencing, is set to NULL * Returns 1 if successful or -1 on error */ int libcaes_context_initialize( libcaes_context_t **context, libcerror_error_t **error ) { libcaes_internal_context_t *internal_context = NULL; static char *function = "libcaes_context_initialize"; #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && ( defined( HAVE_EVP_CRYPTO_AES_CBC ) || defined( HAVE_EVP_CRYPTO_AES_ECB ) ) char error_string[ 256 ]; unsigned long error_code = 0; #endif if( context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid context.", function ); return( -1 ); } if( *context != NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_VALUE_ALREADY_SET, "%s: invalid context value already set.", function ); return( -1 ); } internal_context = memory_allocate_structure( libcaes_internal_context_t ); if( internal_context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_INSUFFICIENT, "%s: unable to create context.", function ); goto on_error; } if( memory_set( internal_context, 0, sizeof( libcaes_internal_context_t ) ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear context.", function ); goto on_error; } #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_ECB_ENCRYPT ) ) /* No additional initialization necessary */ #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && ( defined( HAVE_EVP_CRYPTO_AES_CBC ) || defined( HAVE_EVP_CRYPTO_AES_ECB ) ) #if defined( HAVE_EVP_CIPHER_CTX_INIT ) EVP_CIPHER_CTX_init( &( internal_context->internal_evp_cipher_context ) ); internal_context->evp_cipher_context = &( internal_context->internal_evp_cipher_context ); #else internal_context->evp_cipher_context = EVP_CIPHER_CTX_new(); if( internal_context->evp_cipher_context == NULL ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to create EVP cipher context with error: %s.", function, error_string ); goto on_error; } #endif /* defined( HAVE_EVP_CIPHER_CTX_INIT ) */ #else if( libcaes_tables_initialized == 0 ) { if( libcaes_initialize_tables( error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to initialize tables.", function ); goto on_error; } libcaes_tables_initialized = 1; } #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_ECB_ENCRYPT ) ) */ *context = (libcaes_context_t *) internal_context; return( 1 ); on_error: if( internal_context != NULL ) { memory_free( internal_context ); } return( -1 ); } /* Frees a context * Returns 1 if successful or -1 on error */ int libcaes_context_free( libcaes_context_t **context, libcerror_error_t **error ) { libcaes_internal_context_t *internal_context = NULL; static char *function = "libcaes_context_free"; int result = 1; #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_EVP_CIPHER_CTX_CLEANUP ) char error_string[ 256 ]; unsigned long error_code = 0; #endif if( context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid context.", function ); return( -1 ); } if( *context != NULL ) { internal_context = (libcaes_internal_context_t *) *context; *context = NULL; #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_ECB_ENCRYPT ) ) /* No additional clean up necessary */ #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && ( defined( HAVE_EVP_CRYPTO_AES_CBC ) || defined( HAVE_EVP_CRYPTO_AES_ECB ) ) #if defined( HAVE_EVP_CIPHER_CTX_CLEANUP ) if( EVP_CIPHER_CTX_cleanup( &( internal_context->internal_evp_cipher_context ) ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_FINALIZE_FAILED, "%s: unable to clean up EVP cipher context with error: %s.", function, error_string ); result = -1; } /* Make sure the error state is removed otherwise OpenSSL will leak memory */ ERR_remove_thread_state( NULL ); #else EVP_CIPHER_CTX_free( internal_context->evp_cipher_context ); #endif /* defined( HAVE_EVP_CIPHER_CTX_CLEANUP ) */ internal_context->evp_cipher_context = NULL; #else /* No additional clean up necessary */ #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_ECB_ENCRYPT ) ) */ memory_free( internal_context ); } return( result ); } /* Sets the key * Returns 1 if successful or -1 on error */ int libcaes_context_set_key( libcaes_context_t *context, int mode, const uint8_t *key, size_t key_bit_size, libcerror_error_t **error ) { libcaes_internal_context_t *internal_context = NULL; static char *function = "libcaes_context_set_key"; if( context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid context.", function ); return( -1 ); } internal_context = (libcaes_internal_context_t *) context; if( ( mode != LIBCAES_CRYPT_MODE_DECRYPT ) && ( mode != LIBCAES_CRYPT_MODE_ENCRYPT ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported mode.", function ); return( -1 ); } if( ( key_bit_size != 128 ) && ( key_bit_size != 192 ) && ( key_bit_size != 256 ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported key bit size.", function ); return( -1 ); } #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_ECB_ENCRYPT ) ) if( mode == LIBCAES_CRYPT_MODE_ENCRYPT ) { if( AES_set_encrypt_key( (unsigned char *) key, (int) key_bit_size, &( internal_context->key ) ) != 0 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to set encryption key.", function ); return( -1 ); } } else { if( AES_set_decrypt_key( (unsigned char *) key, (int) key_bit_size, &( internal_context->key ) ) != 0 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to set decryption key.", function ); return( -1 ); } } #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && ( defined( HAVE_EVP_CRYPTO_AES_CBC ) || defined( HAVE_EVP_CRYPTO_AES_ECB ) ) if( key == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid key.", function ); return( -1 ); } if( memory_copy( internal_context->key, key, key_bit_size / 8 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy key.", function ); return( -1 ); } internal_context->key_bit_size = key_bit_size; #else if( mode == LIBCAES_CRYPT_MODE_ENCRYPT ) { if( libcaes_internal_context_set_encryption_key( internal_context, key, key_bit_size, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to set encryption key.", function ); return( -1 ); } } else { if( libcaes_internal_context_set_decryption_key( internal_context, key, key_bit_size, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to set decryption key.", function ); return( -1 ); } } #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_ECB_ENCRYPT ) ) */ return( 1 ); } #if !defined( LIBCAES_HAVE_AES_SUPPORT ) /* Initializes the AES encryption and decryption tables * Returns 1 if successful or -1 on error */ int libcaes_initialize_tables( libcerror_error_t **error ) { uint8_t logs_table[ 256 ]; uint8_t powers_table[ 256 ]; static char *function = "libcaes_initialize_tables"; uint16_t byte_index = 0; uint16_t table_index = 0; uint8_t byte_value = 0; uint8_t round_constant_index = 0; uint8_t substitution_value = 0; if( memory_set( logs_table, 0, sizeof( uint8_t ) * 256 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear logs table.", function ); return( -1 ); } /* Fill the powers and logs tables over GF( 2^8 ) */ byte_value = 1; for( byte_index = 0; byte_index < 256; byte_index++ ) { powers_table[ byte_index ] = byte_value; logs_table[ byte_value ] = (uint8_t) byte_index; if( ( byte_value & 0x80 ) == 0 ) { byte_value ^= ( byte_value << 1 ) & 0xff; } else { byte_value ^= ( ( byte_value << 1 ) & 0xff ) ^ 0x1b; } } /* Fill the round constants */ byte_value = 1; for( round_constant_index = 0; round_constant_index < 10; round_constant_index++ ) { libcaes_round_constants[ round_constant_index ] = (uint32_t) byte_value; if( ( byte_value & 0x80 ) == 0 ) { byte_value = ( byte_value << 1 ) & 0xff; } else { byte_value = ( ( byte_value << 1 ) & 0xff ) ^ 0x1b; } } /* Fill the forward and reverse S-boxes */ libcaes_forward_substitution_box[ 0x00 ] = 0x63; libcaes_reverse_substitution_box[ 0x63 ] = 0x00; for( byte_index = 1; byte_index < 256; byte_index++ ) { table_index = 255 - logs_table[ byte_index ]; byte_value = powers_table[ table_index ]; substitution_value = ( ( byte_value << 1 ) & 0xff ) | ( byte_value >> 7 ); byte_value ^= substitution_value; substitution_value = ( ( substitution_value << 1 ) & 0xff ) | ( substitution_value >> 7 ); byte_value ^= substitution_value; substitution_value = ( ( substitution_value << 1 ) & 0xff ) | ( substitution_value >> 7 ); byte_value ^= substitution_value; substitution_value = ( ( substitution_value << 1 ) & 0xff ) | ( substitution_value >> 7 ); substitution_value ^= byte_value ^ 0x63; libcaes_forward_substitution_box[ byte_index ] = substitution_value; libcaes_reverse_substitution_box[ substitution_value ] = (uint8_t) byte_index; } /* Fill the forward and reverse tables */ for( byte_index = 0; byte_index < 256; byte_index++ ) { byte_value = libcaes_forward_substitution_box[ byte_index ]; if( ( byte_value & 0x80 ) == 0 ) { substitution_value = ( byte_value << 1 ) & 0xff; } else { substitution_value = ( ( byte_value << 1 ) & 0xff ) ^ 0x1b; } libcaes_forward_table0[ byte_index ] = byte_value ^ substitution_value; libcaes_forward_table0[ byte_index ] <<= 8; libcaes_forward_table0[ byte_index ] |= byte_value; libcaes_forward_table0[ byte_index ] <<= 8; libcaes_forward_table0[ byte_index ] |= byte_value; libcaes_forward_table0[ byte_index ] <<= 8; libcaes_forward_table0[ byte_index ] |= substitution_value; libcaes_forward_table1[ byte_index ] = byte_stream_bit_rotate_left( libcaes_forward_table0[ byte_index ], 8 ); libcaes_forward_table2[ byte_index ] = byte_stream_bit_rotate_left( libcaes_forward_table1[ byte_index ], 8 ); libcaes_forward_table3[ byte_index ] = byte_stream_bit_rotate_left( libcaes_forward_table2[ byte_index ], 8 ); substitution_value = libcaes_reverse_substitution_box[ byte_index ]; libcaes_reverse_table0[ byte_index ] = 0; if( substitution_value != 0 ) { table_index = logs_table[ 0x0b ]; table_index += logs_table[ substitution_value ]; table_index %= 255; libcaes_reverse_table0[ byte_index ] ^= powers_table[ table_index ]; libcaes_reverse_table0[ byte_index ] <<= 8; table_index = logs_table[ 0x0d ]; table_index += logs_table[ substitution_value ]; table_index %= 255; libcaes_reverse_table0[ byte_index ] ^= powers_table[ table_index ]; libcaes_reverse_table0[ byte_index ] <<= 8; table_index = logs_table[ 0x09 ]; table_index += logs_table[ substitution_value ]; table_index %= 255; libcaes_reverse_table0[ byte_index ] ^= powers_table[ table_index ]; libcaes_reverse_table0[ byte_index ] <<= 8; table_index = logs_table[ 0x0e ]; table_index += logs_table[ substitution_value ]; table_index %= 255; libcaes_reverse_table0[ byte_index ] ^= powers_table[ table_index ]; } libcaes_reverse_table1[ byte_index ] = byte_stream_bit_rotate_left( libcaes_reverse_table0[ byte_index ], 8 ); libcaes_reverse_table2[ byte_index ] = byte_stream_bit_rotate_left( libcaes_reverse_table1[ byte_index ], 8 ); libcaes_reverse_table3[ byte_index ] = byte_stream_bit_rotate_left( libcaes_reverse_table2[ byte_index ], 8 ); } return( 1 ); } /* Sets the AES decryption key * Returns 1 if successful or -1 on error */ int libcaes_internal_context_set_decryption_key( libcaes_internal_context_t *internal_context, const uint8_t *key, size_t key_bit_size, libcerror_error_t **error ) { libcaes_internal_context_t *encryption_context = NULL; static char *function = "libcaes_internal_context_set_decryption_key"; uint32_t *encryption_round_keys = NULL; uint32_t *round_keys = NULL; size_t round_keys_byte_offset = 0; uint8_t byte_value0 = 0; uint8_t byte_value1 = 0; uint8_t byte_value2 = 0; uint8_t byte_value3 = 0; int round_key_iterator = 0; if( internal_context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid context.", function ); return( -1 ); } if( key == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid key.", function ); return( -1 ); } if( ( key_bit_size != 128 ) && ( key_bit_size != 192 ) && ( key_bit_size != 256 ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported key bit size.", function ); return( -1 ); } if( key_bit_size == 128 ) { internal_context->number_of_round_keys = 10; } else if( key_bit_size == 192 ) { internal_context->number_of_round_keys = 12; } else if( key_bit_size == 256 ) { internal_context->number_of_round_keys = 14; } /* Align the buffer to next 16-byte blocks */ internal_context->round_keys = (uint32_t *) ( 16 + ( (intptr_t) internal_context->round_keys_data & ~( 15 ) ) ); round_keys = internal_context->round_keys; if( libcaes_context_initialize( (libcaes_context_t **) &encryption_context, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to create encryption context.", function ); goto on_error; } if( libcaes_internal_context_set_encryption_key( encryption_context, key, key_bit_size, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to set encryption key.", function ); goto on_error; } /* Point to the end of the round keys */ round_keys_byte_offset = encryption_context->number_of_round_keys * sizeof( uint32_t ); encryption_round_keys = &( encryption_context->round_keys[ round_keys_byte_offset ] ); round_keys[ 0 ] = encryption_round_keys[ 0 ]; round_keys[ 1 ] = encryption_round_keys[ 1 ]; round_keys[ 2 ] = encryption_round_keys[ 2 ]; round_keys[ 3 ] = encryption_round_keys[ 3 ]; round_keys += 4; encryption_round_keys -= 4; for( round_key_iterator = internal_context->number_of_round_keys; round_key_iterator > 1; round_key_iterator-- ) { byte_value0 = ( encryption_round_keys[ 0 ] & 0xff ); byte_value1 = ( ( encryption_round_keys[ 0 ] >> 8 ) & 0xff ); byte_value2 = ( ( encryption_round_keys[ 0 ] >> 16 ) & 0xff ); byte_value3 = ( ( encryption_round_keys[ 0 ] >> 24 ) & 0xff ); byte_value0 = libcaes_forward_substitution_box[ byte_value0 ]; byte_value1 = libcaes_forward_substitution_box[ byte_value1 ]; byte_value2 = libcaes_forward_substitution_box[ byte_value2 ]; byte_value3 = libcaes_forward_substitution_box[ byte_value3 ]; round_keys[ 0 ] = libcaes_reverse_table0[ byte_value0 ] ^ libcaes_reverse_table1[ byte_value1 ] ^ libcaes_reverse_table2[ byte_value2 ] ^ libcaes_reverse_table3[ byte_value3 ]; byte_value0 = ( encryption_round_keys[ 1 ] & 0xff ); byte_value1 = ( ( encryption_round_keys[ 1 ] >> 8 ) & 0xff ); byte_value2 = ( ( encryption_round_keys[ 1 ] >> 16 ) & 0xff ); byte_value3 = ( ( encryption_round_keys[ 1 ] >> 24 ) & 0xff ); byte_value0 = libcaes_forward_substitution_box[ byte_value0 ]; byte_value1 = libcaes_forward_substitution_box[ byte_value1 ]; byte_value2 = libcaes_forward_substitution_box[ byte_value2 ]; byte_value3 = libcaes_forward_substitution_box[ byte_value3 ]; round_keys[ 1 ] = libcaes_reverse_table0[ byte_value0 ] ^ libcaes_reverse_table1[ byte_value1 ] ^ libcaes_reverse_table2[ byte_value2 ] ^ libcaes_reverse_table3[ byte_value3 ]; byte_value0 = ( encryption_round_keys[ 2 ] & 0xff ); byte_value1 = ( ( encryption_round_keys[ 2 ] >> 8 ) & 0xff ); byte_value2 = ( ( encryption_round_keys[ 2 ] >> 16 ) & 0xff ); byte_value3 = ( ( encryption_round_keys[ 2 ] >> 24 ) & 0xff ); byte_value0 = libcaes_forward_substitution_box[ byte_value0 ]; byte_value1 = libcaes_forward_substitution_box[ byte_value1 ]; byte_value2 = libcaes_forward_substitution_box[ byte_value2 ]; byte_value3 = libcaes_forward_substitution_box[ byte_value3 ]; round_keys[ 2 ] = libcaes_reverse_table0[ byte_value0 ] ^ libcaes_reverse_table1[ byte_value1 ] ^ libcaes_reverse_table2[ byte_value2 ] ^ libcaes_reverse_table3[ byte_value3 ]; byte_value0 = ( encryption_round_keys[ 3 ] & 0xff ); byte_value1 = ( ( encryption_round_keys[ 3 ] >> 8 ) & 0xff ); byte_value2 = ( ( encryption_round_keys[ 3 ] >> 16 ) & 0xff ); byte_value3 = ( ( encryption_round_keys[ 3 ] >> 24 ) & 0xff ); byte_value0 = libcaes_forward_substitution_box[ byte_value0 ]; byte_value1 = libcaes_forward_substitution_box[ byte_value1 ]; byte_value2 = libcaes_forward_substitution_box[ byte_value2 ]; byte_value3 = libcaes_forward_substitution_box[ byte_value3 ]; round_keys[ 3 ] = libcaes_reverse_table0[ byte_value0 ] ^ libcaes_reverse_table1[ byte_value1 ] ^ libcaes_reverse_table2[ byte_value2 ] ^ libcaes_reverse_table3[ byte_value3 ]; round_keys += 4; encryption_round_keys -= 4; } round_keys[ 0 ] = encryption_round_keys[ 0 ]; round_keys[ 1 ] = encryption_round_keys[ 1 ]; round_keys[ 2 ] = encryption_round_keys[ 2 ]; round_keys[ 3 ] = encryption_round_keys[ 3 ]; if( libcaes_context_free( (libcaes_context_t **) &encryption_context, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_FINALIZE_FAILED, "%s: unable to free encryption context.", function ); goto on_error; } return( 1 ); on_error: if( encryption_context != NULL ) { libcaes_context_free( (libcaes_context_t **) &encryption_context, NULL ); } return( -1 ); } /* Sets the AES encryption key * Returns 1 if successful or -1 on error */ int libcaes_internal_context_set_encryption_key( libcaes_internal_context_t *internal_context, const uint8_t *key, size_t key_bit_size, libcerror_error_t **error ) { static char *function = "libcaes_internal_context_set_encryption_key"; uint32_t *round_keys = NULL; size_t key_index = 0; int round_constant_index = 0; if( internal_context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid context.", function ); return( -1 ); } if( key == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid key.", function ); return( -1 ); } if( ( key_bit_size != 128 ) && ( key_bit_size != 192 ) && ( key_bit_size != 256 ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported key bit size.", function ); return( -1 ); } /* Align the buffer to next 16-byte blocks */ internal_context->round_keys = (uint32_t *) ( 16 + ( (intptr_t) internal_context->round_keys_data & ~( 15 ) ) ); round_keys = internal_context->round_keys; for( key_index = 0; key_index < key_bit_size / 8; key_index += 4 ) { byte_stream_copy_to_uint32_little_endian( &( key[ key_index ] ), round_keys[ round_constant_index ] ); round_constant_index++; } if( key_bit_size == 128 ) { internal_context->number_of_round_keys = 10; for( round_constant_index = 0; round_constant_index < 10; round_constant_index++ ) { round_keys[ 4 ] = libcaes_round_constants[ round_constant_index ]; round_keys[ 4 ] ^= round_keys[ 0 ]; round_keys[ 4 ] ^= (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 3 ] >> 8 ) & 0xff ]; round_keys[ 4 ] ^= ( (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 3 ] >> 16 ) & 0xff ] ) << 8; round_keys[ 4 ] ^= ( (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 3 ] >> 24 ) & 0xff ] ) << 16; round_keys[ 4 ] ^= ( (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 3 ] ) & 0xff ] ) << 24; round_keys[ 5 ] = round_keys[ 1 ] ^ round_keys[ 4 ]; round_keys[ 6 ] = round_keys[ 2 ] ^ round_keys[ 5 ]; round_keys[ 7 ] = round_keys[ 3 ] ^ round_keys[ 6 ]; round_keys += 4; } } else if( key_bit_size == 192 ) { internal_context->number_of_round_keys = 12; for( round_constant_index = 0; round_constant_index < 8; round_constant_index++ ) { round_keys[ 6 ] = libcaes_round_constants[ round_constant_index ]; round_keys[ 6 ] ^= round_keys[ 0 ]; round_keys[ 6 ] ^= (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 5 ] >> 8 ) & 0xff ]; round_keys[ 6 ] ^= ( (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 5 ] >> 16 ) & 0xff ] ) << 8; round_keys[ 6 ] ^= ( (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 5 ] >> 24 ) & 0xff ] ) << 16; round_keys[ 6 ] ^= ( (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 5 ] ) & 0xff ] ) << 24; round_keys[ 7 ] = round_keys[ 1 ] ^ round_keys[ 6 ]; round_keys[ 8 ] = round_keys[ 2 ] ^ round_keys[ 7 ]; round_keys[ 9 ] = round_keys[ 3 ] ^ round_keys[ 8 ]; round_keys[ 10 ] = round_keys[ 4 ] ^ round_keys[ 9 ]; round_keys[ 11 ] = round_keys[ 5 ] ^ round_keys[ 10 ]; round_keys += 6; } } else if( key_bit_size == 256 ) { internal_context->number_of_round_keys = 14; for( round_constant_index = 0; round_constant_index < 7; round_constant_index++ ) { round_keys[ 8 ] = libcaes_round_constants[ round_constant_index ]; round_keys[ 8 ] ^= round_keys[ 0 ]; round_keys[ 8 ] ^= (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 7 ] >> 8 ) & 0xff ]; round_keys[ 8 ] ^= ( (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 7 ] >> 16 ) & 0xff ] ) << 8; round_keys[ 8 ] ^= ( (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 7 ] >> 24 ) & 0xff ] ) << 16; round_keys[ 8 ] ^= ( (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 7 ] ) & 0xff ] ) << 24; round_keys[ 9 ] = round_keys[ 1 ] ^ round_keys[ 8 ]; round_keys[ 10 ] = round_keys[ 2 ] ^ round_keys[ 9 ]; round_keys[ 11 ] = round_keys[ 3 ] ^ round_keys[ 10 ]; round_keys[ 12 ] = round_keys[ 4 ]; round_keys[ 12 ] ^= (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 11 ] ) & 0xff ]; round_keys[ 12 ] ^= ( (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 11 ] >> 8 ) & 0xff ] ) << 8; round_keys[ 12 ] ^= ( (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 11 ] >> 16 ) & 0xff ] ) << 16; round_keys[ 12 ] ^= ( (uint32_t) libcaes_forward_substitution_box[ ( round_keys[ 11 ] >> 24 ) & 0xff ] ) << 24; round_keys[ 13 ] = round_keys[ 5 ] ^ round_keys[ 12 ]; round_keys[ 14 ] = round_keys[ 6 ] ^ round_keys[ 13 ]; round_keys[ 15 ] = round_keys[ 7 ] ^ round_keys[ 14 ]; round_keys += 8; } } return( 1 ); } #endif /* !defined( LIBCAES_HAVE_AES_SUPPORT ) */ #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && defined( HAVE_AES_CBC_ENCRYPT ) /* De- or encrypts a block of data using AES-CBC (Cipher Block Chaining) using OpenSSL * The size must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ int libcaes_crypt_cbc( libcaes_context_t *context, int mode, const uint8_t *initialization_vector, size_t initialization_vector_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ) { uint8_t safe_initialization_vector[ 16 ]; libcaes_internal_context_t *internal_context = NULL; static char *function = "libcaes_crypt_cbc"; int safe_mode = 0; if( context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid context.", function ); return( -1 ); } internal_context = (libcaes_internal_context_t *) context; if( ( mode != LIBCAES_CRYPT_MODE_DECRYPT ) && ( mode != LIBCAES_CRYPT_MODE_ENCRYPT ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported mode.", function ); return( -1 ); } if( initialization_vector == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid initialization vector.", function ); return( -1 ); } if( initialization_vector_size != 16 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid initialization vector size value out of bounds.", function ); return( -1 ); } if( input_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid input data.", function ); return( -1 ); } /* Check if the input data size is a multitude of 16-byte */ if( ( ( input_data_size & (size_t) 0x0f ) != 0 ) || ( input_data_size > (size_t) SSIZE_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid input data size value out of bounds.", function ); return( -1 ); } if( output_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid output data.", function ); return( -1 ); } if( ( output_data_size < input_data_size ) || ( output_data_size > (size_t) SSIZE_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid output data size value out of bounds.", function ); return( -1 ); } if( mode == LIBCAES_CRYPT_MODE_ENCRYPT ) { safe_mode = AES_ENCRYPT; } else { safe_mode = AES_DECRYPT; } /* AES_cbc_encrypt overwrites the data in the initialization vector */ if( memory_copy( safe_initialization_vector, initialization_vector, 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy initialization vector.", function ); return( -1 ); } AES_cbc_encrypt( (unsigned char *) input_data, (unsigned char *) output_data, input_data_size, &( internal_context->key ), (unsigned char *) safe_initialization_vector, safe_mode ); if( memory_set( safe_initialization_vector, 0, 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear initialization vector.", function ); return( -1 ); } return( 1 ); } #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_CBC ) /* De- or encrypts a block of data using AES-CBC (Cipher Block Chaining) using OpenSSL EVP * The size must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ int libcaes_crypt_cbc( libcaes_context_t *context, int mode, const uint8_t *initialization_vector, size_t initialization_vector_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ) { uint8_t block_data[ EVP_MAX_BLOCK_LENGTH ]; char error_string[ 256 ]; #if defined( HAVE_EVP_CIPHERINIT_EX2 ) OSSL_PARAM parameters[2]; EVP_CIPHER *cipher = NULL; const char *cipher_string = NULL; unsigned int padding = 0; #else const EVP_CIPHER *cipher = NULL; #endif libcaes_internal_context_t *internal_context = NULL; static char *function = "libcaes_crypt_cbc"; unsigned long error_code = 0; int safe_output_data_size = 0; if( context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid context.", function ); return( -1 ); } internal_context = (libcaes_internal_context_t *) context; if( ( internal_context->key_bit_size != 128 ) && ( internal_context->key_bit_size != 192 ) && ( internal_context->key_bit_size != 256 ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: invalid context - unsupported key bit size.", function ); return( -1 ); } if( ( mode != LIBCAES_CRYPT_MODE_DECRYPT ) && ( mode != LIBCAES_CRYPT_MODE_ENCRYPT ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported mode.", function ); return( -1 ); } if( initialization_vector == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid initialization vector.", function ); return( -1 ); } if( initialization_vector_size != 16 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid initialization vector size value out of bounds.", function ); return( -1 ); } if( input_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid input data.", function ); return( -1 ); } /* Check if the input data size is a multitude of 16-byte */ if( ( ( input_data_size & (size_t) 0x0f ) != 0 ) || ( input_data_size > (size_t) INT_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid input data size value out of bounds.", function ); return( -1 ); } if( output_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid output data.", function ); return( -1 ); } if( ( output_data_size < input_data_size ) || ( output_data_size > (size_t) INT_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid output data size value out of bounds.", function ); return( -1 ); } if( memory_set( block_data, 0, EVP_MAX_BLOCK_LENGTH ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear input block data.", function ); goto on_error; } #if defined( HAVE_EVP_CIPHERINIT_EX2 ) if( EVP_CIPHER_CTX_reset( internal_context->evp_cipher_context ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to reset cipher context with error: %s.", function, error_string ); goto on_error; } if( internal_context->key_bit_size == 128 ) { cipher_string = "AES-128-CBC"; } else if( internal_context->key_bit_size == 192 ) { cipher_string = "AES-192-CBC"; } else if( internal_context->key_bit_size == 256 ) { cipher_string = "AES-256-CBC"; } cipher = EVP_CIPHER_fetch( NULL, cipher_string, NULL ); if( cipher == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_VALUE_MISSING, "%s: missing cipher.", function ); goto on_error; } parameters[0] = OSSL_PARAM_construct_uint( OSSL_CIPHER_PARAM_PADDING, &padding ); parameters[1] = OSSL_PARAM_construct_end(); if( EVP_CipherInit_ex2( internal_context->evp_cipher_context, cipher, (unsigned char *) internal_context->key, (unsigned char *) initialization_vector, mode, parameters ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to initialize cipher with error: %s.", function, error_string ); goto on_error; } #else if( internal_context->key_bit_size == 128 ) { cipher = EVP_aes_128_cbc(); } else if( internal_context->key_bit_size == 192 ) { cipher = EVP_aes_192_cbc(); } else if( internal_context->key_bit_size == 256 ) { cipher = EVP_aes_256_cbc(); } if( EVP_CipherInit_ex( internal_context->evp_cipher_context, cipher, NULL, (unsigned char *) internal_context->key, (unsigned char *) initialization_vector, mode ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to initialize cipher with error: %s.", function, error_string ); goto on_error; } if( EVP_CIPHER_CTX_set_padding( internal_context->evp_cipher_context, 1 ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to set padding in context with error: %s.", function, error_string ); goto on_error; } #endif /* defined( HAVE_EVP_CIPHERINIT_EX2 ) */ if( EVP_CipherUpdate( internal_context->evp_cipher_context, (unsigned char *) output_data, &safe_output_data_size, (unsigned char *) input_data, input_data_size ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to update cipher with error: %s.", function, error_string ); goto on_error; } /* Just ignore the output of this function */ EVP_CipherFinal_ex( internal_context->evp_cipher_context, (unsigned char *) block_data, &safe_output_data_size ); #if defined( HAVE_EVP_CIPHERINIT_EX2 ) EVP_CIPHER_free( cipher ); #endif return( 1 ); on_error: #if defined( HAVE_EVP_CIPHERINIT_EX2 ) if( cipher != NULL ) { EVP_CIPHER_free( cipher ); } #endif return( -1 ); } #else /* De- or encrypts a block of data using AES-CBC (Cipher Block Chaining) using fallback implementation * The size must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ int libcaes_crypt_cbc( libcaes_context_t *context, int mode, const uint8_t *initialization_vector, size_t initialization_vector_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ) { uint8_t internal_initialization_vector[ 16 ]; static char *function = "libcaes_crypt_cbc"; size_t data_offset = 0; #if !defined( LIBCAES_UNFOLLED_LOOPS ) uint8_t block_index = 0; #endif if( context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid context.", function ); return( -1 ); } if( ( mode != LIBCAES_CRYPT_MODE_DECRYPT ) && ( mode != LIBCAES_CRYPT_MODE_ENCRYPT ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported mode.", function ); return( -1 ); } if( initialization_vector == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid initialization vector.", function ); return( -1 ); } if( initialization_vector_size != 16 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid initialization vector size value out of bounds.", function ); return( -1 ); } if( input_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid input data.", function ); return( -1 ); } /* Check if the input data size is a multitude of 16-byte */ if( ( ( input_data_size & (size_t) 0x0f ) != 0 ) || ( input_data_size < 16 ) || ( input_data_size > (size_t) SSIZE_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid input data size value out of bounds.", function ); return( -1 ); } if( output_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid output data.", function ); return( -1 ); } if( ( output_data_size < input_data_size ) || ( output_data_size > (size_t) SSIZE_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid output data size value of bounds.", function ); return( -1 ); } if( memory_copy( internal_initialization_vector, initialization_vector, 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy initialization vector.", function ); goto on_error; } if( ( mode == LIBCAES_CRYPT_MODE_ENCRYPT ) && ( output_data != input_data ) ) { if( memory_copy( output_data, input_data, input_data_size ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy input data to output data.", function ); goto on_error; } } while( data_offset <= ( input_data_size - 16 ) ) { if( mode == LIBCAES_CRYPT_MODE_ENCRYPT ) { #if defined( LIBCAES_UNFOLLED_LOOPS ) output_data[ data_offset++ ] ^= internal_initialization_vector[ 0 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 1 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 2 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 3 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 4 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 5 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 6 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 7 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 8 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 9 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 10 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 11 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 12 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 13 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 14 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 15 ]; #else for( block_index = 0; block_index < 16; block_index++ ) { output_data[ data_offset++ ] ^= internal_initialization_vector[ block_index ]; } #endif data_offset -= 16; if( libcaes_crypt_ecb( context, LIBCAES_CRYPT_MODE_ENCRYPT, &( output_data[ data_offset ] ), 16, &( output_data[ data_offset ] ), 16, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ENCRYPTION, LIBCERROR_ENCRYPTION_ERROR_ENCRYPT_FAILED, "%s: unable to encrypt output data.", function ); goto on_error; } if( memory_copy( internal_initialization_vector, &( output_data[ data_offset ] ), 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy enrypted output data to initialization vector.", function ); goto on_error; } } else { if( libcaes_crypt_ecb( context, LIBCAES_CRYPT_MODE_DECRYPT, &( input_data[ data_offset ] ), 16, &( output_data[ data_offset ] ), 16, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ENCRYPTION, LIBCERROR_ENCRYPTION_ERROR_GENERIC, "%s: unable to decrypt output data.", function ); goto on_error; } #if defined( LIBCAES_UNFOLLED_LOOPS ) output_data[ data_offset++ ] ^= internal_initialization_vector[ 0 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 1 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 2 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 3 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 4 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 5 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 6 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 7 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 8 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 9 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 10 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 11 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 12 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 13 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 14 ]; output_data[ data_offset++ ] ^= internal_initialization_vector[ 15 ]; #else for( block_index = 0; block_index < 16; block_index++ ) { output_data[ data_offset++ ] ^= internal_initialization_vector[ block_index ]; } #endif data_offset -= 16; if( memory_copy( internal_initialization_vector, &( input_data[ data_offset ] ), 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy enrypted input data to initialization vector.", function ); goto on_error; } } data_offset += 16; } if( memory_set( internal_initialization_vector, 0, 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear initialization vector.", function ); goto on_error; } return( 1 ); on_error: memory_set( internal_initialization_vector, 0, 16 ); return( -1 ); } #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && defined( HAVE_AES_CBC_ENCRYPT ) */ /* De- or encrypts a block of data using AES-CCM (Counter with CBC-MAC) * Note that the key must be set in encryption mode (LIBCAES_CRYPT_MODE_ENCRYPT) for both de- and encryption. * Returns 1 if successful or -1 on error */ int libcaes_crypt_ccm( libcaes_context_t *context, int mode, const uint8_t *nonce, size_t nonce_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ) { uint8_t block_data[ 16 ]; uint8_t internal_initialization_vector[ 16 ]; static char *function = "libcaes_crypt_ccm"; size_t data_offset = 0; size_t remaining_data_size = 0; uint8_t block_index = 0; if( context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid context.", function ); return( -1 ); } if( ( mode != LIBCAES_CRYPT_MODE_DECRYPT ) && ( mode != LIBCAES_CRYPT_MODE_ENCRYPT ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported mode.", function ); return( -1 ); } if( nonce == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid nonce.", function ); return( -1 ); } if( nonce_size >= (size_t) 15 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid nonce size value out of bounds.", function ); return( -1 ); } if( input_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid input data.", function ); return( -1 ); } if( ( input_data_size < 16 ) || ( input_data_size > (size_t) SSIZE_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid input data size value out of bounds.", function ); return( -1 ); } if( output_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid output data.", function ); return( -1 ); } if( ( output_data_size < input_data_size ) || ( output_data_size > (size_t) SSIZE_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid output data size value out of bounds.", function ); return( -1 ); } /* The IV consists of: * 1 byte size value formatted as: 15 - nonce size - 1 * a maximum of 14 bytes containing nonce bytes * 1 byte counter */ if( memory_set( internal_initialization_vector, 0, 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear initialization vector.", function ); goto on_error; } if( memory_copy( &( internal_initialization_vector[ 1 ] ), nonce, nonce_size ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy nonce to initialization vector.", function ); goto on_error; } internal_initialization_vector[ 0 ] = 15 - (uint8_t) nonce_size - 1; if( memory_copy( output_data, input_data, input_data_size ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy input data to output data.", function ); goto on_error; } while( data_offset <= ( input_data_size - 16 ) ) { if( libcaes_crypt_ecb( context, LIBCAES_CRYPT_MODE_ENCRYPT, internal_initialization_vector, 16, block_data, 16, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ENCRYPTION, LIBCERROR_ENCRYPTION_ERROR_ENCRYPT_FAILED, "%s: unable to encrypt initialization vector.", function ); goto on_error; } #if defined( LIBCAES_UNFOLLED_LOOPS ) output_data[ data_offset++ ] ^= block_data[ 0 ]; output_data[ data_offset++ ] ^= block_data[ 1 ]; output_data[ data_offset++ ] ^= block_data[ 2 ]; output_data[ data_offset++ ] ^= block_data[ 3 ]; output_data[ data_offset++ ] ^= block_data[ 4 ]; output_data[ data_offset++ ] ^= block_data[ 5 ]; output_data[ data_offset++ ] ^= block_data[ 6 ]; output_data[ data_offset++ ] ^= block_data[ 7 ]; output_data[ data_offset++ ] ^= block_data[ 8 ]; output_data[ data_offset++ ] ^= block_data[ 9 ]; output_data[ data_offset++ ] ^= block_data[ 10 ]; output_data[ data_offset++ ] ^= block_data[ 11 ]; output_data[ data_offset++ ] ^= block_data[ 12 ]; output_data[ data_offset++ ] ^= block_data[ 13 ]; output_data[ data_offset++ ] ^= block_data[ 14 ]; output_data[ data_offset++ ] ^= block_data[ 15 ]; #else for( block_index = 0; block_index < 16; block_index++ ) { output_data[ data_offset++ ] ^= block_data[ block_index ]; } #endif internal_initialization_vector[ 15 ] += 1; } if( data_offset < input_data_size ) { remaining_data_size = input_data_size - data_offset; if( libcaes_crypt_ecb( context, LIBCAES_CRYPT_MODE_ENCRYPT, internal_initialization_vector, 16, block_data, 16, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ENCRYPTION, LIBCERROR_ENCRYPTION_ERROR_ENCRYPT_FAILED, "%s: unable to encrypt initialization vector.", function ); goto on_error; } for( block_index = 0; block_index < (uint8_t) remaining_data_size; block_index++ ) { output_data[ data_offset++ ] ^= block_data[ block_index ]; } } if( memory_set( block_data, 0, 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear block data.", function ); goto on_error; } if( memory_set( internal_initialization_vector, 0, 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear initialization vector.", function ); goto on_error; } return( 1 ); on_error: memory_set( block_data, 0, 16 ); memory_set( internal_initialization_vector, 0, 16 ); return( -1 ); } /* De- or encrypts a block of data using AES-CFB (Cipher Feedback Mode) * Note that the key must be set with mode LIBCAES_CRYPT_MODE_ENCRYPT * Returns 1 if successful or -1 on error */ int libcaes_crypt_cfb( libcaes_context_t *context, int mode, const uint8_t *initialization_vector, size_t initialization_vector_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ) { uint8_t internal_initialization_vector[ 16 ]; static char *function = "libcaes_crypt_cfb"; size_t data_offset = 0; size_t initialization_vector_index = 0; uint8_t byte_value = 0; if( ( mode != LIBCAES_CRYPT_MODE_DECRYPT ) && ( mode != LIBCAES_CRYPT_MODE_ENCRYPT ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported mode.", function ); return( -1 ); } if( initialization_vector == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid initialization vector.", function ); return( -1 ); } if( initialization_vector_size != 16 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid initialization vector size value out of bounds.", function ); return( -1 ); } if( input_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid input data.", function ); return( -1 ); } /* Check if the input data size is a multitude of 16-byte */ if( ( ( input_data_size & (size_t) 0x0f ) != 0 ) || ( input_data_size < 16 ) || ( input_data_size > (size_t) SSIZE_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid input data size value out of bounds.", function ); return( -1 ); } if( output_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid output data.", function ); return( -1 ); } if( ( output_data_size < input_data_size ) || ( output_data_size > (size_t) SSIZE_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid output data size value out of bounds.", function ); return( -1 ); } if( memory_copy( internal_initialization_vector, initialization_vector, 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy initialization vector.", function ); goto on_error; } initialization_vector_index = 16; for( data_offset = 0; data_offset < input_data_size; data_offset++ ) { if( initialization_vector_index > 15 ) { if( libcaes_crypt_ecb( context, LIBCAES_CRYPT_MODE_ENCRYPT, internal_initialization_vector, initialization_vector_size, internal_initialization_vector, initialization_vector_size, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ENCRYPTION, LIBCERROR_ENCRYPTION_ERROR_GENERIC, "%s: unable to de/encrypt initialization vector.", function ); goto on_error; } initialization_vector_index = 0; } output_data[ data_offset ] = input_data[ data_offset ] ^ internal_initialization_vector[ initialization_vector_index ]; if( mode == LIBCAES_CRYPT_MODE_ENCRYPT ) { byte_value = output_data[ data_offset ]; } else { byte_value = input_data[ data_offset ]; } internal_initialization_vector[ initialization_vector_index++ ] = byte_value; } if( memory_set( internal_initialization_vector, 0, 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear initialization vector.", function ); goto on_error; } return( 1 ); on_error: memory_set( internal_initialization_vector, 0, 16 ); return( -1 ); } #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && defined( HAVE_AES_ECB_ENCRYPT ) /* De- or encrypts a block of data using AES-ECB (Electronic CodeBook) using OpenSSL * The size must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ int libcaes_crypt_ecb( libcaes_context_t *context, int mode, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ) { libcaes_internal_context_t *internal_context = NULL; static char *function = "libcaes_crypt_ecb"; int result = 1; int safe_mode = 0; if( context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid context.", function ); return( -1 ); } internal_context = (libcaes_internal_context_t *) context; if( ( mode != LIBCAES_CRYPT_MODE_DECRYPT ) && ( mode != LIBCAES_CRYPT_MODE_ENCRYPT ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported mode.", function ); return( -1 ); } if( input_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid input data.", function ); return( -1 ); } if( ( input_data_size < 16 ) || ( input_data_size > (size_t) SSIZE_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid input data size value out of bounds.", function ); return( -1 ); } if( output_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid output data.", function ); return( -1 ); } if( ( output_data_size < input_data_size ) || ( output_data_size > (size_t) SSIZE_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid output data size value out of bounds.", function ); return( -1 ); } if( mode == LIBCAES_CRYPT_MODE_ENCRYPT ) { safe_mode = AES_ENCRYPT; } else { safe_mode = AES_DECRYPT; } AES_ecb_encrypt( (unsigned char *) input_data, (unsigned char *) output_data, &( internal_context->key ), safe_mode ); return( result ); } #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_ECB ) /* De- or encrypts a block of data using AES-ECB (Electronic CodeBook) using OpenSSL EVP * The size must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ int libcaes_crypt_ecb( libcaes_context_t *context, int mode, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ) { uint8_t block_data[ EVP_MAX_BLOCK_LENGTH ]; char error_string[ 256 ]; #if defined( HAVE_EVP_CIPHERINIT_EX2 ) OSSL_PARAM parameters[2]; EVP_CIPHER *cipher = NULL; const char *cipher_string = NULL; unsigned int padding = 0; #else const EVP_CIPHER *cipher = NULL; #endif libcaes_internal_context_t *internal_context = NULL; static char *function = "libcaes_crypt_ecb"; unsigned long error_code = 0; int safe_output_data_size = 0; if( context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid context.", function ); return( -1 ); } internal_context = (libcaes_internal_context_t *) context; if( ( internal_context->key_bit_size != 128 ) && ( internal_context->key_bit_size != 192 ) && ( internal_context->key_bit_size != 256 ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: invalid context - unsupported key bit size.", function ); return( -1 ); } if( ( mode != LIBCAES_CRYPT_MODE_DECRYPT ) && ( mode != LIBCAES_CRYPT_MODE_ENCRYPT ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported mode.", function ); return( -1 ); } if( input_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid input data.", function ); return( -1 ); } if( ( input_data_size < 16 ) || ( input_data_size > (size_t) INT_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid input data size value out of bounds.", function ); return( -1 ); } if( output_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid output data.", function ); return( -1 ); } if( ( output_data_size < input_data_size ) || ( output_data_size > (size_t) INT_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid output data size value out of bounds.", function ); return( -1 ); } if( memory_set( block_data, 0, EVP_MAX_BLOCK_LENGTH ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear block data.", function ); goto on_error; } #if defined( HAVE_EVP_CIPHERINIT_EX2 ) if( EVP_CIPHER_CTX_reset( internal_context->evp_cipher_context ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to reset cipher context with error: %s.", function, error_string ); goto on_error; } if( internal_context->key_bit_size == 128 ) { cipher_string = "AES-128-ECB"; } else if( internal_context->key_bit_size == 192 ) { cipher_string = "AES-192-ECB"; } else if( internal_context->key_bit_size == 256 ) { cipher_string = "AES-256-ECB"; } cipher = EVP_CIPHER_fetch( NULL, cipher_string, NULL ); if( cipher == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_VALUE_MISSING, "%s: missing cipher.", function ); goto on_error; } parameters[0] = OSSL_PARAM_construct_uint( OSSL_CIPHER_PARAM_PADDING, &padding ); parameters[1] = OSSL_PARAM_construct_end(); if( EVP_CipherInit_ex2( internal_context->evp_cipher_context, cipher, (unsigned char *) internal_context->key, NULL, mode, parameters ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to initialize cipher with error: %s.", function, error_string ); goto on_error; } #else if( internal_context->key_bit_size == 128 ) { cipher = EVP_aes_128_ecb(); } else if( internal_context->key_bit_size == 192 ) { cipher = EVP_aes_192_ecb(); } else if( internal_context->key_bit_size == 256 ) { cipher = EVP_aes_256_ecb(); } if( EVP_CipherInit_ex( internal_context->evp_cipher_context, cipher, NULL, (unsigned char *) internal_context->key, NULL, mode ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to initialize cipher with error: %s.", function, error_string ); goto on_error; } if( EVP_CIPHER_CTX_set_padding( internal_context->evp_cipher_context, 1 ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to set padding in context with error: %s.", function, error_string ); goto on_error; } #endif /* defined( HAVE_EVP_CIPHERINIT_EX2 ) */ if( EVP_CipherUpdate( internal_context->evp_cipher_context, (unsigned char *) output_data, &safe_output_data_size, (unsigned char *) input_data, 16 ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to update cipher with error: %s.", function, error_string ); goto on_error; } /* Just ignore the output of this function */ EVP_CipherFinal_ex( internal_context->evp_cipher_context, (unsigned char *) block_data, &safe_output_data_size ); #if defined( HAVE_EVP_CIPHERINIT_EX2 ) EVP_CIPHER_free( cipher ); #endif return( 1 ); on_error: #if defined( HAVE_EVP_CIPHERINIT_EX2 ) if( cipher != NULL ) { EVP_CIPHER_free( cipher ); } #endif return( -1 ); } #else /* De- or encrypts a block of data using AES-ECB (Electronic CodeBook) using fallback implementation * The size must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ int libcaes_crypt_ecb( libcaes_context_t *context, int mode, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ) { uint32_t cipher_values_32bit[ 4 ]; uint32_t values_32bit[ 4 ]; libcaes_internal_context_t *internal_context = NULL; uint32_t *round_keys = NULL; static char *function = "libcaes_crypt_ecb"; size_t data_offset = 0; uint32_t substitution_value = 0; uint32_t table_value = 0; int result = 1; int round_key_iterator = 0; if( context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid context.", function ); return( -1 ); } internal_context = (libcaes_internal_context_t *) context; if( ( mode != LIBCAES_CRYPT_MODE_DECRYPT ) && ( mode != LIBCAES_CRYPT_MODE_ENCRYPT ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported mode.", function ); return( -1 ); } if( input_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid input data.", function ); return( -1 ); } /* Check if the input data size is a multitude of 16-byte */ if( ( ( input_data_size & (size_t) 0x0f ) != 0 ) || ( input_data_size < 16 ) || ( input_data_size > (size_t) SSIZE_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid input data size value out of bounds.", function ); return( -1 ); } if( output_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid output data.", function ); return( -1 ); } if( ( output_data_size < input_data_size ) || ( output_data_size > (size_t) SSIZE_MAX ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid output data size value out of bounds.", function ); return( -1 ); } while( data_offset < input_data_size ) { byte_stream_copy_to_uint32_little_endian( &( input_data[ data_offset ] ), values_32bit[ 0 ] ); byte_stream_copy_to_uint32_little_endian( &( input_data[ data_offset + 4 ] ), values_32bit[ 1 ] ); byte_stream_copy_to_uint32_little_endian( &( input_data[ data_offset + 8 ] ), values_32bit[ 2 ] ); byte_stream_copy_to_uint32_little_endian( &( input_data[ data_offset + 12 ] ), values_32bit[ 3 ] ); round_keys = internal_context->round_keys; values_32bit[ 0 ] ^= round_keys[ 0 ]; values_32bit[ 1 ] ^= round_keys[ 1 ]; values_32bit[ 2 ] ^= round_keys[ 2 ]; values_32bit[ 3 ] ^= round_keys[ 3 ]; round_keys += 4; if( mode == LIBCAES_CRYPT_MODE_ENCRYPT ) { for( round_key_iterator = ( internal_context->number_of_round_keys / 2 ); round_key_iterator > 1; round_key_iterator-- ) { libcaes_calculate_forward_table_round( round_keys, cipher_values_32bit, values_32bit, table_value ); round_keys += 4; libcaes_calculate_forward_table_round( round_keys, values_32bit, cipher_values_32bit, table_value ); round_keys += 4; } libcaes_calculate_forward_table_round( round_keys, cipher_values_32bit, values_32bit, table_value ); round_keys += 4; libcaes_calculate_forward_substitution_round( round_keys, values_32bit, cipher_values_32bit, substitution_value ); } else { for( round_key_iterator = ( internal_context->number_of_round_keys / 2 ); round_key_iterator > 1; round_key_iterator-- ) { libcaes_calculate_reverse_table_round( round_keys, cipher_values_32bit, values_32bit, table_value ); round_keys += 4; libcaes_calculate_reverse_table_round( round_keys, values_32bit, cipher_values_32bit, table_value ); round_keys += 4; } libcaes_calculate_reverse_table_round( round_keys, cipher_values_32bit, values_32bit, table_value ); round_keys += 4; libcaes_calculate_reverse_substitution_round( round_keys, values_32bit, cipher_values_32bit, table_value ); } byte_stream_copy_from_uint32_little_endian( &( output_data[ data_offset ] ), values_32bit[ 0 ] ); byte_stream_copy_from_uint32_little_endian( &( output_data[ data_offset + 4 ] ), values_32bit[ 1 ] ); byte_stream_copy_from_uint32_little_endian( &( output_data[ data_offset + 8 ] ), values_32bit[ 2 ] ); byte_stream_copy_from_uint32_little_endian( &( output_data[ data_offset + 12 ] ), values_32bit[ 3 ] ); if( memory_set( values_32bit, 0, sizeof( uint32_t ) * 4 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear values 32-bit.", function ); result = -1; } if( memory_set( cipher_values_32bit, 0, sizeof( uint32_t ) * 4 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear cipher values 32-bit.", function ); result = -1; } data_offset += 16; } return( result ); } #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && defined( HAVE_AES_ECB_ENCRYPT ) */ libcaes-20240413/libcaes/libcaes_definitions.h0000644000175000017500000000331714606477645022012 0ustar00lordyestalordyesta/* * The internal definitions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( LIBCAES_INTERNAL_DEFINITIONS_H ) #define LIBCAES_INTERNAL_DEFINITIONS_H #include #include /* Define HAVE_LOCAL_LIBCAES for local use of libcaes */ #if !defined( HAVE_LOCAL_LIBCAES ) #include /* The definitions in are copied here * for local use of libcaes */ #else #define LIBCAES_VERSION 20240413 /* The libcaes version string */ #define LIBCAES_VERSION_STRING "20240413" /* The crypt modes */ enum LIBCAES_CRYPT_MODES { LIBCAES_CRYPT_MODE_DECRYPT = 0, LIBCAES_CRYPT_MODE_ENCRYPT = 1 }; #endif /* !defined( HAVE_LOCAL_LIBCAES ) */ #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) #define LIBCAES_HAVE_AES_SUPPORT #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) #define LIBCAES_HAVE_AES_SUPPORT #endif #define LIBCAES_UNFOLLED_LOOPS #endif /* !defined( LIBCAES_INTERNAL_DEFINITIONS_H ) */ libcaes-20240413/libcaes/libcaes.rc0000644000175000017500000000206314606477645017571 0ustar00lordyestalordyesta#include #ifdef GCC_WINDRES VS_VERSION_INFO VERSIONINFO #else VS_VERSION_INFO VERSIONINFO MOVEABLE IMPURE LOADONCALL DISCARDABLE #endif FILEVERSION 1,0,0,0 PRODUCTVERSION 1,0,0,0 FILEFLAGSMASK VS_FFI_FILEFLAGSMASK #ifdef _DEBUG FILEFLAGS 0x1L #else FILEFLAGS 0x0L #endif FILEOS VOS__WINDOWS32 FILETYPE VFT_DLL FILESUBTYPE 0x0L BEGIN BLOCK "StringFileInfo" BEGIN BLOCK "040904E4" BEGIN VALUE "FileDescription", "Library to support cross-platform AES encryption\0" VALUE "FileVersion", "20240413" "\0" VALUE "InternalName", "libcaes.dll\0" VALUE "LegalCopyright", "(C) 2011-2024, Joachim Metz \0" VALUE "OriginalFilename", "libcaes.dll\0" VALUE "ProductName", "libcaes\0" VALUE "ProductVersion", "20240413" "\0" VALUE "Comments", "For more information visit https://github.com/libyal/libcaes/\0" END END BLOCK "VarFileInfo" BEGIN VALUE "Translation", 0x0409, 1200 END END libcaes-20240413/libcaes/Makefile.am0000644000175000017500000000173614606475165017676 0ustar00lordyestalordyestaAM_CPPFLAGS = \ -I../include -I$(top_srcdir)/include \ -I../common -I$(top_srcdir)/common \ @LIBCERROR_CPPFLAGS@ \ @LIBCRYPTO_CPPFLAGS@ \ @LIBCAES_DLL_EXPORT@ lib_LTLIBRARIES = libcaes.la libcaes_la_SOURCES = \ libcaes.c \ libcaes_context.c libcaes_context.h \ libcaes_definitions.h \ libcaes_extern.h \ libcaes_error.c libcaes_error.h \ libcaes_libcerror.h \ libcaes_support.c libcaes_support.h \ libcaes_tweaked_context.c libcaes_tweaked_context.h \ libcaes_types.h \ libcaes_unused.h libcaes_la_LIBADD = \ @LIBCERROR_LIBADD@ \ @LIBCRYPTO_LIBADD@ \ @LIBDL_LIBADD@ libcaes_la_LDFLAGS = -no-undefined -version-info 1:0:0 EXTRA_DIST = \ libcaes_definitions.h.in \ libcaes.rc \ libcaes.rc.in DISTCLEANFILES = \ libcaes_definitions.h \ libcaes.rc \ Makefile \ Makefile.in sources-local: $(BUILT_SOURCES) splint-local: @echo "Running splint on libcaes ..." -splint -preproc -redef $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(libcaes_la_SOURCES) libcaes-20240413/libcaes/libcaes_definitions.h.in0000644000175000017500000000332114606473412022376 0ustar00lordyestalordyesta/* * The internal definitions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( LIBCAES_INTERNAL_DEFINITIONS_H ) #define LIBCAES_INTERNAL_DEFINITIONS_H #include #include /* Define HAVE_LOCAL_LIBCAES for local use of libcaes */ #if !defined( HAVE_LOCAL_LIBCAES ) #include /* The definitions in are copied here * for local use of libcaes */ #else #define LIBCAES_VERSION @VERSION@ /* The libcaes version string */ #define LIBCAES_VERSION_STRING "@VERSION@" /* The crypt modes */ enum LIBCAES_CRYPT_MODES { LIBCAES_CRYPT_MODE_DECRYPT = 0, LIBCAES_CRYPT_MODE_ENCRYPT = 1 }; #endif /* !defined( HAVE_LOCAL_LIBCAES ) */ #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) #define LIBCAES_HAVE_AES_SUPPORT #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) #define LIBCAES_HAVE_AES_SUPPORT #endif #define LIBCAES_UNFOLLED_LOOPS #endif /* !defined( LIBCAES_INTERNAL_DEFINITIONS_H ) */ libcaes-20240413/libcaes/libcaes_error.h0000644000175000017500000000335414606473412020615 0ustar00lordyestalordyesta/* * Error functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_INTERNAL_ERROR_H ) #define _LIBCAES_INTERNAL_ERROR_H #include #include #include #if !defined( HAVE_LOCAL_LIBCAES ) #include #endif #include "libcaes_extern.h" #if defined( __cplusplus ) extern "C" { #endif #if !defined( HAVE_LOCAL_LIBCAES ) LIBCAES_EXTERN \ void libcaes_error_free( libcaes_error_t **error ); LIBCAES_EXTERN \ int libcaes_error_fprint( libcaes_error_t *error, FILE *stream ); LIBCAES_EXTERN \ int libcaes_error_sprint( libcaes_error_t *error, char *string, size_t size ); LIBCAES_EXTERN \ int libcaes_error_backtrace_fprint( libcaes_error_t *error, FILE *stream ); LIBCAES_EXTERN \ int libcaes_error_backtrace_sprint( libcaes_error_t *error, char *string, size_t size ); #endif /* !defined( HAVE_LOCAL_LIBCAES ) */ #if defined( __cplusplus ) } #endif #endif /* !defined( _LIBCAES_INTERNAL_ERROR_H ) */ libcaes-20240413/libcaes/libcaes_types.h0000644000175000017500000000311014606473412020616 0ustar00lordyestalordyesta/* * The internal type definitions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_INTERNAL_TYPES_H ) #define _LIBCAES_INTERNAL_TYPES_H #include #include /* Define HAVE_LOCAL_LIBCAES for local use of libcaes * The definitions in are copied here * for local use of libcaes */ #if defined( HAVE_LOCAL_LIBCAES ) /* The following type definitions hide internal data structures */ #if defined( HAVE_DEBUG_OUTPUT ) && !defined( WINAPI ) typedef struct libcaes_context {} libcaes_context_t; typedef struct libcaes_tweaked_context {} libcaes_tweaked_context_t; #else typedef intptr_t libcaes_context_t; typedef intptr_t libcaes_tweaked_context_t; #endif /* defined( HAVE_DEBUG_OUTPUT ) && !defined( WINAPI ) */ #endif /* defined( HAVE_LOCAL_LIBCAES ) */ #endif /* !defined( _LIBCAES_INTERNAL_TYPES_H ) */ libcaes-20240413/libcaes/libcaes_extern.h0000644000175000017500000000254014606473412020765 0ustar00lordyestalordyesta/* * The internal extern definition * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_INTERNAL_EXTERN_H ) #define _LIBCAES_INTERNAL_EXTERN_H #include /* Define HAVE_LOCAL_LIBCAES for local use of libcaes */ #if !defined( HAVE_LOCAL_LIBCAES ) #include #if defined( __CYGWIN__ ) || defined( __MINGW32__ ) #define LIBCAES_EXTERN_VARIABLE extern #else #define LIBCAES_EXTERN_VARIABLE LIBCAES_EXTERN #endif #else #define LIBCAES_EXTERN /* extern */ #define LIBCAES_EXTERN_VARIABLE extern #endif /* !defined( HAVE_LOCAL_LIBCAES ) */ #endif /* !defined( _LIBCAES_INTERNAL_EXTERN_H ) */ libcaes-20240413/libcaes/libcaes_support.h0000644000175000017500000000224114606473412021172 0ustar00lordyestalordyesta/* * Support functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_SUPPORT_H ) #define _LIBCAES_SUPPORT_H #include #include #include "libcaes_extern.h" #if defined( __cplusplus ) extern "C" { #endif #if !defined( HAVE_LOCAL_LIBCAES ) LIBCAES_EXTERN \ const char *libcaes_get_version( void ); #endif #if defined( __cplusplus ) } #endif #endif /* !defined( _LIBCAES_SUPPORT_H ) */ libcaes-20240413/libcaes/libcaes.rc.in0000644000175000017500000000206514606473412020164 0ustar00lordyestalordyesta#include #ifdef GCC_WINDRES VS_VERSION_INFO VERSIONINFO #else VS_VERSION_INFO VERSIONINFO MOVEABLE IMPURE LOADONCALL DISCARDABLE #endif FILEVERSION 1,0,0,0 PRODUCTVERSION 1,0,0,0 FILEFLAGSMASK VS_FFI_FILEFLAGSMASK #ifdef _DEBUG FILEFLAGS 0x1L #else FILEFLAGS 0x0L #endif FILEOS VOS__WINDOWS32 FILETYPE VFT_DLL FILESUBTYPE 0x0L BEGIN BLOCK "StringFileInfo" BEGIN BLOCK "040904E4" BEGIN VALUE "FileDescription", "Library to support cross-platform AES encryption\0" VALUE "FileVersion", "@VERSION@" "\0" VALUE "InternalName", "libcaes.dll\0" VALUE "LegalCopyright", "(C) 2011-2024, Joachim Metz \0" VALUE "OriginalFilename", "libcaes.dll\0" VALUE "ProductName", "libcaes\0" VALUE "ProductVersion", "@VERSION@" "\0" VALUE "Comments", "For more information visit https://github.com/libyal/libcaes/\0" END END BLOCK "VarFileInfo" BEGIN VALUE "Translation", 0x0409, 1200 END END libcaes-20240413/libcaes/libcaes_libcerror.h0000644000175000017500000000263314606473412021446 0ustar00lordyestalordyesta/* * The libcerror header wrapper * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_LIBCERROR_H ) #define _LIBCAES_LIBCERROR_H #include /* Define HAVE_LOCAL_LIBCERROR for local use of libcerror */ #if defined( HAVE_LOCAL_LIBCERROR ) #include #include #include #include #else /* If libtool DLL support is enabled set LIBCERROR_DLL_IMPORT * before including libcerror.h */ #if defined( _WIN32 ) && defined( DLL_IMPORT ) #define LIBCERROR_DLL_IMPORT #endif #include #endif /* defined( HAVE_LOCAL_LIBCERROR ) */ #endif /* !defined( _LIBCAES_LIBCERROR_H ) */ libcaes-20240413/libcaes/libcaes_support.c0000644000175000017500000000212514606473412021166 0ustar00lordyestalordyesta/* * Support functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include "libcaes_definitions.h" #include "libcaes_support.h" #if !defined( HAVE_LOCAL_LIBCAES ) /* Returns the library version as a string */ const char *libcaes_get_version( void ) { return( (const char *) LIBCAES_VERSION_STRING ); } #endif libcaes-20240413/libcaes/Makefile.in0000644000175000017500000006256414606477627017722 0ustar00lordyestalordyesta# Makefile.in generated by automake 1.16.5 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2021 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = libcaes ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/common.m4 \ $(top_srcdir)/m4/gettext.m4 $(top_srcdir)/m4/host-cpu-c-abi.m4 \ $(top_srcdir)/m4/iconv.m4 $(top_srcdir)/m4/intlmacosx.m4 \ $(top_srcdir)/m4/lib-ld.m4 $(top_srcdir)/m4/lib-link.m4 \ $(top_srcdir)/m4/lib-prefix.m4 $(top_srcdir)/m4/libcerror.m4 \ $(top_srcdir)/m4/libcrypto.m4 $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/nls.m4 $(top_srcdir)/m4/po.m4 \ $(top_srcdir)/m4/progtest.m4 $(top_srcdir)/m4/python.m4 \ $(top_srcdir)/m4/tests.m4 $(top_srcdir)/m4/types.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/common/config.h CONFIG_CLEAN_FILES = libcaes_definitions.h libcaes.rc CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(libdir)" LTLIBRARIES = $(lib_LTLIBRARIES) libcaes_la_DEPENDENCIES = am_libcaes_la_OBJECTS = libcaes.lo libcaes_context.lo libcaes_error.lo \ libcaes_support.lo libcaes_tweaked_context.lo libcaes_la_OBJECTS = $(am_libcaes_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = libcaes_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(libcaes_la_LDFLAGS) $(LDFLAGS) -o $@ AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)/common depcomp = $(SHELL) $(top_srcdir)/depcomp am__maybe_remake_depfiles = depfiles am__depfiles_remade = ./$(DEPDIR)/libcaes.Plo \ ./$(DEPDIR)/libcaes_context.Plo ./$(DEPDIR)/libcaes_error.Plo \ ./$(DEPDIR)/libcaes_support.Plo \ ./$(DEPDIR)/libcaes_tweaked_context.Plo am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libcaes_la_SOURCES) DIST_SOURCES = $(libcaes_la_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__extra_recursive_targets = sources-recursive splint-recursive am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/libcaes.rc.in \ $(srcdir)/libcaes_definitions.h.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CSCOPE = @CSCOPE@ CTAGS = @CTAGS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DPKG_DATE = @DPKG_DATE@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ ETAGS = @ETAGS@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ FILECMD = @FILECMD@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GREP = @GREP@ HAVE_DLLMAIN = @HAVE_DLLMAIN@ HAVE_INTTYPES_H = @HAVE_INTTYPES_H@ HAVE_LIBCERROR = @HAVE_LIBCERROR@ HAVE_LOCAL_LIBCERROR = @HAVE_LOCAL_LIBCERROR@ HAVE_OFF64_T = @HAVE_OFF64_T@ HAVE_OPENSSL_EVP_H = @HAVE_OPENSSL_EVP_H@ HAVE_SIZE32_T = @HAVE_SIZE32_T@ HAVE_SIZE64_T = @HAVE_SIZE64_T@ HAVE_SSIZE32_T = @HAVE_SSIZE32_T@ HAVE_SSIZE64_T = @HAVE_SSIZE64_T@ HAVE_STDINT_H = @HAVE_STDINT_H@ HAVE_SYS_TYPES_H = @HAVE_SYS_TYPES_H@ HAVE_WCHAR_H = @HAVE_WCHAR_H@ HAVE_WIDE_CHARACTER_TYPE = @HAVE_WIDE_CHARACTER_TYPE@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBCAES_DLL_EXPORT = @LIBCAES_DLL_EXPORT@ LIBCAES_DLL_IMPORT = @LIBCAES_DLL_IMPORT@ LIBCERROR_CPPFLAGS = @LIBCERROR_CPPFLAGS@ LIBCERROR_LIBADD = @LIBCERROR_LIBADD@ LIBCRYPTO_CPPFLAGS = @LIBCRYPTO_CPPFLAGS@ LIBCRYPTO_LIBADD = @LIBCRYPTO_LIBADD@ LIBDL_LIBADD = @LIBDL_LIBADD@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIB_FUZZING_ENGINE = @LIB_FUZZING_ENGINE@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGMERGE = @MSGMERGE@ MSGMERGE_FOR_MSGFMT_OPTION = @MSGMERGE_FOR_MSGFMT_OPTION@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ PKGCONFIG = @PKGCONFIG@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ PYTHON = @PYTHON@ PYTHON_CONFIG = @PYTHON_CONFIG@ PYTHON_CPPFLAGS = @PYTHON_CPPFLAGS@ PYTHON_EXEC_PREFIX = @PYTHON_EXEC_PREFIX@ PYTHON_LDFLAGS = @PYTHON_LDFLAGS@ PYTHON_LIBRARY_DIR = @PYTHON_LIBRARY_DIR@ PYTHON_PACKAGE_DIR = @PYTHON_PACKAGE_DIR@ PYTHON_PLATFORM = @PYTHON_PLATFORM@ PYTHON_PREFIX = @PYTHON_PREFIX@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ SPEC_DATE = @SPEC_DATE@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ ax_libcerror_pc_libs_private = @ax_libcerror_pc_libs_private@ ax_libcerror_spec_build_requires = @ax_libcerror_spec_build_requires@ ax_libcerror_spec_requires = @ax_libcerror_spec_requires@ ax_libcrypto_pc_libs_private = @ax_libcrypto_pc_libs_private@ ax_libcrypto_spec_build_requires = @ax_libcrypto_spec_build_requires@ ax_libcrypto_spec_requires = @ax_libcrypto_spec_requires@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libcaes_spec_requires = @libcaes_spec_requires@ libcerror_CFLAGS = @libcerror_CFLAGS@ libcerror_LIBS = @libcerror_LIBS@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ openssl_CFLAGS = @openssl_CFLAGS@ openssl_LIBS = @openssl_LIBS@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ pyexecdir = @pyexecdir@ pythondir = @pythondir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ AM_CPPFLAGS = \ -I../include -I$(top_srcdir)/include \ -I../common -I$(top_srcdir)/common \ @LIBCERROR_CPPFLAGS@ \ @LIBCRYPTO_CPPFLAGS@ \ @LIBCAES_DLL_EXPORT@ lib_LTLIBRARIES = libcaes.la libcaes_la_SOURCES = \ libcaes.c \ libcaes_context.c libcaes_context.h \ libcaes_definitions.h \ libcaes_extern.h \ libcaes_error.c libcaes_error.h \ libcaes_libcerror.h \ libcaes_support.c libcaes_support.h \ libcaes_tweaked_context.c libcaes_tweaked_context.h \ libcaes_types.h \ libcaes_unused.h libcaes_la_LIBADD = \ @LIBCERROR_LIBADD@ \ @LIBCRYPTO_LIBADD@ \ @LIBDL_LIBADD@ libcaes_la_LDFLAGS = -no-undefined -version-info 1:0:0 EXTRA_DIST = \ libcaes_definitions.h.in \ libcaes.rc \ libcaes.rc.in DISTCLEANFILES = \ libcaes_definitions.h \ libcaes.rc \ Makefile \ Makefile.in all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu libcaes/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu libcaes/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): libcaes_definitions.h: $(top_builddir)/config.status $(srcdir)/libcaes_definitions.h.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ libcaes.rc: $(top_builddir)/config.status $(srcdir)/libcaes.rc.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ install-libLTLIBRARIES: $(lib_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(libdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(libdir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(libdir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(libdir)"; \ } uninstall-libLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(lib_LTLIBRARIES)'; test -n "$(libdir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(libdir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(libdir)/$$f"; \ done clean-libLTLIBRARIES: -test -z "$(lib_LTLIBRARIES)" || rm -f $(lib_LTLIBRARIES) @list='$(lib_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libcaes.la: $(libcaes_la_OBJECTS) $(libcaes_la_DEPENDENCIES) $(EXTRA_libcaes_la_DEPENDENCIES) $(AM_V_CCLD)$(libcaes_la_LINK) -rpath $(libdir) $(libcaes_la_OBJECTS) $(libcaes_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libcaes.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libcaes_context.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libcaes_error.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libcaes_support.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libcaes_tweaked_context.Plo@am__quote@ # am--include-marker $(am__depfiles_remade): @$(MKDIR_P) $(@D) @echo '# dummy' >$@-t && $(am__mv) $@-t $@ am--depfiles: $(am__depfiles_remade) .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs sources-local: splint-local: ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: for dir in "$(DESTDIR)$(libdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) -test -z "$(DISTCLEANFILES)" || rm -f $(DISTCLEANFILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libLTLIBRARIES clean-libtool \ mostlyclean-am distclean: distclean-am -rm -f ./$(DEPDIR)/libcaes.Plo -rm -f ./$(DEPDIR)/libcaes_context.Plo -rm -f ./$(DEPDIR)/libcaes_error.Plo -rm -f ./$(DEPDIR)/libcaes_support.Plo -rm -f ./$(DEPDIR)/libcaes_tweaked_context.Plo -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-libLTLIBRARIES install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f ./$(DEPDIR)/libcaes.Plo -rm -f ./$(DEPDIR)/libcaes_context.Plo -rm -f ./$(DEPDIR)/libcaes_error.Plo -rm -f ./$(DEPDIR)/libcaes_support.Plo -rm -f ./$(DEPDIR)/libcaes_tweaked_context.Plo -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: sources: sources-am sources-am: sources-local splint: splint-am splint-am: splint-local uninstall-am: uninstall-libLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am am--depfiles check check-am clean \ clean-generic clean-libLTLIBRARIES clean-libtool cscopelist-am \ ctags ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-libLTLIBRARIES install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ sources-am sources-local splint-am splint-local tags tags-am \ uninstall uninstall-am uninstall-libLTLIBRARIES .PRECIOUS: Makefile sources-local: $(BUILT_SOURCES) splint-local: @echo "Running splint on libcaes ..." -splint -preproc -redef $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(libcaes_la_SOURCES) # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: libcaes-20240413/libcaes/libcaes_tweaked_context.c0000644000175000017500000010051714606473412022646 0ustar00lordyestalordyesta/* * AES encryption functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include #include #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) #include #include #endif #if defined( HAVE_EVP_CIPHERINIT_EX2 ) #include #endif #include "libcaes_context.h" #include "libcaes_definitions.h" #include "libcaes_libcerror.h" #include "libcaes_tweaked_context.h" #include "libcaes_types.h" /* Creates a tweaked context * Make sure the value context is referencing, is set to NULL * Returns 1 if successful or -1 on error */ int libcaes_tweaked_context_initialize( libcaes_tweaked_context_t **tweaked_context, libcerror_error_t **error ) { libcaes_internal_tweaked_context_t *internal_tweaked_context = NULL; static char *function = "libcaes_tweaked_context_initialize"; #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) char error_string[ 256 ]; unsigned long error_code = 0; #endif if( tweaked_context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid tweaked context.", function ); return( -1 ); } if( *tweaked_context != NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_VALUE_ALREADY_SET, "%s: invalid tweaked context value already set.", function ); return( -1 ); } internal_tweaked_context = memory_allocate_structure( libcaes_internal_tweaked_context_t ); if( internal_tweaked_context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_INSUFFICIENT, "%s: unable to create tweaked context.", function ); goto on_error; } if( memory_set( internal_tweaked_context, 0, sizeof( libcaes_internal_tweaked_context_t ) ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear tweaked context.", function ); memory_free( internal_tweaked_context ); return( -1 ); } #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) #if defined( HAVE_EVP_CIPHER_CTX_INIT ) EVP_CIPHER_CTX_init( &( internal_tweaked_context->internal_evp_cipher_context ) ); internal_tweaked_context->evp_cipher_context = &( internal_tweaked_context->internal_evp_cipher_context ); #else internal_tweaked_context->evp_cipher_context = EVP_CIPHER_CTX_new(); if( internal_tweaked_context->evp_cipher_context == NULL ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to create EVP cipher context with error: %s.", function, error_string ); goto on_error; } #endif /* defined( HAVE_EVP_CIPHER_CTX_INIT ) */ #else if( libcaes_context_initialize( &( internal_tweaked_context->main_context ), error ) != 1) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to initialize main context.", function ); goto on_error; } if( libcaes_context_initialize( &( internal_tweaked_context->tweak_context ), error ) != 1) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to initialize tweak context.", function ); goto on_error; } #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) */ *tweaked_context = (libcaes_tweaked_context_t *) internal_tweaked_context; return( 1 ); on_error: if( internal_tweaked_context != NULL ) { #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) /* No additional clean up necessary */ #else if( internal_tweaked_context->main_context != NULL ) { libcaes_context_free( &( internal_tweaked_context->main_context ), NULL ); } #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) */ memory_free( internal_tweaked_context ); } return( -1 ); } /* Frees a tweaked context * Returns 1 if successful or -1 on error */ int libcaes_tweaked_context_free( libcaes_tweaked_context_t **tweaked_context, libcerror_error_t **error ) { libcaes_internal_tweaked_context_t *internal_tweaked_context = NULL; static char *function = "libcaes_tweaked_context_free"; int result = 1; #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_EVP_CIPHER_CTX_CLEANUP ) char error_string[ 256 ]; unsigned long error_code = 0; #endif if( tweaked_context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid tweaked context.", function ); return( -1 ); } if( *tweaked_context != NULL ) { internal_tweaked_context = (libcaes_internal_tweaked_context_t *) *tweaked_context; *tweaked_context = NULL; #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) #if defined( HAVE_EVP_CIPHER_CTX_CLEANUP ) if( EVP_CIPHER_CTX_cleanup( &( internal_tweaked_context->internal_evp_cipher_context ) ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_FINALIZE_FAILED, "%s: unable to clean up EVP cipher context with error: %s.", function, error_string ); result = -1; } /* Make sure the error state is removed otherwise OpenSSL will leak memory */ ERR_remove_thread_state( NULL ); #else EVP_CIPHER_CTX_free( internal_tweaked_context->evp_cipher_context ); #endif /* defined( HAVE_EVP_CIPHER_CTX_CLEANUP ) */ internal_tweaked_context->evp_cipher_context = NULL; #else if( libcaes_context_free( &( internal_tweaked_context->tweak_context ), error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_FINALIZE_FAILED, "%s: unable to free tweak context.", function ); result = -1; } if( libcaes_context_free( &( internal_tweaked_context->main_context ), error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_FINALIZE_FAILED, "%s: unable to free main context.", function ); result = -1; } #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) */ memory_free( internal_tweaked_context ); } return( result ); } /* Sets the keys * Returns 1 if successful or -1 on error */ int libcaes_tweaked_context_set_keys( libcaes_tweaked_context_t *tweaked_context, int mode, const uint8_t *key, size_t key_bit_size, const uint8_t *tweak_key, size_t tweak_key_bit_size, libcerror_error_t **error ) { libcaes_internal_tweaked_context_t *internal_tweaked_context = NULL; static char *function = "libcaes_tweaked_context_set_key"; #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) size_t key_byte_size = 0; #endif if( tweaked_context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid tweaked context.", function ); return( -1 ); } internal_tweaked_context = (libcaes_internal_tweaked_context_t *) tweaked_context; if( ( mode != LIBCAES_CRYPT_MODE_DECRYPT ) && ( mode != LIBCAES_CRYPT_MODE_ENCRYPT ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported mode.", function ); return( -1 ); } if( ( key_bit_size != 128 ) && ( key_bit_size != 256 ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported key bit size.", function ); return( -1 ); } if( tweak_key_bit_size != key_bit_size ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported tweak key bit size.", function ); return( -1 ); } #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) if( key == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid key.", function ); return( -1 ); } if( tweak_key == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid tweak key.", function ); return( -1 ); } key_byte_size = key_bit_size / 8; if( memory_copy( internal_tweaked_context->key, key, key_byte_size ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy key.", function ); return( -1 ); } if( memory_copy( &( internal_tweaked_context->key[ key_byte_size ] ), tweak_key, key_byte_size ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy tweak key.", function ); return( -1 ); } internal_tweaked_context->key_bit_size = key_bit_size; #else if( libcaes_context_set_key( internal_tweaked_context->main_context, mode, key, key_bit_size, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to set key in main context.", function ); return( -1 ); } if( libcaes_context_set_key( internal_tweaked_context->tweak_context, LIBCAES_CRYPT_MODE_ENCRYPT, tweak_key, tweak_key_bit_size, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to set tweak key in tweak context.", function ); return( -1 ); } #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) */ return( 1 ); } #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) /* De- or encrypts a block of data using AES-XTS (XEX-based tweaked-codebook mode with ciphertext stealing) using OpenSSL EVP * The size must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ int libcaes_crypt_xts( libcaes_tweaked_context_t *tweaked_context, int mode, const uint8_t *tweak_value, size_t tweak_value_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ) { uint8_t block_data[ EVP_MAX_BLOCK_LENGTH ]; char error_string[ 256 ]; #if defined( HAVE_EVP_CIPHERINIT_EX2 ) OSSL_PARAM parameters[2]; EVP_CIPHER *cipher = NULL; const char *cipher_string = NULL; unsigned int padding = 0; #else const EVP_CIPHER *cipher = NULL; #endif libcaes_internal_tweaked_context_t *internal_tweaked_context = NULL; static char *function = "libcaes_crypt_xts"; unsigned long error_code = 0; int safe_output_data_size = 0; if( tweaked_context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid tweaked context.", function ); return( -1 ); } internal_tweaked_context = (libcaes_internal_tweaked_context_t *) tweaked_context; if( ( mode != LIBCAES_CRYPT_MODE_DECRYPT ) && ( mode != LIBCAES_CRYPT_MODE_ENCRYPT ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported mode.", function ); return( -1 ); } if( tweak_value == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid tweak value.", function ); return( -1 ); } if( tweak_value_size != 16 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid tweak value size value out of bounds.", function ); return( -1 ); } if( input_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid input data.", function ); return( -1 ); } if( input_data_size > (size_t) INT_MAX ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_EXCEEDS_MAXIMUM, "%s: invalid input data size value exceeds maximum.", function ); return( -1 ); } if( input_data_size < 16 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_TOO_SMALL, "%s: invalid input data size value too small.", function ); return( -1 ); } if( output_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid output data.", function ); return( -1 ); } if( output_data_size > (size_t) INT_MAX ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_EXCEEDS_MAXIMUM, "%s: invalid output data size value exceeds maximum.", function ); return( -1 ); } if( output_data_size < input_data_size ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid ouput data size smaller than input data size.", function ); return( -1 ); } if( memory_set( block_data, 0, EVP_MAX_BLOCK_LENGTH ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear input block data.", function ); goto on_error; } #if defined( HAVE_EVP_CIPHERINIT_EX2 ) if( EVP_CIPHER_CTX_reset( internal_tweaked_context->evp_cipher_context ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to reset cipher context with error: %s.", function, error_string ); goto on_error; } if( internal_tweaked_context->key_bit_size == 128 ) { cipher_string = "AES-128-XTS"; } else if( internal_tweaked_context->key_bit_size == 256 ) { cipher_string = "AES-256-XTS"; } cipher = EVP_CIPHER_fetch( NULL, cipher_string, NULL ); if( cipher == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_VALUE_MISSING, "%s: missing cipher.", function ); goto on_error; } parameters[0] = OSSL_PARAM_construct_uint( OSSL_CIPHER_PARAM_PADDING, &padding ); parameters[1] = OSSL_PARAM_construct_end(); if( EVP_CipherInit_ex2( internal_tweaked_context->evp_cipher_context, cipher, (unsigned char *) internal_tweaked_context->key, (unsigned char *) tweak_value, mode, parameters ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to initialize cipher with error: %s.", function, error_string ); goto on_error; } #else if( internal_tweaked_context->key_bit_size == 128 ) { cipher = EVP_aes_128_xts(); } else if( internal_tweaked_context->key_bit_size == 256 ) { cipher = EVP_aes_256_xts(); } if( EVP_CipherInit_ex( internal_tweaked_context->evp_cipher_context, cipher, NULL, (unsigned char *) internal_tweaked_context->key, (unsigned char *) tweak_value, mode ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to initialize cipher with error: %s.", function, error_string ); goto on_error; } if( EVP_CIPHER_CTX_set_padding( internal_tweaked_context->evp_cipher_context, 1 ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to set padding in context with error: %s.", function, error_string ); goto on_error; } #endif /* defined( HAVE_EVP_CIPHERINIT_EX2 ) */ if( EVP_CipherUpdate( internal_tweaked_context->evp_cipher_context, (unsigned char *) output_data, &safe_output_data_size, (unsigned char *) input_data, input_data_size ) != 1 ) { error_code = ERR_get_error(); ERR_error_string_n( error_code, error_string, 256 ); libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to update cipher with error: %s.", function, error_string ); goto on_error; } /* Just ignore the output of this function */ EVP_CipherFinal_ex( internal_tweaked_context->evp_cipher_context, (unsigned char *) block_data, &safe_output_data_size ); #if defined( HAVE_EVP_CIPHERINIT_EX2 ) EVP_CIPHER_free( cipher ); #endif return( 1 ); on_error: #if defined( HAVE_EVP_CIPHERINIT_EX2 ) if( cipher != NULL ) { EVP_CIPHER_free( cipher ); } #endif return( -1 ); } #else /* De- or encrypts a block of data using AES-XTS (XEX-based tweaked-codebook mode with ciphertext stealing) using fallback implementation * The size must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ int libcaes_crypt_xts( libcaes_tweaked_context_t *tweaked_context, int mode, const uint8_t *tweak_value, size_t tweak_value_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcerror_error_t **error ) { uint8_t encrypted_tweak_value[ 16 ]; uint8_t encrypted_tweak_value_copy[ 16 ]; libcaes_internal_tweaked_context_t *internal_tweaked_context = NULL; static char *function = "libcaes_crypt_xts"; size_t data_offset = 0; size_t remaining_data_size = 0; uint8_t block_index = 0; uint8_t byte_value = 0; uint8_t carry_bit = 0; if( tweaked_context == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid tweaked context.", function ); return( -1 ); } internal_tweaked_context = (libcaes_internal_tweaked_context_t *) tweaked_context; if( ( mode != LIBCAES_CRYPT_MODE_DECRYPT ) && ( mode != LIBCAES_CRYPT_MODE_ENCRYPT ) ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE, "%s: unsupported mode.", function ); return( -1 ); } if( tweak_value == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid tweak value.", function ); return( -1 ); } if( tweak_value_size != 16 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid tweak value size value out of bounds.", function ); return( -1 ); } if( input_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid input data.", function ); return( -1 ); } if( input_data_size < 16 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_TOO_SMALL, "%s: invalid input data size value too small.", function ); return( -1 ); } if( input_data_size > (size_t) SSIZE_MAX ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_EXCEEDS_MAXIMUM, "%s: invalid input data size value exceeds maximum.", function ); return( -1 ); } if( output_data == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE, "%s: invalid output data.", function ); return( -1 ); } if( output_data_size > (size_t) SSIZE_MAX ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_EXCEEDS_MAXIMUM, "%s: invalid output data size value exceeds maximum.", function ); return( -1 ); } if( output_data_size < input_data_size ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid ouput data size smaller than input data size.", function ); return( -1 ); } if( libcaes_crypt_ecb( internal_tweaked_context->tweak_context, LIBCAES_CRYPT_MODE_ENCRYPT, tweak_value, 16, encrypted_tweak_value, 16, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ENCRYPTION, LIBCERROR_ENCRYPTION_ERROR_GENERIC, "%s: unable to encrypt tweak value.", function ); goto on_error; } if( memory_copy( output_data, input_data, input_data_size ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy input data to output data.", function ); return( -1 ); } remaining_data_size = input_data_size; while( data_offset <= ( input_data_size - 16 ) ) { if( ( remaining_data_size < 32 ) && ( remaining_data_size != 16 ) ) { /* If the input data size is not a multitude of 16 the remaining data needs to be handled differently */ if( mode == LIBCAES_CRYPT_MODE_DECRYPT ) { if( memory_copy( encrypted_tweak_value_copy, encrypted_tweak_value, 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy encrypted tweak value.", function ); goto on_error; } /* Update the encrypted tweak value for the next 16-byte block */ carry_bit = 0; for( block_index = 0; block_index < 16; block_index++ ) { byte_value = ( encrypted_tweak_value[ block_index ] << 1 ) | carry_bit; carry_bit = encrypted_tweak_value[ block_index ] >> 7; encrypted_tweak_value[ block_index ] = byte_value; } if( carry_bit > 0 ) { encrypted_tweak_value[ 0 ] ^= 0x87; } } } #if defined( LIBCAES_UNFOLLED_LOOPS ) output_data[ data_offset++ ] ^= encrypted_tweak_value[ 0 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 1 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 2 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 3 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 4 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 5 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 6 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 7 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 8 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 9 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 10 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 11 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 12 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 13 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 14 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 15 ]; #else for( block_index = 0; block_index < 16; block_index++ ) { output_data[ data_offset++ ] ^= encrypted_tweak_value[ block_index ]; } #endif data_offset -= 16; if( libcaes_crypt_ecb( internal_tweaked_context->main_context, mode, &( output_data[ data_offset ] ), 16, &( output_data[ data_offset ] ), 16, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ENCRYPTION, LIBCERROR_ENCRYPTION_ERROR_GENERIC, "%s: unable to de/encrypt data.", function ); goto on_error; } #if defined( LIBCAES_UNFOLLED_LOOPS ) output_data[ data_offset++ ] ^= encrypted_tweak_value[ 0 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 1 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 2 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 3 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 4 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 5 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 6 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 7 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 8 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 9 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 10 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 11 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 12 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 13 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 14 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 15 ]; #else for( block_index = 0; block_index < 16; block_index++ ) { output_data[ data_offset++ ] ^= encrypted_tweak_value[ block_index ]; } #endif remaining_data_size -= 16; /* Update the encrypted tweak value for the next 16-byte block */ carry_bit = 0; for( block_index = 0; block_index < 16; block_index++ ) { byte_value = ( encrypted_tweak_value[ block_index ] << 1 ) | carry_bit; carry_bit = encrypted_tweak_value[ block_index ] >> 7; encrypted_tweak_value[ block_index ] = byte_value; } if( carry_bit > 0 ) { encrypted_tweak_value[ 0 ] ^= 0x87; } } /* Any remaining data needs to be handled differently */ if( remaining_data_size > 0 ) { if( mode == LIBCAES_CRYPT_MODE_DECRYPT ) { if( memory_copy( encrypted_tweak_value, encrypted_tweak_value_copy, 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy encrypted tweak value.", function ); goto on_error; } if( memory_set( encrypted_tweak_value_copy, 0, 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear encrypted tweak value copy.", function ); goto on_error; } } /* Swap the data of the last 16-byte block with the remaining data */ data_offset -= 16; if( memory_copy( &( output_data[ data_offset + 16 ] ), &( output_data[ data_offset ] ), remaining_data_size ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy remaining output data.", function ); goto on_error; } if( memory_copy( &( output_data[ data_offset ] ), &( input_data[ data_offset + 16 ] ), remaining_data_size ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_COPY_FAILED, "%s: unable to copy input data to block data.", function ); goto on_error; } #if defined( LIBCAES_UNFOLLED_LOOPS ) output_data[ data_offset++ ] ^= encrypted_tweak_value[ 0 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 1 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 2 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 3 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 4 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 5 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 6 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 7 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 8 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 9 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 10 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 11 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 12 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 13 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 14 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 15 ]; #else for( block_index = 0; block_index < 16; block_index++ ) { output_data[ data_offset++ ] ^= encrypted_tweak_value[ block_index ]; } #endif data_offset -= 16; if( libcaes_crypt_ecb( internal_tweaked_context->main_context, mode, &( output_data[ data_offset ] ), 16, &( output_data[ data_offset ] ), 16, error ) != 1 ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_ENCRYPTION, LIBCERROR_ENCRYPTION_ERROR_GENERIC, "%s: unable to de/encrypt data.", function ); goto on_error; } #if defined( LIBCAES_UNFOLLED_LOOPS ) output_data[ data_offset++ ] ^= encrypted_tweak_value[ 0 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 1 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 2 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 3 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 4 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 5 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 6 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 7 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 8 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 9 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 10 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 11 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 12 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 13 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 14 ]; output_data[ data_offset++ ] ^= encrypted_tweak_value[ 15 ]; #else for( block_index = 0; block_index < 16; block_index++ ) { output_data[ data_offset++ ] ^= encrypted_tweak_value[ block_index ]; } #endif } if( memory_set( encrypted_tweak_value, 0, 16 ) == NULL ) { libcerror_error_set( error, LIBCERROR_ERROR_DOMAIN_MEMORY, LIBCERROR_MEMORY_ERROR_SET_FAILED, "%s: unable to clear encrypted tweak value.", function ); goto on_error; } return( 1 ); on_error: memory_set( encrypted_tweak_value_copy, 0, 16 ); memory_set( encrypted_tweak_value, 0, 16 ); return( -1 ); } #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) */ libcaes-20240413/libcaes.spec.in0000644000175000017500000000405014606473411017103 0ustar00lordyestalordyestaName: libcaes Version: @VERSION@ Release: 1 Summary: Library to support cross-platform AES encryption Group: System Environment/Libraries License: LGPL-3.0-or-later Source: %{name}-%{version}.tar.gz URL: https://github.com/libyal/libcaes @libcaes_spec_requires@ @ax_libcerror_spec_requires@ @ax_libcrypto_spec_requires@ BuildRequires: gcc @ax_libcerror_spec_build_requires@ @ax_libcrypto_spec_build_requires@ %description -n libcaes Library to support cross-platform AES encryption %package -n libcaes-static Summary: Library to support cross-platform AES encryption Group: Development/Libraries Requires: libcaes = %{version}-%{release} %description -n libcaes-static Static library version of libcaes. %package -n libcaes-devel Summary: Header files and libraries for developing applications for libcaes Group: Development/Libraries Requires: libcaes = %{version}-%{release} %description -n libcaes-devel Header files and libraries for developing applications for libcaes. %package -n libcaes-python3 Summary: Python 3 bindings for libcaes Group: System Environment/Libraries Requires: libcaes = %{version}-%{release} python3 BuildRequires: python3-devel python3-setuptools %description -n libcaes-python3 Python 3 bindings for libcaes %prep %setup -q %build %configure --prefix=/usr --libdir=%{_libdir} --mandir=%{_mandir} --enable-python make %{?_smp_mflags} %install rm -rf %{buildroot} %make_install %clean rm -rf %{buildroot} %post -p /sbin/ldconfig %postun -p /sbin/ldconfig %files -n libcaes %license COPYING COPYING.LESSER %doc AUTHORS README %{_libdir}/*.so.* %files -n libcaes-static %license COPYING COPYING.LESSER %doc AUTHORS README %{_libdir}/*.a %files -n libcaes-devel %license COPYING COPYING.LESSER %doc AUTHORS README %{_libdir}/*.so %{_libdir}/pkgconfig/libcaes.pc %{_includedir}/* %{_mandir}/man3/* %files -n libcaes-python3 %license COPYING COPYING.LESSER %doc AUTHORS README %{_libdir}/python3*/site-packages/*.a %{_libdir}/python3*/site-packages/*.so %changelog * @SPEC_DATE@ Joachim Metz @VERSION@-1 - Auto-generated libcaes-20240413/m4/0000755000175000017500000000000014606477653014555 5ustar00lordyestalordyestalibcaes-20240413/m4/tests.m40000644000175000017500000000136414533041421016140 0ustar00lordyestalordyestadnl Functions for testing dnl dnl Version: 20200712 dnl Function to detect if tests dependencies are available AC_DEFUN([AX_TESTS_CHECK_LOCAL], [AC_CHECK_HEADERS([dlfcn.h]) AC_CHECK_FUNCS([fmemopen getopt mkstemp setenv tzset unlink]) AC_CHECK_LIB( dl, dlsym) AS_IF( [test "x$lt_cv_prog_gnu_ld" = xyes && test "x$ac_cv_lib_dl_dlsym" = xyes], [AC_DEFINE( [HAVE_GNU_DL_DLSYM], [1], [Define to 1 if dlsym function is available in GNU dl.]) ]) ]) dnl Function to detect if OSS-Fuzz build environment is available AC_DEFUN([AX_TESTS_CHECK_OSSFUZZ], [AM_CONDITIONAL( HAVE_LIB_FUZZING_ENGINE, [test "x${LIB_FUZZING_ENGINE}" != x]) AC_SUBST( [LIB_FUZZING_ENGINE], ["${LIB_FUZZING_ENGINE}"]) ]) libcaes-20240413/m4/lib-prefix.m40000644000175000017500000002725014533041421017041 0ustar00lordyestalordyesta# lib-prefix.m4 serial 17 dnl Copyright (C) 2001-2005, 2008-2020 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. dnl AC_LIB_PREFIX adds to the CPPFLAGS and LDFLAGS the flags that are needed dnl to access previously installed libraries. The basic assumption is that dnl a user will want packages to use other packages he previously installed dnl with the same --prefix option. dnl This macro is not needed if only AC_LIB_LINKFLAGS is used to locate dnl libraries, but is otherwise very convenient. AC_DEFUN([AC_LIB_PREFIX], [ AC_BEFORE([$0], [AC_LIB_LINKFLAGS]) AC_REQUIRE([AC_PROG_CC]) AC_REQUIRE([AC_CANONICAL_HOST]) AC_REQUIRE([AC_LIB_PREPARE_MULTILIB]) AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) dnl By default, look in $includedir and $libdir. use_additional=yes AC_LIB_WITH_FINAL_PREFIX([ eval additional_includedir=\"$includedir\" eval additional_libdir=\"$libdir\" ]) AC_ARG_WITH([lib-prefix], [[ --with-lib-prefix[=DIR] search for libraries in DIR/include and DIR/lib --without-lib-prefix don't search for libraries in includedir and libdir]], [ if test "X$withval" = "Xno"; then use_additional=no else if test "X$withval" = "X"; then AC_LIB_WITH_FINAL_PREFIX([ eval additional_includedir=\"$includedir\" eval additional_libdir=\"$libdir\" ]) else additional_includedir="$withval/include" additional_libdir="$withval/$acl_libdirstem" fi fi ]) if test $use_additional = yes; then dnl Potentially add $additional_includedir to $CPPFLAGS. dnl But don't add it dnl 1. if it's the standard /usr/include, dnl 2. if it's already present in $CPPFLAGS, dnl 3. if it's /usr/local/include and we are using GCC on Linux, dnl 4. if it doesn't exist as a directory. if test "X$additional_includedir" != "X/usr/include"; then haveit= for x in $CPPFLAGS; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) if test "X$x" = "X-I$additional_includedir"; then haveit=yes break fi done if test -z "$haveit"; then if test "X$additional_includedir" = "X/usr/local/include"; then if test -n "$GCC"; then case $host_os in linux* | gnu* | k*bsd*-gnu) haveit=yes;; esac fi fi if test -z "$haveit"; then if test -d "$additional_includedir"; then dnl Really add $additional_includedir to $CPPFLAGS. CPPFLAGS="${CPPFLAGS}${CPPFLAGS:+ }-I$additional_includedir" fi fi fi fi dnl Potentially add $additional_libdir to $LDFLAGS. dnl But don't add it dnl 1. if it's the standard /usr/lib, dnl 2. if it's already present in $LDFLAGS, dnl 3. if it's /usr/local/lib and we are using GCC on Linux, dnl 4. if it doesn't exist as a directory. if test "X$additional_libdir" != "X/usr/$acl_libdirstem"; then haveit= for x in $LDFLAGS; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) if test "X$x" = "X-L$additional_libdir"; then haveit=yes break fi done if test -z "$haveit"; then if test "X$additional_libdir" = "X/usr/local/$acl_libdirstem"; then if test -n "$GCC"; then case $host_os in linux*) haveit=yes;; esac fi fi if test -z "$haveit"; then if test -d "$additional_libdir"; then dnl Really add $additional_libdir to $LDFLAGS. LDFLAGS="${LDFLAGS}${LDFLAGS:+ }-L$additional_libdir" fi fi fi fi fi ]) dnl AC_LIB_PREPARE_PREFIX creates variables acl_final_prefix, dnl acl_final_exec_prefix, containing the values to which $prefix and dnl $exec_prefix will expand at the end of the configure script. AC_DEFUN([AC_LIB_PREPARE_PREFIX], [ dnl Unfortunately, prefix and exec_prefix get only finally determined dnl at the end of configure. if test "X$prefix" = "XNONE"; then acl_final_prefix="$ac_default_prefix" else acl_final_prefix="$prefix" fi if test "X$exec_prefix" = "XNONE"; then acl_final_exec_prefix='${prefix}' else acl_final_exec_prefix="$exec_prefix" fi acl_save_prefix="$prefix" prefix="$acl_final_prefix" eval acl_final_exec_prefix=\"$acl_final_exec_prefix\" prefix="$acl_save_prefix" ]) dnl AC_LIB_WITH_FINAL_PREFIX([statement]) evaluates statement, with the dnl variables prefix and exec_prefix bound to the values they will have dnl at the end of the configure script. AC_DEFUN([AC_LIB_WITH_FINAL_PREFIX], [ acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" $1 exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" ]) dnl AC_LIB_PREPARE_MULTILIB creates dnl - a function acl_is_expected_elfclass, that tests whether standard input dn; has a 32-bit or 64-bit ELF header, depending on the host CPU ABI, dnl - 3 variables acl_libdirstem, acl_libdirstem2, acl_libdirstem3, containing dnl the basename of the libdir to try in turn, either "lib" or "lib64" or dnl "lib/64" or "lib32" or "lib/sparcv9" or "lib/amd64" or similar. AC_DEFUN([AC_LIB_PREPARE_MULTILIB], [ dnl There is no formal standard regarding lib, lib32, and lib64. dnl On most glibc systems, the current practice is that on a system supporting dnl 32-bit and 64-bit instruction sets or ABIs, 64-bit libraries go under dnl $prefix/lib64 and 32-bit libraries go under $prefix/lib. However, on dnl Arch Linux based distributions, it's the opposite: 32-bit libraries go dnl under $prefix/lib32 and 64-bit libraries go under $prefix/lib. dnl We determine the compiler's default mode by looking at the compiler's dnl library search path. If at least one of its elements ends in /lib64 or dnl points to a directory whose absolute pathname ends in /lib64, we use that dnl for 64-bit ABIs. Similarly for 32-bit ABIs. Otherwise we use the default, dnl namely "lib". dnl On Solaris systems, the current practice is that on a system supporting dnl 32-bit and 64-bit instruction sets or ABIs, 64-bit libraries go under dnl $prefix/lib/64 (which is a symlink to either $prefix/lib/sparcv9 or dnl $prefix/lib/amd64) and 32-bit libraries go under $prefix/lib. AC_REQUIRE([AC_CANONICAL_HOST]) AC_REQUIRE([gl_HOST_CPU_C_ABI_32BIT]) AC_CACHE_CHECK([for ELF binary format], [gl_cv_elf], [AC_EGREP_CPP([Extensible Linking Format], [#ifdef __ELF__ Extensible Linking Format #endif ], [gl_cv_elf=yes], [gl_cv_elf=no]) ]) if test $gl_cv_elf; then # Extract the ELF class of a file (5th byte) in decimal. # Cf. https://en.wikipedia.org/wiki/Executable_and_Linkable_Format#File_header if od -A x < /dev/null >/dev/null 2>/dev/null; then # Use POSIX od. func_elfclass () { od -A n -t d1 -j 4 -N 1 } else # Use BSD hexdump. func_elfclass () { dd bs=1 count=1 skip=4 2>/dev/null | hexdump -e '1/1 "%3d "' echo } fi changequote(,)dnl case $HOST_CPU_C_ABI_32BIT in yes) # 32-bit ABI. acl_is_expected_elfclass () { test "`func_elfclass | sed -e 's/[ ]//g'`" = 1 } ;; no) # 64-bit ABI. acl_is_expected_elfclass () { test "`func_elfclass | sed -e 's/[ ]//g'`" = 2 } ;; *) # Unknown. acl_is_expected_elfclass () { : } ;; esac changequote([,])dnl else acl_is_expected_elfclass () { : } fi dnl Allow the user to override the result by setting acl_cv_libdirstems. AC_CACHE_CHECK([for the common suffixes of directories in the library search path], [acl_cv_libdirstems], [dnl Try 'lib' first, because that's the default for libdir in GNU, see dnl . acl_libdirstem=lib acl_libdirstem2= acl_libdirstem3= case "$host_os" in solaris*) dnl See Solaris 10 Software Developer Collection > Solaris 64-bit Developer's Guide > The Development Environment dnl . dnl "Portable Makefiles should refer to any library directories using the 64 symbolic link." dnl But we want to recognize the sparcv9 or amd64 subdirectory also if the dnl symlink is missing, so we set acl_libdirstem2 too. if test $HOST_CPU_C_ABI_32BIT = no; then acl_libdirstem2=lib/64 case "$host_cpu" in sparc*) acl_libdirstem3=lib/sparcv9 ;; i*86 | x86_64) acl_libdirstem3=lib/amd64 ;; esac fi ;; *) dnl If $CC generates code for a 32-bit ABI, the libraries are dnl surely under $prefix/lib or $prefix/lib32, not $prefix/lib64. dnl Similarly, if $CC generates code for a 64-bit ABI, the libraries dnl are surely under $prefix/lib or $prefix/lib64, not $prefix/lib32. dnl Find the compiler's search path. However, non-system compilers dnl sometimes have odd library search paths. But we can't simply invoke dnl '/usr/bin/gcc -print-search-dirs' because that would not take into dnl account the -m32/-m31 or -m64 options from the $CC or $CFLAGS. searchpath=`(LC_ALL=C $CC $CPPFLAGS $CFLAGS -print-search-dirs) 2>/dev/null \ | sed -n -e 's,^libraries: ,,p' | sed -e 's,^=,,'` if test $HOST_CPU_C_ABI_32BIT != no; then # 32-bit or unknown ABI. if test -d /usr/lib32; then acl_libdirstem2=lib32 fi fi if test $HOST_CPU_C_ABI_32BIT != yes; then # 64-bit or unknown ABI. if test -d /usr/lib64; then acl_libdirstem3=lib64 fi fi if test -n "$searchpath"; then acl_save_IFS="${IFS= }"; IFS=":" for searchdir in $searchpath; do if test -d "$searchdir"; then case "$searchdir" in */lib32/ | */lib32 ) acl_libdirstem2=lib32 ;; */lib64/ | */lib64 ) acl_libdirstem3=lib64 ;; */../ | */.. ) # Better ignore directories of this form. They are misleading. ;; *) searchdir=`cd "$searchdir" && pwd` case "$searchdir" in */lib32 ) acl_libdirstem2=lib32 ;; */lib64 ) acl_libdirstem3=lib64 ;; esac ;; esac fi done IFS="$acl_save_IFS" if test $HOST_CPU_C_ABI_32BIT = yes; then # 32-bit ABI. acl_libdirstem3= fi if test $HOST_CPU_C_ABI_32BIT = no; then # 64-bit ABI. acl_libdirstem2= fi fi ;; esac test -n "$acl_libdirstem2" || acl_libdirstem2="$acl_libdirstem" test -n "$acl_libdirstem3" || acl_libdirstem3="$acl_libdirstem" acl_cv_libdirstems="$acl_libdirstem,$acl_libdirstem2,$acl_libdirstem3" ]) dnl Decompose acl_cv_libdirstems into acl_libdirstem, acl_libdirstem2, and dnl acl_libdirstem3. changequote(,)dnl acl_libdirstem=`echo "$acl_cv_libdirstems" | sed -e 's/,.*//'` acl_libdirstem2=`echo "$acl_cv_libdirstems" | sed -e 's/^[^,]*,//' -e 's/,.*//'` acl_libdirstem3=`echo "$acl_cv_libdirstems" | sed -e 's/^[^,]*,[^,]*,//' -e 's/,.*//'` changequote([,])dnl ]) libcaes-20240413/m4/progtest.m40000644000175000017500000000602214533041421016641 0ustar00lordyestalordyesta# progtest.m4 serial 8 (gettext-0.20.2) dnl Copyright (C) 1996-2003, 2005, 2008-2020 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl dnl This file can be used in projects which are not available under dnl the GNU General Public License or the GNU Lesser General Public dnl License but which still want to provide support for the GNU gettext dnl functionality. dnl Please note that the actual code of the GNU gettext library is covered dnl by the GNU Lesser General Public License, and the rest of the GNU dnl gettext package is covered by the GNU General Public License. dnl They are *not* in the public domain. dnl Authors: dnl Ulrich Drepper , 1996. AC_PREREQ([2.50]) # Search path for a program which passes the given test. dnl AM_PATH_PROG_WITH_TEST(VARIABLE, PROG-TO-CHECK-FOR, dnl TEST-PERFORMED-ON-FOUND_PROGRAM [, VALUE-IF-NOT-FOUND [, PATH]]) AC_DEFUN([AM_PATH_PROG_WITH_TEST], [ # Prepare PATH_SEPARATOR. # The user is always right. if test "${PATH_SEPARATOR+set}" != set; then # Determine PATH_SEPARATOR by trying to find /bin/sh in a PATH which # contains only /bin. Note that ksh looks also at the FPATH variable, # so we have to set that as well for the test. PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \ && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \ || PATH_SEPARATOR=';' } fi # Find out how to test for executable files. Don't use a zero-byte file, # as systems may use methods other than mode bits to determine executability. cat >conf$$.file <<_ASEOF #! /bin/sh exit 0 _ASEOF chmod +x conf$$.file if test -x conf$$.file >/dev/null 2>&1; then ac_executable_p="test -x" else ac_executable_p="test -f" fi rm -f conf$$.file # Extract the first word of "$2", so it can be a program name with args. set dummy $2; ac_word=[$]2 AC_MSG_CHECKING([for $ac_word]) AC_CACHE_VAL([ac_cv_path_$1], [case "[$]$1" in [[\\/]]* | ?:[[\\/]]*) ac_cv_path_$1="[$]$1" # Let the user override the test with a path. ;; *) ac_save_IFS="$IFS"; IFS=$PATH_SEPARATOR for ac_dir in ifelse([$5], , $PATH, [$5]); do IFS="$ac_save_IFS" test -z "$ac_dir" && ac_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if $ac_executable_p "$ac_dir/$ac_word$ac_exec_ext"; then echo "$as_me: trying $ac_dir/$ac_word..." >&AS_MESSAGE_LOG_FD if [$3]; then ac_cv_path_$1="$ac_dir/$ac_word$ac_exec_ext" break 2 fi fi done done IFS="$ac_save_IFS" dnl If no 4th arg is given, leave the cache variable unset, dnl so AC_PATH_PROGS will keep looking. ifelse([$4], , , [ test -z "[$]ac_cv_path_$1" && ac_cv_path_$1="$4" ])dnl ;; esac])dnl $1="$ac_cv_path_$1" if test ifelse([$4], , [-n "[$]$1"], ["[$]$1" != "$4"]); then AC_MSG_RESULT([$][$1]) else AC_MSG_RESULT([no]) fi AC_SUBST([$1])dnl ]) libcaes-20240413/m4/gettext.m40000644000175000017500000003423014533041421016460 0ustar00lordyestalordyesta# gettext.m4 serial 71 (gettext-0.20.2) dnl Copyright (C) 1995-2014, 2016, 2018-2020 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl dnl This file can be used in projects which are not available under dnl the GNU General Public License or the GNU Lesser General Public dnl License but which still want to provide support for the GNU gettext dnl functionality. dnl Please note that the actual code of the GNU gettext library is covered dnl by the GNU Lesser General Public License, and the rest of the GNU dnl gettext package is covered by the GNU General Public License. dnl They are *not* in the public domain. dnl Authors: dnl Ulrich Drepper , 1995-2000. dnl Bruno Haible , 2000-2006, 2008-2010. dnl Macro to add for using GNU gettext. dnl Usage: AM_GNU_GETTEXT([INTLSYMBOL], [NEEDSYMBOL], [INTLDIR]). dnl INTLSYMBOL must be one of 'external', 'use-libtool'. dnl INTLSYMBOL should be 'external' for packages other than GNU gettext, and dnl 'use-libtool' for the packages 'gettext-runtime' and 'gettext-tools'. dnl If INTLSYMBOL is 'use-libtool', then a libtool library dnl $(top_builddir)/intl/libintl.la will be created (shared and/or static, dnl depending on --{enable,disable}-{shared,static} and on the presence of dnl AM-DISABLE-SHARED). dnl If NEEDSYMBOL is specified and is 'need-ngettext', then GNU gettext dnl implementations (in libc or libintl) without the ngettext() function dnl will be ignored. If NEEDSYMBOL is specified and is dnl 'need-formatstring-macros', then GNU gettext implementations that don't dnl support the ISO C 99 formatstring macros will be ignored. dnl INTLDIR is used to find the intl libraries. If empty, dnl the value '$(top_builddir)/intl/' is used. dnl dnl The result of the configuration is one of three cases: dnl 1) GNU gettext, as included in the intl subdirectory, will be compiled dnl and used. dnl Catalog format: GNU --> install in $(datadir) dnl Catalog extension: .mo after installation, .gmo in source tree dnl 2) GNU gettext has been found in the system's C library. dnl Catalog format: GNU --> install in $(datadir) dnl Catalog extension: .mo after installation, .gmo in source tree dnl 3) No internationalization, always use English msgid. dnl Catalog format: none dnl Catalog extension: none dnl If INTLSYMBOL is 'external', only cases 2 and 3 can occur. dnl The use of .gmo is historical (it was needed to avoid overwriting the dnl GNU format catalogs when building on a platform with an X/Open gettext), dnl but we keep it in order not to force irrelevant filename changes on the dnl maintainers. dnl AC_DEFUN([AM_GNU_GETTEXT], [ dnl Argument checking. ifelse([$1], [], , [ifelse([$1], [external], , [ifelse([$1], [use-libtool], , [errprint([ERROR: invalid first argument to AM_GNU_GETTEXT ])])])]) ifelse(ifelse([$1], [], [old])[]ifelse([$1], [no-libtool], [old]), [old], [errprint([ERROR: Use of AM_GNU_GETTEXT without [external] argument is no longer supported. ])]) ifelse([$2], [], , [ifelse([$2], [need-ngettext], , [ifelse([$2], [need-formatstring-macros], , [errprint([ERROR: invalid second argument to AM_GNU_GETTEXT ])])])]) define([gt_included_intl], ifelse([$1], [external], [no], [yes])) gt_NEEDS_INIT AM_GNU_GETTEXT_NEED([$2]) AC_REQUIRE([AM_PO_SUBDIRS])dnl ifelse(gt_included_intl, yes, [ AC_REQUIRE([AM_INTL_SUBDIR])dnl ]) dnl Prerequisites of AC_LIB_LINKFLAGS_BODY. AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) AC_REQUIRE([AC_LIB_RPATH]) dnl Sometimes libintl requires libiconv, so first search for libiconv. dnl Ideally we would do this search only after the dnl if test "$USE_NLS" = "yes"; then dnl if { eval "gt_val=\$$gt_func_gnugettext_libc"; test "$gt_val" != "yes"; }; then dnl tests. But if configure.in invokes AM_ICONV after AM_GNU_GETTEXT dnl the configure script would need to contain the same shell code dnl again, outside any 'if'. There are two solutions: dnl - Invoke AM_ICONV_LINKFLAGS_BODY here, outside any 'if'. dnl - Control the expansions in more detail using AC_PROVIDE_IFELSE. dnl Since AC_PROVIDE_IFELSE is not documented, we avoid it. ifelse(gt_included_intl, yes, , [ AC_REQUIRE([AM_ICONV_LINKFLAGS_BODY]) ]) dnl Sometimes, on Mac OS X, libintl requires linking with CoreFoundation. gt_INTL_MACOSX dnl Set USE_NLS. AC_REQUIRE([AM_NLS]) ifelse(gt_included_intl, yes, [ BUILD_INCLUDED_LIBINTL=no USE_INCLUDED_LIBINTL=no ]) LIBINTL= LTLIBINTL= POSUB= dnl Add a version number to the cache macros. case " $gt_needs " in *" need-formatstring-macros "*) gt_api_version=3 ;; *" need-ngettext "*) gt_api_version=2 ;; *) gt_api_version=1 ;; esac gt_func_gnugettext_libc="gt_cv_func_gnugettext${gt_api_version}_libc" gt_func_gnugettext_libintl="gt_cv_func_gnugettext${gt_api_version}_libintl" dnl If we use NLS figure out what method if test "$USE_NLS" = "yes"; then gt_use_preinstalled_gnugettext=no ifelse(gt_included_intl, yes, [ AC_MSG_CHECKING([whether included gettext is requested]) AC_ARG_WITH([included-gettext], [ --with-included-gettext use the GNU gettext library included here], nls_cv_force_use_gnu_gettext=$withval, nls_cv_force_use_gnu_gettext=no) AC_MSG_RESULT([$nls_cv_force_use_gnu_gettext]) nls_cv_use_gnu_gettext="$nls_cv_force_use_gnu_gettext" if test "$nls_cv_force_use_gnu_gettext" != "yes"; then ]) dnl User does not insist on using GNU NLS library. Figure out what dnl to use. If GNU gettext is available we use this. Else we have dnl to fall back to GNU NLS library. if test $gt_api_version -ge 3; then gt_revision_test_code=' #ifndef __GNU_GETTEXT_SUPPORTED_REVISION #define __GNU_GETTEXT_SUPPORTED_REVISION(major) ((major) == 0 ? 0 : -1) #endif changequote(,)dnl typedef int array [2 * (__GNU_GETTEXT_SUPPORTED_REVISION(0) >= 1) - 1]; changequote([,])dnl ' else gt_revision_test_code= fi if test $gt_api_version -ge 2; then gt_expression_test_code=' + * ngettext ("", "", 0)' else gt_expression_test_code= fi AC_CACHE_CHECK([for GNU gettext in libc], [$gt_func_gnugettext_libc], [AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[ #include #ifndef __GNU_GETTEXT_SUPPORTED_REVISION extern int _nl_msg_cat_cntr; extern int *_nl_domain_bindings; #define __GNU_GETTEXT_SYMBOL_EXPRESSION (_nl_msg_cat_cntr + *_nl_domain_bindings) #else #define __GNU_GETTEXT_SYMBOL_EXPRESSION 0 #endif $gt_revision_test_code ]], [[ bindtextdomain ("", ""); return * gettext ("")$gt_expression_test_code + __GNU_GETTEXT_SYMBOL_EXPRESSION ]])], [eval "$gt_func_gnugettext_libc=yes"], [eval "$gt_func_gnugettext_libc=no"])]) if { eval "gt_val=\$$gt_func_gnugettext_libc"; test "$gt_val" != "yes"; }; then dnl Sometimes libintl requires libiconv, so first search for libiconv. ifelse(gt_included_intl, yes, , [ AM_ICONV_LINK ]) dnl Search for libintl and define LIBINTL, LTLIBINTL and INCINTL dnl accordingly. Don't use AC_LIB_LINKFLAGS_BODY([intl],[iconv]) dnl because that would add "-liconv" to LIBINTL and LTLIBINTL dnl even if libiconv doesn't exist. AC_LIB_LINKFLAGS_BODY([intl]) AC_CACHE_CHECK([for GNU gettext in libintl], [$gt_func_gnugettext_libintl], [gt_save_CPPFLAGS="$CPPFLAGS" CPPFLAGS="$CPPFLAGS $INCINTL" gt_save_LIBS="$LIBS" LIBS="$LIBS $LIBINTL" dnl Now see whether libintl exists and does not depend on libiconv. AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[ #include #ifndef __GNU_GETTEXT_SUPPORTED_REVISION extern int _nl_msg_cat_cntr; extern #ifdef __cplusplus "C" #endif const char *_nl_expand_alias (const char *); #define __GNU_GETTEXT_SYMBOL_EXPRESSION (_nl_msg_cat_cntr + *_nl_expand_alias ("")) #else #define __GNU_GETTEXT_SYMBOL_EXPRESSION 0 #endif $gt_revision_test_code ]], [[ bindtextdomain ("", ""); return * gettext ("")$gt_expression_test_code + __GNU_GETTEXT_SYMBOL_EXPRESSION ]])], [eval "$gt_func_gnugettext_libintl=yes"], [eval "$gt_func_gnugettext_libintl=no"]) dnl Now see whether libintl exists and depends on libiconv. if { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" != yes; } && test -n "$LIBICONV"; then LIBS="$LIBS $LIBICONV" AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[ #include #ifndef __GNU_GETTEXT_SUPPORTED_REVISION extern int _nl_msg_cat_cntr; extern #ifdef __cplusplus "C" #endif const char *_nl_expand_alias (const char *); #define __GNU_GETTEXT_SYMBOL_EXPRESSION (_nl_msg_cat_cntr + *_nl_expand_alias ("")) #else #define __GNU_GETTEXT_SYMBOL_EXPRESSION 0 #endif $gt_revision_test_code ]], [[ bindtextdomain ("", ""); return * gettext ("")$gt_expression_test_code + __GNU_GETTEXT_SYMBOL_EXPRESSION ]])], [LIBINTL="$LIBINTL $LIBICONV" LTLIBINTL="$LTLIBINTL $LTLIBICONV" eval "$gt_func_gnugettext_libintl=yes" ]) fi CPPFLAGS="$gt_save_CPPFLAGS" LIBS="$gt_save_LIBS"]) fi dnl If an already present or preinstalled GNU gettext() is found, dnl use it. But if this macro is used in GNU gettext, and GNU dnl gettext is already preinstalled in libintl, we update this dnl libintl. (Cf. the install rule in intl/Makefile.in.) if { eval "gt_val=\$$gt_func_gnugettext_libc"; test "$gt_val" = "yes"; } \ || { { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" = "yes"; } \ && test "$PACKAGE" != gettext-runtime \ && test "$PACKAGE" != gettext-tools; }; then gt_use_preinstalled_gnugettext=yes else dnl Reset the values set by searching for libintl. LIBINTL= LTLIBINTL= INCINTL= fi ifelse(gt_included_intl, yes, [ if test "$gt_use_preinstalled_gnugettext" != "yes"; then dnl GNU gettext is not found in the C library. dnl Fall back on included GNU gettext library. nls_cv_use_gnu_gettext=yes fi fi if test "$nls_cv_use_gnu_gettext" = "yes"; then dnl Mark actions used to generate GNU NLS library. BUILD_INCLUDED_LIBINTL=yes USE_INCLUDED_LIBINTL=yes LIBINTL="ifelse([$3],[],\${top_builddir}/intl,[$3])/libintl.la $LIBICONV $LIBTHREAD" LTLIBINTL="ifelse([$3],[],\${top_builddir}/intl,[$3])/libintl.la $LTLIBICONV $LTLIBTHREAD" LIBS=`echo " $LIBS " | sed -e 's/ -lintl / /' -e 's/^ //' -e 's/ $//'` fi CATOBJEXT= if test "$gt_use_preinstalled_gnugettext" = "yes" \ || test "$nls_cv_use_gnu_gettext" = "yes"; then dnl Mark actions to use GNU gettext tools. CATOBJEXT=.gmo fi ]) if test -n "$INTL_MACOSX_LIBS"; then if test "$gt_use_preinstalled_gnugettext" = "yes" \ || test "$nls_cv_use_gnu_gettext" = "yes"; then dnl Some extra flags are needed during linking. LIBINTL="$LIBINTL $INTL_MACOSX_LIBS" LTLIBINTL="$LTLIBINTL $INTL_MACOSX_LIBS" fi fi if test "$gt_use_preinstalled_gnugettext" = "yes" \ || test "$nls_cv_use_gnu_gettext" = "yes"; then AC_DEFINE([ENABLE_NLS], [1], [Define to 1 if translation of program messages to the user's native language is requested.]) else USE_NLS=no fi fi AC_MSG_CHECKING([whether to use NLS]) AC_MSG_RESULT([$USE_NLS]) if test "$USE_NLS" = "yes"; then AC_MSG_CHECKING([where the gettext function comes from]) if test "$gt_use_preinstalled_gnugettext" = "yes"; then if { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" = "yes"; }; then gt_source="external libintl" else gt_source="libc" fi else gt_source="included intl directory" fi AC_MSG_RESULT([$gt_source]) fi if test "$USE_NLS" = "yes"; then if test "$gt_use_preinstalled_gnugettext" = "yes"; then if { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" = "yes"; }; then AC_MSG_CHECKING([how to link with libintl]) AC_MSG_RESULT([$LIBINTL]) AC_LIB_APPENDTOVAR([CPPFLAGS], [$INCINTL]) fi dnl For backward compatibility. Some packages may be using this. AC_DEFINE([HAVE_GETTEXT], [1], [Define if the GNU gettext() function is already present or preinstalled.]) AC_DEFINE([HAVE_DCGETTEXT], [1], [Define if the GNU dcgettext() function is already present or preinstalled.]) fi dnl We need to process the po/ directory. POSUB=po fi ifelse(gt_included_intl, yes, [ dnl In GNU gettext we have to set BUILD_INCLUDED_LIBINTL to 'yes' dnl because some of the testsuite requires it. BUILD_INCLUDED_LIBINTL=yes dnl Make all variables we use known to autoconf. AC_SUBST([BUILD_INCLUDED_LIBINTL]) AC_SUBST([USE_INCLUDED_LIBINTL]) AC_SUBST([CATOBJEXT]) ]) dnl For backward compatibility. Some Makefiles may be using this. INTLLIBS="$LIBINTL" AC_SUBST([INTLLIBS]) dnl Make all documented variables known to autoconf. AC_SUBST([LIBINTL]) AC_SUBST([LTLIBINTL]) AC_SUBST([POSUB]) ]) dnl gt_NEEDS_INIT ensures that the gt_needs variable is initialized. m4_define([gt_NEEDS_INIT], [ m4_divert_text([DEFAULTS], [gt_needs=]) m4_define([gt_NEEDS_INIT], []) ]) dnl Usage: AM_GNU_GETTEXT_NEED([NEEDSYMBOL]) AC_DEFUN([AM_GNU_GETTEXT_NEED], [ m4_divert_text([INIT_PREPARE], [gt_needs="$gt_needs $1"]) ]) dnl Usage: AM_GNU_GETTEXT_VERSION([gettext-version]) AC_DEFUN([AM_GNU_GETTEXT_VERSION], []) dnl Usage: AM_GNU_GETTEXT_REQUIRE_VERSION([gettext-version]) AC_DEFUN([AM_GNU_GETTEXT_REQUIRE_VERSION], []) libcaes-20240413/m4/lib-ld.m40000644000175000017500000001237214533041421016142 0ustar00lordyestalordyesta# lib-ld.m4 serial 9 dnl Copyright (C) 1996-2003, 2009-2020 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl Subroutines of libtool.m4, dnl with replacements s/_*LT_PATH/AC_LIB_PROG/ and s/lt_/acl_/ to avoid dnl collision with libtool.m4. dnl From libtool-2.4. Sets the variable with_gnu_ld to yes or no. AC_DEFUN([AC_LIB_PROG_LD_GNU], [AC_CACHE_CHECK([if the linker ($LD) is GNU ld], [acl_cv_prog_gnu_ld], [# I'd rather use --version here, but apparently some GNU lds only accept -v. case `$LD -v 2>&1 /dev/null 2>&1 \ && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \ || PATH_SEPARATOR=';' } fi if test -n "$LD"; then AC_MSG_CHECKING([for ld]) elif test "$GCC" = yes; then AC_MSG_CHECKING([for ld used by $CC]) elif test "$with_gnu_ld" = yes; then AC_MSG_CHECKING([for GNU ld]) else AC_MSG_CHECKING([for non-GNU ld]) fi if test -n "$LD"; then # Let the user override the test with a path. : else AC_CACHE_VAL([acl_cv_path_LD], [ acl_cv_path_LD= # Final result of this test ac_prog=ld # Program to search in $PATH if test "$GCC" = yes; then # Check if gcc -print-prog-name=ld gives a path. case $host in *-*-mingw*) # gcc leaves a trailing carriage return which upsets mingw acl_output=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; *) acl_output=`($CC -print-prog-name=ld) 2>&5` ;; esac case $acl_output in # Accept absolute paths. [[\\/]]* | ?:[[\\/]]*) re_direlt='/[[^/]][[^/]]*/\.\./' # Canonicalize the pathname of ld acl_output=`echo "$acl_output" | sed 's%\\\\%/%g'` while echo "$acl_output" | grep "$re_direlt" > /dev/null 2>&1; do acl_output=`echo $acl_output | sed "s%$re_direlt%/%"` done # Got the pathname. No search in PATH is needed. acl_cv_path_LD="$acl_output" ac_prog= ;; "") # If it fails, then pretend we aren't using GCC. ;; *) # If it is relative, then search for the first ld in PATH. with_gnu_ld=unknown ;; esac fi if test -n "$ac_prog"; then # Search for $ac_prog in $PATH. acl_save_ifs="$IFS"; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS="$acl_save_ifs" test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then acl_cv_path_LD="$ac_dir/$ac_prog" # Check to see if the program is GNU ld. I'd rather use --version, # but apparently some variants of GNU ld only accept -v. # Break only if it was the GNU/non-GNU ld that we prefer. case `"$acl_cv_path_LD" -v 2>&1 @])], [ac_cv_enable_$2=$enableval], [ac_cv_enable_$2=$4])dnl AC_CACHE_CHECK( [whether to enable $3], [ac_cv_enable_$2], [ac_cv_enable_$2=$4])dnl ]) dnl Function to test if the location of a certain feature was provided AC_DEFUN([AX_COMMON_ARG_WITH], [ AC_ARG_WITH( [$1], [AS_HELP_STRING( [--with-$1[[=$5]]], [$3 @<:@default=$4@:>@])], [ac_cv_with_$2=$withval], [ac_cv_with_$2=$4])dnl AC_CACHE_CHECK( [whether to use $3], [ac_cv_with_$2], [ac_cv_with_$2=$4])dnl ]) dnl Function to detect whether shared libary support should be disabled AC_DEFUN([AX_COMMON_CHECK_DISABLE_SHARED_LIBS], [ AX_COMMON_ARG_DISABLE( [shared-libs], [shared_libs], [disable shared library support]) ]) dnl Function to detect whether debug output should be enabled AC_DEFUN([AX_COMMON_CHECK_ENABLE_DEBUG_OUTPUT], [ AX_COMMON_ARG_ENABLE( [debug-output], [debug_output], [enable debug output], [no]) AS_IF( [test "x$ac_cv_enable_debug_output" != xno ], [AC_DEFINE( [HAVE_DEBUG_OUTPUT], [1], [Define to 1 if debug output should be used.]) ac_cv_enable_debug_output=yes]) ]) dnl Function to detect whether static executables support should be enabled AC_DEFUN([AX_COMMON_CHECK_ENABLE_STATIC_EXECUTABLES], [ AX_COMMON_ARG_ENABLE( [static-executables], [static_executables], [build static executables (binaries)], [no]) AS_IF( [test "x$ac_cv_enable_static_executables" != xno], [STATIC_LDFLAGS="-all-static"; AC_SUBST( [STATIC_LDFLAGS]) ac_cv_enable_static_executables=yes enable_shared=no]) ]) dnl Function to detect whether verbose output should be enabled AC_DEFUN([AX_COMMON_CHECK_ENABLE_VERBOSE_OUTPUT], [ AX_COMMON_ARG_ENABLE( [verbose-output], [verbose_output], [enable verbose output], [no]) AS_IF( [test "x$ac_cv_enable_verbose_output" != xno ], [AC_DEFINE( [HAVE_VERBOSE_OUTPUT], [1], [Define to 1 if verbose output should be used.]) ac_cv_enable_verbose_output=yes]) ]) dnl Function to detect whether static executables support should be enabled AC_DEFUN([AX_COMMON_CHECK_ENABLE_WIDE_CHARACTER_TYPE], [ AX_COMMON_ARG_ENABLE( [wide-character-type], [wide_character_type], [enable wide character type support], [no]) ]) dnl Function to detect whether WINAPI support should be enabled AC_DEFUN([AX_COMMON_CHECK_ENABLE_WINAPI], [ AX_COMMON_ARG_ENABLE( [winapi], [winapi], [enable WINAPI support for cross-compilation], [auto-detect]) AS_IF( [test "x$ac_cv_enable_winapi" = xauto-detect], [ac_common_check_winapi_target_string="$target" AS_IF( [test "x$ac_common_check_winapi_target_string" = x], [ac_common_check_winapi_target_string="$host"]) AS_CASE( [$ac_common_check_winapi_target_string], [*mingw*],[AC_MSG_NOTICE( [detected MinGW enabling WINAPI support for cross-compilation]) ac_cv_enable_winapi=yes], [*msys*],[AC_MSG_NOTICE( [detected MSYS enabling WINAPI support for cross-compilation]) ac_cv_enable_winapi=yes], [*],[ac_cv_enable_winapi=no]) ]) ]) dnl Function to detect whether printf conversion specifier "%jd" is available AC_DEFUN([AX_COMMON_CHECK_FUNC_PRINTF_JD], [ AC_MSG_CHECKING( [whether printf supports the conversion specifier "%jd"]) SAVE_CFLAGS="$CFLAGS" CFLAGS="$CFLAGS -Wall -Werror" AC_LANG_PUSH(C) dnl First try to see if compilation and linkage without a parameter succeeds AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[#include ]], [[printf( "%jd" ); ]] )], [ac_cv_cv_have_printf_jd=no], [ac_cv_cv_have_printf_jd=yes]) dnl Second try to see if compilation and linkage with a parameter succeeds AS_IF( [test "x$ac_cv_cv_have_printf_jd" = xyes], [AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[#include #include ]], [[printf( "%jd", (off_t) 10 ); ]] )], [ac_cv_cv_have_printf_jd=yes], [ac_cv_cv_have_printf_jd=no]) ]) dnl Third try to see if the program runs correctly AS_IF( [test "x$ac_cv_cv_have_printf_jd" = xyes], [AC_RUN_IFELSE( [AC_LANG_PROGRAM( [[#include #include ]], [[char string[ 3 ]; if( snprintf( string, 3, "%jd", (off_t) 10 ) < 0 ) return( 1 ); if( ( string[ 0 ] != '1' ) || ( string[ 1 ] != '0' ) ) return( 1 ); ]] )], [ac_cv_cv_have_printf_jd=yes], [ac_cv_cv_have_printf_jd=no], [ac_cv_cv_have_printf_jd=undetermined]) ]) AC_LANG_POP(C) CFLAGS="$SAVE_CFLAGS" AS_IF( [test "x$ac_cv_cv_have_printf_jd" = xyes], [AC_MSG_RESULT( [yes]) AC_DEFINE( [HAVE_PRINTF_JD], [1], [Define to 1 whether printf supports the conversion specifier "%jd".]) ], [AC_MSG_RESULT( [$ac_cv_cv_have_printf_jd]) ]) ]) dnl Function to detect whether printf conversion specifier "%zd" is available AC_DEFUN([AX_COMMON_CHECK_FUNC_PRINTF_ZD], [ AC_MSG_CHECKING( [whether printf supports the conversion specifier "%zd"]) SAVE_CFLAGS="$CFLAGS" CFLAGS="$CFLAGS -Wall -Werror" AC_LANG_PUSH(C) dnl First try to see if compilation and linkage without a parameter succeeds AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[#include ]], [[printf( "%zd" ); ]] )], [ac_cv_cv_have_printf_zd=no], [ac_cv_cv_have_printf_zd=yes]) dnl Second try to see if compilation and linkage with a parameter succeeds AS_IF( [test "x$ac_cv_cv_have_printf_zd" = xyes], [AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[#include #include ]], [[printf( "%zd", (size_t) 10 ); ]] )], [ac_cv_cv_have_printf_zd=yes], [ac_cv_cv_have_printf_zd=no]) ]) dnl Third try to see if the program runs correctly AS_IF( [test "x$ac_cv_cv_have_printf_zd" = xyes], [AC_RUN_IFELSE( [AC_LANG_PROGRAM( [[#include #include ]], [[char string[ 3 ]; if( snprintf( string, 3, "%zd", (size_t) 10 ) < 0 ) return( 1 ); if( ( string[ 0 ] != '1' ) || ( string[ 1 ] != '0' ) ) return( 1 ); ]] )], [ac_cv_cv_have_printf_zd=yes], [ac_cv_cv_have_printf_zd=no], [ac_cv_cv_have_printf_zd=undetermined]) ]) AC_LANG_POP(C) CFLAGS="$SAVE_CFLAGS" AS_IF( [test "x$ac_cv_cv_have_printf_zd" = xyes], [AC_MSG_RESULT( [yes]) AC_DEFINE( [HAVE_PRINTF_ZD], [1], [Define to 1 whether printf supports the conversion specifier "%zd".]) ], [AC_MSG_RESULT( [$ac_cv_cv_have_printf_zd]) ]) ]) dnl Function to detect if common dependencies are available AC_DEFUN([AX_COMMON_CHECK_LOCAL], [ dnl Headers included in common/common.h AS_IF( [test "x$ac_cv_enable_winapi" = xyes], [AC_CHECK_HEADERS([windows.h]) AS_IF( [test "x$ac_cv_header_windows_h" = xno], [AC_MSG_FAILURE( [Missing header: windows.h header is required to compile with winapi support], [1]) ]) ]) AS_IF( [test "x$ac_cv_enable_winapi" = xno], [AC_CHECK_HEADERS([libintl.h]) ]) dnl Headers included in common/types.h AC_CHECK_HEADERS([limits.h]) dnl Headers included in common/memory.h and common/narrow_string.h AC_CHECK_HEADERS([stdlib.h string.h]) dnl Headers included in common/wide_string.h AC_CHECK_HEADERS([wchar.h wctype.h]) dnl File stream functions used in common/file_stream.h AC_CHECK_FUNCS([fclose feof fgets fopen fread fseeko fseeko64 fwrite vfprintf]) AS_IF( [test "x$ac_cv_func_fclose" != xyes], [AC_MSG_FAILURE( [Missing function: fclose], [1]) ]) AS_IF( [test "x$ac_cv_func_feof" != xyes], [AC_MSG_FAILURE( [Missing function: feof], [1]) ]) AS_IF( [test "x$ac_cv_func_fgets" != xyes], [AC_MSG_FAILURE( [Missing function: fgets], [1]) ]) AS_IF( [test "x$ac_cv_func_fopen" != xyes], [AC_MSG_FAILURE( [Missing function: fopen], [1]) ]) AS_IF( [test "x$ac_cv_func_fread" != xyes], [AC_MSG_FAILURE( [Missing function: fread], [1]) ]) AS_IF( [test "x$ac_cv_func_fseeko" != xyes && test "x$ac_cv_func_fseeko64" != xyes], [AC_MSG_FAILURE( [Missing function: fseeko and fseeko64], [1]) ]) AS_IF( [test "x$ac_cv_func_fwrite" != xyes], [AC_MSG_FAILURE( [Missing function: fwrite], [1]) ]) AS_IF( [test "x$ac_cv_func_vfprintf" != xyes], [AC_MSG_FAILURE( [Missing function: vfprintf], [1]) ]) AS_IF( [test "x$ac_cv_enable_wide_character_type" != xno], [AC_CHECK_FUNCS([fgetws]) AS_IF( [test "x$ac_cv_func_fgetws" != xyes], [AC_MSG_FAILURE( [Missing function: fgetws], [1]) ]) ]) dnl Memory functions used in common/memory.h AC_CHECK_FUNCS([free malloc memcmp memcpy memset realloc]) AS_IF( [test "x$ac_cv_func_free" != xyes], [AC_MSG_FAILURE( [Missing function: free], [1]) ]) AS_IF( [test "x$ac_cv_func_malloc" != xyes], [AC_MSG_FAILURE( [Missing function: malloc], [1]) ]) AS_IF( [test "x$ac_cv_func_memcmp" != xyes], [AC_MSG_FAILURE( [Missing function: memcmp], [1]) ]) AS_IF( [test "x$ac_cv_func_memcpy" != xyes], [AC_MSG_FAILURE( [Missing function: memcpy], [1]) ]) AS_IF( [test "x$ac_cv_func_memset" != xyes], [AC_MSG_FAILURE( [Missing function: memset], [1]) ]) AS_IF( [test "x$ac_cv_func_realloc" != xyes], [AC_MSG_FAILURE( [Missing function: realloc], [1]) ]) dnl Narrow character string functions used in common/narrow_string.h AC_CHECK_FUNCS([memchr memrchr snprintf sscanf strcasecmp strchr strlen strncasecmp strncmp strncpy strnicmp strrchr strstr vsnprintf]) AS_IF( [test "x$ac_cv_func_memchr" != xyes && test "x$ac_cv_func_strchr" != xyes], [AC_MSG_FAILURE( [Missing functions: memchr and strchr], [1]) ]) AS_IF( [test "x$ac_cv_func_memcmp" != xyes && test "x$ac_cv_func_strncmp" != xyes], [AC_MSG_FAILURE( [Missing functions: memcmp and strncmp], [1]) ]) AS_IF( [test "x$ac_cv_func_memcpy" != xyes && test "x$ac_cv_func_strncpy" != xyes], [AC_MSG_FAILURE( [Missing functions: memcpy and strncpy], [1]) ]) AS_IF( [test "x$ac_cv_func_memrchr" = xyes], [AC_CHECK_DECLS([memrchr]) AS_IF( [test "x$ac_cv_decl_memrchr" != xyes], [ac_cv_func_memrchr=no]) ]) AS_IF( [test "x$ac_cv_func_memrchr" != xyes && test "x$ac_cv_func_strrchr" != xyes], [AC_MSG_FAILURE( [Missing functions: strrchr and memrchr], [1]) ]) AS_IF( [test "x$ac_cv_func_snprintf" != xyes], [AC_MSG_FAILURE( [Missing function: snprintf], [1]) ]) AS_IF( [test "x$ac_cv_func_sscanf" != xyes], [AC_MSG_FAILURE( [Missing function: sscanf], [1]) ]) AS_IF( [test "x$ac_cv_func_strlen" != xyes], [AC_MSG_FAILURE( [Missing function: strlen], [1]) ]) AS_IF( [test "x$ac_cv_func_strcasecmp" != xyes && test "x$ac_cv_func_strncasecmp" != xyes && test "x$ac_cv_func_strnicmp" != xyes], [AC_MSG_FAILURE( [Missing functions: strncasecmp, strcasecmp and strnicmp], [1]) ]) AS_IF( [test "x$ac_cv_func_strstr" != xyes], [AC_MSG_FAILURE( [Missing function: strstr], [1]) ]) AS_IF( [test "x$ac_cv_func_vsnprintf" != xyes], [AC_MSG_FAILURE( [Missing function: vsnprintf], [1]) ]) dnl Wide character string functions used in common/wide_string.h AS_IF( [test "x$ac_cv_enable_wide_character_type" != xno], [AC_CHECK_FUNCS([swprintf towlower wcscasecmp wcschr wcslen wcsncasecmp wcsncmp wcsncpy wcsnicmp wcsrchr wcsstr wmemchr wmemcmp wmemcpy wmemrchr]) AS_IF( [test "x$ac_cv_func_swprintf" != xyes], [AC_MSG_FAILURE( [Missing function: swprintf], [1]) ]) AS_IF( [test "x$ac_cv_func_wmemchr" != xyes && test "x$ac_cv_func_wcschr" != xyes], [AC_MSG_FAILURE( [Missing functions: wmemchr and wcschr], [1]) ]) AS_IF( [test "x$ac_cv_func_wmemcmp" != xyes && test "x$ac_cv_func_wcsncmp" != xyes], [AC_MSG_FAILURE( [Missing functions: wmemcmp and wcsncmp], [1]) ]) AS_IF( [test "x$ac_cv_func_wmemcpy" != xyes && test "x$ac_cv_func_wcsncpy" != xyes], [AC_MSG_FAILURE( [Missing functions: wmemcpy and wcsncpy], [1]) ]) AS_IF( [test "x$ac_cv_func_wmemrchr" != xyes && test "x$ac_cv_func_wcsrchr" != xyes], [AC_MSG_FAILURE( [Missing functions: wmemrchr and wcsrchr], [1]) ]) AS_IF( [test "x$ac_cv_func_wcslen" != xyes], [AC_MSG_FAILURE( [Missing function: wcslen], [1]) ]) AS_IF( [test "x$ac_cv_func_wcsncasecmp" != xyes && test "x$ac_cv_func_wcscasecmp" != xyes && test "x$ac_cv_func_wcsnicmp" != xyes && test "x$ac_cv_func_towlower" != xyes], [AC_MSG_FAILURE( [Missing functions: wcsncasecmp, wcscasecmp, wcsnicmp and towlower], [1]) ]) AS_IF( [test "x$ac_cv_func_wcsstr" != xyes], [AC_MSG_FAILURE( [Missing function: wcsstr], [1]) ]) ]) dnl Check for printf conversion specifier support AX_COMMON_CHECK_FUNC_PRINTF_JD AX_COMMON_CHECK_FUNC_PRINTF_ZD ]) libcaes-20240413/m4/ltversion.m40000644000175000017500000000131214606477623017036 0ustar00lordyestalordyesta# ltversion.m4 -- version numbers -*- Autoconf -*- # # Copyright (C) 2004, 2011-2019, 2021-2022 Free Software Foundation, # Inc. # Written by Scott James Remnant, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # @configure_input@ # serial 4245 ltversion.m4 # This file is part of GNU Libtool m4_define([LT_PACKAGE_VERSION], [2.4.7]) m4_define([LT_PACKAGE_REVISION], [2.4.7]) AC_DEFUN([LTVERSION_VERSION], [macro_version='2.4.7' macro_revision='2.4.7' _LT_DECL(, macro_version, 0, [Which release of libtool.m4 was used?]) _LT_DECL(, macro_revision, 0) ]) libcaes-20240413/m4/ltsugar.m40000644000175000017500000001045314606477623016500 0ustar00lordyestalordyesta# ltsugar.m4 -- libtool m4 base layer. -*-Autoconf-*- # # Copyright (C) 2004-2005, 2007-2008, 2011-2019, 2021-2022 Free Software # Foundation, Inc. # Written by Gary V. Vaughan, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 6 ltsugar.m4 # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTSUGAR_VERSION], [m4_if([0.1])]) # lt_join(SEP, ARG1, [ARG2...]) # ----------------------------- # Produce ARG1SEPARG2...SEPARGn, omitting [] arguments and their # associated separator. # Needed until we can rely on m4_join from Autoconf 2.62, since all earlier # versions in m4sugar had bugs. m4_define([lt_join], [m4_if([$#], [1], [], [$#], [2], [[$2]], [m4_if([$2], [], [], [[$2]_])$0([$1], m4_shift(m4_shift($@)))])]) m4_define([_lt_join], [m4_if([$#$2], [2], [], [m4_if([$2], [], [], [[$1$2]])$0([$1], m4_shift(m4_shift($@)))])]) # lt_car(LIST) # lt_cdr(LIST) # ------------ # Manipulate m4 lists. # These macros are necessary as long as will still need to support # Autoconf-2.59, which quotes differently. m4_define([lt_car], [[$1]]) m4_define([lt_cdr], [m4_if([$#], 0, [m4_fatal([$0: cannot be called without arguments])], [$#], 1, [], [m4_dquote(m4_shift($@))])]) m4_define([lt_unquote], $1) # lt_append(MACRO-NAME, STRING, [SEPARATOR]) # ------------------------------------------ # Redefine MACRO-NAME to hold its former content plus 'SEPARATOR''STRING'. # Note that neither SEPARATOR nor STRING are expanded; they are appended # to MACRO-NAME as is (leaving the expansion for when MACRO-NAME is invoked). # No SEPARATOR is output if MACRO-NAME was previously undefined (different # than defined and empty). # # This macro is needed until we can rely on Autoconf 2.62, since earlier # versions of m4sugar mistakenly expanded SEPARATOR but not STRING. m4_define([lt_append], [m4_define([$1], m4_ifdef([$1], [m4_defn([$1])[$3]])[$2])]) # lt_combine(SEP, PREFIX-LIST, INFIX, SUFFIX1, [SUFFIX2...]) # ---------------------------------------------------------- # Produce a SEP delimited list of all paired combinations of elements of # PREFIX-LIST with SUFFIX1 through SUFFIXn. Each element of the list # has the form PREFIXmINFIXSUFFIXn. # Needed until we can rely on m4_combine added in Autoconf 2.62. m4_define([lt_combine], [m4_if(m4_eval([$# > 3]), [1], [m4_pushdef([_Lt_sep], [m4_define([_Lt_sep], m4_defn([lt_car]))])]]dnl [[m4_foreach([_Lt_prefix], [$2], [m4_foreach([_Lt_suffix], ]m4_dquote(m4_dquote(m4_shift(m4_shift(m4_shift($@)))))[, [_Lt_sep([$1])[]m4_defn([_Lt_prefix])[$3]m4_defn([_Lt_suffix])])])])]) # lt_if_append_uniq(MACRO-NAME, VARNAME, [SEPARATOR], [UNIQ], [NOT-UNIQ]) # ----------------------------------------------------------------------- # Iff MACRO-NAME does not yet contain VARNAME, then append it (delimited # by SEPARATOR if supplied) and expand UNIQ, else NOT-UNIQ. m4_define([lt_if_append_uniq], [m4_ifdef([$1], [m4_if(m4_index([$3]m4_defn([$1])[$3], [$3$2$3]), [-1], [lt_append([$1], [$2], [$3])$4], [$5])], [lt_append([$1], [$2], [$3])$4])]) # lt_dict_add(DICT, KEY, VALUE) # ----------------------------- m4_define([lt_dict_add], [m4_define([$1($2)], [$3])]) # lt_dict_add_subkey(DICT, KEY, SUBKEY, VALUE) # -------------------------------------------- m4_define([lt_dict_add_subkey], [m4_define([$1($2:$3)], [$4])]) # lt_dict_fetch(DICT, KEY, [SUBKEY]) # ---------------------------------- m4_define([lt_dict_fetch], [m4_ifval([$3], m4_ifdef([$1($2:$3)], [m4_defn([$1($2:$3)])]), m4_ifdef([$1($2)], [m4_defn([$1($2)])]))]) # lt_if_dict_fetch(DICT, KEY, [SUBKEY], VALUE, IF-TRUE, [IF-FALSE]) # ----------------------------------------------------------------- m4_define([lt_if_dict_fetch], [m4_if(lt_dict_fetch([$1], [$2], [$3]), [$4], [$5], [$6])]) # lt_dict_filter(DICT, [SUBKEY], VALUE, [SEPARATOR], KEY, [...]) # -------------------------------------------------------------- m4_define([lt_dict_filter], [m4_if([$5], [], [], [lt_join(m4_quote(m4_default([$4], [[, ]])), lt_unquote(m4_split(m4_normalize(m4_foreach(_Lt_key, lt_car([m4_shiftn(4, $@)]), [lt_if_dict_fetch([$1], _Lt_key, [$2], [$3], [_Lt_key ])])))))])[]dnl ]) libcaes-20240413/m4/host-cpu-c-abi.m40000644000175000017500000005364014533041421017515 0ustar00lordyestalordyesta# host-cpu-c-abi.m4 serial 13 dnl Copyright (C) 2002-2020 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible and Sam Steingold. dnl Sets the HOST_CPU variable to the canonical name of the CPU. dnl Sets the HOST_CPU_C_ABI variable to the canonical name of the CPU with its dnl C language ABI (application binary interface). dnl Also defines __${HOST_CPU}__ and __${HOST_CPU_C_ABI}__ as C macros in dnl config.h. dnl dnl This canonical name can be used to select a particular assembly language dnl source file that will interoperate with C code on the given host. dnl dnl For example: dnl * 'i386' and 'sparc' are different canonical names, because code for i386 dnl will not run on SPARC CPUs and vice versa. They have different dnl instruction sets. dnl * 'sparc' and 'sparc64' are different canonical names, because code for dnl 'sparc' and code for 'sparc64' cannot be linked together: 'sparc' code dnl contains 32-bit instructions, whereas 'sparc64' code contains 64-bit dnl instructions. A process on a SPARC CPU can be in 32-bit mode or in 64-bit dnl mode, but not both. dnl * 'mips' and 'mipsn32' are different canonical names, because they use dnl different argument passing and return conventions for C functions, and dnl although the instruction set of 'mips' is a large subset of the dnl instruction set of 'mipsn32'. dnl * 'mipsn32' and 'mips64' are different canonical names, because they use dnl different sizes for the C types like 'int' and 'void *', and although dnl the instruction sets of 'mipsn32' and 'mips64' are the same. dnl * The same canonical name is used for different endiannesses. You can dnl determine the endianness through preprocessor symbols: dnl - 'arm': test __ARMEL__. dnl - 'mips', 'mipsn32', 'mips64': test _MIPSEB vs. _MIPSEL. dnl - 'powerpc64': test _BIG_ENDIAN vs. _LITTLE_ENDIAN. dnl * The same name 'i386' is used for CPUs of type i386, i486, i586 dnl (Pentium), AMD K7, Pentium II, Pentium IV, etc., because dnl - Instructions that do not exist on all of these CPUs (cmpxchg, dnl MMX, SSE, SSE2, 3DNow! etc.) are not frequently used. If your dnl assembly language source files use such instructions, you will dnl need to make the distinction. dnl - Speed of execution of the common instruction set is reasonable across dnl the entire family of CPUs. If you have assembly language source files dnl that are optimized for particular CPU types (like GNU gmp has), you dnl will need to make the distinction. dnl See . AC_DEFUN([gl_HOST_CPU_C_ABI], [ AC_REQUIRE([AC_CANONICAL_HOST]) AC_REQUIRE([gl_C_ASM]) AC_CACHE_CHECK([host CPU and C ABI], [gl_cv_host_cpu_c_abi], [case "$host_cpu" in changequote(,)dnl i[34567]86 ) changequote([,])dnl gl_cv_host_cpu_c_abi=i386 ;; x86_64 ) # On x86_64 systems, the C compiler may be generating code in one of # these ABIs: # - 64-bit instruction set, 64-bit pointers, 64-bit 'long': x86_64. # - 64-bit instruction set, 64-bit pointers, 32-bit 'long': x86_64 # with native Windows (mingw, MSVC). # - 64-bit instruction set, 32-bit pointers, 32-bit 'long': x86_64-x32. # - 32-bit instruction set, 32-bit pointers, 32-bit 'long': i386. AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#if (defined __x86_64__ || defined __amd64__ \ || defined _M_X64 || defined _M_AMD64) int ok; #else error fail #endif ]])], [AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#if defined __ILP32__ || defined _ILP32 int ok; #else error fail #endif ]])], [gl_cv_host_cpu_c_abi=x86_64-x32], [gl_cv_host_cpu_c_abi=x86_64])], [gl_cv_host_cpu_c_abi=i386]) ;; changequote(,)dnl alphaev[4-8] | alphaev56 | alphapca5[67] | alphaev6[78] ) changequote([,])dnl gl_cv_host_cpu_c_abi=alpha ;; arm* | aarch64 ) # Assume arm with EABI. # On arm64 systems, the C compiler may be generating code in one of # these ABIs: # - aarch64 instruction set, 64-bit pointers, 64-bit 'long': arm64. # - aarch64 instruction set, 32-bit pointers, 32-bit 'long': arm64-ilp32. # - 32-bit instruction set, 32-bit pointers, 32-bit 'long': arm or armhf. AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#ifdef __aarch64__ int ok; #else error fail #endif ]])], [AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#if defined __ILP32__ || defined _ILP32 int ok; #else error fail #endif ]])], [gl_cv_host_cpu_c_abi=arm64-ilp32], [gl_cv_host_cpu_c_abi=arm64])], [# Don't distinguish little-endian and big-endian arm, since they # don't require different machine code for simple operations and # since the user can distinguish them through the preprocessor # defines __ARMEL__ vs. __ARMEB__. # But distinguish arm which passes floating-point arguments and # return values in integer registers (r0, r1, ...) - this is # gcc -mfloat-abi=soft or gcc -mfloat-abi=softfp - from arm which # passes them in float registers (s0, s1, ...) and double registers # (d0, d1, ...) - this is gcc -mfloat-abi=hard. GCC 4.6 or newer # sets the preprocessor defines __ARM_PCS (for the first case) and # __ARM_PCS_VFP (for the second case), but older GCC does not. echo 'double ddd; void func (double dd) { ddd = dd; }' > conftest.c # Look for a reference to the register d0 in the .s file. AC_TRY_COMMAND(${CC-cc} $CFLAGS $CPPFLAGS $gl_c_asm_opt conftest.c) >/dev/null 2>&1 if LC_ALL=C grep 'd0,' conftest.$gl_asmext >/dev/null; then gl_cv_host_cpu_c_abi=armhf else gl_cv_host_cpu_c_abi=arm fi rm -f conftest* ]) ;; hppa1.0 | hppa1.1 | hppa2.0* | hppa64 ) # On hppa, the C compiler may be generating 32-bit code or 64-bit # code. In the latter case, it defines _LP64 and __LP64__. AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#ifdef __LP64__ int ok; #else error fail #endif ]])], [gl_cv_host_cpu_c_abi=hppa64], [gl_cv_host_cpu_c_abi=hppa]) ;; ia64* ) # On ia64 on HP-UX, the C compiler may be generating 64-bit code or # 32-bit code. In the latter case, it defines _ILP32. AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#ifdef _ILP32 int ok; #else error fail #endif ]])], [gl_cv_host_cpu_c_abi=ia64-ilp32], [gl_cv_host_cpu_c_abi=ia64]) ;; mips* ) # We should also check for (_MIPS_SZPTR == 64), but gcc keeps this # at 32. AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#if defined _MIPS_SZLONG && (_MIPS_SZLONG == 64) int ok; #else error fail #endif ]])], [gl_cv_host_cpu_c_abi=mips64], [# In the n32 ABI, _ABIN32 is defined, _ABIO32 is not defined (but # may later get defined by ), and _MIPS_SIM == _ABIN32. # In the 32 ABI, _ABIO32 is defined, _ABIN32 is not defined (but # may later get defined by ), and _MIPS_SIM == _ABIO32. AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#if (_MIPS_SIM == _ABIN32) int ok; #else error fail #endif ]])], [gl_cv_host_cpu_c_abi=mipsn32], [gl_cv_host_cpu_c_abi=mips])]) ;; powerpc* ) # Different ABIs are in use on AIX vs. Mac OS X vs. Linux,*BSD. # No need to distinguish them here; the caller may distinguish # them based on the OS. # On powerpc64 systems, the C compiler may still be generating # 32-bit code. And on powerpc-ibm-aix systems, the C compiler may # be generating 64-bit code. AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#if defined __powerpc64__ || defined _ARCH_PPC64 int ok; #else error fail #endif ]])], [# On powerpc64, there are two ABIs on Linux: The AIX compatible # one and the ELFv2 one. The latter defines _CALL_ELF=2. AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#if defined _CALL_ELF && _CALL_ELF == 2 int ok; #else error fail #endif ]])], [gl_cv_host_cpu_c_abi=powerpc64-elfv2], [gl_cv_host_cpu_c_abi=powerpc64]) ], [gl_cv_host_cpu_c_abi=powerpc]) ;; rs6000 ) gl_cv_host_cpu_c_abi=powerpc ;; riscv32 | riscv64 ) # There are 2 architectures (with variants): rv32* and rv64*. AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#if __riscv_xlen == 64 int ok; #else error fail #endif ]])], [cpu=riscv64], [cpu=riscv32]) # There are 6 ABIs: ilp32, ilp32f, ilp32d, lp64, lp64f, lp64d. # Size of 'long' and 'void *': AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#if defined __LP64__ int ok; #else error fail #endif ]])], [main_abi=lp64], [main_abi=ilp32]) # Float ABIs: # __riscv_float_abi_double: # 'float' and 'double' are passed in floating-point registers. # __riscv_float_abi_single: # 'float' are passed in floating-point registers. # __riscv_float_abi_soft: # No values are passed in floating-point registers. AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#if defined __riscv_float_abi_double int ok; #else error fail #endif ]])], [float_abi=d], [AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#if defined __riscv_float_abi_single int ok; #else error fail #endif ]])], [float_abi=f], [float_abi='']) ]) gl_cv_host_cpu_c_abi="${cpu}-${main_abi}${float_abi}" ;; s390* ) # On s390x, the C compiler may be generating 64-bit (= s390x) code # or 31-bit (= s390) code. AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#if defined __LP64__ || defined __s390x__ int ok; #else error fail #endif ]])], [gl_cv_host_cpu_c_abi=s390x], [gl_cv_host_cpu_c_abi=s390]) ;; sparc | sparc64 ) # UltraSPARCs running Linux have `uname -m` = "sparc64", but the # C compiler still generates 32-bit code. AC_COMPILE_IFELSE( [AC_LANG_SOURCE( [[#if defined __sparcv9 || defined __arch64__ int ok; #else error fail #endif ]])], [gl_cv_host_cpu_c_abi=sparc64], [gl_cv_host_cpu_c_abi=sparc]) ;; *) gl_cv_host_cpu_c_abi="$host_cpu" ;; esac ]) dnl In most cases, $HOST_CPU and $HOST_CPU_C_ABI are the same. HOST_CPU=`echo "$gl_cv_host_cpu_c_abi" | sed -e 's/-.*//'` HOST_CPU_C_ABI="$gl_cv_host_cpu_c_abi" AC_SUBST([HOST_CPU]) AC_SUBST([HOST_CPU_C_ABI]) # This was # AC_DEFINE_UNQUOTED([__${HOST_CPU}__]) # AC_DEFINE_UNQUOTED([__${HOST_CPU_C_ABI}__]) # earlier, but KAI C++ 3.2d doesn't like this. sed -e 's/-/_/g' >> confdefs.h <. ]) # serial 59 LT_INIT # LT_PREREQ(VERSION) # ------------------ # Complain and exit if this libtool version is less that VERSION. m4_defun([LT_PREREQ], [m4_if(m4_version_compare(m4_defn([LT_PACKAGE_VERSION]), [$1]), -1, [m4_default([$3], [m4_fatal([Libtool version $1 or higher is required], 63)])], [$2])]) # _LT_CHECK_BUILDDIR # ------------------ # Complain if the absolute build directory name contains unusual characters m4_defun([_LT_CHECK_BUILDDIR], [case `pwd` in *\ * | *\ *) AC_MSG_WARN([Libtool does not cope well with whitespace in `pwd`]) ;; esac ]) # LT_INIT([OPTIONS]) # ------------------ AC_DEFUN([LT_INIT], [AC_PREREQ([2.62])dnl We use AC_PATH_PROGS_FEATURE_CHECK AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl AC_BEFORE([$0], [LT_LANG])dnl AC_BEFORE([$0], [LT_OUTPUT])dnl AC_BEFORE([$0], [LTDL_INIT])dnl m4_require([_LT_CHECK_BUILDDIR])dnl dnl Autoconf doesn't catch unexpanded LT_ macros by default: m4_pattern_forbid([^_?LT_[A-Z_]+$])dnl m4_pattern_allow([^(_LT_EOF|LT_DLGLOBAL|LT_DLLAZY_OR_NOW|LT_MULTI_MODULE)$])dnl dnl aclocal doesn't pull ltoptions.m4, ltsugar.m4, or ltversion.m4 dnl unless we require an AC_DEFUNed macro: AC_REQUIRE([LTOPTIONS_VERSION])dnl AC_REQUIRE([LTSUGAR_VERSION])dnl AC_REQUIRE([LTVERSION_VERSION])dnl AC_REQUIRE([LTOBSOLETE_VERSION])dnl m4_require([_LT_PROG_LTMAIN])dnl _LT_SHELL_INIT([SHELL=${CONFIG_SHELL-/bin/sh}]) dnl Parse OPTIONS _LT_SET_OPTIONS([$0], [$1]) # This can be used to rebuild libtool when needed LIBTOOL_DEPS=$ltmain # Always use our own libtool. LIBTOOL='$(SHELL) $(top_builddir)/libtool' AC_SUBST(LIBTOOL)dnl _LT_SETUP # Only expand once: m4_define([LT_INIT]) ])# LT_INIT # Old names: AU_ALIAS([AC_PROG_LIBTOOL], [LT_INIT]) AU_ALIAS([AM_PROG_LIBTOOL], [LT_INIT]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_PROG_LIBTOOL], []) dnl AC_DEFUN([AM_PROG_LIBTOOL], []) # _LT_PREPARE_CC_BASENAME # ----------------------- m4_defun([_LT_PREPARE_CC_BASENAME], [ # Calculate cc_basename. Skip known compiler wrappers and cross-prefix. func_cc_basename () { for cc_temp in @S|@*""; do case $cc_temp in compile | *[[\\/]]compile | ccache | *[[\\/]]ccache ) ;; distcc | *[[\\/]]distcc | purify | *[[\\/]]purify ) ;; \-*) ;; *) break;; esac done func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` } ])# _LT_PREPARE_CC_BASENAME # _LT_CC_BASENAME(CC) # ------------------- # It would be clearer to call AC_REQUIREs from _LT_PREPARE_CC_BASENAME, # but that macro is also expanded into generated libtool script, which # arranges for $SED and $ECHO to be set by different means. m4_defun([_LT_CC_BASENAME], [m4_require([_LT_PREPARE_CC_BASENAME])dnl AC_REQUIRE([_LT_DECL_SED])dnl AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])dnl func_cc_basename $1 cc_basename=$func_cc_basename_result ]) # _LT_FILEUTILS_DEFAULTS # ---------------------- # It is okay to use these file commands and assume they have been set # sensibly after 'm4_require([_LT_FILEUTILS_DEFAULTS])'. m4_defun([_LT_FILEUTILS_DEFAULTS], [: ${CP="cp -f"} : ${MV="mv -f"} : ${RM="rm -f"} ])# _LT_FILEUTILS_DEFAULTS # _LT_SETUP # --------- m4_defun([_LT_SETUP], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl AC_REQUIRE([_LT_PREPARE_SED_QUOTE_VARS])dnl AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH])dnl _LT_DECL([], [PATH_SEPARATOR], [1], [The PATH separator for the build system])dnl dnl _LT_DECL([], [host_alias], [0], [The host system])dnl _LT_DECL([], [host], [0])dnl _LT_DECL([], [host_os], [0])dnl dnl _LT_DECL([], [build_alias], [0], [The build system])dnl _LT_DECL([], [build], [0])dnl _LT_DECL([], [build_os], [0])dnl dnl AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([LT_PATH_LD])dnl AC_REQUIRE([LT_PATH_NM])dnl dnl AC_REQUIRE([AC_PROG_LN_S])dnl test -z "$LN_S" && LN_S="ln -s" _LT_DECL([], [LN_S], [1], [Whether we need soft or hard links])dnl dnl AC_REQUIRE([LT_CMD_MAX_LEN])dnl _LT_DECL([objext], [ac_objext], [0], [Object file suffix (normally "o")])dnl _LT_DECL([], [exeext], [0], [Executable file suffix (normally "")])dnl dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_CHECK_SHELL_FEATURES])dnl m4_require([_LT_PATH_CONVERSION_FUNCTIONS])dnl m4_require([_LT_CMD_RELOAD])dnl m4_require([_LT_DECL_FILECMD])dnl m4_require([_LT_CHECK_MAGIC_METHOD])dnl m4_require([_LT_CHECK_SHAREDLIB_FROM_LINKLIB])dnl m4_require([_LT_CMD_OLD_ARCHIVE])dnl m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl m4_require([_LT_WITH_SYSROOT])dnl m4_require([_LT_CMD_TRUNCATE])dnl _LT_CONFIG_LIBTOOL_INIT([ # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes INIT. if test -n "\${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi ]) if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi _LT_CHECK_OBJDIR m4_require([_LT_TAG_COMPILER])dnl case $host_os in aix3*) # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi ;; esac # Global variables: ofile=libtool can_build_shared=yes # All known linkers require a '.a' archive for static linking (except MSVC and # ICC, which need '.lib'). libext=a with_gnu_ld=$lt_cv_prog_gnu_ld old_CC=$CC old_CFLAGS=$CFLAGS # Set sane defaults for various variables test -z "$CC" && CC=cc test -z "$LTCC" && LTCC=$CC test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS test -z "$LD" && LD=ld test -z "$ac_objext" && ac_objext=o _LT_CC_BASENAME([$compiler]) # Only perform the check for file, if the check method requires it test -z "$MAGIC_CMD" && MAGIC_CMD=file case $deplibs_check_method in file_magic*) if test "$file_magic_cmd" = '$MAGIC_CMD'; then _LT_PATH_MAGIC fi ;; esac # Use C for the default configuration in the libtool script LT_SUPPORTED_TAG([CC]) _LT_LANG_C_CONFIG _LT_LANG_DEFAULT_CONFIG _LT_CONFIG_COMMANDS ])# _LT_SETUP # _LT_PREPARE_SED_QUOTE_VARS # -------------------------- # Define a few sed substitution that help us do robust quoting. m4_defun([_LT_PREPARE_SED_QUOTE_VARS], [# Backslashify metacharacters that are still active within # double-quoted strings. sed_quote_subst='s/\([["`$\\]]\)/\\\1/g' # Same as above, but do not quote variable references. double_quote_subst='s/\([["`\\]]\)/\\\1/g' # Sed substitution to delay expansion of an escaped shell variable in a # double_quote_subst'ed string. delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' # Sed substitution to delay expansion of an escaped single quote. delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g' # Sed substitution to avoid accidental globbing in evaled expressions no_glob_subst='s/\*/\\\*/g' ]) # _LT_PROG_LTMAIN # --------------- # Note that this code is called both from 'configure', and 'config.status' # now that we use AC_CONFIG_COMMANDS to generate libtool. Notably, # 'config.status' has no value for ac_aux_dir unless we are using Automake, # so we pass a copy along to make sure it has a sensible value anyway. m4_defun([_LT_PROG_LTMAIN], [m4_ifdef([AC_REQUIRE_AUX_FILE], [AC_REQUIRE_AUX_FILE([ltmain.sh])])dnl _LT_CONFIG_LIBTOOL_INIT([ac_aux_dir='$ac_aux_dir']) ltmain=$ac_aux_dir/ltmain.sh ])# _LT_PROG_LTMAIN ## ------------------------------------- ## ## Accumulate code for creating libtool. ## ## ------------------------------------- ## # So that we can recreate a full libtool script including additional # tags, we accumulate the chunks of code to send to AC_CONFIG_COMMANDS # in macros and then make a single call at the end using the 'libtool' # label. # _LT_CONFIG_LIBTOOL_INIT([INIT-COMMANDS]) # ---------------------------------------- # Register INIT-COMMANDS to be passed to AC_CONFIG_COMMANDS later. m4_define([_LT_CONFIG_LIBTOOL_INIT], [m4_ifval([$1], [m4_append([_LT_OUTPUT_LIBTOOL_INIT], [$1 ])])]) # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_INIT]) # _LT_CONFIG_LIBTOOL([COMMANDS]) # ------------------------------ # Register COMMANDS to be passed to AC_CONFIG_COMMANDS later. m4_define([_LT_CONFIG_LIBTOOL], [m4_ifval([$1], [m4_append([_LT_OUTPUT_LIBTOOL_COMMANDS], [$1 ])])]) # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS]) # _LT_CONFIG_SAVE_COMMANDS([COMMANDS], [INIT_COMMANDS]) # ----------------------------------------------------- m4_defun([_LT_CONFIG_SAVE_COMMANDS], [_LT_CONFIG_LIBTOOL([$1]) _LT_CONFIG_LIBTOOL_INIT([$2]) ]) # _LT_FORMAT_COMMENT([COMMENT]) # ----------------------------- # Add leading comment marks to the start of each line, and a trailing # full-stop to the whole comment if one is not present already. m4_define([_LT_FORMAT_COMMENT], [m4_ifval([$1], [ m4_bpatsubst([m4_bpatsubst([$1], [^ *], [# ])], [['`$\]], [\\\&])]m4_bmatch([$1], [[!?.]$], [], [.]) )]) ## ------------------------ ## ## FIXME: Eliminate VARNAME ## ## ------------------------ ## # _LT_DECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION], [IS-TAGGED?]) # ------------------------------------------------------------------- # CONFIGNAME is the name given to the value in the libtool script. # VARNAME is the (base) name used in the configure script. # VALUE may be 0, 1 or 2 for a computed quote escaped value based on # VARNAME. Any other value will be used directly. m4_define([_LT_DECL], [lt_if_append_uniq([lt_decl_varnames], [$2], [, ], [lt_dict_add_subkey([lt_decl_dict], [$2], [libtool_name], [m4_ifval([$1], [$1], [$2])]) lt_dict_add_subkey([lt_decl_dict], [$2], [value], [$3]) m4_ifval([$4], [lt_dict_add_subkey([lt_decl_dict], [$2], [description], [$4])]) lt_dict_add_subkey([lt_decl_dict], [$2], [tagged?], [m4_ifval([$5], [yes], [no])])]) ]) # _LT_TAGDECL([CONFIGNAME], VARNAME, VALUE, [DESCRIPTION]) # -------------------------------------------------------- m4_define([_LT_TAGDECL], [_LT_DECL([$1], [$2], [$3], [$4], [yes])]) # lt_decl_tag_varnames([SEPARATOR], [VARNAME1...]) # ------------------------------------------------ m4_define([lt_decl_tag_varnames], [_lt_decl_filter([tagged?], [yes], $@)]) # _lt_decl_filter(SUBKEY, VALUE, [SEPARATOR], [VARNAME1..]) # --------------------------------------------------------- m4_define([_lt_decl_filter], [m4_case([$#], [0], [m4_fatal([$0: too few arguments: $#])], [1], [m4_fatal([$0: too few arguments: $#: $1])], [2], [lt_dict_filter([lt_decl_dict], [$1], [$2], [], lt_decl_varnames)], [3], [lt_dict_filter([lt_decl_dict], [$1], [$2], [$3], lt_decl_varnames)], [lt_dict_filter([lt_decl_dict], $@)])[]dnl ]) # lt_decl_quote_varnames([SEPARATOR], [VARNAME1...]) # -------------------------------------------------- m4_define([lt_decl_quote_varnames], [_lt_decl_filter([value], [1], $@)]) # lt_decl_dquote_varnames([SEPARATOR], [VARNAME1...]) # --------------------------------------------------- m4_define([lt_decl_dquote_varnames], [_lt_decl_filter([value], [2], $@)]) # lt_decl_varnames_tagged([SEPARATOR], [VARNAME1...]) # --------------------------------------------------- m4_define([lt_decl_varnames_tagged], [m4_assert([$# <= 2])dnl _$0(m4_quote(m4_default([$1], [[, ]])), m4_ifval([$2], [[$2]], [m4_dquote(lt_decl_tag_varnames)]), m4_split(m4_normalize(m4_quote(_LT_TAGS)), [ ]))]) m4_define([_lt_decl_varnames_tagged], [m4_ifval([$3], [lt_combine([$1], [$2], [_], $3)])]) # lt_decl_all_varnames([SEPARATOR], [VARNAME1...]) # ------------------------------------------------ m4_define([lt_decl_all_varnames], [_$0(m4_quote(m4_default([$1], [[, ]])), m4_if([$2], [], m4_quote(lt_decl_varnames), m4_quote(m4_shift($@))))[]dnl ]) m4_define([_lt_decl_all_varnames], [lt_join($@, lt_decl_varnames_tagged([$1], lt_decl_tag_varnames([[, ]], m4_shift($@))))dnl ]) # _LT_CONFIG_STATUS_DECLARE([VARNAME]) # ------------------------------------ # Quote a variable value, and forward it to 'config.status' so that its # declaration there will have the same value as in 'configure'. VARNAME # must have a single quote delimited value for this to work. m4_define([_LT_CONFIG_STATUS_DECLARE], [$1='`$ECHO "$][$1" | $SED "$delay_single_quote_subst"`']) # _LT_CONFIG_STATUS_DECLARATIONS # ------------------------------ # We delimit libtool config variables with single quotes, so when # we write them to config.status, we have to be sure to quote all # embedded single quotes properly. In configure, this macro expands # each variable declared with _LT_DECL (and _LT_TAGDECL) into: # # ='`$ECHO "$" | $SED "$delay_single_quote_subst"`' m4_defun([_LT_CONFIG_STATUS_DECLARATIONS], [m4_foreach([_lt_var], m4_quote(lt_decl_all_varnames), [m4_n([_LT_CONFIG_STATUS_DECLARE(_lt_var)])])]) # _LT_LIBTOOL_TAGS # ---------------- # Output comment and list of tags supported by the script m4_defun([_LT_LIBTOOL_TAGS], [_LT_FORMAT_COMMENT([The names of the tagged configurations supported by this script])dnl available_tags='_LT_TAGS'dnl ]) # _LT_LIBTOOL_DECLARE(VARNAME, [TAG]) # ----------------------------------- # Extract the dictionary values for VARNAME (optionally with TAG) and # expand to a commented shell variable setting: # # # Some comment about what VAR is for. # visible_name=$lt_internal_name m4_define([_LT_LIBTOOL_DECLARE], [_LT_FORMAT_COMMENT(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [description])))[]dnl m4_pushdef([_libtool_name], m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [libtool_name])))[]dnl m4_case(m4_quote(lt_dict_fetch([lt_decl_dict], [$1], [value])), [0], [_libtool_name=[$]$1], [1], [_libtool_name=$lt_[]$1], [2], [_libtool_name=$lt_[]$1], [_libtool_name=lt_dict_fetch([lt_decl_dict], [$1], [value])])[]dnl m4_ifval([$2], [_$2])[]m4_popdef([_libtool_name])[]dnl ]) # _LT_LIBTOOL_CONFIG_VARS # ----------------------- # Produce commented declarations of non-tagged libtool config variables # suitable for insertion in the LIBTOOL CONFIG section of the 'libtool' # script. Tagged libtool config variables (even for the LIBTOOL CONFIG # section) are produced by _LT_LIBTOOL_TAG_VARS. m4_defun([_LT_LIBTOOL_CONFIG_VARS], [m4_foreach([_lt_var], m4_quote(_lt_decl_filter([tagged?], [no], [], lt_decl_varnames)), [m4_n([_LT_LIBTOOL_DECLARE(_lt_var)])])]) # _LT_LIBTOOL_TAG_VARS(TAG) # ------------------------- m4_define([_LT_LIBTOOL_TAG_VARS], [m4_foreach([_lt_var], m4_quote(lt_decl_tag_varnames), [m4_n([_LT_LIBTOOL_DECLARE(_lt_var, [$1])])])]) # _LT_TAGVAR(VARNAME, [TAGNAME]) # ------------------------------ m4_define([_LT_TAGVAR], [m4_ifval([$2], [$1_$2], [$1])]) # _LT_CONFIG_COMMANDS # ------------------- # Send accumulated output to $CONFIG_STATUS. Thanks to the lists of # variables for single and double quote escaping we saved from calls # to _LT_DECL, we can put quote escaped variables declarations # into 'config.status', and then the shell code to quote escape them in # for loops in 'config.status'. Finally, any additional code accumulated # from calls to _LT_CONFIG_LIBTOOL_INIT is expanded. m4_defun([_LT_CONFIG_COMMANDS], [AC_PROVIDE_IFELSE([LT_OUTPUT], dnl If the libtool generation code has been placed in $CONFIG_LT, dnl instead of duplicating it all over again into config.status, dnl then we will have config.status run $CONFIG_LT later, so it dnl needs to know what name is stored there: [AC_CONFIG_COMMANDS([libtool], [$SHELL $CONFIG_LT || AS_EXIT(1)], [CONFIG_LT='$CONFIG_LT'])], dnl If the libtool generation code is destined for config.status, dnl expand the accumulated commands and init code now: [AC_CONFIG_COMMANDS([libtool], [_LT_OUTPUT_LIBTOOL_COMMANDS], [_LT_OUTPUT_LIBTOOL_COMMANDS_INIT])]) ])#_LT_CONFIG_COMMANDS # Initialize. m4_define([_LT_OUTPUT_LIBTOOL_COMMANDS_INIT], [ # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH sed_quote_subst='$sed_quote_subst' double_quote_subst='$double_quote_subst' delay_variable_subst='$delay_variable_subst' _LT_CONFIG_STATUS_DECLARATIONS LTCC='$LTCC' LTCFLAGS='$LTCFLAGS' compiler='$compiler_DEFAULT' # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$[]1 _LTECHO_EOF' } # Quote evaled strings. for var in lt_decl_all_varnames([[ \ ]], lt_decl_quote_varnames); do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[[\\\\\\\`\\"\\\$]]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done # Double-quote double-evaled strings. for var in lt_decl_all_varnames([[ \ ]], lt_decl_dquote_varnames); do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[[\\\\\\\`\\"\\\$]]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done _LT_OUTPUT_LIBTOOL_INIT ]) # _LT_GENERATED_FILE_INIT(FILE, [COMMENT]) # ------------------------------------ # Generate a child script FILE with all initialization necessary to # reuse the environment learned by the parent script, and make the # file executable. If COMMENT is supplied, it is inserted after the # '#!' sequence but before initialization text begins. After this # macro, additional text can be appended to FILE to form the body of # the child script. The macro ends with non-zero status if the # file could not be fully written (such as if the disk is full). m4_ifdef([AS_INIT_GENERATED], [m4_defun([_LT_GENERATED_FILE_INIT],[AS_INIT_GENERATED($@)])], [m4_defun([_LT_GENERATED_FILE_INIT], [m4_require([AS_PREPARE])]dnl [m4_pushdef([AS_MESSAGE_LOG_FD])]dnl [lt_write_fail=0 cat >$1 <<_ASEOF || lt_write_fail=1 #! $SHELL # Generated by $as_me. $2 SHELL=\${CONFIG_SHELL-$SHELL} export SHELL _ASEOF cat >>$1 <<\_ASEOF || lt_write_fail=1 AS_SHELL_SANITIZE _AS_PREPARE exec AS_MESSAGE_FD>&1 _ASEOF test 0 = "$lt_write_fail" && chmod +x $1[]dnl m4_popdef([AS_MESSAGE_LOG_FD])])])# _LT_GENERATED_FILE_INIT # LT_OUTPUT # --------- # This macro allows early generation of the libtool script (before # AC_OUTPUT is called), incase it is used in configure for compilation # tests. AC_DEFUN([LT_OUTPUT], [: ${CONFIG_LT=./config.lt} AC_MSG_NOTICE([creating $CONFIG_LT]) _LT_GENERATED_FILE_INIT(["$CONFIG_LT"], [# Run this file to recreate a libtool stub with the current configuration.]) cat >>"$CONFIG_LT" <<\_LTEOF lt_cl_silent=false exec AS_MESSAGE_LOG_FD>>config.log { echo AS_BOX([Running $as_me.]) } >&AS_MESSAGE_LOG_FD lt_cl_help="\ '$as_me' creates a local libtool stub from the current configuration, for use in further configure time tests before the real libtool is generated. Usage: $[0] [[OPTIONS]] -h, --help print this help, then exit -V, --version print version number, then exit -q, --quiet do not print progress messages -d, --debug don't remove temporary files Report bugs to ." lt_cl_version="\ m4_ifset([AC_PACKAGE_NAME], [AC_PACKAGE_NAME ])config.lt[]dnl m4_ifset([AC_PACKAGE_VERSION], [ AC_PACKAGE_VERSION]) configured by $[0], generated by m4_PACKAGE_STRING. Copyright (C) 2011 Free Software Foundation, Inc. This config.lt script is free software; the Free Software Foundation gives unlimited permision to copy, distribute and modify it." while test 0 != $[#] do case $[1] in --version | --v* | -V ) echo "$lt_cl_version"; exit 0 ;; --help | --h* | -h ) echo "$lt_cl_help"; exit 0 ;; --debug | --d* | -d ) debug=: ;; --quiet | --q* | --silent | --s* | -q ) lt_cl_silent=: ;; -*) AC_MSG_ERROR([unrecognized option: $[1] Try '$[0] --help' for more information.]) ;; *) AC_MSG_ERROR([unrecognized argument: $[1] Try '$[0] --help' for more information.]) ;; esac shift done if $lt_cl_silent; then exec AS_MESSAGE_FD>/dev/null fi _LTEOF cat >>"$CONFIG_LT" <<_LTEOF _LT_OUTPUT_LIBTOOL_COMMANDS_INIT _LTEOF cat >>"$CONFIG_LT" <<\_LTEOF AC_MSG_NOTICE([creating $ofile]) _LT_OUTPUT_LIBTOOL_COMMANDS AS_EXIT(0) _LTEOF chmod +x "$CONFIG_LT" # configure is writing to config.log, but config.lt does its own redirection, # appending to config.log, which fails on DOS, as config.log is still kept # open by configure. Here we exec the FD to /dev/null, effectively closing # config.log, so it can be properly (re)opened and appended to by config.lt. lt_cl_success=: test yes = "$silent" && lt_config_lt_args="$lt_config_lt_args --quiet" exec AS_MESSAGE_LOG_FD>/dev/null $SHELL "$CONFIG_LT" $lt_config_lt_args || lt_cl_success=false exec AS_MESSAGE_LOG_FD>>config.log $lt_cl_success || AS_EXIT(1) ])# LT_OUTPUT # _LT_CONFIG(TAG) # --------------- # If TAG is the built-in tag, create an initial libtool script with a # default configuration from the untagged config vars. Otherwise add code # to config.status for appending the configuration named by TAG from the # matching tagged config vars. m4_defun([_LT_CONFIG], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl _LT_CONFIG_SAVE_COMMANDS([ m4_define([_LT_TAG], m4_if([$1], [], [C], [$1]))dnl m4_if(_LT_TAG, [C], [ # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes. if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi cfgfile=${ofile}T trap "$RM \"$cfgfile\"; exit 1" 1 2 15 $RM "$cfgfile" cat <<_LT_EOF >> "$cfgfile" #! $SHELL # Generated automatically by $as_me ($PACKAGE) $VERSION # Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: # NOTE: Changes made to this file will be lost: look at ltmain.sh. # Provide generalized library-building support services. # Written by Gordon Matzigkeit, 1996 _LT_COPYING _LT_LIBTOOL_TAGS # Configured defaults for sys_lib_dlsearch_path munging. : \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"} # ### BEGIN LIBTOOL CONFIG _LT_LIBTOOL_CONFIG_VARS _LT_LIBTOOL_TAG_VARS # ### END LIBTOOL CONFIG _LT_EOF cat <<'_LT_EOF' >> "$cfgfile" # ### BEGIN FUNCTIONS SHARED WITH CONFIGURE _LT_PREPARE_MUNGE_PATH_LIST _LT_PREPARE_CC_BASENAME # ### END FUNCTIONS SHARED WITH CONFIGURE _LT_EOF case $host_os in aix3*) cat <<\_LT_EOF >> "$cfgfile" # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi _LT_EOF ;; esac _LT_PROG_LTMAIN # We use sed instead of cat because bash on DJGPP gets confused if # if finds mixed CR/LF and LF-only lines. Since sed operates in # text mode, it properly converts lines to CR/LF. This bash problem # is reportedly fixed, but why not run on old versions too? $SED '$q' "$ltmain" >> "$cfgfile" \ || (rm -f "$cfgfile"; exit 1) mv -f "$cfgfile" "$ofile" || (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") chmod +x "$ofile" ], [cat <<_LT_EOF >> "$ofile" dnl Unfortunately we have to use $1 here, since _LT_TAG is not expanded dnl in a comment (ie after a #). # ### BEGIN LIBTOOL TAG CONFIG: $1 _LT_LIBTOOL_TAG_VARS(_LT_TAG) # ### END LIBTOOL TAG CONFIG: $1 _LT_EOF ])dnl /m4_if ], [m4_if([$1], [], [ PACKAGE='$PACKAGE' VERSION='$VERSION' RM='$RM' ofile='$ofile'], []) ])dnl /_LT_CONFIG_SAVE_COMMANDS ])# _LT_CONFIG # LT_SUPPORTED_TAG(TAG) # --------------------- # Trace this macro to discover what tags are supported by the libtool # --tag option, using: # autoconf --trace 'LT_SUPPORTED_TAG:$1' AC_DEFUN([LT_SUPPORTED_TAG], []) # C support is built-in for now m4_define([_LT_LANG_C_enabled], []) m4_define([_LT_TAGS], []) # LT_LANG(LANG) # ------------- # Enable libtool support for the given language if not already enabled. AC_DEFUN([LT_LANG], [AC_BEFORE([$0], [LT_OUTPUT])dnl m4_case([$1], [C], [_LT_LANG(C)], [C++], [_LT_LANG(CXX)], [Go], [_LT_LANG(GO)], [Java], [_LT_LANG(GCJ)], [Fortran 77], [_LT_LANG(F77)], [Fortran], [_LT_LANG(FC)], [Windows Resource], [_LT_LANG(RC)], [m4_ifdef([_LT_LANG_]$1[_CONFIG], [_LT_LANG($1)], [m4_fatal([$0: unsupported language: "$1"])])])dnl ])# LT_LANG # _LT_LANG(LANGNAME) # ------------------ m4_defun([_LT_LANG], [m4_ifdef([_LT_LANG_]$1[_enabled], [], [LT_SUPPORTED_TAG([$1])dnl m4_append([_LT_TAGS], [$1 ])dnl m4_define([_LT_LANG_]$1[_enabled], [])dnl _LT_LANG_$1_CONFIG($1)])dnl ])# _LT_LANG m4_ifndef([AC_PROG_GO], [ ############################################################ # NOTE: This macro has been submitted for inclusion into # # GNU Autoconf as AC_PROG_GO. When it is available in # # a released version of Autoconf we should remove this # # macro and use it instead. # ############################################################ m4_defun([AC_PROG_GO], [AC_LANG_PUSH(Go)dnl AC_ARG_VAR([GOC], [Go compiler command])dnl AC_ARG_VAR([GOFLAGS], [Go compiler flags])dnl _AC_ARG_VAR_LDFLAGS()dnl AC_CHECK_TOOL(GOC, gccgo) if test -z "$GOC"; then if test -n "$ac_tool_prefix"; then AC_CHECK_PROG(GOC, [${ac_tool_prefix}gccgo], [${ac_tool_prefix}gccgo]) fi fi if test -z "$GOC"; then AC_CHECK_PROG(GOC, gccgo, gccgo, false) fi ])#m4_defun ])#m4_ifndef # _LT_LANG_DEFAULT_CONFIG # ----------------------- m4_defun([_LT_LANG_DEFAULT_CONFIG], [AC_PROVIDE_IFELSE([AC_PROG_CXX], [LT_LANG(CXX)], [m4_define([AC_PROG_CXX], defn([AC_PROG_CXX])[LT_LANG(CXX)])]) AC_PROVIDE_IFELSE([AC_PROG_F77], [LT_LANG(F77)], [m4_define([AC_PROG_F77], defn([AC_PROG_F77])[LT_LANG(F77)])]) AC_PROVIDE_IFELSE([AC_PROG_FC], [LT_LANG(FC)], [m4_define([AC_PROG_FC], defn([AC_PROG_FC])[LT_LANG(FC)])]) dnl The call to [A][M_PROG_GCJ] is quoted like that to stop aclocal dnl pulling things in needlessly. AC_PROVIDE_IFELSE([AC_PROG_GCJ], [LT_LANG(GCJ)], [AC_PROVIDE_IFELSE([A][M_PROG_GCJ], [LT_LANG(GCJ)], [AC_PROVIDE_IFELSE([LT_PROG_GCJ], [LT_LANG(GCJ)], [m4_ifdef([AC_PROG_GCJ], [m4_define([AC_PROG_GCJ], defn([AC_PROG_GCJ])[LT_LANG(GCJ)])]) m4_ifdef([A][M_PROG_GCJ], [m4_define([A][M_PROG_GCJ], defn([A][M_PROG_GCJ])[LT_LANG(GCJ)])]) m4_ifdef([LT_PROG_GCJ], [m4_define([LT_PROG_GCJ], defn([LT_PROG_GCJ])[LT_LANG(GCJ)])])])])]) AC_PROVIDE_IFELSE([AC_PROG_GO], [LT_LANG(GO)], [m4_define([AC_PROG_GO], defn([AC_PROG_GO])[LT_LANG(GO)])]) AC_PROVIDE_IFELSE([LT_PROG_RC], [LT_LANG(RC)], [m4_define([LT_PROG_RC], defn([LT_PROG_RC])[LT_LANG(RC)])]) ])# _LT_LANG_DEFAULT_CONFIG # Obsolete macros: AU_DEFUN([AC_LIBTOOL_CXX], [LT_LANG(C++)]) AU_DEFUN([AC_LIBTOOL_F77], [LT_LANG(Fortran 77)]) AU_DEFUN([AC_LIBTOOL_FC], [LT_LANG(Fortran)]) AU_DEFUN([AC_LIBTOOL_GCJ], [LT_LANG(Java)]) AU_DEFUN([AC_LIBTOOL_RC], [LT_LANG(Windows Resource)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_CXX], []) dnl AC_DEFUN([AC_LIBTOOL_F77], []) dnl AC_DEFUN([AC_LIBTOOL_FC], []) dnl AC_DEFUN([AC_LIBTOOL_GCJ], []) dnl AC_DEFUN([AC_LIBTOOL_RC], []) # _LT_TAG_COMPILER # ---------------- m4_defun([_LT_TAG_COMPILER], [AC_REQUIRE([AC_PROG_CC])dnl _LT_DECL([LTCC], [CC], [1], [A C compiler])dnl _LT_DECL([LTCFLAGS], [CFLAGS], [1], [LTCC compiler flags])dnl _LT_TAGDECL([CC], [compiler], [1], [A language specific compiler])dnl _LT_TAGDECL([with_gcc], [GCC], [0], [Is the compiler the GNU compiler?])dnl # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC ])# _LT_TAG_COMPILER # _LT_COMPILER_BOILERPLATE # ------------------------ # Check for compiler boilerplate output or warnings with # the simple compiler test code. m4_defun([_LT_COMPILER_BOILERPLATE], [m4_require([_LT_DECL_SED])dnl ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" >conftest.$ac_ext eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_compiler_boilerplate=`cat conftest.err` $RM conftest* ])# _LT_COMPILER_BOILERPLATE # _LT_LINKER_BOILERPLATE # ---------------------- # Check for linker boilerplate output or warnings with # the simple link test code. m4_defun([_LT_LINKER_BOILERPLATE], [m4_require([_LT_DECL_SED])dnl ac_outfile=conftest.$ac_objext echo "$lt_simple_link_test_code" >conftest.$ac_ext eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_linker_boilerplate=`cat conftest.err` $RM -r conftest* ])# _LT_LINKER_BOILERPLATE # _LT_REQUIRED_DARWIN_CHECKS # ------------------------- m4_defun_once([_LT_REQUIRED_DARWIN_CHECKS],[ case $host_os in rhapsody* | darwin*) AC_CHECK_TOOL([DSYMUTIL], [dsymutil], [:]) AC_CHECK_TOOL([NMEDIT], [nmedit], [:]) AC_CHECK_TOOL([LIPO], [lipo], [:]) AC_CHECK_TOOL([OTOOL], [otool], [:]) AC_CHECK_TOOL([OTOOL64], [otool64], [:]) _LT_DECL([], [DSYMUTIL], [1], [Tool to manipulate archived DWARF debug symbol files on Mac OS X]) _LT_DECL([], [NMEDIT], [1], [Tool to change global to local symbols on Mac OS X]) _LT_DECL([], [LIPO], [1], [Tool to manipulate fat objects and archives on Mac OS X]) _LT_DECL([], [OTOOL], [1], [ldd/readelf like tool for Mach-O binaries on Mac OS X]) _LT_DECL([], [OTOOL64], [1], [ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4]) AC_CACHE_CHECK([for -single_module linker flag],[lt_cv_apple_cc_single_mod], [lt_cv_apple_cc_single_mod=no if test -z "$LT_MULTI_MODULE"; then # By default we will add the -single_module flag. You can override # by either setting the environment variable LT_MULTI_MODULE # non-empty at configure time, or by adding -multi_module to the # link flags. rm -rf libconftest.dylib* echo "int foo(void){return 1;}" > conftest.c echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c 2>conftest.err _lt_result=$? # If there is a non-empty error log, and "single_module" # appears in it, assume the flag caused a linker warning if test -s conftest.err && $GREP single_module conftest.err; then cat conftest.err >&AS_MESSAGE_LOG_FD # Otherwise, if the output was created with a 0 exit code from # the compiler, it worked. elif test -f libconftest.dylib && test 0 = "$_lt_result"; then lt_cv_apple_cc_single_mod=yes else cat conftest.err >&AS_MESSAGE_LOG_FD fi rm -rf libconftest.dylib* rm -f conftest.* fi]) AC_CACHE_CHECK([for -exported_symbols_list linker flag], [lt_cv_ld_exported_symbols_list], [lt_cv_ld_exported_symbols_list=no save_LDFLAGS=$LDFLAGS echo "_main" > conftest.sym LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])], [lt_cv_ld_exported_symbols_list=yes], [lt_cv_ld_exported_symbols_list=no]) LDFLAGS=$save_LDFLAGS ]) AC_CACHE_CHECK([for -force_load linker flag],[lt_cv_ld_force_load], [lt_cv_ld_force_load=no cat > conftest.c << _LT_EOF int forced_loaded() { return 2;} _LT_EOF echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&AS_MESSAGE_LOG_FD echo "$AR $AR_FLAGS libconftest.a conftest.o" >&AS_MESSAGE_LOG_FD $AR $AR_FLAGS libconftest.a conftest.o 2>&AS_MESSAGE_LOG_FD echo "$RANLIB libconftest.a" >&AS_MESSAGE_LOG_FD $RANLIB libconftest.a 2>&AS_MESSAGE_LOG_FD cat > conftest.c << _LT_EOF int main() { return 0;} _LT_EOF echo "$LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a" >&AS_MESSAGE_LOG_FD $LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a 2>conftest.err _lt_result=$? if test -s conftest.err && $GREP force_load conftest.err; then cat conftest.err >&AS_MESSAGE_LOG_FD elif test -f conftest && test 0 = "$_lt_result" && $GREP forced_load conftest >/dev/null 2>&1; then lt_cv_ld_force_load=yes else cat conftest.err >&AS_MESSAGE_LOG_FD fi rm -f conftest.err libconftest.a conftest conftest.c rm -rf conftest.dSYM ]) case $host_os in rhapsody* | darwin1.[[012]]) _lt_dar_allow_undefined='$wl-undefined ${wl}suppress' ;; darwin1.*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; darwin*) case $MACOSX_DEPLOYMENT_TARGET,$host in 10.[[012]],*|,*powerpc*-darwin[[5-8]]*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; *) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; esac ;; esac if test yes = "$lt_cv_apple_cc_single_mod"; then _lt_dar_single_mod='$single_module' fi if test yes = "$lt_cv_ld_exported_symbols_list"; then _lt_dar_export_syms=' $wl-exported_symbols_list,$output_objdir/$libname-symbols.expsym' else _lt_dar_export_syms='~$NMEDIT -s $output_objdir/$libname-symbols.expsym $lib' fi if test : != "$DSYMUTIL" && test no = "$lt_cv_ld_force_load"; then _lt_dsymutil='~$DSYMUTIL $lib || :' else _lt_dsymutil= fi ;; esac ]) # _LT_DARWIN_LINKER_FEATURES([TAG]) # --------------------------------- # Checks for linker and compiler features on darwin m4_defun([_LT_DARWIN_LINKER_FEATURES], [ m4_require([_LT_REQUIRED_DARWIN_CHECKS]) _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported if test yes = "$lt_cv_ld_force_load"; then _LT_TAGVAR(whole_archive_flag_spec, $1)='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' m4_case([$1], [F77], [_LT_TAGVAR(compiler_needs_object, $1)=yes], [FC], [_LT_TAGVAR(compiler_needs_object, $1)=yes]) else _LT_TAGVAR(whole_archive_flag_spec, $1)='' fi _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=$_lt_dar_allow_undefined case $cc_basename in ifort*|nagfor*) _lt_dar_can_shared=yes ;; *) _lt_dar_can_shared=$GCC ;; esac if test yes = "$_lt_dar_can_shared"; then output_verbose_link_cmd=func_echo_all _LT_TAGVAR(archive_cmds, $1)="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil" _LT_TAGVAR(module_cmds, $1)="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil" _LT_TAGVAR(archive_expsym_cmds, $1)="$SED 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil" _LT_TAGVAR(module_expsym_cmds, $1)="$SED -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil" m4_if([$1], [CXX], [ if test yes != "$lt_cv_apple_cc_single_mod"; then _LT_TAGVAR(archive_cmds, $1)="\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dsymutil" _LT_TAGVAR(archive_expsym_cmds, $1)="$SED 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dar_export_syms$_lt_dsymutil" fi ],[]) else _LT_TAGVAR(ld_shlibs, $1)=no fi ]) # _LT_SYS_MODULE_PATH_AIX([TAGNAME]) # ---------------------------------- # Links a minimal program and checks the executable # for the system default hardcoded library path. In most cases, # this is /usr/lib:/lib, but when the MPI compilers are used # the location of the communication and MPI libs are included too. # If we don't find anything, use the default library path according # to the aix ld manual. # Store the results from the different compilers for each TAGNAME. # Allow to override them for all tags through lt_cv_aix_libpath. m4_defun([_LT_SYS_MODULE_PATH_AIX], [m4_require([_LT_DECL_SED])dnl if test set = "${lt_cv_aix_libpath+set}"; then aix_libpath=$lt_cv_aix_libpath else AC_CACHE_VAL([_LT_TAGVAR([lt_cv_aix_libpath_], [$1])], [AC_LINK_IFELSE([AC_LANG_PROGRAM],[ lt_aix_libpath_sed='[ /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }]' _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])"; then _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi],[]) if test -z "$_LT_TAGVAR([lt_cv_aix_libpath_], [$1])"; then _LT_TAGVAR([lt_cv_aix_libpath_], [$1])=/usr/lib:/lib fi ]) aix_libpath=$_LT_TAGVAR([lt_cv_aix_libpath_], [$1]) fi ])# _LT_SYS_MODULE_PATH_AIX # _LT_SHELL_INIT(ARG) # ------------------- m4_define([_LT_SHELL_INIT], [m4_divert_text([M4SH-INIT], [$1 ])])# _LT_SHELL_INIT # _LT_PROG_ECHO_BACKSLASH # ----------------------- # Find how we can fake an echo command that does not interpret backslash. # In particular, with Autoconf 2.60 or later we add some code to the start # of the generated configure script that will find a shell with a builtin # printf (that we can use as an echo command). m4_defun([_LT_PROG_ECHO_BACKSLASH], [ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO AC_MSG_CHECKING([how to print strings]) # Test print first, because it will be a builtin if present. if test "X`( print -r -- -n ) 2>/dev/null`" = X-n && \ test "X`print -r -- $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='print -r --' elif test "X`printf %s $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='printf %s\n' else # Use this function as a fallback that always works. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $[]1 _LTECHO_EOF' } ECHO='func_fallback_echo' fi # func_echo_all arg... # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "$*" } case $ECHO in printf*) AC_MSG_RESULT([printf]) ;; print*) AC_MSG_RESULT([print -r]) ;; *) AC_MSG_RESULT([cat]) ;; esac m4_ifdef([_AS_DETECT_SUGGESTED], [_AS_DETECT_SUGGESTED([ test -n "${ZSH_VERSION+set}${BASH_VERSION+set}" || ( ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO PATH=/empty FPATH=/empty; export PATH FPATH test "X`printf %s $ECHO`" = "X$ECHO" \ || test "X`print -r -- $ECHO`" = "X$ECHO" )])]) _LT_DECL([], [SHELL], [1], [Shell to use when invoking shell scripts]) _LT_DECL([], [ECHO], [1], [An echo program that protects backslashes]) ])# _LT_PROG_ECHO_BACKSLASH # _LT_WITH_SYSROOT # ---------------- AC_DEFUN([_LT_WITH_SYSROOT], [m4_require([_LT_DECL_SED])dnl AC_MSG_CHECKING([for sysroot]) AC_ARG_WITH([sysroot], [AS_HELP_STRING([--with-sysroot@<:@=DIR@:>@], [Search for dependent libraries within DIR (or the compiler's sysroot if not specified).])], [], [with_sysroot=no]) dnl lt_sysroot will always be passed unquoted. We quote it here dnl in case the user passed a directory name. lt_sysroot= case $with_sysroot in #( yes) if test yes = "$GCC"; then lt_sysroot=`$CC --print-sysroot 2>/dev/null` fi ;; #( /*) lt_sysroot=`echo "$with_sysroot" | $SED -e "$sed_quote_subst"` ;; #( no|'') ;; #( *) AC_MSG_RESULT([$with_sysroot]) AC_MSG_ERROR([The sysroot must be an absolute path.]) ;; esac AC_MSG_RESULT([${lt_sysroot:-no}]) _LT_DECL([], [lt_sysroot], [0], [The root where to search for ]dnl [dependent libraries, and where our libraries should be installed.])]) # _LT_ENABLE_LOCK # --------------- m4_defun([_LT_ENABLE_LOCK], [AC_ARG_ENABLE([libtool-lock], [AS_HELP_STRING([--disable-libtool-lock], [avoid locking (might break parallel builds)])]) test no = "$enable_libtool_lock" || enable_libtool_lock=yes # Some flags need to be propagated to the compiler or linker for good # libtool support. case $host in ia64-*-hpux*) # Find out what ABI is being produced by ac_compile, and set mode # options accordingly. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `$FILECMD conftest.$ac_objext` in *ELF-32*) HPUX_IA64_MODE=32 ;; *ELF-64*) HPUX_IA64_MODE=64 ;; esac fi rm -rf conftest* ;; *-*-irix6*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then if test yes = "$lt_cv_prog_gnu_ld"; then case `$FILECMD conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -melf32bsmip" ;; *N32*) LD="${LD-ld} -melf32bmipn32" ;; *64-bit*) LD="${LD-ld} -melf64bmip" ;; esac else case `$FILECMD conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -32" ;; *N32*) LD="${LD-ld} -n32" ;; *64-bit*) LD="${LD-ld} -64" ;; esac fi fi rm -rf conftest* ;; mips64*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '[#]line '$LINENO' "configure"' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then emul=elf case `$FILECMD conftest.$ac_objext` in *32-bit*) emul="${emul}32" ;; *64-bit*) emul="${emul}64" ;; esac case `$FILECMD conftest.$ac_objext` in *MSB*) emul="${emul}btsmip" ;; *LSB*) emul="${emul}ltsmip" ;; esac case `$FILECMD conftest.$ac_objext` in *N32*) emul="${emul}n32" ;; esac LD="${LD-ld} -m $emul" fi rm -rf conftest* ;; x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ s390*-*linux*|s390*-*tpf*|sparc*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. Note that the listed cases only cover the # situations where additional linker options are needed (such as when # doing 32-bit compilation for a host where ld defaults to 64-bit, or # vice versa); the common cases where no linker options are needed do # not appear in the list. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `$FILECMD conftest.o` in *32-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_i386_fbsd" ;; x86_64-*linux*) case `$FILECMD conftest.o` in *x86-64*) LD="${LD-ld} -m elf32_x86_64" ;; *) LD="${LD-ld} -m elf_i386" ;; esac ;; powerpc64le-*linux*) LD="${LD-ld} -m elf32lppclinux" ;; powerpc64-*linux*) LD="${LD-ld} -m elf32ppclinux" ;; s390x-*linux*) LD="${LD-ld} -m elf_s390" ;; sparc64-*linux*) LD="${LD-ld} -m elf32_sparc" ;; esac ;; *64-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_x86_64_fbsd" ;; x86_64-*linux*) LD="${LD-ld} -m elf_x86_64" ;; powerpcle-*linux*) LD="${LD-ld} -m elf64lppc" ;; powerpc-*linux*) LD="${LD-ld} -m elf64ppc" ;; s390*-*linux*|s390*-*tpf*) LD="${LD-ld} -m elf64_s390" ;; sparc*-*linux*) LD="${LD-ld} -m elf64_sparc" ;; esac ;; esac fi rm -rf conftest* ;; *-*-sco3.2v5*) # On SCO OpenServer 5, we need -belf to get full-featured binaries. SAVE_CFLAGS=$CFLAGS CFLAGS="$CFLAGS -belf" AC_CACHE_CHECK([whether the C compiler needs -belf], lt_cv_cc_needs_belf, [AC_LANG_PUSH(C) AC_LINK_IFELSE([AC_LANG_PROGRAM([[]],[[]])],[lt_cv_cc_needs_belf=yes],[lt_cv_cc_needs_belf=no]) AC_LANG_POP]) if test yes != "$lt_cv_cc_needs_belf"; then # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf CFLAGS=$SAVE_CFLAGS fi ;; *-*solaris*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo 'int i;' > conftest.$ac_ext if AC_TRY_EVAL(ac_compile); then case `$FILECMD conftest.o` in *64-bit*) case $lt_cv_prog_gnu_ld in yes*) case $host in i?86-*-solaris*|x86_64-*-solaris*) LD="${LD-ld} -m elf_x86_64" ;; sparc*-*-solaris*) LD="${LD-ld} -m elf64_sparc" ;; esac # GNU ld 2.21 introduced _sol2 emulations. Use them if available. if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then LD=${LD-ld}_sol2 fi ;; *) if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then LD="${LD-ld} -64" fi ;; esac ;; esac fi rm -rf conftest* ;; esac need_locks=$enable_libtool_lock ])# _LT_ENABLE_LOCK # _LT_PROG_AR # ----------- m4_defun([_LT_PROG_AR], [AC_CHECK_TOOLS(AR, [ar], false) : ${AR=ar} _LT_DECL([], [AR], [1], [The archiver]) # Use ARFLAGS variable as AR's operation code to sync the variable naming with # Automake. If both AR_FLAGS and ARFLAGS are specified, AR_FLAGS should have # higher priority because thats what people were doing historically (setting # ARFLAGS for automake and AR_FLAGS for libtool). FIXME: Make the AR_FLAGS # variable obsoleted/removed. test ${AR_FLAGS+y} || AR_FLAGS=${ARFLAGS-cr} lt_ar_flags=$AR_FLAGS _LT_DECL([], [lt_ar_flags], [0], [Flags to create an archive (by configure)]) # Make AR_FLAGS overridable by 'make ARFLAGS='. Don't try to run-time override # by AR_FLAGS because that was never working and AR_FLAGS is about to die. _LT_DECL([], [AR_FLAGS], [\@S|@{ARFLAGS-"\@S|@lt_ar_flags"}], [Flags to create an archive]) AC_CACHE_CHECK([for archiver @FILE support], [lt_cv_ar_at_file], [lt_cv_ar_at_file=no AC_COMPILE_IFELSE([AC_LANG_PROGRAM], [echo conftest.$ac_objext > conftest.lst lt_ar_try='$AR $AR_FLAGS libconftest.a @conftest.lst >&AS_MESSAGE_LOG_FD' AC_TRY_EVAL([lt_ar_try]) if test 0 -eq "$ac_status"; then # Ensure the archiver fails upon bogus file names. rm -f conftest.$ac_objext libconftest.a AC_TRY_EVAL([lt_ar_try]) if test 0 -ne "$ac_status"; then lt_cv_ar_at_file=@ fi fi rm -f conftest.* libconftest.a ]) ]) if test no = "$lt_cv_ar_at_file"; then archiver_list_spec= else archiver_list_spec=$lt_cv_ar_at_file fi _LT_DECL([], [archiver_list_spec], [1], [How to feed a file listing to the archiver]) ])# _LT_PROG_AR # _LT_CMD_OLD_ARCHIVE # ------------------- m4_defun([_LT_CMD_OLD_ARCHIVE], [_LT_PROG_AR AC_CHECK_TOOL(STRIP, strip, :) test -z "$STRIP" && STRIP=: _LT_DECL([], [STRIP], [1], [A symbol stripping program]) AC_CHECK_TOOL(RANLIB, ranlib, :) test -z "$RANLIB" && RANLIB=: _LT_DECL([], [RANLIB], [1], [Commands used to install an old-style archive]) # Determine commands to create old-style static archives. old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs' old_postinstall_cmds='chmod 644 $oldlib' old_postuninstall_cmds= if test -n "$RANLIB"; then case $host_os in bitrig* | openbsd*) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib" ;; *) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$tool_oldlib" ;; esac old_archive_cmds="$old_archive_cmds~\$RANLIB \$tool_oldlib" fi case $host_os in darwin*) lock_old_archive_extraction=yes ;; *) lock_old_archive_extraction=no ;; esac _LT_DECL([], [old_postinstall_cmds], [2]) _LT_DECL([], [old_postuninstall_cmds], [2]) _LT_TAGDECL([], [old_archive_cmds], [2], [Commands used to build an old-style archive]) _LT_DECL([], [lock_old_archive_extraction], [0], [Whether to use a lock for old archive extraction]) ])# _LT_CMD_OLD_ARCHIVE # _LT_COMPILER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, # [OUTPUT-FILE], [ACTION-SUCCESS], [ACTION-FAILURE]) # ---------------------------------------------------------------- # Check whether the given compiler option works AC_DEFUN([_LT_COMPILER_OPTION], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_SED])dnl AC_CACHE_CHECK([$1], [$2], [$2=no m4_if([$4], , [ac_outfile=conftest.$ac_objext], [ac_outfile=$4]) echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="$3" ## exclude from sc_useless_quotes_in_assignment # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&AS_MESSAGE_LOG_FD echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then $2=yes fi fi $RM conftest* ]) if test yes = "[$]$2"; then m4_if([$5], , :, [$5]) else m4_if([$6], , :, [$6]) fi ])# _LT_COMPILER_OPTION # Old name: AU_ALIAS([AC_LIBTOOL_COMPILER_OPTION], [_LT_COMPILER_OPTION]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_COMPILER_OPTION], []) # _LT_LINKER_OPTION(MESSAGE, VARIABLE-NAME, FLAGS, # [ACTION-SUCCESS], [ACTION-FAILURE]) # ---------------------------------------------------- # Check whether the given linker option works AC_DEFUN([_LT_LINKER_OPTION], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_SED])dnl AC_CACHE_CHECK([$1], [$2], [$2=no save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS $3" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&AS_MESSAGE_LOG_FD $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then $2=yes fi else $2=yes fi fi $RM -r conftest* LDFLAGS=$save_LDFLAGS ]) if test yes = "[$]$2"; then m4_if([$4], , :, [$4]) else m4_if([$5], , :, [$5]) fi ])# _LT_LINKER_OPTION # Old name: AU_ALIAS([AC_LIBTOOL_LINKER_OPTION], [_LT_LINKER_OPTION]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_LINKER_OPTION], []) # LT_CMD_MAX_LEN #--------------- AC_DEFUN([LT_CMD_MAX_LEN], [AC_REQUIRE([AC_CANONICAL_HOST])dnl # find the maximum length of command line arguments AC_MSG_CHECKING([the maximum length of command line arguments]) AC_CACHE_VAL([lt_cv_sys_max_cmd_len], [dnl i=0 teststring=ABCD case $build_os in msdosdjgpp*) # On DJGPP, this test can blow up pretty badly due to problems in libc # (any single argument exceeding 2000 bytes causes a buffer overrun # during glob expansion). Even if it were fixed, the result of this # check would be larger than it should be. lt_cv_sys_max_cmd_len=12288; # 12K is about right ;; gnu*) # Under GNU Hurd, this test is not required because there is # no limit to the length of command line arguments. # Libtool will interpret -1 as no limit whatsoever lt_cv_sys_max_cmd_len=-1; ;; cygwin* | mingw* | cegcc*) # On Win9x/ME, this test blows up -- it succeeds, but takes # about 5 minutes as the teststring grows exponentially. # Worse, since 9x/ME are not pre-emptively multitasking, # you end up with a "frozen" computer, even though with patience # the test eventually succeeds (with a max line length of 256k). # Instead, let's just punt: use the minimum linelength reported by # all of the supported platforms: 8192 (on NT/2K/XP). lt_cv_sys_max_cmd_len=8192; ;; mint*) # On MiNT this can take a long time and run out of memory. lt_cv_sys_max_cmd_len=8192; ;; amigaos*) # On AmigaOS with pdksh, this test takes hours, literally. # So we just punt and use a minimum line length of 8192. lt_cv_sys_max_cmd_len=8192; ;; bitrig* | darwin* | dragonfly* | freebsd* | midnightbsd* | netbsd* | openbsd*) # This has been around since 386BSD, at least. Likely further. if test -x /sbin/sysctl; then lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` elif test -x /usr/sbin/sysctl; then lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` else lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs fi # And add a safety zone lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` ;; interix*) # We know the value 262144 and hardcode it with a safety zone (like BSD) lt_cv_sys_max_cmd_len=196608 ;; os2*) # The test takes a long time on OS/2. lt_cv_sys_max_cmd_len=8192 ;; osf*) # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not # nice to cause kernel panics so lets avoid the loop below. # First set a reasonable default. lt_cv_sys_max_cmd_len=16384 # if test -x /sbin/sysconfig; then case `/sbin/sysconfig -q proc exec_disable_arg_limit` in *1*) lt_cv_sys_max_cmd_len=-1 ;; esac fi ;; sco3.2v5*) lt_cv_sys_max_cmd_len=102400 ;; sysv5* | sco5v6* | sysv4.2uw2*) kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` if test -n "$kargmax"; then lt_cv_sys_max_cmd_len=`echo $kargmax | $SED 's/.*[[ ]]//'` else lt_cv_sys_max_cmd_len=32768 fi ;; *) lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` if test -n "$lt_cv_sys_max_cmd_len" && \ test undefined != "$lt_cv_sys_max_cmd_len"; then lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` else # Make teststring a little bigger before we do anything with it. # a 1K string should be a reasonable start. for i in 1 2 3 4 5 6 7 8; do teststring=$teststring$teststring done SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} # If test is not a shell built-in, we'll probably end up computing a # maximum length that is only half of the actual maximum length, but # we can't tell. while { test X`env echo "$teststring$teststring" 2>/dev/null` \ = "X$teststring$teststring"; } >/dev/null 2>&1 && test 17 != "$i" # 1/2 MB should be enough do i=`expr $i + 1` teststring=$teststring$teststring done # Only check the string length outside the loop. lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1` teststring= # Add a significant safety factor because C++ compilers can tack on # massive amounts of additional arguments before passing them to the # linker. It appears as though 1/2 is a usable value. lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` fi ;; esac ]) if test -n "$lt_cv_sys_max_cmd_len"; then AC_MSG_RESULT($lt_cv_sys_max_cmd_len) else AC_MSG_RESULT(none) fi max_cmd_len=$lt_cv_sys_max_cmd_len _LT_DECL([], [max_cmd_len], [0], [What is the maximum length of a command?]) ])# LT_CMD_MAX_LEN # Old name: AU_ALIAS([AC_LIBTOOL_SYS_MAX_CMD_LEN], [LT_CMD_MAX_LEN]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_SYS_MAX_CMD_LEN], []) # _LT_HEADER_DLFCN # ---------------- m4_defun([_LT_HEADER_DLFCN], [AC_CHECK_HEADERS([dlfcn.h], [], [], [AC_INCLUDES_DEFAULT])dnl ])# _LT_HEADER_DLFCN # _LT_TRY_DLOPEN_SELF (ACTION-IF-TRUE, ACTION-IF-TRUE-W-USCORE, # ACTION-IF-FALSE, ACTION-IF-CROSS-COMPILING) # ---------------------------------------------------------------- m4_defun([_LT_TRY_DLOPEN_SELF], [m4_require([_LT_HEADER_DLFCN])dnl if test yes = "$cross_compiling"; then : [$4] else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF [#line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisibility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; }] _LT_EOF if AC_TRY_EVAL(ac_link) && test -s "conftest$ac_exeext" 2>/dev/null; then (./conftest; exit; ) >&AS_MESSAGE_LOG_FD 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) $1 ;; x$lt_dlneed_uscore) $2 ;; x$lt_dlunknown|x*) $3 ;; esac else : # compilation failed $3 fi fi rm -fr conftest* ])# _LT_TRY_DLOPEN_SELF # LT_SYS_DLOPEN_SELF # ------------------ AC_DEFUN([LT_SYS_DLOPEN_SELF], [m4_require([_LT_HEADER_DLFCN])dnl if test yes != "$enable_dlopen"; then enable_dlopen=unknown enable_dlopen_self=unknown enable_dlopen_self_static=unknown else lt_cv_dlopen=no lt_cv_dlopen_libs= case $host_os in beos*) lt_cv_dlopen=load_add_on lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ;; mingw* | pw32* | cegcc*) lt_cv_dlopen=LoadLibrary lt_cv_dlopen_libs= ;; cygwin*) lt_cv_dlopen=dlopen lt_cv_dlopen_libs= ;; darwin*) # if libdl is installed we need to link against it AC_CHECK_LIB([dl], [dlopen], [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl],[ lt_cv_dlopen=dyld lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ]) ;; tpf*) # Don't try to run any link tests for TPF. We know it's impossible # because TPF is a cross-compiler, and we know how we open DSOs. lt_cv_dlopen=dlopen lt_cv_dlopen_libs= lt_cv_dlopen_self=no ;; *) AC_CHECK_FUNC([shl_load], [lt_cv_dlopen=shl_load], [AC_CHECK_LIB([dld], [shl_load], [lt_cv_dlopen=shl_load lt_cv_dlopen_libs=-ldld], [AC_CHECK_FUNC([dlopen], [lt_cv_dlopen=dlopen], [AC_CHECK_LIB([dl], [dlopen], [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl], [AC_CHECK_LIB([svld], [dlopen], [lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-lsvld], [AC_CHECK_LIB([dld], [dld_link], [lt_cv_dlopen=dld_link lt_cv_dlopen_libs=-ldld]) ]) ]) ]) ]) ]) ;; esac if test no = "$lt_cv_dlopen"; then enable_dlopen=no else enable_dlopen=yes fi case $lt_cv_dlopen in dlopen) save_CPPFLAGS=$CPPFLAGS test yes = "$ac_cv_header_dlfcn_h" && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" save_LDFLAGS=$LDFLAGS wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" save_LIBS=$LIBS LIBS="$lt_cv_dlopen_libs $LIBS" AC_CACHE_CHECK([whether a program can dlopen itself], lt_cv_dlopen_self, [dnl _LT_TRY_DLOPEN_SELF( lt_cv_dlopen_self=yes, lt_cv_dlopen_self=yes, lt_cv_dlopen_self=no, lt_cv_dlopen_self=cross) ]) if test yes = "$lt_cv_dlopen_self"; then wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" AC_CACHE_CHECK([whether a statically linked program can dlopen itself], lt_cv_dlopen_self_static, [dnl _LT_TRY_DLOPEN_SELF( lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=yes, lt_cv_dlopen_self_static=no, lt_cv_dlopen_self_static=cross) ]) fi CPPFLAGS=$save_CPPFLAGS LDFLAGS=$save_LDFLAGS LIBS=$save_LIBS ;; esac case $lt_cv_dlopen_self in yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; *) enable_dlopen_self=unknown ;; esac case $lt_cv_dlopen_self_static in yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; *) enable_dlopen_self_static=unknown ;; esac fi _LT_DECL([dlopen_support], [enable_dlopen], [0], [Whether dlopen is supported]) _LT_DECL([dlopen_self], [enable_dlopen_self], [0], [Whether dlopen of programs is supported]) _LT_DECL([dlopen_self_static], [enable_dlopen_self_static], [0], [Whether dlopen of statically linked programs is supported]) ])# LT_SYS_DLOPEN_SELF # Old name: AU_ALIAS([AC_LIBTOOL_DLOPEN_SELF], [LT_SYS_DLOPEN_SELF]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_DLOPEN_SELF], []) # _LT_COMPILER_C_O([TAGNAME]) # --------------------------- # Check to see if options -c and -o are simultaneously supported by compiler. # This macro does not hard code the compiler like AC_PROG_CC_C_O. m4_defun([_LT_COMPILER_C_O], [m4_require([_LT_DECL_SED])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_TAG_COMPILER])dnl AC_CACHE_CHECK([if $compiler supports -c -o file.$ac_objext], [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)], [_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [[^ ]]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&AS_MESSAGE_LOG_FD echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then _LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes fi fi chmod u+w . 2>&AS_MESSAGE_LOG_FD $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* ]) _LT_TAGDECL([compiler_c_o], [lt_cv_prog_compiler_c_o], [1], [Does compiler simultaneously support -c and -o options?]) ])# _LT_COMPILER_C_O # _LT_COMPILER_FILE_LOCKS([TAGNAME]) # ---------------------------------- # Check to see if we can do hard links to lock some files if needed m4_defun([_LT_COMPILER_FILE_LOCKS], [m4_require([_LT_ENABLE_LOCK])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl _LT_COMPILER_C_O([$1]) hard_links=nottested if test no = "$_LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)" && test no != "$need_locks"; then # do not overwrite the value of need_locks provided by the user AC_MSG_CHECKING([if we can lock with hard links]) hard_links=yes $RM conftest* ln conftest.a conftest.b 2>/dev/null && hard_links=no touch conftest.a ln conftest.a conftest.b 2>&5 || hard_links=no ln conftest.a conftest.b 2>/dev/null && hard_links=no AC_MSG_RESULT([$hard_links]) if test no = "$hard_links"; then AC_MSG_WARN(['$CC' does not support '-c -o', so 'make -j' may be unsafe]) need_locks=warn fi else need_locks=no fi _LT_DECL([], [need_locks], [1], [Must we lock files when doing compilation?]) ])# _LT_COMPILER_FILE_LOCKS # _LT_CHECK_OBJDIR # ---------------- m4_defun([_LT_CHECK_OBJDIR], [AC_CACHE_CHECK([for objdir], [lt_cv_objdir], [rm -f .libs 2>/dev/null mkdir .libs 2>/dev/null if test -d .libs; then lt_cv_objdir=.libs else # MS-DOS does not allow filenames that begin with a dot. lt_cv_objdir=_libs fi rmdir .libs 2>/dev/null]) objdir=$lt_cv_objdir _LT_DECL([], [objdir], [0], [The name of the directory that contains temporary libtool files])dnl m4_pattern_allow([LT_OBJDIR])dnl AC_DEFINE_UNQUOTED([LT_OBJDIR], "$lt_cv_objdir/", [Define to the sub-directory where libtool stores uninstalled libraries.]) ])# _LT_CHECK_OBJDIR # _LT_LINKER_HARDCODE_LIBPATH([TAGNAME]) # -------------------------------------- # Check hardcoding attributes. m4_defun([_LT_LINKER_HARDCODE_LIBPATH], [AC_MSG_CHECKING([how to hardcode library paths into programs]) _LT_TAGVAR(hardcode_action, $1)= if test -n "$_LT_TAGVAR(hardcode_libdir_flag_spec, $1)" || test -n "$_LT_TAGVAR(runpath_var, $1)" || test yes = "$_LT_TAGVAR(hardcode_automatic, $1)"; then # We can hardcode non-existent directories. if test no != "$_LT_TAGVAR(hardcode_direct, $1)" && # If the only mechanism to avoid hardcoding is shlibpath_var, we # have to relink, otherwise we might link with an installed library # when we should be linking with a yet-to-be-installed one ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, $1)" && test no != "$_LT_TAGVAR(hardcode_minus_L, $1)"; then # Linking always hardcodes the temporary library directory. _LT_TAGVAR(hardcode_action, $1)=relink else # We can link without hardcoding, and we can hardcode nonexisting dirs. _LT_TAGVAR(hardcode_action, $1)=immediate fi else # We cannot hardcode anything, or else we can only hardcode existing # directories. _LT_TAGVAR(hardcode_action, $1)=unsupported fi AC_MSG_RESULT([$_LT_TAGVAR(hardcode_action, $1)]) if test relink = "$_LT_TAGVAR(hardcode_action, $1)" || test yes = "$_LT_TAGVAR(inherit_rpath, $1)"; then # Fast installation is not supported enable_fast_install=no elif test yes = "$shlibpath_overrides_runpath" || test no = "$enable_shared"; then # Fast installation is not necessary enable_fast_install=needless fi _LT_TAGDECL([], [hardcode_action], [0], [How to hardcode a shared library path into an executable]) ])# _LT_LINKER_HARDCODE_LIBPATH # _LT_CMD_STRIPLIB # ---------------- m4_defun([_LT_CMD_STRIPLIB], [m4_require([_LT_DECL_EGREP]) striplib= old_striplib= AC_MSG_CHECKING([whether stripping libraries is possible]) if test -z "$STRIP"; then AC_MSG_RESULT([no]) else if $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then old_striplib="$STRIP --strip-debug" striplib="$STRIP --strip-unneeded" AC_MSG_RESULT([yes]) else case $host_os in darwin*) # FIXME - insert some real tests, host_os isn't really good enough striplib="$STRIP -x" old_striplib="$STRIP -S" AC_MSG_RESULT([yes]) ;; freebsd*) if $STRIP -V 2>&1 | $GREP "elftoolchain" >/dev/null; then old_striplib="$STRIP --strip-debug" striplib="$STRIP --strip-unneeded" AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) fi ;; *) AC_MSG_RESULT([no]) ;; esac fi fi _LT_DECL([], [old_striplib], [1], [Commands to strip libraries]) _LT_DECL([], [striplib], [1]) ])# _LT_CMD_STRIPLIB # _LT_PREPARE_MUNGE_PATH_LIST # --------------------------- # Make sure func_munge_path_list() is defined correctly. m4_defun([_LT_PREPARE_MUNGE_PATH_LIST], [[# func_munge_path_list VARIABLE PATH # ----------------------------------- # VARIABLE is name of variable containing _space_ separated list of # directories to be munged by the contents of PATH, which is string # having a format: # "DIR[:DIR]:" # string "DIR[ DIR]" will be prepended to VARIABLE # ":DIR[:DIR]" # string "DIR[ DIR]" will be appended to VARIABLE # "DIRP[:DIRP]::[DIRA:]DIRA" # string "DIRP[ DIRP]" will be prepended to VARIABLE and string # "DIRA[ DIRA]" will be appended to VARIABLE # "DIR[:DIR]" # VARIABLE will be replaced by "DIR[ DIR]" func_munge_path_list () { case x@S|@2 in x) ;; *:) eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'` \@S|@@S|@1\" ;; x:*) eval @S|@1=\"\@S|@@S|@1 `$ECHO @S|@2 | $SED 's/:/ /g'`\" ;; *::*) eval @S|@1=\"\@S|@@S|@1\ `$ECHO @S|@2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" eval @S|@1=\"`$ECHO @S|@2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \@S|@@S|@1\" ;; *) eval @S|@1=\"`$ECHO @S|@2 | $SED 's/:/ /g'`\" ;; esac } ]])# _LT_PREPARE_PATH_LIST # _LT_SYS_DYNAMIC_LINKER([TAG]) # ----------------------------- # PORTME Fill in your ld.so characteristics m4_defun([_LT_SYS_DYNAMIC_LINKER], [AC_REQUIRE([AC_CANONICAL_HOST])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_OBJDUMP])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_CHECK_SHELL_FEATURES])dnl m4_require([_LT_PREPARE_MUNGE_PATH_LIST])dnl AC_MSG_CHECKING([dynamic linker characteristics]) m4_if([$1], [], [ if test yes = "$GCC"; then case $host_os in darwin*) lt_awk_arg='/^libraries:/,/LR/' ;; *) lt_awk_arg='/^libraries:/' ;; esac case $host_os in mingw* | cegcc*) lt_sed_strip_eq='s|=\([[A-Za-z]]:\)|\1|g' ;; *) lt_sed_strip_eq='s|=/|/|g' ;; esac lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq` case $lt_search_path_spec in *\;*) # if the path contains ";" then we assume it to be the separator # otherwise default to the standard path separator (i.e. ":") - it is # assumed that no part of a normal pathname contains ";" but that should # okay in the real world where ";" in dirpaths is itself problematic. lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED 's/;/ /g'` ;; *) lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED "s/$PATH_SEPARATOR/ /g"` ;; esac # Ok, now we have the path, separated by spaces, we can step through it # and add multilib dir if necessary... lt_tmp_lt_search_path_spec= lt_multi_os_dir=/`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` # ...but if some path component already ends with the multilib dir we assume # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer). case "$lt_multi_os_dir; $lt_search_path_spec " in "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*) lt_multi_os_dir= ;; esac for lt_sys_path in $lt_search_path_spec; do if test -d "$lt_sys_path$lt_multi_os_dir"; then lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path$lt_multi_os_dir" elif test -n "$lt_multi_os_dir"; then test -d "$lt_sys_path" && \ lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" fi done lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk ' BEGIN {RS = " "; FS = "/|\n";} { lt_foo = ""; lt_count = 0; for (lt_i = NF; lt_i > 0; lt_i--) { if ($lt_i != "" && $lt_i != ".") { if ($lt_i == "..") { lt_count++; } else { if (lt_count == 0) { lt_foo = "/" $lt_i lt_foo; } else { lt_count--; } } } } if (lt_foo != "") { lt_freq[[lt_foo]]++; } if (lt_freq[[lt_foo]] == 1) { print lt_foo; } }'` # AWK program above erroneously prepends '/' to C:/dos/paths # for these hosts. case $host_os in mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\ $SED 's|/\([[A-Za-z]]:\)|\1|g'` ;; esac sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP` else sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" fi]) library_names_spec= libname_spec='lib$name' soname_spec= shrext_cmds=.so postinstall_cmds= postuninstall_cmds= finish_cmds= finish_eval= shlibpath_var= shlibpath_overrides_runpath=unknown version_type=none dynamic_linker="$host_os ld.so" sys_lib_dlsearch_path_spec="/lib /usr/lib" need_lib_prefix=unknown hardcode_into_libs=no # when you set need_version to no, make sure it does not cause -set_version # flags to be left without arguments need_version=unknown AC_ARG_VAR([LT_SYS_LIBRARY_PATH], [User-defined run-time library search path.]) case $host_os in aix3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname.a' shlibpath_var=LIBPATH # AIX 3 has no versioning support, so we append a major version to the name. soname_spec='$libname$release$shared_ext$major' ;; aix[[4-9]]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no hardcode_into_libs=yes if test ia64 = "$host_cpu"; then # AIX 5 supports IA64 library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH else # With GCC up to 2.95.x, collect2 would create an import file # for dependence libraries. The import file would start with # the line '#! .'. This would cause the generated library to # depend on '.', always an invalid library. This was fixed in # development snapshots of GCC prior to 3.0. case $host_os in aix4 | aix4.[[01]] | aix4.[[01]].*) if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' echo ' yes ' echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then : else can_build_shared=no fi ;; esac # Using Import Files as archive members, it is possible to support # filename-based versioning of shared library archives on AIX. While # this would work for both with and without runtime linking, it will # prevent static linking of such archives. So we do filename-based # shared library versioning with .so extension only, which is used # when both runtime linking and shared linking is enabled. # Unfortunately, runtime linking may impact performance, so we do # not want this to be the default eventually. Also, we use the # versioned .so libs for executables only if there is the -brtl # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only. # To allow for filename-based versioning support, we need to create # libNAME.so.V as an archive file, containing: # *) an Import File, referring to the versioned filename of the # archive as well as the shared archive member, telling the # bitwidth (32 or 64) of that shared object, and providing the # list of exported symbols of that shared object, eventually # decorated with the 'weak' keyword # *) the shared object with the F_LOADONLY flag set, to really avoid # it being seen by the linker. # At run time we better use the real file rather than another symlink, # but for link time we create the symlink libNAME.so -> libNAME.so.V case $with_aix_soname,$aix_use_runtimelinking in # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct # soname into executable. Probably we can add versioning support to # collect2, so additional links can be useful in future. aix,yes) # traditional libtool dynamic_linker='AIX unversionable lib.so' # If using run time linking (on AIX 4.2 or later) use lib.so # instead of lib.a to let people know that these are not # typical AIX shared libraries. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; aix,no) # traditional AIX only dynamic_linker='AIX lib.a[(]lib.so.V[)]' # We preserve .a as extension for shared libraries through AIX4.2 # and later when we are not doing run time linking. library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' ;; svr4,*) # full svr4 only dynamic_linker="AIX lib.so.V[(]$shared_archive_member_spec.o[)]" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,yes) # both, prefer svr4 dynamic_linker="AIX lib.so.V[(]$shared_archive_member_spec.o[)], lib.a[(]lib.so.V[)]" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # unpreferred sharedlib libNAME.a needs extra handling postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"' postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,no) # both, prefer aix dynamic_linker="AIX lib.a[(]lib.so.V[)], lib.so.V[(]$shared_archive_member_spec.o[)]" library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)' postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"' ;; esac shlibpath_var=LIBPATH fi ;; amigaos*) case $host_cpu in powerpc) # Since July 2007 AmigaOS4 officially supports .so libraries. # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; m68k) library_names_spec='$libname.ixlibrary $libname.a' # Create ${libname}_ixlibrary.a entries in /sys/libs. finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([[^/]]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' ;; esac ;; beos*) library_names_spec='$libname$shared_ext' dynamic_linker="$host_os ld.so" shlibpath_var=LIBRARY_PATH ;; bsdi[[45]]*) version_type=linux # correct to gnu/linux during the next big refactor need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" # the default ld.so.conf also contains /usr/contrib/lib and # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow # libtool to hard-code these into programs ;; cygwin* | mingw* | pw32* | cegcc*) version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no case $GCC,$cc_basename in yes,*) # gcc library_names_spec='$libname.dll.a' # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes case $host_os in cygwin*) # Cygwin DLLs use 'cyg' prefix rather than 'lib' soname_spec='`echo $libname | $SED -e 's/^lib/cyg/'``echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' m4_if([$1], [],[ sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api"]) ;; mingw* | cegcc*) # MinGW DLLs use traditional 'lib' prefix soname_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' ;; pw32*) # pw32 DLLs use 'pw' prefix rather than 'lib' library_names_spec='`echo $libname | $SED -e 's/^lib/pw/'``echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' ;; esac dynamic_linker='Win32 ld.exe' ;; *,cl* | *,icl*) # Native MSVC or ICC libname_spec='$name' soname_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext' library_names_spec='$libname.dll.lib' case $build_os in mingw*) sys_lib_search_path_spec= lt_save_ifs=$IFS IFS=';' for lt_path in $LIB do IFS=$lt_save_ifs # Let DOS variable expansion print the short 8.3 style file name. lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" done IFS=$lt_save_ifs # Convert to MSYS style. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's|\\\\|/|g' -e 's| \\([[a-zA-Z]]\\):| /\\1|g' -e 's|^ ||'` ;; cygwin*) # Convert to unix form, then to dos form, then back to unix form # but this time dos style (no spaces!) so that the unix form looks # like /cygdrive/c/PROGRA~1:/cygdr... sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` ;; *) sys_lib_search_path_spec=$LIB if $ECHO "$sys_lib_search_path_spec" | [$GREP ';[c-zC-Z]:/' >/dev/null]; then # It is most probably a Windows format PATH. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` else sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` fi # FIXME: find the short name or the path components, as spaces are # common. (e.g. "Program Files" -> "PROGRA~1") ;; esac # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes dynamic_linker='Win32 link.exe' ;; *) # Assume MSVC and ICC wrapper library_names_spec='$libname`echo $release | $SED -e 's/[[.]]/-/g'`$versuffix$shared_ext $libname.lib' dynamic_linker='Win32 ld.exe' ;; esac # FIXME: first we should search . and the directory the executable is in shlibpath_var=PATH ;; darwin* | rhapsody*) dynamic_linker="$host_os dyld" version_type=darwin need_lib_prefix=no need_version=no library_names_spec='$libname$release$major$shared_ext $libname$shared_ext' soname_spec='$libname$release$major$shared_ext' shlibpath_overrides_runpath=yes shlibpath_var=DYLD_LIBRARY_PATH shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' m4_if([$1], [],[ sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib"]) sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' ;; dgux*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; freebsd* | dragonfly* | midnightbsd*) # DragonFly does not have aout. When/if they implement a new # versioning mechanism, adjust this. if test -x /usr/bin/objformat; then objformat=`/usr/bin/objformat` else case $host_os in freebsd[[23]].*) objformat=aout ;; *) objformat=elf ;; esac fi version_type=freebsd-$objformat case $version_type in freebsd-elf*) library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' need_version=no need_lib_prefix=no ;; freebsd-*) library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' need_version=yes ;; esac shlibpath_var=LD_LIBRARY_PATH case $host_os in freebsd2.*) shlibpath_overrides_runpath=yes ;; freebsd3.[[01]]* | freebsdelf3.[[01]]*) shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; freebsd3.[[2-9]]* | freebsdelf3.[[2-9]]* | \ freebsd4.[[0-5]] | freebsdelf4.[[0-5]] | freebsd4.1.1 | freebsdelf4.1.1) shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; *) # from 4.6 on, and DragonFly shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; esac ;; haiku*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no dynamic_linker="$host_os runtime_loader" library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LIBRARY_PATH shlibpath_overrides_runpath=no sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' hardcode_into_libs=yes ;; hpux9* | hpux10* | hpux11*) # Give a soname corresponding to the major version so that dld.sl refuses to # link against other versions. version_type=sunos need_lib_prefix=no need_version=no case $host_cpu in ia64*) shrext_cmds='.so' hardcode_into_libs=yes dynamic_linker="$host_os dld.so" shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' if test 32 = "$HPUX_IA64_MODE"; then sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" sys_lib_dlsearch_path_spec=/usr/lib/hpux32 else sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" sys_lib_dlsearch_path_spec=/usr/lib/hpux64 fi ;; hppa*64*) shrext_cmds='.sl' hardcode_into_libs=yes dynamic_linker="$host_os dld.sl" shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; *) shrext_cmds='.sl' dynamic_linker="$host_os dld.sl" shlibpath_var=SHLIB_PATH shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' ;; esac # HP-UX runs *really* slowly unless shared libraries are mode 555, ... postinstall_cmds='chmod 555 $lib' # or fails outright, so override atomically: install_override_mode=555 ;; interix[[3-9]]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; irix5* | irix6* | nonstopux*) case $host_os in nonstopux*) version_type=nonstopux ;; *) if test yes = "$lt_cv_prog_gnu_ld"; then version_type=linux # correct to gnu/linux during the next big refactor else version_type=irix fi ;; esac need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext' case $host_os in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in # libtool.m4 will add one of these switches to LD *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= libmagic=32-bit;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 libmagic=N32;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 libmagic=64-bit;; *) libsuff= shlibsuff= libmagic=never-match;; esac ;; esac shlibpath_var=LD_LIBRARY${shlibsuff}_PATH shlibpath_overrides_runpath=no sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff" sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff" hardcode_into_libs=yes ;; # No shared lib support for Linux oldld, aout, or coff. linux*oldld* | linux*aout* | linux*coff*) dynamic_linker=no ;; linux*android*) version_type=none # Android doesn't support versioned libraries. need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext' soname_spec='$libname$release$shared_ext' finish_cmds= shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes dynamic_linker='Android linker' # Don't embed -rpath directories since the linker doesn't support them. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no # Some binutils ld are patched to set DT_RUNPATH AC_CACHE_VAL([lt_cv_shlibpath_overrides_runpath], [lt_cv_shlibpath_overrides_runpath=no save_LDFLAGS=$LDFLAGS save_libdir=$libdir eval "libdir=/foo; wl=\"$_LT_TAGVAR(lt_prog_compiler_wl, $1)\"; \ LDFLAGS=\"\$LDFLAGS $_LT_TAGVAR(hardcode_libdir_flag_spec, $1)\"" AC_LINK_IFELSE([AC_LANG_PROGRAM([],[])], [AS_IF([ ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null], [lt_cv_shlibpath_overrides_runpath=yes])]) LDFLAGS=$save_LDFLAGS libdir=$save_libdir ]) shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes # Add ABI-specific directories to the system library path. sys_lib_dlsearch_path_spec="/lib64 /usr/lib64 /lib /usr/lib" # Ideally, we could use ldconfig to report *all* directores which are # searched for libraries, however this is still not possible. Aside from not # being certain /sbin/ldconfig is available, command # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64, # even though it is searched at run-time. Try to do the best guess by # appending ld.so.conf contents (and includes) to the search path. if test -f /etc/ld.so.conf; then lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \[$]2)); skip = 1; } { if (!skip) print \[$]0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` sys_lib_dlsearch_path_spec="$sys_lib_dlsearch_path_spec $lt_ld_extra" fi # We used to test for /lib/ld.so.1 and disable shared libraries on # powerpc, because MkLinux only supported shared libraries with the # GNU dynamic linker. Since this was broken with cross compilers, # most powerpc-linux boxes support dynamic linking these days and # people can always --disable-shared, the test was removed, and we # assume the GNU/Linux dynamic linker is in use. dynamic_linker='GNU/Linux ld.so' ;; netbsd*) version_type=sunos need_lib_prefix=no need_version=no if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' dynamic_linker='NetBSD (a.out) ld.so' else library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='NetBSD ld.elf_so' fi shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; newsos6) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; *nto* | *qnx*) version_type=qnx need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='ldqnx.so' ;; openbsd* | bitrig*) version_type=sunos sys_lib_dlsearch_path_spec=/usr/lib need_lib_prefix=no if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then need_version=no else need_version=yes fi library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; os2*) libname_spec='$name' version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no # OS/2 can only load a DLL with a base name of 8 characters or less. soname_spec='`test -n "$os2dllname" && libname="$os2dllname"; v=$($ECHO $release$versuffix | tr -d .-); n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _); $ECHO $n$v`$shared_ext' library_names_spec='${libname}_dll.$libext' dynamic_linker='OS/2 ld.exe' shlibpath_var=BEGINLIBPATH sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' ;; osf3* | osf4* | osf5*) version_type=osf need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; rdos*) dynamic_linker=no ;; solaris*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes # ldd complains unless libraries are executable postinstall_cmds='chmod +x $lib' ;; sunos4*) version_type=sunos library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes if test yes = "$with_gnu_ld"; then need_lib_prefix=no fi need_version=yes ;; sysv4 | sysv4.3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH case $host_vendor in sni) shlibpath_overrides_runpath=no need_lib_prefix=no runpath_var=LD_RUN_PATH ;; siemens) need_lib_prefix=no ;; motorola) need_lib_prefix=no need_version=no shlibpath_overrides_runpath=no sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' ;; esac ;; sysv4*MP*) if test -d /usr/nec; then version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext' soname_spec='$libname$shared_ext.$major' shlibpath_var=LD_LIBRARY_PATH fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) version_type=sco need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes if test yes = "$with_gnu_ld"; then sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' else sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' case $host_os in sco3.2v5*) sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" ;; esac fi sys_lib_dlsearch_path_spec='/usr/lib' ;; tpf*) # TPF is a cross-target only. Preferred cross-host = GNU/Linux. version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; uts4*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; *) dynamic_linker=no ;; esac AC_MSG_RESULT([$dynamic_linker]) test no = "$dynamic_linker" && can_build_shared=no variables_saved_for_relink="PATH $shlibpath_var $runpath_var" if test yes = "$GCC"; then variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" fi if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec fi if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec fi # remember unaugmented sys_lib_dlsearch_path content for libtool script decls... configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec # ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH" # to be used as default LT_SYS_LIBRARY_PATH value in generated libtool configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH _LT_DECL([], [variables_saved_for_relink], [1], [Variables whose values should be saved in libtool wrapper scripts and restored at link time]) _LT_DECL([], [need_lib_prefix], [0], [Do we need the "lib" prefix for modules?]) _LT_DECL([], [need_version], [0], [Do we need a version for libraries?]) _LT_DECL([], [version_type], [0], [Library versioning type]) _LT_DECL([], [runpath_var], [0], [Shared library runtime path variable]) _LT_DECL([], [shlibpath_var], [0],[Shared library path variable]) _LT_DECL([], [shlibpath_overrides_runpath], [0], [Is shlibpath searched before the hard-coded library search path?]) _LT_DECL([], [libname_spec], [1], [Format of library name prefix]) _LT_DECL([], [library_names_spec], [1], [[List of archive names. First name is the real one, the rest are links. The last name is the one that the linker finds with -lNAME]]) _LT_DECL([], [soname_spec], [1], [[The coded name of the library, if different from the real name]]) _LT_DECL([], [install_override_mode], [1], [Permission mode override for installation of shared libraries]) _LT_DECL([], [postinstall_cmds], [2], [Command to use after installation of a shared archive]) _LT_DECL([], [postuninstall_cmds], [2], [Command to use after uninstallation of a shared archive]) _LT_DECL([], [finish_cmds], [2], [Commands used to finish a libtool library installation in a directory]) _LT_DECL([], [finish_eval], [1], [[As "finish_cmds", except a single script fragment to be evaled but not shown]]) _LT_DECL([], [hardcode_into_libs], [0], [Whether we should hardcode library paths into libraries]) _LT_DECL([], [sys_lib_search_path_spec], [2], [Compile-time system search path for libraries]) _LT_DECL([sys_lib_dlsearch_path_spec], [configure_time_dlsearch_path], [2], [Detected run-time system search path for libraries]) _LT_DECL([], [configure_time_lt_sys_library_path], [2], [Explicit LT_SYS_LIBRARY_PATH set during ./configure time]) ])# _LT_SYS_DYNAMIC_LINKER # _LT_PATH_TOOL_PREFIX(TOOL) # -------------------------- # find a file program that can recognize shared library AC_DEFUN([_LT_PATH_TOOL_PREFIX], [m4_require([_LT_DECL_EGREP])dnl AC_MSG_CHECKING([for $1]) AC_CACHE_VAL(lt_cv_path_MAGIC_CMD, [case $MAGIC_CMD in [[\\/*] | ?:[\\/]*]) lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD=$MAGIC_CMD lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR dnl $ac_dummy forces splitting on constant user-supplied paths. dnl POSIX.2 word splitting is done only on the output of word expansions, dnl not every word. This closes a longstanding sh security hole. ac_dummy="m4_if([$2], , $PATH, [$2])" for ac_dir in $ac_dummy; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$1"; then lt_cv_path_MAGIC_CMD=$ac_dir/"$1" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD=$lt_cv_path_MAGIC_CMD if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS=$lt_save_ifs MAGIC_CMD=$lt_save_MAGIC_CMD ;; esac]) MAGIC_CMD=$lt_cv_path_MAGIC_CMD if test -n "$MAGIC_CMD"; then AC_MSG_RESULT($MAGIC_CMD) else AC_MSG_RESULT(no) fi _LT_DECL([], [MAGIC_CMD], [0], [Used to examine libraries when file_magic_cmd begins with "file"])dnl ])# _LT_PATH_TOOL_PREFIX # Old name: AU_ALIAS([AC_PATH_TOOL_PREFIX], [_LT_PATH_TOOL_PREFIX]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_PATH_TOOL_PREFIX], []) # _LT_PATH_MAGIC # -------------- # find a file program that can recognize a shared library m4_defun([_LT_PATH_MAGIC], [_LT_PATH_TOOL_PREFIX(${ac_tool_prefix}file, /usr/bin$PATH_SEPARATOR$PATH) if test -z "$lt_cv_path_MAGIC_CMD"; then if test -n "$ac_tool_prefix"; then _LT_PATH_TOOL_PREFIX(file, /usr/bin$PATH_SEPARATOR$PATH) else MAGIC_CMD=: fi fi ])# _LT_PATH_MAGIC # LT_PATH_LD # ---------- # find the pathname to the GNU or non-GNU linker AC_DEFUN([LT_PATH_LD], [AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_PROG_ECHO_BACKSLASH])dnl AC_ARG_WITH([gnu-ld], [AS_HELP_STRING([--with-gnu-ld], [assume the C compiler uses GNU ld @<:@default=no@:>@])], [test no = "$withval" || with_gnu_ld=yes], [with_gnu_ld=no])dnl ac_prog=ld if test yes = "$GCC"; then # Check if gcc -print-prog-name=ld gives a path. AC_MSG_CHECKING([for ld used by $CC]) case $host in *-*-mingw*) # gcc leaves a trailing carriage return, which upsets mingw ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; *) ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; esac case $ac_prog in # Accept absolute paths. [[\\/]]* | ?:[[\\/]]*) re_direlt='/[[^/]][[^/]]*/\.\./' # Canonicalize the pathname of ld ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` done test -z "$LD" && LD=$ac_prog ;; "") # If it fails, then pretend we aren't using GCC. ac_prog=ld ;; *) # If it is relative, then search for the first ld in PATH. with_gnu_ld=unknown ;; esac elif test yes = "$with_gnu_ld"; then AC_MSG_CHECKING([for GNU ld]) else AC_MSG_CHECKING([for non-GNU ld]) fi AC_CACHE_VAL(lt_cv_path_LD, [if test -z "$LD"; then lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then lt_cv_path_LD=$ac_dir/$ac_prog # Check to see if the program is GNU ld. I'd rather use --version, # but apparently some variants of GNU ld only accept -v. # Break only if it was the GNU/non-GNU ld that we prefer. case `"$lt_cv_path_LD" -v 2>&1 &1 conftest.i cat conftest.i conftest.i >conftest2.i : ${lt_DD:=$DD} AC_PATH_PROGS_FEATURE_CHECK([lt_DD], [dd], [if "$ac_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=: fi]) rm -f conftest.i conftest2.i conftest.out]) ])# _LT_PATH_DD # _LT_CMD_TRUNCATE # ---------------- # find command to truncate a binary pipe m4_defun([_LT_CMD_TRUNCATE], [m4_require([_LT_PATH_DD]) AC_CACHE_CHECK([how to truncate binary pipes], [lt_cv_truncate_bin], [printf 0123456789abcdef0123456789abcdef >conftest.i cat conftest.i conftest.i >conftest2.i lt_cv_truncate_bin= if "$ac_cv_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1" fi rm -f conftest.i conftest2.i conftest.out test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q"]) _LT_DECL([lt_truncate_bin], [lt_cv_truncate_bin], [1], [Command to truncate a binary pipe]) ])# _LT_CMD_TRUNCATE # _LT_CHECK_MAGIC_METHOD # ---------------------- # how to check for library dependencies # -- PORTME fill in with the dynamic library characteristics m4_defun([_LT_CHECK_MAGIC_METHOD], [m4_require([_LT_DECL_EGREP]) m4_require([_LT_DECL_OBJDUMP]) AC_CACHE_CHECK([how to recognize dependent libraries], lt_cv_deplibs_check_method, [lt_cv_file_magic_cmd='$MAGIC_CMD' lt_cv_file_magic_test_file= lt_cv_deplibs_check_method='unknown' # Need to set the preceding variable on all platforms that support # interlibrary dependencies. # 'none' -- dependencies not supported. # 'unknown' -- same as none, but documents that we really don't know. # 'pass_all' -- all dependencies passed with no checks. # 'test_compile' -- check by making test program. # 'file_magic [[regex]]' -- check by looking for files in library path # that responds to the $file_magic_cmd with a given extended regex. # If you have 'file' or equivalent on your system and you're not sure # whether 'pass_all' will *always* work, you probably want this one. case $host_os in aix[[4-9]]*) lt_cv_deplibs_check_method=pass_all ;; beos*) lt_cv_deplibs_check_method=pass_all ;; bsdi[[45]]*) lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib)' lt_cv_file_magic_cmd='$FILECMD -L' lt_cv_file_magic_test_file=/shlib/libc.so ;; cygwin*) # func_win32_libid is a shell function defined in ltmain.sh lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' ;; mingw* | pw32*) # Base MSYS/MinGW do not provide the 'file' command needed by # func_win32_libid shell function, so use a weaker test based on 'objdump', # unless we find 'file', for example because we are cross-compiling. if ( file / ) >/dev/null 2>&1; then lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' else # Keep this pattern in sync with the one in func_win32_libid. lt_cv_deplibs_check_method='file_magic file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' lt_cv_file_magic_cmd='$OBJDUMP -f' fi ;; cegcc*) # use the weaker test based on 'objdump'. See mingw*. lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?' lt_cv_file_magic_cmd='$OBJDUMP -f' ;; darwin* | rhapsody*) lt_cv_deplibs_check_method=pass_all ;; freebsd* | dragonfly* | midnightbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then case $host_cpu in i*86 ) # Not sure whether the presence of OpenBSD here was a mistake. # Let's accept both of them until this is cleared up. lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[[3-9]]86 (compact )?demand paged shared library' lt_cv_file_magic_cmd=$FILECMD lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` ;; esac else lt_cv_deplibs_check_method=pass_all fi ;; haiku*) lt_cv_deplibs_check_method=pass_all ;; hpux10.20* | hpux11*) lt_cv_file_magic_cmd=$FILECMD case $host_cpu in ia64*) lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|ELF-[[0-9]][[0-9]]) shared object file - IA64' lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so ;; hppa*64*) [lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF[ -][0-9][0-9])(-bit)?( [LM]SB)? shared object( file)?[, -]* PA-RISC [0-9]\.[0-9]'] lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl ;; *) lt_cv_deplibs_check_method='file_magic (s[[0-9]][[0-9]][[0-9]]|PA-RISC[[0-9]]\.[[0-9]]) shared library' lt_cv_file_magic_test_file=/usr/lib/libc.sl ;; esac ;; interix[[3-9]]*) # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|\.a)$' ;; irix5* | irix6* | nonstopux*) case $LD in *-32|*"-32 ") libmagic=32-bit;; *-n32|*"-n32 ") libmagic=N32;; *-64|*"-64 ") libmagic=64-bit;; *) libmagic=never-match;; esac lt_cv_deplibs_check_method=pass_all ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) lt_cv_deplibs_check_method=pass_all ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so|_pic\.a)$' fi ;; newos6*) lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (executable|dynamic lib)' lt_cv_file_magic_cmd=$FILECMD lt_cv_file_magic_test_file=/usr/lib/libnls.so ;; *nto* | *qnx*) lt_cv_deplibs_check_method=pass_all ;; openbsd* | bitrig*) if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|\.so|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[[^/]]+(\.so\.[[0-9]]+\.[[0-9]]+|_pic\.a)$' fi ;; osf3* | osf4* | osf5*) lt_cv_deplibs_check_method=pass_all ;; rdos*) lt_cv_deplibs_check_method=pass_all ;; solaris*) lt_cv_deplibs_check_method=pass_all ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) lt_cv_deplibs_check_method=pass_all ;; sysv4 | sysv4.3*) case $host_vendor in motorola) lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[ML]]SB (shared object|dynamic lib) M[[0-9]][[0-9]]* Version [[0-9]]' lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` ;; ncr) lt_cv_deplibs_check_method=pass_all ;; sequent) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method='file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB (shared object|dynamic lib )' ;; sni) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method="file_magic ELF [[0-9]][[0-9]]*-bit [[LM]]SB dynamic lib" lt_cv_file_magic_test_file=/lib/libc.so ;; siemens) lt_cv_deplibs_check_method=pass_all ;; pc) lt_cv_deplibs_check_method=pass_all ;; esac ;; tpf*) lt_cv_deplibs_check_method=pass_all ;; os2*) lt_cv_deplibs_check_method=pass_all ;; esac ]) file_magic_glob= want_nocaseglob=no if test "$build" = "$host"; then case $host_os in mingw* | pw32*) if ( shopt | grep nocaseglob ) >/dev/null 2>&1; then want_nocaseglob=yes else file_magic_glob=`echo aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ | $SED -e "s/\(..\)/s\/[[\1]]\/[[\1]]\/g;/g"` fi ;; esac fi file_magic_cmd=$lt_cv_file_magic_cmd deplibs_check_method=$lt_cv_deplibs_check_method test -z "$deplibs_check_method" && deplibs_check_method=unknown _LT_DECL([], [deplibs_check_method], [1], [Method to check whether dependent libraries are shared objects]) _LT_DECL([], [file_magic_cmd], [1], [Command to use when deplibs_check_method = "file_magic"]) _LT_DECL([], [file_magic_glob], [1], [How to find potential files when deplibs_check_method = "file_magic"]) _LT_DECL([], [want_nocaseglob], [1], [Find potential files using nocaseglob when deplibs_check_method = "file_magic"]) ])# _LT_CHECK_MAGIC_METHOD # LT_PATH_NM # ---------- # find the pathname to a BSD- or MS-compatible name lister AC_DEFUN([LT_PATH_NM], [AC_REQUIRE([AC_PROG_CC])dnl AC_CACHE_CHECK([for BSD- or MS-compatible name lister (nm)], lt_cv_path_NM, [if test -n "$NM"; then # Let the user override the test. lt_cv_path_NM=$NM else lt_nm_to_check=${ac_tool_prefix}nm if test -n "$ac_tool_prefix" && test "$build" = "$host"; then lt_nm_to_check="$lt_nm_to_check nm" fi for lt_tmp_nm in $lt_nm_to_check; do lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. tmp_nm=$ac_dir/$lt_tmp_nm if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext"; then # Check to see if the nm accepts a BSD-compat flag. # Adding the 'sed 1q' prevents false positives on HP-UX, which says: # nm: unknown option "B" ignored # Tru64's nm complains that /dev/null is an invalid object file # MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty case $build_os in mingw*) lt_bad_file=conftest.nm/nofile ;; *) lt_bad_file=/dev/null ;; esac case `"$tmp_nm" -B $lt_bad_file 2>&1 | $SED '1q'` in *$lt_bad_file* | *'Invalid file or object type'*) lt_cv_path_NM="$tmp_nm -B" break 2 ;; *) case `"$tmp_nm" -p /dev/null 2>&1 | $SED '1q'` in */dev/null*) lt_cv_path_NM="$tmp_nm -p" break 2 ;; *) lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but continue # so that we can try to find one that supports BSD flags ;; esac ;; esac fi done IFS=$lt_save_ifs done : ${lt_cv_path_NM=no} fi]) if test no != "$lt_cv_path_NM"; then NM=$lt_cv_path_NM else # Didn't find any BSD compatible name lister, look for dumpbin. if test -n "$DUMPBIN"; then : # Let the user override the test. else AC_CHECK_TOOLS(DUMPBIN, [dumpbin "link -dump"], :) case `$DUMPBIN -symbols -headers /dev/null 2>&1 | $SED '1q'` in *COFF*) DUMPBIN="$DUMPBIN -symbols -headers" ;; *) DUMPBIN=: ;; esac fi AC_SUBST([DUMPBIN]) if test : != "$DUMPBIN"; then NM=$DUMPBIN fi fi test -z "$NM" && NM=nm AC_SUBST([NM]) _LT_DECL([], [NM], [1], [A BSD- or MS-compatible name lister])dnl AC_CACHE_CHECK([the name lister ($NM) interface], [lt_cv_nm_interface], [lt_cv_nm_interface="BSD nm" echo "int some_variable = 0;" > conftest.$ac_ext (eval echo "\"\$as_me:$LINENO: $ac_compile\"" >&AS_MESSAGE_LOG_FD) (eval "$ac_compile" 2>conftest.err) cat conftest.err >&AS_MESSAGE_LOG_FD (eval echo "\"\$as_me:$LINENO: $NM \\\"conftest.$ac_objext\\\"\"" >&AS_MESSAGE_LOG_FD) (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) cat conftest.err >&AS_MESSAGE_LOG_FD (eval echo "\"\$as_me:$LINENO: output\"" >&AS_MESSAGE_LOG_FD) cat conftest.out >&AS_MESSAGE_LOG_FD if $GREP 'External.*some_variable' conftest.out > /dev/null; then lt_cv_nm_interface="MS dumpbin" fi rm -f conftest*]) ])# LT_PATH_NM # Old names: AU_ALIAS([AM_PROG_NM], [LT_PATH_NM]) AU_ALIAS([AC_PROG_NM], [LT_PATH_NM]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_PROG_NM], []) dnl AC_DEFUN([AC_PROG_NM], []) # _LT_CHECK_SHAREDLIB_FROM_LINKLIB # -------------------------------- # how to determine the name of the shared library # associated with a specific link library. # -- PORTME fill in with the dynamic library characteristics m4_defun([_LT_CHECK_SHAREDLIB_FROM_LINKLIB], [m4_require([_LT_DECL_EGREP]) m4_require([_LT_DECL_OBJDUMP]) m4_require([_LT_DECL_DLLTOOL]) AC_CACHE_CHECK([how to associate runtime and link libraries], lt_cv_sharedlib_from_linklib_cmd, [lt_cv_sharedlib_from_linklib_cmd='unknown' case $host_os in cygwin* | mingw* | pw32* | cegcc*) # two different shell functions defined in ltmain.sh; # decide which one to use based on capabilities of $DLLTOOL case `$DLLTOOL --help 2>&1` in *--identify-strict*) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib ;; *) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib_fallback ;; esac ;; *) # fallback: assume linklib IS sharedlib lt_cv_sharedlib_from_linklib_cmd=$ECHO ;; esac ]) sharedlib_from_linklib_cmd=$lt_cv_sharedlib_from_linklib_cmd test -z "$sharedlib_from_linklib_cmd" && sharedlib_from_linklib_cmd=$ECHO _LT_DECL([], [sharedlib_from_linklib_cmd], [1], [Command to associate shared and link libraries]) ])# _LT_CHECK_SHAREDLIB_FROM_LINKLIB # _LT_PATH_MANIFEST_TOOL # ---------------------- # locate the manifest tool m4_defun([_LT_PATH_MANIFEST_TOOL], [AC_CHECK_TOOL(MANIFEST_TOOL, mt, :) test -z "$MANIFEST_TOOL" && MANIFEST_TOOL=mt AC_CACHE_CHECK([if $MANIFEST_TOOL is a manifest tool], [lt_cv_path_mainfest_tool], [lt_cv_path_mainfest_tool=no echo "$as_me:$LINENO: $MANIFEST_TOOL '-?'" >&AS_MESSAGE_LOG_FD $MANIFEST_TOOL '-?' 2>conftest.err > conftest.out cat conftest.err >&AS_MESSAGE_LOG_FD if $GREP 'Manifest Tool' conftest.out > /dev/null; then lt_cv_path_mainfest_tool=yes fi rm -f conftest*]) if test yes != "$lt_cv_path_mainfest_tool"; then MANIFEST_TOOL=: fi _LT_DECL([], [MANIFEST_TOOL], [1], [Manifest tool])dnl ])# _LT_PATH_MANIFEST_TOOL # _LT_DLL_DEF_P([FILE]) # --------------------- # True iff FILE is a Windows DLL '.def' file. # Keep in sync with func_dll_def_p in the libtool script AC_DEFUN([_LT_DLL_DEF_P], [dnl test DEF = "`$SED -n dnl -e '\''s/^[[ ]]*//'\'' dnl Strip leading whitespace -e '\''/^\(;.*\)*$/d'\'' dnl Delete empty lines and comments -e '\''s/^\(EXPORTS\|LIBRARY\)\([[ ]].*\)*$/DEF/p'\'' dnl -e q dnl Only consider the first "real" line $1`" dnl ])# _LT_DLL_DEF_P # LT_LIB_M # -------- # check for math library AC_DEFUN([LT_LIB_M], [AC_REQUIRE([AC_CANONICAL_HOST])dnl LIBM= case $host in *-*-beos* | *-*-cegcc* | *-*-cygwin* | *-*-haiku* | *-*-pw32* | *-*-darwin*) # These system don't have libm, or don't need it ;; *-ncr-sysv4.3*) AC_CHECK_LIB(mw, _mwvalidcheckl, LIBM=-lmw) AC_CHECK_LIB(m, cos, LIBM="$LIBM -lm") ;; *) AC_CHECK_LIB(m, cos, LIBM=-lm) ;; esac AC_SUBST([LIBM]) ])# LT_LIB_M # Old name: AU_ALIAS([AC_CHECK_LIBM], [LT_LIB_M]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_CHECK_LIBM], []) # _LT_COMPILER_NO_RTTI([TAGNAME]) # ------------------------------- m4_defun([_LT_COMPILER_NO_RTTI], [m4_require([_LT_TAG_COMPILER])dnl _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= if test yes = "$GCC"; then case $cc_basename in nvcc*) _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -Xcompiler -fno-builtin' ;; *) _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' ;; esac _LT_COMPILER_OPTION([if $compiler supports -fno-rtti -fno-exceptions], lt_cv_prog_compiler_rtti_exceptions, [-fno-rtti -fno-exceptions], [], [_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)="$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1) -fno-rtti -fno-exceptions"]) fi _LT_TAGDECL([no_builtin_flag], [lt_prog_compiler_no_builtin_flag], [1], [Compiler flag to turn off builtin functions]) ])# _LT_COMPILER_NO_RTTI # _LT_CMD_GLOBAL_SYMBOLS # ---------------------- m4_defun([_LT_CMD_GLOBAL_SYMBOLS], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_PROG_CC])dnl AC_REQUIRE([AC_PROG_AWK])dnl AC_REQUIRE([LT_PATH_NM])dnl AC_REQUIRE([LT_PATH_LD])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_TAG_COMPILER])dnl # Check for command to grab the raw symbol name followed by C symbol from nm. AC_MSG_CHECKING([command to parse $NM output from $compiler object]) AC_CACHE_VAL([lt_cv_sys_global_symbol_pipe], [ # These are sane defaults that work on at least a few old systems. # [They come from Ultrix. What could be older than Ultrix?!! ;)] # Character class describing NM global symbol codes. symcode='[[BCDEGRST]]' # Regexp to match symbols that can be accessed directly from C. sympat='\([[_A-Za-z]][[_A-Za-z0-9]]*\)' # Define system-specific variables. case $host_os in aix*) symcode='[[BCDT]]' ;; cygwin* | mingw* | pw32* | cegcc*) symcode='[[ABCDGISTW]]' ;; hpux*) if test ia64 = "$host_cpu"; then symcode='[[ABCDEGRST]]' fi ;; irix* | nonstopux*) symcode='[[BCDEGRST]]' ;; osf*) symcode='[[BCDEGQRST]]' ;; solaris*) symcode='[[BDRT]]' ;; sco3.2v5*) symcode='[[DT]]' ;; sysv4.2uw2*) symcode='[[DT]]' ;; sysv5* | sco5v6* | unixware* | OpenUNIX*) symcode='[[ABDT]]' ;; sysv4) symcode='[[DFNSTU]]' ;; esac # If we're using GNU nm, then use its standard symbol codes. case `$NM -V 2>&1` in *GNU* | *'with BFD'*) symcode='[[ABCDGIRSTW]]' ;; esac if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Gets list of data symbols to import. lt_cv_sys_global_symbol_to_import="$SED -n -e 's/^I .* \(.*\)$/\1/p'" # Adjust the below global symbol transforms to fixup imported variables. lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'" lt_c_name_hook=" -e 's/^I .* \(.*\)$/ {\"\1\", (void *) 0},/p'" lt_c_name_lib_hook="\ -e 's/^I .* \(lib.*\)$/ {\"\1\", (void *) 0},/p'\ -e 's/^I .* \(.*\)$/ {\"lib\1\", (void *) 0},/p'" else # Disable hooks by default. lt_cv_sys_global_symbol_to_import= lt_cdecl_hook= lt_c_name_hook= lt_c_name_lib_hook= fi # Transform an extracted symbol line into a proper C declaration. # Some systems (esp. on ia64) link data and code symbols differently, # so use this general approach. lt_cv_sys_global_symbol_to_cdecl="$SED -n"\ $lt_cdecl_hook\ " -e 's/^T .* \(.*\)$/extern int \1();/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/extern char \1;/p'" # Transform an extracted symbol line into symbol name and symbol address lt_cv_sys_global_symbol_to_c_name_address="$SED -n"\ $lt_c_name_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/p'" # Transform an extracted symbol line into symbol name with lib prefix and # symbol address. lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="$SED -n"\ $lt_c_name_lib_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(lib.*\)$/ {\"\1\", (void *) \&\1},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"lib\1\", (void *) \&\1},/p'" # Handle CRLF in mingw tool chain opt_cr= case $build_os in mingw*) opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp ;; esac # Try without a prefix underscore, then with it. for ac_symprfx in "" "_"; do # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. symxfrm="\\1 $ac_symprfx\\2 \\2" # Write the raw and C identifiers. if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Fake it for dumpbin and say T for any non-static function, # D for any global variable and I for any imported variable. # Also find C++ and __fastcall symbols from MSVC++ or ICC, # which start with @ or ?. lt_cv_sys_global_symbol_pipe="$AWK ['"\ " {last_section=section; section=\$ 3};"\ " /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\ " /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\ " /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn[2],2)};"\ " /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\ " /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\ " \$ 0!~/External *\|/{next};"\ " / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\ " {if(hide[section]) next};"\ " {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\ " {split(\$ 0,a,/\||\r/); split(a[2],s)};"\ " s[1]~/^[@?]/{print f,s[1],s[1]; next};"\ " s[1]~prfx {split(s[1],t,\"@\"); print f,t[1],substr(t[1],length(prfx))}"\ " ' prfx=^$ac_symprfx]" else lt_cv_sys_global_symbol_pipe="$SED -n -e 's/^.*[[ ]]\($symcode$symcode*\)[[ ]][[ ]]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" fi lt_cv_sys_global_symbol_pipe="$lt_cv_sys_global_symbol_pipe | $SED '/ __gnu_lto/d'" # Check to see that the pipe works correctly. pipe_works=no rm -f conftest* cat > conftest.$ac_ext <<_LT_EOF #ifdef __cplusplus extern "C" { #endif char nm_test_var; void nm_test_func(void); void nm_test_func(void){} #ifdef __cplusplus } #endif int main(){nm_test_var='a';nm_test_func();return(0);} _LT_EOF if AC_TRY_EVAL(ac_compile); then # Now try to grab the symbols. nlist=conftest.nm if AC_TRY_EVAL(NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) && test -s "$nlist"; then # Try sorting and uniquifying the output. if sort "$nlist" | uniq > "$nlist"T; then mv -f "$nlist"T "$nlist" else rm -f "$nlist"T fi # Make sure that we snagged all the symbols we need. if $GREP ' nm_test_var$' "$nlist" >/dev/null; then if $GREP ' nm_test_func$' "$nlist" >/dev/null; then cat <<_LT_EOF > conftest.$ac_ext /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE /* DATA imports from DLLs on WIN32 can't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT@&t@_DLSYM_CONST #elif defined __osf__ /* This system does not cope well with relocations in const data. */ # define LT@&t@_DLSYM_CONST #else # define LT@&t@_DLSYM_CONST const #endif #ifdef __cplusplus extern "C" { #endif _LT_EOF # Now generate the symbol file. eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext' cat <<_LT_EOF >> conftest.$ac_ext /* The mapping between symbol names and symbols. */ LT@&t@_DLSYM_CONST struct { const char *name; void *address; } lt__PROGRAM__LTX_preloaded_symbols[[]] = { { "@PROGRAM@", (void *) 0 }, _LT_EOF $SED "s/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext cat <<\_LT_EOF >> conftest.$ac_ext {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt__PROGRAM__LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif _LT_EOF # Now try linking the two files. mv conftest.$ac_objext conftstm.$ac_objext lt_globsym_save_LIBS=$LIBS lt_globsym_save_CFLAGS=$CFLAGS LIBS=conftstm.$ac_objext CFLAGS="$CFLAGS$_LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)" if AC_TRY_EVAL(ac_link) && test -s conftest$ac_exeext; then pipe_works=yes fi LIBS=$lt_globsym_save_LIBS CFLAGS=$lt_globsym_save_CFLAGS else echo "cannot find nm_test_func in $nlist" >&AS_MESSAGE_LOG_FD fi else echo "cannot find nm_test_var in $nlist" >&AS_MESSAGE_LOG_FD fi else echo "cannot run $lt_cv_sys_global_symbol_pipe" >&AS_MESSAGE_LOG_FD fi else echo "$progname: failed program was:" >&AS_MESSAGE_LOG_FD cat conftest.$ac_ext >&5 fi rm -rf conftest* conftst* # Do not use the global_symbol_pipe unless it works. if test yes = "$pipe_works"; then break else lt_cv_sys_global_symbol_pipe= fi done ]) if test -z "$lt_cv_sys_global_symbol_pipe"; then lt_cv_sys_global_symbol_to_cdecl= fi if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then AC_MSG_RESULT(failed) else AC_MSG_RESULT(ok) fi # Response file support. if test "$lt_cv_nm_interface" = "MS dumpbin"; then nm_file_list_spec='@' elif $NM --help 2>/dev/null | grep '[[@]]FILE' >/dev/null; then nm_file_list_spec='@' fi _LT_DECL([global_symbol_pipe], [lt_cv_sys_global_symbol_pipe], [1], [Take the output of nm and produce a listing of raw symbols and C names]) _LT_DECL([global_symbol_to_cdecl], [lt_cv_sys_global_symbol_to_cdecl], [1], [Transform the output of nm in a proper C declaration]) _LT_DECL([global_symbol_to_import], [lt_cv_sys_global_symbol_to_import], [1], [Transform the output of nm into a list of symbols to manually relocate]) _LT_DECL([global_symbol_to_c_name_address], [lt_cv_sys_global_symbol_to_c_name_address], [1], [Transform the output of nm in a C name address pair]) _LT_DECL([global_symbol_to_c_name_address_lib_prefix], [lt_cv_sys_global_symbol_to_c_name_address_lib_prefix], [1], [Transform the output of nm in a C name address pair when lib prefix is needed]) _LT_DECL([nm_interface], [lt_cv_nm_interface], [1], [The name lister interface]) _LT_DECL([], [nm_file_list_spec], [1], [Specify filename containing input files for $NM]) ]) # _LT_CMD_GLOBAL_SYMBOLS # _LT_COMPILER_PIC([TAGNAME]) # --------------------------- m4_defun([_LT_COMPILER_PIC], [m4_require([_LT_TAG_COMPILER])dnl _LT_TAGVAR(lt_prog_compiler_wl, $1)= _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)= m4_if([$1], [CXX], [ # C++ specific cases for pic, static, wl, etc. if test yes = "$GXX"; then _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' case $host_os in aix*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the '-m68020' flag to GCC prevents building anything better, # like '-m68040'. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | os2* | pw32* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) case $host_os in os2*) _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' ;; esac ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' ;; *djgpp*) # DJGPP does not support shared libraries at all _LT_TAGVAR(lt_prog_compiler_pic, $1)= ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. _LT_TAGVAR(lt_prog_compiler_static, $1)= ;; interix[[3-9]]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic fi ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac ;; *qnx* | *nto*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac else case $host_os in aix[[4-9]]*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' else _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' fi ;; chorus*) case $cc_basename in cxch68*) # Green Hills C++ Compiler # _LT_TAGVAR(lt_prog_compiler_static, $1)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" ;; esac ;; mingw* | cygwin* | os2* | pw32* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) ;; dgux*) case $cc_basename in ec++*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' ;; ghcx*) # Green Hills C++ Compiler _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; *) ;; esac ;; freebsd* | dragonfly* | midnightbsd*) # FreeBSD uses GNU C++ ;; hpux9* | hpux10* | hpux11*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' if test ia64 != "$host_cpu"; then _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' fi ;; aCC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' ;; esac ;; *) ;; esac ;; interix*) # This is c89, which is MS Visual C++ (no shared libs) # Anyone wants to do a port? ;; irix5* | irix6* | nonstopux*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' # CC pic flag -KPIC is the default. ;; *) ;; esac ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in KCC*) # KAI C++ Compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; ecpc* ) # old Intel C++ for x86_64, which still supported -KPIC. _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; icpc* ) # Intel C++, used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; pgCC* | pgcpp*) # Portland Group C++ compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; cxx*) # Compaq C++ # Make sure the PIC flag is empty. It appears that all Alpha # Linux and Compaq Tru64 Unix objects are PIC. _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; xlc* | xlC* | bgxl[[cC]]* | mpixl[[cC]]*) # IBM XL 8.0, 9.0 on PPC and BlueGene _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink' ;; *) case `$CC -V 2>&1 | $SED 5q` in *Sun\ C*) # Sun C++ 5.9 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; esac ;; esac ;; lynxos*) ;; m88k*) ;; mvs*) case $cc_basename in cxx*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-W c,exportall' ;; *) ;; esac ;; netbsd*) ;; *qnx* | *nto*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; osf3* | osf4* | osf5*) case $cc_basename in KCC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='--backend -Wl,' ;; RCC*) # Rational C++ 2.4.1 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; cxx*) # Digital/Compaq C++ _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # Make sure the PIC flag is empty. It appears that all Alpha # Linux and Compaq Tru64 Unix objects are PIC. _LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; *) ;; esac ;; psos*) ;; solaris*) case $cc_basename in CC* | sunCC*) # Sun C++ 4.2, 5.x and Centerline C++ _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; gcx*) # Green Hills C++ Compiler _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' ;; *) ;; esac ;; sunos4*) case $cc_basename in CC*) # Sun C++ 4.x _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; lcc*) # Lucid _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' ;; *) ;; esac ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) case $cc_basename in CC*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; esac ;; tandem*) case $cc_basename in NCC*) # NonStop-UX NCC 3.20 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' ;; *) ;; esac ;; vxworks*) ;; *) _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; esac fi ], [ if test yes = "$GCC"; then _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' case $host_os in aix*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the '-m68020' flag to GCC prevents building anything better, # like '-m68040'. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) case $host_os in os2*) _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' ;; esac ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. _LT_TAGVAR(lt_prog_compiler_static, $1)= ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac ;; interix[[3-9]]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; msdosdjgpp*) # Just because we use GCC doesn't mean we suddenly get shared libraries # on systems that don't support them. _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no enable_shared=no ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(lt_prog_compiler_pic, $1)=-Kconform_pic fi ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' ;; esac case $cc_basename in nvcc*) # Cuda Compiler Driver 2.2 _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Xlinker ' if test -n "$_LT_TAGVAR(lt_prog_compiler_pic, $1)"; then _LT_TAGVAR(lt_prog_compiler_pic, $1)="-Xcompiler $_LT_TAGVAR(lt_prog_compiler_pic, $1)" fi ;; esac else # PORTME Check for flag to pass linker flags through the system compiler. case $host_os in aix*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' else _LT_TAGVAR(lt_prog_compiler_static, $1)='-bnso -bI:/lib/syscalls.exp' fi ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fno-common' case $cc_basename in nagfor*) # NAG Fortran compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,-Wl,,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; esac ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). m4_if([$1], [GCJ], [], [_LT_TAGVAR(lt_prog_compiler_pic, $1)='-DDLL_EXPORT']) case $host_os in os2*) _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-static' ;; esac ;; hpux9* | hpux10* | hpux11*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but # not for PA HP-UX. case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)='+Z' ;; esac # Is there a better lt_prog_compiler_static that works with the bundled CC? _LT_TAGVAR(lt_prog_compiler_static, $1)='$wl-a ${wl}archive' ;; irix5* | irix6* | nonstopux*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # PIC (with -KPIC) is the default. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in # old Intel for x86_64, which still supported -KPIC. ecc*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; # icc used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. icc* | ifort*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; # Lahey Fortran 8.1. lf95*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='--shared' _LT_TAGVAR(lt_prog_compiler_static, $1)='--static' ;; nagfor*) # NAG Fortran compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,-Wl,,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; tcc*) # Fabrice Bellard et al's Tiny C Compiler _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group compilers (*not* the Pentium gcc compiler, # which looks to be a dead project) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; ccc*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # All Alpha code is PIC. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; xl* | bgxl* | bgf* | mpixl*) # IBM XL C 8.0/Fortran 10.1, 11.1 on PPC and BlueGene _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-qpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-qstaticlink' ;; *) case `$CC -V 2>&1 | $SED 5q` in *Sun\ Ceres\ Fortran* | *Sun*Fortran*\ [[1-7]].* | *Sun*Fortran*\ 8.[[0-3]]*) # Sun Fortran 8.3 passes all unrecognized flags to the linker _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='' ;; *Sun\ F* | *Sun*Fortran*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' ;; *Sun\ C*) # Sun C 5.9 _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' ;; *Intel*\ [[CF]]*Compiler*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-static' ;; *Portland\ Group*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fpic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; esac ;; esac ;; newsos6) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. _LT_TAGVAR(lt_prog_compiler_pic, $1)='-fPIC -shared' ;; osf3* | osf4* | osf5*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' # All OSF/1 code is PIC. _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; rdos*) _LT_TAGVAR(lt_prog_compiler_static, $1)='-non_shared' ;; solaris*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' case $cc_basename in f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ';; *) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,';; esac ;; sunos4*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Qoption ld ' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-PIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; sysv4 | sysv4.2uw2* | sysv4.3*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(lt_prog_compiler_pic, $1)='-Kconform_pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' fi ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_pic, $1)='-KPIC' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; unicos*) _LT_TAGVAR(lt_prog_compiler_wl, $1)='-Wl,' _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; uts4*) _LT_TAGVAR(lt_prog_compiler_pic, $1)='-pic' _LT_TAGVAR(lt_prog_compiler_static, $1)='-Bstatic' ;; *) _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no ;; esac fi ]) case $host_os in # For platforms that do not support PIC, -DPIC is meaningless: *djgpp*) _LT_TAGVAR(lt_prog_compiler_pic, $1)= ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)="$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])" ;; esac AC_CACHE_CHECK([for $compiler option to produce PIC], [_LT_TAGVAR(lt_cv_prog_compiler_pic, $1)], [_LT_TAGVAR(lt_cv_prog_compiler_pic, $1)=$_LT_TAGVAR(lt_prog_compiler_pic, $1)]) _LT_TAGVAR(lt_prog_compiler_pic, $1)=$_LT_TAGVAR(lt_cv_prog_compiler_pic, $1) # # Check to make sure the PIC flag actually works. # if test -n "$_LT_TAGVAR(lt_prog_compiler_pic, $1)"; then _LT_COMPILER_OPTION([if $compiler PIC flag $_LT_TAGVAR(lt_prog_compiler_pic, $1) works], [_LT_TAGVAR(lt_cv_prog_compiler_pic_works, $1)], [$_LT_TAGVAR(lt_prog_compiler_pic, $1)@&t@m4_if([$1],[],[ -DPIC],[m4_if([$1],[CXX],[ -DPIC],[])])], [], [case $_LT_TAGVAR(lt_prog_compiler_pic, $1) in "" | " "*) ;; *) _LT_TAGVAR(lt_prog_compiler_pic, $1)=" $_LT_TAGVAR(lt_prog_compiler_pic, $1)" ;; esac], [_LT_TAGVAR(lt_prog_compiler_pic, $1)= _LT_TAGVAR(lt_prog_compiler_can_build_shared, $1)=no]) fi _LT_TAGDECL([pic_flag], [lt_prog_compiler_pic], [1], [Additional compiler flags for building library objects]) _LT_TAGDECL([wl], [lt_prog_compiler_wl], [1], [How to pass a linker flag through the compiler]) # # Check to make sure the static flag actually works. # wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) eval lt_tmp_static_flag=\"$_LT_TAGVAR(lt_prog_compiler_static, $1)\" _LT_LINKER_OPTION([if $compiler static flag $lt_tmp_static_flag works], _LT_TAGVAR(lt_cv_prog_compiler_static_works, $1), $lt_tmp_static_flag, [], [_LT_TAGVAR(lt_prog_compiler_static, $1)=]) _LT_TAGDECL([link_static_flag], [lt_prog_compiler_static], [1], [Compiler flag to prevent dynamic linking]) ])# _LT_COMPILER_PIC # _LT_LINKER_SHLIBS([TAGNAME]) # ---------------------------- # See if the linker supports building shared libraries. m4_defun([_LT_LINKER_SHLIBS], [AC_REQUIRE([LT_PATH_LD])dnl AC_REQUIRE([LT_PATH_NM])dnl m4_require([_LT_PATH_MANIFEST_TOOL])dnl m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_DECL_SED])dnl m4_require([_LT_CMD_GLOBAL_SYMBOLS])dnl m4_require([_LT_TAG_COMPILER])dnl AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) m4_if([$1], [CXX], [ _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'] case $host_os in aix[[4-9]]*) # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to GNU nm, but means don't demangle to AIX nm. # Without the "-l" option, or with the "-B" option, AIX nm treats # weak defined symbols like other global defined symbols, whereas # GNU nm marks them as "W". # While the 'weak' keyword is ignored in the Export File, we need # it in the Import File for the 'aix-soname' feature, so we have # to replace the "-B" option with "-P" for AIX nm. if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' else _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\([[^B]]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "L") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && ([substr](\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' fi ;; pw32*) _LT_TAGVAR(export_symbols_cmds, $1)=$ltdll_cmds ;; cygwin* | mingw* | cegcc*) case $cc_basename in cl* | icl*) _LT_TAGVAR(exclude_expsyms, $1)='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' ;; *) _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/;s/^.*[[ ]]__nm__\([[^ ]]*\)[[ ]][[^ ]]*/\1 DATA/;/^I[[ ]]/d;/^[[AITW]][[ ]]/s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname'] ;; esac ;; *) _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' ;; esac ], [ runpath_var= _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_cmds, $1)= _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(compiler_needs_object, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(old_archive_from_new_cmds, $1)= _LT_TAGVAR(old_archive_from_expsyms_cmds, $1)= _LT_TAGVAR(thread_safe_flag_spec, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= # include_expsyms should be a list of space-separated symbols to be *always* # included in the symbol list _LT_TAGVAR(include_expsyms, $1)= # exclude_expsyms can be an extended regexp of symbols to exclude # it will be wrapped by ' (' and ')$', so one must not match beginning or # end of line. Example: 'a|bc|.*d.*' will exclude the symbols 'a' and 'bc', # as well as any symbol that contains 'd'. _LT_TAGVAR(exclude_expsyms, $1)=['_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*'] # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out # platforms (ab)use it in PIC code, but their linkers get confused if # the symbol is explicitly referenced. Since portable code cannot # rely on this symbol name, it's probably fine to never include it in # preloaded symbol tables. # Exclude shared library initialization/finalization symbols. dnl Note also adjust exclude_expsyms for C++ above. extract_expsyms_cmds= case $host_os in cygwin* | mingw* | pw32* | cegcc*) # FIXME: the MSVC++ and ICC port hasn't been tested in a loooong time # When not using gcc, we currently assume that we are using # Microsoft Visual C++ or Intel C++ Compiler. if test yes != "$GCC"; then with_gnu_ld=no fi ;; interix*) # we just hope/assume this is gcc and not c89 (= MSVC++ or ICC) with_gnu_ld=yes ;; openbsd* | bitrig*) with_gnu_ld=no ;; esac _LT_TAGVAR(ld_shlibs, $1)=yes # On some targets, GNU ld is compatible enough with the native linker # that we're better off using the native interface for both. lt_use_gnu_ld_interface=no if test yes = "$with_gnu_ld"; then case $host_os in aix*) # The AIX port of GNU ld has always aspired to compatibility # with the native linker. However, as the warning in the GNU ld # block says, versions before 2.19.5* couldn't really create working # shared libraries, regardless of the interface used. case `$LD -v 2>&1` in *\ \(GNU\ Binutils\)\ 2.19.5*) ;; *\ \(GNU\ Binutils\)\ 2.[[2-9]]*) ;; *\ \(GNU\ Binutils\)\ [[3-9]]*) ;; *) lt_use_gnu_ld_interface=yes ;; esac ;; *) lt_use_gnu_ld_interface=yes ;; esac fi if test yes = "$lt_use_gnu_ld_interface"; then # If archive_cmds runs LD, not CC, wlarc should be empty wlarc='$wl' # Set some defaults for GNU ld with shared library support. These # are reset later if shared libraries are not supported. Putting them # here allows them to be overridden if necessary. runpath_var=LD_RUN_PATH _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' # ancient GNU ld didn't support --whole-archive et. al. if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' else _LT_TAGVAR(whole_archive_flag_spec, $1)= fi supports_anon_versioning=no case `$LD -v | $SED -e 's/([[^)]]\+)\s\+//' 2>&1` in *GNU\ gold*) supports_anon_versioning=yes ;; *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.10.*) ;; # catch versions < 2.11 *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... *\ 2.11.*) ;; # other 2.11 versions *) supports_anon_versioning=yes ;; esac # See if GNU ld supports shared libraries. case $host_os in aix[[3-9]]*) # On AIX/PPC, the GNU linker is very broken if test ia64 != "$host_cpu"; then _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: the GNU linker, at least up to release 2.19, is reported *** to be unable to reliably create shared libraries on AIX. *** Therefore, libtool is disabling shared libraries support. If you *** really care for shared libraries, you may want to install binutils *** 2.20 or above, or modify your PATH so that a non-GNU linker is found. *** You will then need to restart the configuration process. _LT_EOF fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='' ;; m68k) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; cygwin* | mingw* | pw32* | cegcc*) # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, # as there is no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-all-symbols' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1 DATA/;s/^.*[[ ]]__nm__\([[^ ]]*\)[[ ]][[^ ]]*/\1 DATA/;/^I[[ ]]/d;/^[[AITW]][[ ]]/s/.* //'\'' | sort | uniq > $export_symbols' _LT_TAGVAR(exclude_expsyms, $1)=['[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname'] if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file, use it as # is; otherwise, prepend EXPORTS... _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; haiku*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(link_all_deplibs, $1)=yes ;; os2*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=unsupported shrext_cmds=.dll _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes _LT_TAGVAR(file_list_spec, $1)='@' ;; interix[[3-9]]*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$SED "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) tmp_diet=no if test linux-dietlibc = "$host_os"; then case $cc_basename in diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) esac fi if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ && test no = "$tmp_diet" then tmp_addflag=' $pic_flag' tmp_sharedflag='-shared' case $cc_basename,$host_cpu in pgcc*) # Portland Group C compiler _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag' ;; pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group f77 and f90 compilers _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag -Mnomain' ;; ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 tmp_addflag=' -i_dynamic' ;; efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 tmp_addflag=' -i_dynamic -nofor_main' ;; ifc* | ifort*) # Intel Fortran compiler tmp_addflag=' -nofor_main' ;; lf95*) # Lahey Fortran 8.1 _LT_TAGVAR(whole_archive_flag_spec, $1)= tmp_sharedflag='--shared' ;; nagfor*) # NAGFOR 5.3 tmp_sharedflag='-Wl,-shared' ;; xl[[cC]]* | bgxl[[cC]]* | mpixl[[cC]]*) # IBM XL C 8.0 on PPC (deal with xlf below) tmp_sharedflag='-qmkshrobj' tmp_addflag= ;; nvcc*) # Cuda Compiler Driver 2.2 _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes ;; esac case `$CC -V 2>&1 | $SED 5q` in *Sun\ C*) # Sun C 5.9 _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes tmp_sharedflag='-G' ;; *Sun\ F*) # Sun Fortran 8.3 tmp_sharedflag='-G' ;; esac _LT_TAGVAR(archive_cmds, $1)='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' if test yes = "$supports_anon_versioning"; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' fi case $cc_basename in tcc*) _LT_TAGVAR(export_dynamic_flag_spec, $1)='-rdynamic' ;; xlf* | bgf* | bgxlf* | mpixlf*) # IBM XL Fortran 10.1 on PPC cannot create shared libs itself _LT_TAGVAR(whole_archive_flag_spec, $1)='--whole-archive$convenience --no-whole-archive' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(archive_cmds, $1)='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib' if test yes = "$supports_anon_versioning"; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' fi ;; esac else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' wlarc= else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' fi ;; solaris*) if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: The releases 2.8.* of the GNU linker cannot reliably *** create shared libraries on Solaris systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.9.1 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) case `$LD -v 2>&1` in *\ [[01]].* | *\ 2.[[0-9]].* | *\ 2.1[[0-5]].*) _LT_TAGVAR(ld_shlibs, $1)=no cat <<_LT_EOF 1>&2 *** Warning: Releases of the GNU linker prior to 2.16.91.0.3 cannot *** reliably create shared libraries on SCO systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.16.91.0.3 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF ;; *) # For security reasons, it is highly recommended that you always # use absolute paths for naming shared libraries, and exclude the # DT_RUNPATH tag from executables and libraries. But doing so # requires that you compile everything twice, which is a pain. if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; sunos4*) _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' wlarc= _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac if test no = "$_LT_TAGVAR(ld_shlibs, $1)"; then runpath_var= _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= fi else # PORTME fill in a description of your system's linker (not GNU ld) case $host_os in aix3*) _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(archive_expsym_cmds, $1)='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' # Note: this linker hardcodes the directories in LIBPATH if there # are no directories specified by -L. _LT_TAGVAR(hardcode_minus_L, $1)=yes if test yes = "$GCC" && test -z "$lt_prog_compiler_static"; then # Neither direct hardcoding nor static linking is supported with a # broken collect2. _LT_TAGVAR(hardcode_direct, $1)=unsupported fi ;; aix[[4-9]]*) if test ia64 = "$host_cpu"; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag= else # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to GNU nm, but means don't demangle to AIX nm. # Without the "-l" option, or with the "-B" option, AIX nm treats # weak defined symbols like other global defined symbols, whereas # GNU nm marks them as "W". # While the 'weak' keyword is ignored in the Export File, we need # it in the Import File for the 'aix-soname' feature, so we have # to replace the "-B" option with "-P" for AIX nm. if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then _LT_TAGVAR(export_symbols_cmds, $1)='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && ([substr](\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' else _LT_TAGVAR(export_symbols_cmds, $1)='`func_echo_all $NM | $SED -e '\''s/B\([[^B]]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "L") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && ([substr](\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' fi aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # have runtime linking enabled, and use it for executables. # For shared libraries, we enable/disable runtime linking # depending on the kind of the shared library created - # when "with_aix_soname,aix_use_runtimelinking" is: # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables # "aix,yes" lib.so shared, rtl:yes, for executables # lib.a static archive # "both,no" lib.so.V(shr.o) shared, rtl:yes # lib.a(lib.so.V) shared, rtl:no, for executables # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a(lib.so.V) shared, rtl:no # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a static archive case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*) for ld_flag in $LDFLAGS; do if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then aix_use_runtimelinking=yes break fi done if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then # With aix-soname=svr4, we create the lib.so.V shared archives only, # so we don't have lib.a shared libs to link our executables. # We have to force runtime linking in this case. aix_use_runtimelinking=yes LDFLAGS="$LDFLAGS -Wl,-brtl" fi ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. _LT_TAGVAR(archive_cmds, $1)='' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(file_list_spec, $1)='$wl-f,' case $with_aix_soname,$aix_use_runtimelinking in aix,*) ;; # traditional, no import file svr4,* | *,yes) # use import file # The Import File defines what to hardcode. _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no ;; esac if test yes = "$GCC"; then case $host_os in aix4.[[012]]|aix4.[[012]].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`$CC -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 _LT_TAGVAR(hardcode_direct, $1)=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)= fi ;; esac shared_flag='-shared' if test yes = "$aix_use_runtimelinking"; then shared_flag="$shared_flag "'$wl-G' fi # Need to ensure runtime linking is disabled for the traditional # shared library, or the linker may eventually find shared libraries # /with/ Import File - we do not want to mix them. shared_flag_aix='-shared' shared_flag_svr4='-shared $wl-G' else # not using gcc if test ia64 = "$host_cpu"; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test yes = "$aix_use_runtimelinking"; then shared_flag='$wl-G' else shared_flag='$wl-bM:SRE' fi shared_flag_aix='$wl-bM:SRE' shared_flag_svr4='$wl-G' fi fi _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to export. _LT_TAGVAR(always_export_symbols, $1)=yes if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. _LT_TAGVAR(allow_undefined_flag, $1)='-berok' # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag else if test ia64 = "$host_cpu"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $libdir:/usr/lib:/lib' _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs" _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. _LT_TAGVAR(no_undefined_flag, $1)=' $wl-bernotok' _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-berok' if test yes = "$with_gnu_ld"; then # We only use this code for GNU lds that support --whole-archive. _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience' fi _LT_TAGVAR(archive_cmds_need_lc, $1)=yes _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' # -brtl affects multiple linker settings, -berok does not and is overridden later compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([[, ]]\\)%-berok\\1%g"`' if test svr4 != "$with_aix_soname"; then # This is similar to how AIX traditionally builds its shared libraries. _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' fi if test aix != "$with_aix_soname"; then _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' else # used by -dlpreopen to get the symbols _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir' fi _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d' fi fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='' ;; m68k) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac ;; bsdi[[45]]*) _LT_TAGVAR(export_dynamic_flag_spec, $1)=-rdynamic ;; cygwin* | mingw* | pw32* | cegcc*) # When not using gcc, we currently assume that we are using # Microsoft Visual C++ or Intel C++ Compiler. # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. case $cc_basename in cl* | icl*) # Native MSVC or ICC _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(file_list_spec, $1)='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp "$export_symbols" "$output_objdir/$soname.def"; echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; else $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes _LT_TAGVAR(exclude_expsyms, $1)='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' _LT_TAGVAR(export_symbols_cmds, $1)='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[[BCDGRS]][[ ]]/s/.*[[ ]]\([[^ ]]*\)/\1,DATA/'\'' | $SED -e '\''/^[[AITW]][[ ]]/s/.*[[ ]]//'\'' | sort | uniq > $export_symbols' # Don't use ranlib _LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib' _LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile=$lt_outputfile.exe lt_tool_outputfile=$lt_tool_outputfile.exe ;; esac~ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # Assume MSVC and ICC wrapper _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames=' # The linker will automatically build a .lib file if we build a DLL. _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' # FIXME: Should let the user specify the lib program. _LT_TAGVAR(old_archive_cmds, $1)='lib -OUT:$oldlib$oldobjs$old_deplibs' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes ;; esac ;; darwin* | rhapsody*) _LT_DARWIN_LINKER_FEATURES($1) ;; dgux*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor # support. Future versions do this automatically, but an explicit c++rt0.o # does not break anything, and helps significantly (at the cost of a little # extra space). freebsd2.2*) _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # Unfortunately, older versions of FreeBSD 2 do not have this feature. freebsd2.*) _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; # FreeBSD 3 and greater uses gcc -shared to do shared libraries. freebsd* | dragonfly* | midnightbsd*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; hpux9*) if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' else _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_direct, $1)=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' ;; hpux10*) if test yes,no = "$GCC,$with_gnu_ld"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi if test no = "$with_gnu_ld"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes fi ;; hpux11*) if test yes,no = "$GCC,$with_gnu_ld"; then case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' ;; esac else case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) m4_if($1, [], [ # Older versions of the 11.00 compiler do not understand -b yet # (HP92453-01 A.11.01.20 doesn't, HP92453-01 B.11.X.35175-35176.GP does) _LT_LINKER_OPTION([if $CC understands -b], _LT_TAGVAR(lt_cv_prog_compiler__b, $1), [-b], [_LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags'], [_LT_TAGVAR(archive_cmds, $1)='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags'])], [_LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags']) ;; esac fi if test no = "$with_gnu_ld"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: case $host_cpu in hppa*64*|ia64*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. _LT_TAGVAR(hardcode_minus_L, $1)=yes ;; esac fi ;; irix5* | irix6* | nonstopux*) if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' # Try to use the -exported_symbol ld option, if it does not # work, assume that -exports_file does not work either and # implicitly export all symbols. # This should be the same for all languages, so no per-tag cache variable. AC_CACHE_CHECK([whether the $host_os linker accepts -exported_symbol], [lt_cv_irix_exported_symbol], [save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS -shared $wl-exported_symbol ${wl}foo $wl-update_registry $wl/dev/null" AC_LINK_IFELSE( [AC_LANG_SOURCE( [AC_LANG_CASE([C], [[int foo (void) { return 0; }]], [C++], [[int foo (void) { return 0; }]], [Fortran 77], [[ subroutine foo end]], [Fortran], [[ subroutine foo end]])])], [lt_cv_irix_exported_symbol=yes], [lt_cv_irix_exported_symbol=no]) LDFLAGS=$save_LDFLAGS]) if test yes = "$lt_cv_irix_exported_symbol"; then _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations $wl-exports_file $wl$export_symbols -o $lib' fi else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -exports_file $export_symbols -o $lib' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(inherit_rpath, $1)=yes _LT_TAGVAR(link_all_deplibs, $1)=yes ;; linux*) case $cc_basename in tcc*) # Fabrice Bellard et al's Tiny C Compiler _LT_TAGVAR(ld_shlibs, $1)=yes _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out else _LT_TAGVAR(archive_cmds, $1)='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; newsos6) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *nto* | *qnx*) ;; openbsd* | bitrig*) if test -f /usr/libexec/ld.so; then _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=yes if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags $wl-retain-symbols-file,$export_symbols' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' fi else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; os2*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=unsupported shrext_cmds=.dll _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes _LT_TAGVAR(file_list_spec, $1)='@' ;; osf3*) if test yes = "$GCC"; then _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' else _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: ;; osf4* | osf5*) # as osf3* with the addition of -msym flag if test yes = "$GCC"; then _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $pic_flag $libobjs $deplibs $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' else _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $wl-input $wl$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~$RM $lib.exp' # Both c and cxx compiler support -rpath directly _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' fi _LT_TAGVAR(archive_cmds_need_lc, $1)='no' _LT_TAGVAR(hardcode_libdir_separator, $1)=: ;; solaris*) _LT_TAGVAR(no_undefined_flag, $1)=' -z defs' if test yes = "$GCC"; then wlarc='$wl' _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $wl-z ${wl}text $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag $wl-z ${wl}text $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' else case `$CC -V 2>&1` in *"Compilers 5.0"*) wlarc='' _LT_TAGVAR(archive_cmds, $1)='$LD -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $LD -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' ;; *) wlarc='$wl' _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' ;; esac fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands '-z linker_flag'. GCC discards it without '$wl', # but is careful enough not to reorder. # Supported since Solaris 2.6 (maybe 2.5.1?) if test yes = "$GCC"; then _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' else _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' fi ;; esac _LT_TAGVAR(link_all_deplibs, $1)=yes ;; sunos4*) if test sequent = "$host_vendor"; then # Use $CC to link under sequent, because it throws in some extra .o # files that make .init and .fini sections work. _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h $soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; sysv4) case $host_vendor in sni) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=yes # is this really true??? ;; siemens) ## LD is ld it makes a PLAMLIB ## CC just makes a GrossModule. _LT_TAGVAR(archive_cmds, $1)='$LD -G -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(reload_cmds, $1)='$CC -r -o $output$reload_objs' _LT_TAGVAR(hardcode_direct, $1)=no ;; motorola) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_direct, $1)=no #Motorola manual says yes, but my tests say they lie ;; esac runpath_var='LD_RUN_PATH' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; sysv4.3*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)='-Bexport' ;; sysv4*MP*) if test -d /usr/nec; then _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var=LD_RUN_PATH hardcode_runpath_var=yes _LT_TAGVAR(ld_shlibs, $1)=yes fi ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*) _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We CANNOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(allow_undefined_flag, $1)='$wl-z,nodefs' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Bexport' runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; uts4*) _LT_TAGVAR(archive_cmds, $1)='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(ld_shlibs, $1)=no ;; esac if test sni = "$host_vendor"; then case $host in sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Blargedynsym' ;; esac fi fi ]) AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)]) test no = "$_LT_TAGVAR(ld_shlibs, $1)" && can_build_shared=no _LT_TAGVAR(with_gnu_ld, $1)=$with_gnu_ld _LT_DECL([], [libext], [0], [Old archive suffix (normally "a")])dnl _LT_DECL([], [shrext_cmds], [1], [Shared library suffix (normally ".so")])dnl _LT_DECL([], [extract_expsyms_cmds], [2], [The commands to extract the exported symbol list from a shared archive]) # # Do we need to explicitly link libc? # case "x$_LT_TAGVAR(archive_cmds_need_lc, $1)" in x|xyes) # Assume -lc should be added _LT_TAGVAR(archive_cmds_need_lc, $1)=yes if test yes,yes = "$GCC,$enable_shared"; then case $_LT_TAGVAR(archive_cmds, $1) in *'~'*) # FIXME: we may have to deal with multi-command sequences. ;; '$CC '*) # Test whether the compiler implicitly links with -lc since on some # systems, -lgcc has to come before -lc. If gcc already passes -lc # to ld, don't add -lc before -lgcc. AC_CACHE_CHECK([whether -lc should be explicitly linked in], [lt_cv_]_LT_TAGVAR(archive_cmds_need_lc, $1), [$RM conftest* echo "$lt_simple_compile_test_code" > conftest.$ac_ext if AC_TRY_EVAL(ac_compile) 2>conftest.err; then soname=conftest lib=conftest libobjs=conftest.$ac_objext deplibs= wl=$_LT_TAGVAR(lt_prog_compiler_wl, $1) pic_flag=$_LT_TAGVAR(lt_prog_compiler_pic, $1) compiler_flags=-v linker_flags=-v verstring= output_objdir=. libname=conftest lt_save_allow_undefined_flag=$_LT_TAGVAR(allow_undefined_flag, $1) _LT_TAGVAR(allow_undefined_flag, $1)= if AC_TRY_EVAL(_LT_TAGVAR(archive_cmds, $1) 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) then lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1)=no else lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1)=yes fi _LT_TAGVAR(allow_undefined_flag, $1)=$lt_save_allow_undefined_flag else cat conftest.err 1>&5 fi $RM conftest* ]) _LT_TAGVAR(archive_cmds_need_lc, $1)=$lt_cv_[]_LT_TAGVAR(archive_cmds_need_lc, $1) ;; esac fi ;; esac _LT_TAGDECL([build_libtool_need_lc], [archive_cmds_need_lc], [0], [Whether or not to add -lc for building shared libraries]) _LT_TAGDECL([allow_libtool_libs_with_static_runtimes], [enable_shared_with_static_runtimes], [0], [Whether or not to disallow shared libs when runtime libs are static]) _LT_TAGDECL([], [export_dynamic_flag_spec], [1], [Compiler flag to allow reflexive dlopens]) _LT_TAGDECL([], [whole_archive_flag_spec], [1], [Compiler flag to generate shared objects directly from archives]) _LT_TAGDECL([], [compiler_needs_object], [1], [Whether the compiler copes with passing no objects directly]) _LT_TAGDECL([], [old_archive_from_new_cmds], [2], [Create an old-style archive from a shared archive]) _LT_TAGDECL([], [old_archive_from_expsyms_cmds], [2], [Create a temporary old-style archive to link instead of a shared archive]) _LT_TAGDECL([], [archive_cmds], [2], [Commands used to build a shared archive]) _LT_TAGDECL([], [archive_expsym_cmds], [2]) _LT_TAGDECL([], [module_cmds], [2], [Commands used to build a loadable module if different from building a shared archive.]) _LT_TAGDECL([], [module_expsym_cmds], [2]) _LT_TAGDECL([], [with_gnu_ld], [1], [Whether we are building with GNU ld or not]) _LT_TAGDECL([], [allow_undefined_flag], [1], [Flag that allows shared libraries with undefined symbols to be built]) _LT_TAGDECL([], [no_undefined_flag], [1], [Flag that enforces no undefined symbols]) _LT_TAGDECL([], [hardcode_libdir_flag_spec], [1], [Flag to hardcode $libdir into a binary during linking. This must work even if $libdir does not exist]) _LT_TAGDECL([], [hardcode_libdir_separator], [1], [Whether we need a single "-rpath" flag with a separated argument]) _LT_TAGDECL([], [hardcode_direct], [0], [Set to "yes" if using DIR/libNAME$shared_ext during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_direct_absolute], [0], [Set to "yes" if using DIR/libNAME$shared_ext during linking hardcodes DIR into the resulting binary and the resulting library dependency is "absolute", i.e impossible to change by setting $shlibpath_var if the library is relocated]) _LT_TAGDECL([], [hardcode_minus_L], [0], [Set to "yes" if using the -LDIR flag during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_shlibpath_var], [0], [Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR into the resulting binary]) _LT_TAGDECL([], [hardcode_automatic], [0], [Set to "yes" if building a shared library automatically hardcodes DIR into the library and all subsequent libraries and executables linked against it]) _LT_TAGDECL([], [inherit_rpath], [0], [Set to yes if linker adds runtime paths of dependent libraries to runtime path list]) _LT_TAGDECL([], [link_all_deplibs], [0], [Whether libtool must link a program against all its dependency libraries]) _LT_TAGDECL([], [always_export_symbols], [0], [Set to "yes" if exported symbols are required]) _LT_TAGDECL([], [export_symbols_cmds], [2], [The commands to list exported symbols]) _LT_TAGDECL([], [exclude_expsyms], [1], [Symbols that should not be listed in the preloaded symbols]) _LT_TAGDECL([], [include_expsyms], [1], [Symbols that must always be exported]) _LT_TAGDECL([], [prelink_cmds], [2], [Commands necessary for linking programs (against libraries) with templates]) _LT_TAGDECL([], [postlink_cmds], [2], [Commands necessary for finishing linking programs]) _LT_TAGDECL([], [file_list_spec], [1], [Specify filename containing input files]) dnl FIXME: Not yet implemented dnl _LT_TAGDECL([], [thread_safe_flag_spec], [1], dnl [Compiler flag to generate thread safe objects]) ])# _LT_LINKER_SHLIBS # _LT_LANG_C_CONFIG([TAG]) # ------------------------ # Ensure that the configuration variables for a C compiler are suitably # defined. These variables are subsequently used by _LT_CONFIG to write # the compiler configuration to 'libtool'. m4_defun([_LT_LANG_C_CONFIG], [m4_require([_LT_DECL_EGREP])dnl lt_save_CC=$CC AC_LANG_PUSH(C) # Source file extension for C test sources. ac_ext=c # Object file extension for compiled C test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(){return(0);}' _LT_TAG_COMPILER # Save the default compiler, since it gets overwritten when the other # tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP. compiler_DEFAULT=$CC # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) LT_SYS_DLOPEN_SELF _LT_CMD_STRIPLIB # Report what library types will actually be built AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_CONFIG($1) fi AC_LANG_POP CC=$lt_save_CC ])# _LT_LANG_C_CONFIG # _LT_LANG_CXX_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for a C++ compiler are suitably # defined. These variables are subsequently used by _LT_CONFIG to write # the compiler configuration to 'libtool'. m4_defun([_LT_LANG_CXX_CONFIG], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl m4_require([_LT_DECL_EGREP])dnl m4_require([_LT_PATH_MANIFEST_TOOL])dnl if test -n "$CXX" && ( test no != "$CXX" && ( (test g++ = "$CXX" && `g++ -v >/dev/null 2>&1` ) || (test g++ != "$CXX"))); then AC_PROG_CXXCPP else _lt_caught_CXX_error=yes fi AC_LANG_PUSH(C++) _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(compiler_needs_object, $1)=no _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=unsupported _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for C++ test sources. ac_ext=cpp # Object file extension for compiled C++ test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the CXX compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test yes != "$_lt_caught_CXX_error"; then # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(int, char *[[]]) { return(0); }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_LD=$LD lt_save_GCC=$GCC GCC=$GXX lt_save_with_gnu_ld=$with_gnu_ld lt_save_path_LD=$lt_cv_path_LD if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx else $as_unset lt_cv_prog_gnu_ld fi if test -n "${lt_cv_path_LDCXX+set}"; then lt_cv_path_LD=$lt_cv_path_LDCXX else $as_unset lt_cv_path_LD fi test -z "${LDCXX+set}" || LD=$LDCXX CC=${CXX-"c++"} CFLAGS=$CXXFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) if test -n "$compiler"; then # We don't want -fno-exception when compiling C++ code, so set the # no_builtin_flag separately if test yes = "$GXX"; then _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)=' -fno-builtin' else _LT_TAGVAR(lt_prog_compiler_no_builtin_flag, $1)= fi if test yes = "$GXX"; then # Set up default GNU C++ configuration LT_PATH_LD # Check if GNU C++ uses GNU ld as the underlying linker, since the # archiving commands below assume that GNU ld is being used. if test yes = "$with_gnu_ld"; then _LT_TAGVAR(archive_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' # If archive_cmds runs LD, not CC, wlarc should be empty # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to # investigate it a little bit more. (MM) wlarc='$wl' # ancient GNU ld didn't support --whole-archive et. al. if eval "`$CC -print-prog-name=ld` --help 2>&1" | $GREP 'no-whole-archive' > /dev/null; then _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' else _LT_TAGVAR(whole_archive_flag_spec, $1)= fi else with_gnu_ld=no wlarc= # A generic and very simple default shared library creation # command for GNU C++ for the case where it uses the native # linker, instead of GNU ld. If possible, this setting should # overridden to take advantage of the native linker features on # the platform it is being used on. _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' fi # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else GXX=no with_gnu_ld=no wlarc= fi # PORTME: fill in a description of your system's C++ link characteristics AC_MSG_CHECKING([whether the $compiler linker ($LD) supports shared libraries]) _LT_TAGVAR(ld_shlibs, $1)=yes case $host_os in aix3*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aix[[4-9]]*) if test ia64 = "$host_cpu"; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag= else aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # have runtime linking enabled, and use it for executables. # For shared libraries, we enable/disable runtime linking # depending on the kind of the shared library created - # when "with_aix_soname,aix_use_runtimelinking" is: # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables # "aix,yes" lib.so shared, rtl:yes, for executables # lib.a static archive # "both,no" lib.so.V(shr.o) shared, rtl:yes # lib.a(lib.so.V) shared, rtl:no, for executables # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a(lib.so.V) shared, rtl:no # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a static archive case $host_os in aix4.[[23]]|aix4.[[23]].*|aix[[5-9]]*) for ld_flag in $LDFLAGS; do case $ld_flag in *-brtl*) aix_use_runtimelinking=yes break ;; esac done if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then # With aix-soname=svr4, we create the lib.so.V shared archives only, # so we don't have lib.a shared libs to link our executables. # We have to force runtime linking in this case. aix_use_runtimelinking=yes LDFLAGS="$LDFLAGS -Wl,-brtl" fi ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. _LT_TAGVAR(archive_cmds, $1)='' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(file_list_spec, $1)='$wl-f,' case $with_aix_soname,$aix_use_runtimelinking in aix,*) ;; # no import file svr4,* | *,yes) # use import file # The Import File defines what to hardcode. _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no ;; esac if test yes = "$GXX"; then case $host_os in aix4.[[012]]|aix4.[[012]].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`$CC -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 _LT_TAGVAR(hardcode_direct, $1)=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)= fi esac shared_flag='-shared' if test yes = "$aix_use_runtimelinking"; then shared_flag=$shared_flag' $wl-G' fi # Need to ensure runtime linking is disabled for the traditional # shared library, or the linker may eventually find shared libraries # /with/ Import File - we do not want to mix them. shared_flag_aix='-shared' shared_flag_svr4='-shared $wl-G' else # not using gcc if test ia64 = "$host_cpu"; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test yes = "$aix_use_runtimelinking"; then shared_flag='$wl-G' else shared_flag='$wl-bM:SRE' fi shared_flag_aix='$wl-bM:SRE' shared_flag_svr4='$wl-G' fi fi _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to # export. _LT_TAGVAR(always_export_symbols, $1)=yes if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. # The "-G" linker flag allows undefined symbols. _LT_TAGVAR(no_undefined_flag, $1)='-bernotok' # Determine the default libpath from the value encoded in an empty # executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag else if test ia64 = "$host_cpu"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $libdir:/usr/lib:/lib' _LT_TAGVAR(allow_undefined_flag, $1)="-z nodefs" _LT_TAGVAR(archive_expsym_cmds, $1)="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. _LT_SYS_MODULE_PATH_AIX([$1]) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. _LT_TAGVAR(no_undefined_flag, $1)=' $wl-bernotok' _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-berok' if test yes = "$with_gnu_ld"; then # We only use this code for GNU lds that support --whole-archive. _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives _LT_TAGVAR(whole_archive_flag_spec, $1)='$convenience' fi _LT_TAGVAR(archive_cmds_need_lc, $1)=yes _LT_TAGVAR(archive_expsym_cmds, $1)='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' # -brtl affects multiple linker settings, -berok does not and is overridden later compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([[, ]]\\)%-berok\\1%g"`' if test svr4 != "$with_aix_soname"; then # This is similar to how AIX traditionally builds its shared # libraries. Need -bnortl late, we may have -brtl in LDFLAGS. _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' fi if test aix != "$with_aix_soname"; then _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' else # used by -dlpreopen to get the symbols _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$MV $output_objdir/$realname.d/$soname $output_objdir' fi _LT_TAGVAR(archive_expsym_cmds, $1)="$_LT_TAGVAR(archive_expsym_cmds, $1)"'~$RM -r $output_objdir/$realname.d' fi fi ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then _LT_TAGVAR(allow_undefined_flag, $1)=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME _LT_TAGVAR(archive_cmds, $1)='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; chorus*) case $cc_basename in *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; cygwin* | mingw* | pw32* | cegcc*) case $GXX,$cc_basename in ,cl* | no,cl* | ,icl* | no,icl*) # Native MSVC or ICC # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)=' ' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=yes _LT_TAGVAR(file_list_spec, $1)='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. _LT_TAGVAR(archive_cmds, $1)='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp "$export_symbols" "$output_objdir/$soname.def"; echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; else $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, $1)='true' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes # Don't use ranlib _LT_TAGVAR(old_postinstall_cmds, $1)='chmod 644 $oldlib' _LT_TAGVAR(postlink_cmds, $1)='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile=$lt_outputfile.exe lt_tool_outputfile=$lt_tool_outputfile.exe ;; esac~ func_to_tool_file "$lt_outputfile"~ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # g++ # _LT_TAGVAR(hardcode_libdir_flag_spec, $1) is actually meaningless, # as there is no search path for DLLs. _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-all-symbols' _LT_TAGVAR(allow_undefined_flag, $1)=unsupported _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file, use it as # is; otherwise, prepend EXPORTS... _LT_TAGVAR(archive_expsym_cmds, $1)='if _LT_DLL_DEF_P([$export_symbols]); then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; darwin* | rhapsody*) _LT_DARWIN_LINKER_FEATURES($1) ;; os2*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-L$libdir' _LT_TAGVAR(hardcode_minus_L, $1)=yes _LT_TAGVAR(allow_undefined_flag, $1)=unsupported shrext_cmds=.dll _LT_TAGVAR(archive_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(archive_expsym_cmds, $1)='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' _LT_TAGVAR(old_archive_From_new_cmds, $1)='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=yes _LT_TAGVAR(file_list_spec, $1)='@' ;; dgux*) case $cc_basename in ec++*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; ghcx*) # Green Hills C++ Compiler # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; freebsd2.*) # C++ shared libraries reported to be fairly broken before # switch to ELF _LT_TAGVAR(ld_shlibs, $1)=no ;; freebsd-elf*) _LT_TAGVAR(archive_cmds_need_lc, $1)=no ;; freebsd* | dragonfly* | midnightbsd*) # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF # conventions _LT_TAGVAR(ld_shlibs, $1)=yes ;; haiku*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(link_all_deplibs, $1)=yes ;; hpux9*) _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, # but as the default # location of the library. case $cc_basename in CC*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aCC*) _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -b $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes = "$GXX"; then _LT_TAGVAR(archive_cmds, $1)='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; hpux10*|hpux11*) if test no = "$with_gnu_ld"; then _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl+b $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: case $host_cpu in hppa*64*|ia64*) ;; *) _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' ;; esac fi case $host_cpu in hppa*64*|ia64*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no ;; *) _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(hardcode_minus_L, $1)=yes # Not in the search PATH, # but as the default # location of the library. ;; esac case $cc_basename in CC*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; aCC*) case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; esac # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes = "$GXX"; then if test no = "$with_gnu_ld"; then case $host_cpu in hppa*64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib -fPIC $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; ia64*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; esac fi else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; interix[[3-9]]*) _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$SED "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; irix5* | irix6*) case $cc_basename in CC*) # SGI C++ _LT_TAGVAR(archive_cmds, $1)='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' # Archives containing C++ object files must be created using # "CC -ar", where "CC" is the IRIX C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -ar -WR,-u -o $oldlib $oldobjs' ;; *) if test yes = "$GXX"; then if test no = "$with_gnu_ld"; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' else _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` -o $lib' fi fi _LT_TAGVAR(link_all_deplibs, $1)=yes ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: _LT_TAGVAR(inherit_rpath, $1)=yes ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in KCC*) # Kuck and Associates, Inc. (KAI) C++ Compiler # KCC will only create a shared library if the output file # ends with ".so" (or ".sl" for HP-UX), so rename the library # to its proper name (with version) after linking. _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib $wl-retain-symbols-file,$export_symbols; mv \$templib $lib' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' # Archives containing C++ object files must be created using # "CC -Bstatic", where "CC" is the KAI C++ compiler. _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' ;; icpc* | ecpc* ) # Intel C++ with_gnu_ld=yes # version 8.0 and above of icpc choke on multiply defined symbols # if we add $predep_objects and $postdep_objects, however 7.1 and # earlier do not add the objects themselves. case `$CC -V 2>&1` in *"Version 7."*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; *) # Version 8.0 or newer tmp_idyn= case $host_cpu in ia64*) tmp_idyn=' -i_dynamic';; esac _LT_TAGVAR(archive_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; esac _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive$convenience $wl--no-whole-archive' ;; pgCC* | pgcpp*) # Portland Group C++ compiler case `$CC -V` in *pgCC\ [[1-5]].* | *pgcpp\ [[1-5]].*) _LT_TAGVAR(prelink_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~ compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"' _LT_TAGVAR(old_archive_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~ $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~ $RANLIB $oldlib' _LT_TAGVAR(archive_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; *) # Version 6 and above use weak symbols _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl--rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' ;; cxx*) # Compaq C++ _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib $wl-retain-symbols-file $wl$export_symbols' runpath_var=LD_RUN_PATH _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "X$list" | $Xsed' ;; xl* | mpixl* | bgxl*) # IBM XL 8.0 on PPC, with GNU ld _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl--export-dynamic' _LT_TAGVAR(archive_cmds, $1)='$CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' if test yes = "$supports_anon_versioning"; then _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' fi ;; *) case `$CC -V 2>&1 | $SED 5q` in *Sun\ C*) # Sun C++ 5.9 _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs' _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file $wl$export_symbols' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' _LT_TAGVAR(compiler_needs_object, $1)=yes # Not sure whether something based on # $CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 # would be better. output_verbose_link_cmd='func_echo_all' # Archives containing C++ object files must be created using # "CC -xar", where "CC" is the Sun C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' ;; esac ;; esac ;; lynxos*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; m88k*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; mvs*) case $cc_basename in cxx*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then _LT_TAGVAR(archive_cmds, $1)='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' wlarc= _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no fi # Workaround some broken pre-1.5 toolchains output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' ;; *nto* | *qnx*) _LT_TAGVAR(ld_shlibs, $1)=yes ;; openbsd* | bitrig*) if test -f /usr/libexec/ld.so; then _LT_TAGVAR(hardcode_direct, $1)=yes _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=yes _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`"; then _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file,$export_symbols -o $lib' _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-E' _LT_TAGVAR(whole_archive_flag_spec, $1)=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' fi output_verbose_link_cmd=func_echo_all else _LT_TAGVAR(ld_shlibs, $1)=no fi ;; osf3* | osf4* | osf5*) case $cc_basename in KCC*) # Kuck and Associates, Inc. (KAI) C++ Compiler # KCC will only create a shared library if the output file # ends with ".so" (or ".sl" for HP-UX), so rename the library # to its proper name (with version) after linking. _LT_TAGVAR(archive_cmds, $1)='tempext=`echo $shared_ext | $SED -e '\''s/\([[^()0-9A-Za-z{}]]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Archives containing C++ object files must be created using # the KAI C++ compiler. case $host in osf3*) _LT_TAGVAR(old_archive_cmds, $1)='$CC -Bstatic -o $oldlib $oldobjs' ;; *) _LT_TAGVAR(old_archive_cmds, $1)='$CC -o $oldlib $oldobjs' ;; esac ;; RCC*) # Rational C++ 2.4.1 # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; cxx*) case $host in osf3*) _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $soname `test -n "$verstring" && func_echo_all "$wl-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' ;; *) _LT_TAGVAR(allow_undefined_flag, $1)=' -expect_unresolved \*' _LT_TAGVAR(archive_cmds, $1)='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ echo "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname $wl-input $wl$lib.exp `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~ $RM $lib.exp' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-rpath $libdir' ;; esac _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes,no = "$GXX,$with_gnu_ld"; then _LT_TAGVAR(allow_undefined_flag, $1)=' $wl-expect_unresolved $wl\*' case $host in osf3*) _LT_TAGVAR(archive_cmds, $1)='$CC -shared -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' ;; esac _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-rpath $wl$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no fi ;; esac ;; psos*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; sunos4*) case $cc_basename in CC*) # Sun C++ 4.x # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; lcc*) # Lucid # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; solaris*) case $cc_basename in CC* | sunCC*) # Sun C++ 4.2, 5.x and Centerline C++ _LT_TAGVAR(archive_cmds_need_lc,$1)=yes _LT_TAGVAR(no_undefined_flag, $1)=' -zdefs' _LT_TAGVAR(archive_cmds, $1)='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G$allow_undefined_flag $wl-M $wl$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='-R$libdir' _LT_TAGVAR(hardcode_shlibpath_var, $1)=no case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands '-z linker_flag'. # Supported since Solaris 2.6 (maybe 2.5.1?) _LT_TAGVAR(whole_archive_flag_spec, $1)='-z allextract$convenience -z defaultextract' ;; esac _LT_TAGVAR(link_all_deplibs, $1)=yes output_verbose_link_cmd='func_echo_all' # Archives containing C++ object files must be created using # "CC -xar", where "CC" is the Sun C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC -xar -o $oldlib $oldobjs' ;; gcx*) # Green Hills C++ Compiler _LT_TAGVAR(archive_cmds, $1)='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' # The C++ compiler must be used to create the archive. _LT_TAGVAR(old_archive_cmds, $1)='$CC $LDFLAGS -archive -o $oldlib $oldobjs' ;; *) # GNU C++ compiler with Solaris linker if test yes,no = "$GXX,$with_gnu_ld"; then _LT_TAGVAR(no_undefined_flag, $1)=' $wl-z ${wl}defs' if $CC --version | $GREP -v '^2\.7' > /dev/null; then _LT_TAGVAR(archive_cmds, $1)='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else # g++ 2.7 appears to require '-G' NOT '-shared' on this # platform. _LT_TAGVAR(archive_cmds, $1)='$CC -G -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' _LT_TAGVAR(archive_expsym_cmds, $1)='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' fi _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R $wl$libdir' case $host_os in solaris2.[[0-5]] | solaris2.[[0-5]].*) ;; *) _LT_TAGVAR(whole_archive_flag_spec, $1)='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' ;; esac fi ;; esac ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[[01]].[[10]]* | unixware7* | sco3.2v5.0.[[024]]*) _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no runpath_var='LD_RUN_PATH' case $cc_basename in CC*) _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We CANNOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. _LT_TAGVAR(no_undefined_flag, $1)='$wl-z,text' _LT_TAGVAR(allow_undefined_flag, $1)='$wl-z,nodefs' _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(hardcode_shlibpath_var, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)='$wl-R,$libdir' _LT_TAGVAR(hardcode_libdir_separator, $1)=':' _LT_TAGVAR(link_all_deplibs, $1)=yes _LT_TAGVAR(export_dynamic_flag_spec, $1)='$wl-Bexport' runpath_var='LD_RUN_PATH' case $cc_basename in CC*) _LT_TAGVAR(archive_cmds, $1)='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(old_archive_cmds, $1)='$CC -Tprelink_objects $oldobjs~ '"$_LT_TAGVAR(old_archive_cmds, $1)" _LT_TAGVAR(reload_cmds, $1)='$CC -Tprelink_objects $reload_objs~ '"$_LT_TAGVAR(reload_cmds, $1)" ;; *) _LT_TAGVAR(archive_cmds, $1)='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' _LT_TAGVAR(archive_expsym_cmds, $1)='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; tandem*) case $cc_basename in NCC*) # NonStop-UX NCC 3.20 # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac ;; vxworks*) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; *) # FIXME: insert proper C++ library support _LT_TAGVAR(ld_shlibs, $1)=no ;; esac AC_MSG_RESULT([$_LT_TAGVAR(ld_shlibs, $1)]) test no = "$_LT_TAGVAR(ld_shlibs, $1)" && can_build_shared=no _LT_TAGVAR(GCC, $1)=$GXX _LT_TAGVAR(LD, $1)=$LD ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_SYS_HIDDEN_LIBDEPS($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS LDCXX=$LD LD=$lt_save_LD GCC=$lt_save_GCC with_gnu_ld=$lt_save_with_gnu_ld lt_cv_path_LDCXX=$lt_cv_path_LD lt_cv_path_LD=$lt_save_path_LD lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld fi # test yes != "$_lt_caught_CXX_error" AC_LANG_POP ])# _LT_LANG_CXX_CONFIG # _LT_FUNC_STRIPNAME_CNF # ---------------------- # func_stripname_cnf prefix suffix name # strip PREFIX and SUFFIX off of NAME. # PREFIX and SUFFIX must not contain globbing or regex special # characters, hashes, percent signs, but SUFFIX may contain a leading # dot (in which case that matches only a dot). # # This function is identical to the (non-XSI) version of func_stripname, # except this one can be used by m4 code that may be executed by configure, # rather than the libtool script. m4_defun([_LT_FUNC_STRIPNAME_CNF],[dnl AC_REQUIRE([_LT_DECL_SED]) AC_REQUIRE([_LT_PROG_ECHO_BACKSLASH]) func_stripname_cnf () { case @S|@2 in .*) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%\\\\@S|@2\$%%"`;; *) func_stripname_result=`$ECHO "@S|@3" | $SED "s%^@S|@1%%; s%@S|@2\$%%"`;; esac } # func_stripname_cnf ])# _LT_FUNC_STRIPNAME_CNF # _LT_SYS_HIDDEN_LIBDEPS([TAGNAME]) # --------------------------------- # Figure out "hidden" library dependencies from verbose # compiler output when linking a shared library. # Parse the compiler output and extract the necessary # objects, libraries and library flags. m4_defun([_LT_SYS_HIDDEN_LIBDEPS], [m4_require([_LT_FILEUTILS_DEFAULTS])dnl AC_REQUIRE([_LT_FUNC_STRIPNAME_CNF])dnl # Dependencies to place before and after the object being linked: _LT_TAGVAR(predep_objects, $1)= _LT_TAGVAR(postdep_objects, $1)= _LT_TAGVAR(predeps, $1)= _LT_TAGVAR(postdeps, $1)= _LT_TAGVAR(compiler_lib_search_path, $1)= dnl we can't use the lt_simple_compile_test_code here, dnl because it contains code intended for an executable, dnl not a library. It's possible we should let each dnl tag define a new lt_????_link_test_code variable, dnl but it's only used here... m4_if([$1], [], [cat > conftest.$ac_ext <<_LT_EOF int a; void foo (void) { a = 0; } _LT_EOF ], [$1], [CXX], [cat > conftest.$ac_ext <<_LT_EOF class Foo { public: Foo (void) { a = 0; } private: int a; }; _LT_EOF ], [$1], [F77], [cat > conftest.$ac_ext <<_LT_EOF subroutine foo implicit none integer*4 a a=0 return end _LT_EOF ], [$1], [FC], [cat > conftest.$ac_ext <<_LT_EOF subroutine foo implicit none integer a a=0 return end _LT_EOF ], [$1], [GCJ], [cat > conftest.$ac_ext <<_LT_EOF public class foo { private int a; public void bar (void) { a = 0; } }; _LT_EOF ], [$1], [GO], [cat > conftest.$ac_ext <<_LT_EOF package foo func foo() { } _LT_EOF ]) _lt_libdeps_save_CFLAGS=$CFLAGS case "$CC $CFLAGS " in #( *\ -flto*\ *) CFLAGS="$CFLAGS -fno-lto" ;; *\ -fwhopr*\ *) CFLAGS="$CFLAGS -fno-whopr" ;; *\ -fuse-linker-plugin*\ *) CFLAGS="$CFLAGS -fno-use-linker-plugin" ;; esac dnl Parse the compiler output and extract the necessary dnl objects, libraries and library flags. if AC_TRY_EVAL(ac_compile); then # Parse the compiler output and extract the necessary # objects, libraries and library flags. # Sentinel used to keep track of whether or not we are before # the conftest object file. pre_test_object_deps_done=no for p in `eval "$output_verbose_link_cmd"`; do case $prev$p in -L* | -R* | -l*) # Some compilers place space between "-{L,R}" and the path. # Remove the space. if test x-L = "$p" || test x-R = "$p"; then prev=$p continue fi # Expand the sysroot to ease extracting the directories later. if test -z "$prev"; then case $p in -L*) func_stripname_cnf '-L' '' "$p"; prev=-L; p=$func_stripname_result ;; -R*) func_stripname_cnf '-R' '' "$p"; prev=-R; p=$func_stripname_result ;; -l*) func_stripname_cnf '-l' '' "$p"; prev=-l; p=$func_stripname_result ;; esac fi case $p in =*) func_stripname_cnf '=' '' "$p"; p=$lt_sysroot$func_stripname_result ;; esac if test no = "$pre_test_object_deps_done"; then case $prev in -L | -R) # Internal compiler library paths should come after those # provided the user. The postdeps already come after the # user supplied libs so there is no need to process them. if test -z "$_LT_TAGVAR(compiler_lib_search_path, $1)"; then _LT_TAGVAR(compiler_lib_search_path, $1)=$prev$p else _LT_TAGVAR(compiler_lib_search_path, $1)="${_LT_TAGVAR(compiler_lib_search_path, $1)} $prev$p" fi ;; # The "-l" case would never come before the object being # linked, so don't bother handling this case. esac else if test -z "$_LT_TAGVAR(postdeps, $1)"; then _LT_TAGVAR(postdeps, $1)=$prev$p else _LT_TAGVAR(postdeps, $1)="${_LT_TAGVAR(postdeps, $1)} $prev$p" fi fi prev= ;; *.lto.$objext) ;; # Ignore GCC LTO objects *.$objext) # This assumes that the test object file only shows up # once in the compiler output. if test "$p" = "conftest.$objext"; then pre_test_object_deps_done=yes continue fi if test no = "$pre_test_object_deps_done"; then if test -z "$_LT_TAGVAR(predep_objects, $1)"; then _LT_TAGVAR(predep_objects, $1)=$p else _LT_TAGVAR(predep_objects, $1)="$_LT_TAGVAR(predep_objects, $1) $p" fi else if test -z "$_LT_TAGVAR(postdep_objects, $1)"; then _LT_TAGVAR(postdep_objects, $1)=$p else _LT_TAGVAR(postdep_objects, $1)="$_LT_TAGVAR(postdep_objects, $1) $p" fi fi ;; *) ;; # Ignore the rest. esac done # Clean up. rm -f a.out a.exe else echo "libtool.m4: error: problem compiling $1 test program" fi $RM -f confest.$objext CFLAGS=$_lt_libdeps_save_CFLAGS # PORTME: override above test on systems where it is broken m4_if([$1], [CXX], [case $host_os in interix[[3-9]]*) # Interix 3.5 installs completely hosed .la files for C++, so rather than # hack all around it, let's just trust "g++" to DTRT. _LT_TAGVAR(predep_objects,$1)= _LT_TAGVAR(postdep_objects,$1)= _LT_TAGVAR(postdeps,$1)= ;; esac ]) case " $_LT_TAGVAR(postdeps, $1) " in *" -lc "*) _LT_TAGVAR(archive_cmds_need_lc, $1)=no ;; esac _LT_TAGVAR(compiler_lib_search_dirs, $1)= if test -n "${_LT_TAGVAR(compiler_lib_search_path, $1)}"; then _LT_TAGVAR(compiler_lib_search_dirs, $1)=`echo " ${_LT_TAGVAR(compiler_lib_search_path, $1)}" | $SED -e 's! -L! !g' -e 's!^ !!'` fi _LT_TAGDECL([], [compiler_lib_search_dirs], [1], [The directories searched by this compiler when creating a shared library]) _LT_TAGDECL([], [predep_objects], [1], [Dependencies to place before and after the objects being linked to create a shared library]) _LT_TAGDECL([], [postdep_objects], [1]) _LT_TAGDECL([], [predeps], [1]) _LT_TAGDECL([], [postdeps], [1]) _LT_TAGDECL([], [compiler_lib_search_path], [1], [The library search path used internally by the compiler when linking a shared library]) ])# _LT_SYS_HIDDEN_LIBDEPS # _LT_LANG_F77_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for a Fortran 77 compiler are # suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_F77_CONFIG], [AC_LANG_PUSH(Fortran 77) if test -z "$F77" || test no = "$F77"; then _lt_disable_F77=yes fi _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for f77 test sources. ac_ext=f # Object file extension for compiled f77 test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the F77 compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test yes != "$_lt_disable_F77"; then # Code to be used in simple compile tests lt_simple_compile_test_code="\ subroutine t return end " # Code to be used in simple link tests lt_simple_link_test_code="\ program t end " # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_GCC=$GCC lt_save_CFLAGS=$CFLAGS CC=${F77-"f77"} CFLAGS=$FFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) GCC=$G77 if test -n "$compiler"; then AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_TAGVAR(GCC, $1)=$G77 _LT_TAGVAR(LD, $1)=$LD ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS fi # test yes != "$_lt_disable_F77" AC_LANG_POP ])# _LT_LANG_F77_CONFIG # _LT_LANG_FC_CONFIG([TAG]) # ------------------------- # Ensure that the configuration variables for a Fortran compiler are # suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_FC_CONFIG], [AC_LANG_PUSH(Fortran) if test -z "$FC" || test no = "$FC"; then _lt_disable_FC=yes fi _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(allow_undefined_flag, $1)= _LT_TAGVAR(always_export_symbols, $1)=no _LT_TAGVAR(archive_expsym_cmds, $1)= _LT_TAGVAR(export_dynamic_flag_spec, $1)= _LT_TAGVAR(hardcode_direct, $1)=no _LT_TAGVAR(hardcode_direct_absolute, $1)=no _LT_TAGVAR(hardcode_libdir_flag_spec, $1)= _LT_TAGVAR(hardcode_libdir_separator, $1)= _LT_TAGVAR(hardcode_minus_L, $1)=no _LT_TAGVAR(hardcode_automatic, $1)=no _LT_TAGVAR(inherit_rpath, $1)=no _LT_TAGVAR(module_cmds, $1)= _LT_TAGVAR(module_expsym_cmds, $1)= _LT_TAGVAR(link_all_deplibs, $1)=unknown _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds _LT_TAGVAR(no_undefined_flag, $1)= _LT_TAGVAR(whole_archive_flag_spec, $1)= _LT_TAGVAR(enable_shared_with_static_runtimes, $1)=no # Source file extension for fc test sources. ac_ext=${ac_fc_srcext-f} # Object file extension for compiled fc test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # No sense in running all these tests if we already determined that # the FC compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test yes != "$_lt_disable_FC"; then # Code to be used in simple compile tests lt_simple_compile_test_code="\ subroutine t return end " # Code to be used in simple link tests lt_simple_link_test_code="\ program t end " # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_GCC=$GCC lt_save_CFLAGS=$CFLAGS CC=${FC-"f95"} CFLAGS=$FCFLAGS compiler=$CC GCC=$ac_cv_fc_compiler_gnu _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) if test -n "$compiler"; then AC_MSG_CHECKING([if libtool supports shared libraries]) AC_MSG_RESULT([$can_build_shared]) AC_MSG_CHECKING([whether to build shared libraries]) test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[[4-9]]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac AC_MSG_RESULT([$enable_shared]) AC_MSG_CHECKING([whether to build static libraries]) # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes AC_MSG_RESULT([$enable_static]) _LT_TAGVAR(GCC, $1)=$ac_cv_fc_compiler_gnu _LT_TAGVAR(LD, $1)=$LD ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... _LT_SYS_HIDDEN_LIBDEPS($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_SYS_DYNAMIC_LINKER($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi # test -n "$compiler" GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS fi # test yes != "$_lt_disable_FC" AC_LANG_POP ])# _LT_LANG_FC_CONFIG # _LT_LANG_GCJ_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for the GNU Java Compiler compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_GCJ_CONFIG], [AC_REQUIRE([LT_PROG_GCJ])dnl AC_LANG_SAVE # Source file extension for Java test sources. ac_ext=java # Object file extension for compiled Java test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="class foo {}" # Code to be used in simple link tests lt_simple_link_test_code='public class conftest { public static void main(String[[]] argv) {}; }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC=yes CC=${GCJ-"gcj"} CFLAGS=$GCJFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_TAGVAR(LD, $1)=$LD _LT_CC_BASENAME([$compiler]) # GCJ did not exist at the time GCC didn't implicitly link libc in. _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi AC_LANG_RESTORE GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_GCJ_CONFIG # _LT_LANG_GO_CONFIG([TAG]) # -------------------------- # Ensure that the configuration variables for the GNU Go compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_GO_CONFIG], [AC_REQUIRE([LT_PROG_GO])dnl AC_LANG_SAVE # Source file extension for Go test sources. ac_ext=go # Object file extension for compiled Go test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="package main; func main() { }" # Code to be used in simple link tests lt_simple_link_test_code='package main; func main() { }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC=yes CC=${GOC-"gccgo"} CFLAGS=$GOFLAGS compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_TAGVAR(LD, $1)=$LD _LT_CC_BASENAME([$compiler]) # Go did not exist at the time GCC didn't implicitly link libc in. _LT_TAGVAR(archive_cmds_need_lc, $1)=no _LT_TAGVAR(old_archive_cmds, $1)=$old_archive_cmds _LT_TAGVAR(reload_flag, $1)=$reload_flag _LT_TAGVAR(reload_cmds, $1)=$reload_cmds ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then _LT_COMPILER_NO_RTTI($1) _LT_COMPILER_PIC($1) _LT_COMPILER_C_O($1) _LT_COMPILER_FILE_LOCKS($1) _LT_LINKER_SHLIBS($1) _LT_LINKER_HARDCODE_LIBPATH($1) _LT_CONFIG($1) fi AC_LANG_RESTORE GCC=$lt_save_GCC CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_GO_CONFIG # _LT_LANG_RC_CONFIG([TAG]) # ------------------------- # Ensure that the configuration variables for the Windows resource compiler # are suitably defined. These variables are subsequently used by _LT_CONFIG # to write the compiler configuration to 'libtool'. m4_defun([_LT_LANG_RC_CONFIG], [AC_REQUIRE([LT_PROG_RC])dnl AC_LANG_SAVE # Source file extension for RC test sources. ac_ext=rc # Object file extension for compiled RC test sources. objext=o _LT_TAGVAR(objext, $1)=$objext # Code to be used in simple compile tests lt_simple_compile_test_code='sample MENU { MENUITEM "&Soup", 100, CHECKED }' # Code to be used in simple link tests lt_simple_link_test_code=$lt_simple_compile_test_code # ltmain only uses $CC for tagged configurations so make sure $CC is set. _LT_TAG_COMPILER # save warnings/boilerplate of simple test code _LT_COMPILER_BOILERPLATE _LT_LINKER_BOILERPLATE # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_GCC=$GCC GCC= CC=${RC-"windres"} CFLAGS= compiler=$CC _LT_TAGVAR(compiler, $1)=$CC _LT_CC_BASENAME([$compiler]) _LT_TAGVAR(lt_cv_prog_compiler_c_o, $1)=yes if test -n "$compiler"; then : _LT_CONFIG($1) fi GCC=$lt_save_GCC AC_LANG_RESTORE CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS ])# _LT_LANG_RC_CONFIG # LT_PROG_GCJ # ----------- AC_DEFUN([LT_PROG_GCJ], [m4_ifdef([AC_PROG_GCJ], [AC_PROG_GCJ], [m4_ifdef([A][M_PROG_GCJ], [A][M_PROG_GCJ], [AC_CHECK_TOOL(GCJ, gcj,) test set = "${GCJFLAGS+set}" || GCJFLAGS="-g -O2" AC_SUBST(GCJFLAGS)])])[]dnl ]) # Old name: AU_ALIAS([LT_AC_PROG_GCJ], [LT_PROG_GCJ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_GCJ], []) # LT_PROG_GO # ---------- AC_DEFUN([LT_PROG_GO], [AC_CHECK_TOOL(GOC, gccgo,) ]) # LT_PROG_RC # ---------- AC_DEFUN([LT_PROG_RC], [AC_CHECK_TOOL(RC, windres,) ]) # Old name: AU_ALIAS([LT_AC_PROG_RC], [LT_PROG_RC]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_RC], []) # _LT_DECL_EGREP # -------------- # If we don't have a new enough Autoconf to choose the best grep # available, choose the one first in the user's PATH. m4_defun([_LT_DECL_EGREP], [AC_REQUIRE([AC_PROG_EGREP])dnl AC_REQUIRE([AC_PROG_FGREP])dnl test -z "$GREP" && GREP=grep _LT_DECL([], [GREP], [1], [A grep program that handles long lines]) _LT_DECL([], [EGREP], [1], [An ERE matcher]) _LT_DECL([], [FGREP], [1], [A literal string matcher]) dnl Non-bleeding-edge autoconf doesn't subst GREP, so do it here too AC_SUBST([GREP]) ]) # _LT_DECL_OBJDUMP # -------------- # If we don't have a new enough Autoconf to choose the best objdump # available, choose the one first in the user's PATH. m4_defun([_LT_DECL_OBJDUMP], [AC_CHECK_TOOL(OBJDUMP, objdump, false) test -z "$OBJDUMP" && OBJDUMP=objdump _LT_DECL([], [OBJDUMP], [1], [An object symbol dumper]) AC_SUBST([OBJDUMP]) ]) # _LT_DECL_DLLTOOL # ---------------- # Ensure DLLTOOL variable is set. m4_defun([_LT_DECL_DLLTOOL], [AC_CHECK_TOOL(DLLTOOL, dlltool, false) test -z "$DLLTOOL" && DLLTOOL=dlltool _LT_DECL([], [DLLTOOL], [1], [DLL creation program]) AC_SUBST([DLLTOOL]) ]) # _LT_DECL_FILECMD # ---------------- # Check for a file(cmd) program that can be used to detect file type and magic m4_defun([_LT_DECL_FILECMD], [AC_CHECK_TOOL([FILECMD], [file], [:]) _LT_DECL([], [FILECMD], [1], [A file(cmd) program that detects file types]) ])# _LD_DECL_FILECMD # _LT_DECL_SED # ------------ # Check for a fully-functional sed program, that truncates # as few characters as possible. Prefer GNU sed if found. m4_defun([_LT_DECL_SED], [AC_PROG_SED test -z "$SED" && SED=sed Xsed="$SED -e 1s/^X//" _LT_DECL([], [SED], [1], [A sed program that does not truncate output]) _LT_DECL([], [Xsed], ["\$SED -e 1s/^X//"], [Sed that helps us avoid accidentally triggering echo(1) options like -n]) ])# _LT_DECL_SED m4_ifndef([AC_PROG_SED], [ ############################################################ # NOTE: This macro has been submitted for inclusion into # # GNU Autoconf as AC_PROG_SED. When it is available in # # a released version of Autoconf we should remove this # # macro and use it instead. # ############################################################ m4_defun([AC_PROG_SED], [AC_MSG_CHECKING([for a sed that does not truncate output]) AC_CACHE_VAL(lt_cv_path_SED, [# Loop through the user's path and test for sed and gsed. # Then use that list of sed's as ones to test for truncation. as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS test -z "$as_dir" && as_dir=. for lt_ac_prog in sed gsed; do for ac_exec_ext in '' $ac_executable_extensions; do if $as_executable_p "$as_dir/$lt_ac_prog$ac_exec_ext"; then lt_ac_sed_list="$lt_ac_sed_list $as_dir/$lt_ac_prog$ac_exec_ext" fi done done done IFS=$as_save_IFS lt_ac_max=0 lt_ac_count=0 # Add /usr/xpg4/bin/sed as it is typically found on Solaris # along with /bin/sed that truncates output. for lt_ac_sed in $lt_ac_sed_list /usr/xpg4/bin/sed; do test ! -f "$lt_ac_sed" && continue cat /dev/null > conftest.in lt_ac_count=0 echo $ECHO_N "0123456789$ECHO_C" >conftest.in # Check for GNU sed and select it if it is found. if "$lt_ac_sed" --version 2>&1 < /dev/null | grep 'GNU' > /dev/null; then lt_cv_path_SED=$lt_ac_sed break fi while true; do cat conftest.in conftest.in >conftest.tmp mv conftest.tmp conftest.in cp conftest.in conftest.nl echo >>conftest.nl $lt_ac_sed -e 's/a$//' < conftest.nl >conftest.out || break cmp -s conftest.out conftest.nl || break # 10000 chars as input seems more than enough test 10 -lt "$lt_ac_count" && break lt_ac_count=`expr $lt_ac_count + 1` if test "$lt_ac_count" -gt "$lt_ac_max"; then lt_ac_max=$lt_ac_count lt_cv_path_SED=$lt_ac_sed fi done done ]) SED=$lt_cv_path_SED AC_SUBST([SED]) AC_MSG_RESULT([$SED]) ])#AC_PROG_SED ])#m4_ifndef # Old name: AU_ALIAS([LT_AC_PROG_SED], [AC_PROG_SED]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([LT_AC_PROG_SED], []) # _LT_CHECK_SHELL_FEATURES # ------------------------ # Find out whether the shell is Bourne or XSI compatible, # or has some other useful features. m4_defun([_LT_CHECK_SHELL_FEATURES], [if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then lt_unset=unset else lt_unset=false fi _LT_DECL([], [lt_unset], [0], [whether the shell understands "unset"])dnl # test EBCDIC or ASCII case `echo X|tr X '\101'` in A) # ASCII based system # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr lt_SP2NL='tr \040 \012' lt_NL2SP='tr \015\012 \040\040' ;; *) # EBCDIC based system lt_SP2NL='tr \100 \n' lt_NL2SP='tr \r\n \100\100' ;; esac _LT_DECL([SP2NL], [lt_SP2NL], [1], [turn spaces into newlines])dnl _LT_DECL([NL2SP], [lt_NL2SP], [1], [turn newlines into spaces])dnl ])# _LT_CHECK_SHELL_FEATURES # _LT_PATH_CONVERSION_FUNCTIONS # ----------------------------- # Determine what file name conversion functions should be used by # func_to_host_file (and, implicitly, by func_to_host_path). These are needed # for certain cross-compile configurations and native mingw. m4_defun([_LT_PATH_CONVERSION_FUNCTIONS], [AC_REQUIRE([AC_CANONICAL_HOST])dnl AC_REQUIRE([AC_CANONICAL_BUILD])dnl AC_MSG_CHECKING([how to convert $build file names to $host format]) AC_CACHE_VAL(lt_cv_to_host_file_cmd, [case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_w32 ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_cygwin_to_w32 ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_w32 ;; esac ;; *-*-cygwin* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_cygwin ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_noop ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_cygwin ;; esac ;; * ) # unhandled hosts (and "normal" native builds) lt_cv_to_host_file_cmd=func_convert_file_noop ;; esac ]) to_host_file_cmd=$lt_cv_to_host_file_cmd AC_MSG_RESULT([$lt_cv_to_host_file_cmd]) _LT_DECL([to_host_file_cmd], [lt_cv_to_host_file_cmd], [0], [convert $build file names to $host format])dnl AC_MSG_CHECKING([how to convert $build file names to toolchain format]) AC_CACHE_VAL(lt_cv_to_tool_file_cmd, [#assume ordinary cross tools, or native build. lt_cv_to_tool_file_cmd=func_convert_file_noop case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_tool_file_cmd=func_convert_file_msys_to_w32 ;; esac ;; esac ]) to_tool_file_cmd=$lt_cv_to_tool_file_cmd AC_MSG_RESULT([$lt_cv_to_tool_file_cmd]) _LT_DECL([to_tool_file_cmd], [lt_cv_to_tool_file_cmd], [0], [convert $build files to toolchain format])dnl ])# _LT_PATH_CONVERSION_FUNCTIONS libcaes-20240413/m4/po.m40000644000175000017500000004461714533041421015424 0ustar00lordyestalordyesta# po.m4 serial 31 (gettext-0.20.2) dnl Copyright (C) 1995-2014, 2016, 2018-2020 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl dnl This file can be used in projects which are not available under dnl the GNU General Public License or the GNU Lesser General Public dnl License but which still want to provide support for the GNU gettext dnl functionality. dnl Please note that the actual code of the GNU gettext library is covered dnl by the GNU Lesser General Public License, and the rest of the GNU dnl gettext package is covered by the GNU General Public License. dnl They are *not* in the public domain. dnl Authors: dnl Ulrich Drepper , 1995-2000. dnl Bruno Haible , 2000-2003. AC_PREREQ([2.60]) dnl Checks for all prerequisites of the po subdirectory. AC_DEFUN([AM_PO_SUBDIRS], [ AC_REQUIRE([AC_PROG_MAKE_SET])dnl AC_REQUIRE([AC_PROG_INSTALL])dnl AC_REQUIRE([AC_PROG_MKDIR_P])dnl AC_REQUIRE([AC_PROG_SED])dnl AC_REQUIRE([AM_NLS])dnl dnl Release version of the gettext macros. This is used to ensure that dnl the gettext macros and po/Makefile.in.in are in sync. AC_SUBST([GETTEXT_MACRO_VERSION], [0.20]) dnl Perform the following tests also if --disable-nls has been given, dnl because they are needed for "make dist" to work. dnl Search for GNU msgfmt in the PATH. dnl The first test excludes Solaris msgfmt and early GNU msgfmt versions. dnl The second test excludes FreeBSD msgfmt. AM_PATH_PROG_WITH_TEST(MSGFMT, msgfmt, [$ac_dir/$ac_word --statistics /dev/null >&]AS_MESSAGE_LOG_FD[ 2>&1 && (if $ac_dir/$ac_word --statistics /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi)], :) AC_PATH_PROG([GMSGFMT], [gmsgfmt], [$MSGFMT]) dnl Test whether it is GNU msgfmt >= 0.15. changequote(,)dnl case `$GMSGFMT --version | sed 1q | sed -e 's,^[^0-9]*,,'` in '' | 0.[0-9] | 0.[0-9].* | 0.1[0-4] | 0.1[0-4].*) GMSGFMT_015=: ;; *) GMSGFMT_015=$GMSGFMT ;; esac changequote([,])dnl AC_SUBST([GMSGFMT_015]) dnl Search for GNU xgettext 0.12 or newer in the PATH. dnl The first test excludes Solaris xgettext and early GNU xgettext versions. dnl The second test excludes FreeBSD xgettext. AM_PATH_PROG_WITH_TEST(XGETTEXT, xgettext, [$ac_dir/$ac_word --omit-header --copyright-holder= --msgid-bugs-address= /dev/null >&]AS_MESSAGE_LOG_FD[ 2>&1 && (if $ac_dir/$ac_word --omit-header --copyright-holder= --msgid-bugs-address= /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi)], :) dnl Remove leftover from FreeBSD xgettext call. rm -f messages.po dnl Test whether it is GNU xgettext >= 0.15. changequote(,)dnl case `$XGETTEXT --version | sed 1q | sed -e 's,^[^0-9]*,,'` in '' | 0.[0-9] | 0.[0-9].* | 0.1[0-4] | 0.1[0-4].*) XGETTEXT_015=: ;; *) XGETTEXT_015=$XGETTEXT ;; esac changequote([,])dnl AC_SUBST([XGETTEXT_015]) dnl Search for GNU msgmerge 0.11 or newer in the PATH. AM_PATH_PROG_WITH_TEST(MSGMERGE, msgmerge, [$ac_dir/$ac_word --update -q /dev/null /dev/null >&]AS_MESSAGE_LOG_FD[ 2>&1], :) dnl Test whether it is GNU msgmerge >= 0.20. if LC_ALL=C $MSGMERGE --help | grep ' --for-msgfmt ' >/dev/null; then MSGMERGE_FOR_MSGFMT_OPTION='--for-msgfmt' else dnl Test whether it is GNU msgmerge >= 0.12. if LC_ALL=C $MSGMERGE --help | grep ' --no-fuzzy-matching ' >/dev/null; then MSGMERGE_FOR_MSGFMT_OPTION='--no-fuzzy-matching --no-location --quiet' else dnl With these old versions, $(MSGMERGE) $(MSGMERGE_FOR_MSGFMT_OPTION) is dnl slow. But this is not a big problem, as such old gettext versions are dnl hardly in use any more. MSGMERGE_FOR_MSGFMT_OPTION='--no-location --quiet' fi fi AC_SUBST([MSGMERGE_FOR_MSGFMT_OPTION]) dnl Support for AM_XGETTEXT_OPTION. test -n "${XGETTEXT_EXTRA_OPTIONS+set}" || XGETTEXT_EXTRA_OPTIONS= AC_SUBST([XGETTEXT_EXTRA_OPTIONS]) AC_CONFIG_COMMANDS([po-directories], [[ for ac_file in $CONFIG_FILES; do # Support "outfile[:infile[:infile...]]" case "$ac_file" in *:*) ac_file=`echo "$ac_file"|sed 's%:.*%%'` ;; esac # PO directories have a Makefile.in generated from Makefile.in.in. case "$ac_file" in */Makefile.in) # Adjust a relative srcdir. ac_dir=`echo "$ac_file"|sed 's%/[^/][^/]*$%%'` ac_dir_suffix=/`echo "$ac_dir"|sed 's%^\./%%'` ac_dots=`echo "$ac_dir_suffix"|sed 's%/[^/]*%../%g'` # In autoconf-2.13 it is called $ac_given_srcdir. # In autoconf-2.50 it is called $srcdir. test -n "$ac_given_srcdir" || ac_given_srcdir="$srcdir" case "$ac_given_srcdir" in .) top_srcdir=`echo $ac_dots|sed 's%/$%%'` ;; /*) top_srcdir="$ac_given_srcdir" ;; *) top_srcdir="$ac_dots$ac_given_srcdir" ;; esac # Treat a directory as a PO directory if and only if it has a # POTFILES.in file. This allows packages to have multiple PO # directories under different names or in different locations. if test -f "$ac_given_srcdir/$ac_dir/POTFILES.in"; then rm -f "$ac_dir/POTFILES" test -n "$as_me" && echo "$as_me: creating $ac_dir/POTFILES" || echo "creating $ac_dir/POTFILES" gt_tab=`printf '\t'` cat "$ac_given_srcdir/$ac_dir/POTFILES.in" | sed -e "/^#/d" -e "/^[ ${gt_tab}]*\$/d" -e "s,.*, $top_srcdir/& \\\\," | sed -e "\$s/\(.*\) \\\\/\1/" > "$ac_dir/POTFILES" POMAKEFILEDEPS="POTFILES.in" # ALL_LINGUAS, POFILES, UPDATEPOFILES, DUMMYPOFILES, GMOFILES depend # on $ac_dir but don't depend on user-specified configuration # parameters. if test -f "$ac_given_srcdir/$ac_dir/LINGUAS"; then # The LINGUAS file contains the set of available languages. if test -n "$OBSOLETE_ALL_LINGUAS"; then test -n "$as_me" && echo "$as_me: setting ALL_LINGUAS in configure.in is obsolete" || echo "setting ALL_LINGUAS in configure.in is obsolete" fi ALL_LINGUAS=`sed -e "/^#/d" -e "s/#.*//" "$ac_given_srcdir/$ac_dir/LINGUAS"` POMAKEFILEDEPS="$POMAKEFILEDEPS LINGUAS" else # The set of available languages was given in configure.in. ALL_LINGUAS=$OBSOLETE_ALL_LINGUAS fi # Compute POFILES # as $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).po) # Compute UPDATEPOFILES # as $(foreach lang, $(ALL_LINGUAS), $(lang).po-update) # Compute DUMMYPOFILES # as $(foreach lang, $(ALL_LINGUAS), $(lang).nop) # Compute GMOFILES # as $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).gmo) case "$ac_given_srcdir" in .) srcdirpre= ;; *) srcdirpre='$(srcdir)/' ;; esac POFILES= UPDATEPOFILES= DUMMYPOFILES= GMOFILES= for lang in $ALL_LINGUAS; do POFILES="$POFILES $srcdirpre$lang.po" UPDATEPOFILES="$UPDATEPOFILES $lang.po-update" DUMMYPOFILES="$DUMMYPOFILES $lang.nop" GMOFILES="$GMOFILES $srcdirpre$lang.gmo" done # CATALOGS depends on both $ac_dir and the user's LINGUAS # environment variable. INST_LINGUAS= if test -n "$ALL_LINGUAS"; then for presentlang in $ALL_LINGUAS; do useit=no if test "%UNSET%" != "$LINGUAS"; then desiredlanguages="$LINGUAS" else desiredlanguages="$ALL_LINGUAS" fi for desiredlang in $desiredlanguages; do # Use the presentlang catalog if desiredlang is # a. equal to presentlang, or # b. a variant of presentlang (because in this case, # presentlang can be used as a fallback for messages # which are not translated in the desiredlang catalog). case "$desiredlang" in "$presentlang"*) useit=yes;; esac done if test $useit = yes; then INST_LINGUAS="$INST_LINGUAS $presentlang" fi done fi CATALOGS= if test -n "$INST_LINGUAS"; then for lang in $INST_LINGUAS; do CATALOGS="$CATALOGS $lang.gmo" done fi test -n "$as_me" && echo "$as_me: creating $ac_dir/Makefile" || echo "creating $ac_dir/Makefile" sed -e "/^POTFILES =/r $ac_dir/POTFILES" -e "/^# Makevars/r $ac_given_srcdir/$ac_dir/Makevars" -e "s|@POFILES@|$POFILES|g" -e "s|@UPDATEPOFILES@|$UPDATEPOFILES|g" -e "s|@DUMMYPOFILES@|$DUMMYPOFILES|g" -e "s|@GMOFILES@|$GMOFILES|g" -e "s|@CATALOGS@|$CATALOGS|g" -e "s|@POMAKEFILEDEPS@|$POMAKEFILEDEPS|g" "$ac_dir/Makefile.in" > "$ac_dir/Makefile" for f in "$ac_given_srcdir/$ac_dir"/Rules-*; do if test -f "$f"; then case "$f" in *.orig | *.bak | *~) ;; *) cat "$f" >> "$ac_dir/Makefile" ;; esac fi done fi ;; esac done]], [# Capture the value of obsolete ALL_LINGUAS because we need it to compute # POFILES, UPDATEPOFILES, DUMMYPOFILES, GMOFILES, CATALOGS. OBSOLETE_ALL_LINGUAS="$ALL_LINGUAS" # Capture the value of LINGUAS because we need it to compute CATALOGS. LINGUAS="${LINGUAS-%UNSET%}" ]) ]) dnl Postprocesses a Makefile in a directory containing PO files. AC_DEFUN([AM_POSTPROCESS_PO_MAKEFILE], [ # When this code is run, in config.status, two variables have already been # set: # - OBSOLETE_ALL_LINGUAS is the value of LINGUAS set in configure.in, # - LINGUAS is the value of the environment variable LINGUAS at configure # time. changequote(,)dnl # Adjust a relative srcdir. ac_dir=`echo "$ac_file"|sed 's%/[^/][^/]*$%%'` ac_dir_suffix=/`echo "$ac_dir"|sed 's%^\./%%'` ac_dots=`echo "$ac_dir_suffix"|sed 's%/[^/]*%../%g'` # In autoconf-2.13 it is called $ac_given_srcdir. # In autoconf-2.50 it is called $srcdir. test -n "$ac_given_srcdir" || ac_given_srcdir="$srcdir" case "$ac_given_srcdir" in .) top_srcdir=`echo $ac_dots|sed 's%/$%%'` ;; /*) top_srcdir="$ac_given_srcdir" ;; *) top_srcdir="$ac_dots$ac_given_srcdir" ;; esac # Find a way to echo strings without interpreting backslash. if test "X`(echo '\t') 2>/dev/null`" = 'X\t'; then gt_echo='echo' else if test "X`(printf '%s\n' '\t') 2>/dev/null`" = 'X\t'; then gt_echo='printf %s\n' else echo_func () { cat < "$ac_file.tmp" tab=`printf '\t'` if grep -l '@TCLCATALOGS@' "$ac_file" > /dev/null; then # Add dependencies that cannot be formulated as a simple suffix rule. for lang in $ALL_LINGUAS; do frobbedlang=`echo $lang | sed -e 's/\..*$//' -e 'y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/'` cat >> "$ac_file.tmp" < /dev/null; then # Add dependencies that cannot be formulated as a simple suffix rule. for lang in $ALL_LINGUAS; do frobbedlang=`echo $lang | sed -e 's/_/-/g' -e 's/^sr-CS/sr-SP/' -e 's/@latin$/-Latn/' -e 's/@cyrillic$/-Cyrl/' -e 's/^sr-SP$/sr-SP-Latn/' -e 's/^uz-UZ$/uz-UZ-Latn/'` cat >> "$ac_file.tmp" <> "$ac_file.tmp" < arguments AC_DEFUN([AX_LIBCERROR_CHECK_LIB], [AS_IF( [test "x$ac_cv_enable_shared_libs" = xno || test "x$ac_cv_with_libcerror" = xno], [ac_cv_libcerror=no], [ac_cv_libcerror=check dnl Check if the directory provided as parameter exists dnl For both --with-libcerror which returns "yes" and --with-libcerror= which returns "" dnl treat them as auto-detection. AS_IF( [test "x$ac_cv_with_libcerror" != x && test "x$ac_cv_with_libcerror" != xauto-detect && test "x$ac_cv_with_libcerror" != xyes], [AS_IF( [test -d "$ac_cv_with_libcerror"], [CFLAGS="$CFLAGS -I${ac_cv_with_libcerror}/include" LDFLAGS="$LDFLAGS -L${ac_cv_with_libcerror}/lib"], [AC_MSG_FAILURE( [no such directory: $ac_cv_with_libcerror], [1]) ]) ], [dnl Check for a pkg-config file AS_IF( [test "x$cross_compiling" != "xyes" && test "x$PKGCONFIG" != "x"], [PKG_CHECK_MODULES( [libcerror], [libcerror >= 20120425], [ac_cv_libcerror=yes], [ac_cv_libcerror=check]) ]) AS_IF( [test "x$ac_cv_libcerror" = xyes], [ac_cv_libcerror_CPPFLAGS="$pkg_cv_libcerror_CFLAGS" ac_cv_libcerror_LIBADD="$pkg_cv_libcerror_LIBS"]) ]) AS_IF( [test "x$ac_cv_libcerror" = xcheck], [dnl Check for headers AC_CHECK_HEADERS([libcerror.h]) AS_IF( [test "x$ac_cv_header_libcerror_h" = xno], [ac_cv_libcerror=no], [dnl Check for the individual functions ac_cv_libcerror=yes AC_CHECK_LIB( cerror, libcerror_get_version, [ac_cv_libcerror_dummy=yes], [ac_cv_libcerror=no]) dnl Error functions AC_CHECK_LIB( cerror, libcerror_error_free, [ac_cv_libcerror_dummy=yes], [ac_cv_libcerror=no]) AC_CHECK_LIB( cerror, libcerror_error_set, [ac_cv_libcerror_dummy=yes], [ac_cv_libcerror=no]) AC_CHECK_LIB( cerror, libcerror_error_matches, [ac_cv_libcerror_dummy=yes], [ac_cv_libcerror=no]) AC_CHECK_LIB( cerror, libcerror_error_fprint, [ac_cv_libcerror_dummy=yes], [ac_cv_libcerror=no]) AC_CHECK_LIB( cerror, libcerror_error_sprint, [ac_cv_libcerror_dummy=yes], [ac_cv_libcerror=no]) AC_CHECK_LIB( cerror, libcerror_error_backtrace_fprint, [ac_cv_libcerror_dummy=yes], [ac_cv_libcerror=no]) AC_CHECK_LIB( cerror, libcerror_error_backtrace_sprint, [ac_cv_libcerror_dummy=yes], [ac_cv_libcerror=no]) dnl System error functions AC_CHECK_LIB( cerror, libcerror_system_set_error, [ac_cv_libcerror_dummy=yes], [ac_cv_libcerror=no]) ac_cv_libcerror_LIBADD="-lcerror"]) ]) AS_IF( [test "x$ac_cv_libcerror" != xyes && test "x$ac_cv_with_libcerror" != x && test "x$ac_cv_with_libcerror" != xauto-detect && test "x$ac_cv_with_libcerror" != xyes], [AC_MSG_FAILURE( [unable to find supported libcerror in directory: $ac_cv_with_libcerror], [1]) ]) ]) AS_IF( [test "x$ac_cv_libcerror" = xyes], [AC_DEFINE( [HAVE_LIBCERROR], [1], [Define to 1 if you have the `cerror' library (-lcerror).]) ]) AS_IF( [test "x$ac_cv_libcerror" = xyes], [AC_SUBST( [HAVE_LIBCERROR], [1]) ], [AC_SUBST( [HAVE_LIBCERROR], [0]) ]) ]) dnl Function to detect if libcerror dependencies are available AC_DEFUN([AX_LIBCERROR_CHECK_LOCAL], [dnl Headers included in libcerror/libcerror_error.c AC_CHECK_HEADERS([stdarg.h varargs.h]) AS_IF( [test "x$ac_cv_header_stdarg_h" != xyes && test "x$ac_cv_header_varargs_h" != xyes], [AC_MSG_FAILURE( [Missing headers: stdarg.h and varargs.h], [1]) ]) dnl Wide character string functions used in libcerror/libcerror_error.c AS_IF( [test "x$ac_cv_enable_wide_character_type" != xno], [AC_CHECK_FUNCS([wcstombs]) AS_IF( [test "x$ac_cv_func_wcstombs" != xyes], [AC_MSG_FAILURE( [Missing function: wcstombs], [1]) ]) ]) dnl Check for error string functions used in libcerror/libcerror_system.c AC_FUNC_STRERROR_R() AS_IF( [test "x$ac_cv_have_decl_strerror_r" != xyes], [AC_CHECK_FUNCS([strerror]) AS_IF( [test "x$ac_cv_func_strerror" != xyes], [AC_MSG_FAILURE( [Missing functions: strerror_r and strerror], [1]) ]) ]) ac_cv_libcerror_CPPFLAGS="-I../libcerror -I\$(top_srcdir)/libcerror"; ac_cv_libcerror_LIBADD="../libcerror/libcerror.la"; ac_cv_libcerror=local ]) dnl Function to detect how to enable libcerror AC_DEFUN([AX_LIBCERROR_CHECK_ENABLE], [AX_COMMON_ARG_WITH( [libcerror], [libcerror], [search for libcerror in includedir and libdir or in the specified DIR, or no if to use local version], [auto-detect], [DIR]) dnl Check for a shared library version AX_LIBCERROR_CHECK_LIB dnl Check if the dependencies for the local library version AS_IF( [test "x$ac_cv_libcerror" != xyes], [AX_LIBCERROR_CHECK_LOCAL AC_DEFINE( [HAVE_LOCAL_LIBCERROR], [1], [Define to 1 if the local version of libcerror is used.]) AC_SUBST( [HAVE_LOCAL_LIBCERROR], [1]) ]) AM_CONDITIONAL( [HAVE_LOCAL_LIBCERROR], [test "x$ac_cv_libcerror" = xlocal]) AS_IF( [test "x$ac_cv_libcerror_CPPFLAGS" != "x"], [AC_SUBST( [LIBCERROR_CPPFLAGS], [$ac_cv_libcerror_CPPFLAGS]) ]) AS_IF( [test "x$ac_cv_libcerror_LIBADD" != "x"], [AC_SUBST( [LIBCERROR_LIBADD], [$ac_cv_libcerror_LIBADD]) ]) AS_IF( [test "x$ac_cv_libcerror" = xyes], [AC_SUBST( [ax_libcerror_pc_libs_private], [-lcerror]) ]) AS_IF( [test "x$ac_cv_libcerror" = xyes], [AC_SUBST( [ax_libcerror_spec_requires], [libcerror]) AC_SUBST( [ax_libcerror_spec_build_requires], [libcerror-devel]) ]) ]) libcaes-20240413/m4/intlmacosx.m40000644000175000017500000000623514533041421017161 0ustar00lordyestalordyesta# intlmacosx.m4 serial 8 (gettext-0.20.2) dnl Copyright (C) 2004-2014, 2016, 2019-2020 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl dnl This file can be used in projects which are not available under dnl the GNU General Public License or the GNU Lesser General Public dnl License but which still want to provide support for the GNU gettext dnl functionality. dnl Please note that the actual code of the GNU gettext library is covered dnl by the GNU Lesser General Public License, and the rest of the GNU dnl gettext package is covered by the GNU General Public License. dnl They are *not* in the public domain. dnl Checks for special options needed on Mac OS X. dnl Defines INTL_MACOSX_LIBS. AC_DEFUN([gt_INTL_MACOSX], [ dnl Check for API introduced in Mac OS X 10.4. AC_CACHE_CHECK([for CFPreferencesCopyAppValue], [gt_cv_func_CFPreferencesCopyAppValue], [gt_save_LIBS="$LIBS" LIBS="$LIBS -Wl,-framework -Wl,CoreFoundation" AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[#include ]], [[CFPreferencesCopyAppValue(NULL, NULL)]])], [gt_cv_func_CFPreferencesCopyAppValue=yes], [gt_cv_func_CFPreferencesCopyAppValue=no]) LIBS="$gt_save_LIBS"]) if test $gt_cv_func_CFPreferencesCopyAppValue = yes; then AC_DEFINE([HAVE_CFPREFERENCESCOPYAPPVALUE], [1], [Define to 1 if you have the Mac OS X function CFPreferencesCopyAppValue in the CoreFoundation framework.]) fi dnl Don't check for the API introduced in Mac OS X 10.5, CFLocaleCopyCurrent, dnl because in macOS 10.13.4 it has the following behaviour: dnl When two or more languages are specified in the dnl "System Preferences > Language & Region > Preferred Languages" panel, dnl it returns en_CC where CC is the territory (even when English is not among dnl the preferred languages!). What we want instead is what dnl CFLocaleCopyCurrent returned in earlier macOS releases and what dnl CFPreferencesCopyAppValue still returns, namely ll_CC where ll is the dnl first among the preferred languages and CC is the territory. AC_CACHE_CHECK([for CFLocaleCopyPreferredLanguages], [gt_cv_func_CFLocaleCopyPreferredLanguages], [gt_save_LIBS="$LIBS" LIBS="$LIBS -Wl,-framework -Wl,CoreFoundation" AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[#include ]], [[CFLocaleCopyPreferredLanguages();]])], [gt_cv_func_CFLocaleCopyPreferredLanguages=yes], [gt_cv_func_CFLocaleCopyPreferredLanguages=no]) LIBS="$gt_save_LIBS"]) if test $gt_cv_func_CFLocaleCopyPreferredLanguages = yes; then AC_DEFINE([HAVE_CFLOCALECOPYPREFERREDLANGUAGES], [1], [Define to 1 if you have the Mac OS X function CFLocaleCopyPreferredLanguages in the CoreFoundation framework.]) fi INTL_MACOSX_LIBS= if test $gt_cv_func_CFPreferencesCopyAppValue = yes \ || test $gt_cv_func_CFLocaleCopyPreferredLanguages = yes; then INTL_MACOSX_LIBS="-Wl,-framework -Wl,CoreFoundation" fi AC_SUBST([INTL_MACOSX_LIBS]) ]) libcaes-20240413/m4/lt~obsolete.m40000644000175000017500000001400714606477623017370 0ustar00lordyestalordyesta# lt~obsolete.m4 -- aclocal satisfying obsolete definitions. -*-Autoconf-*- # # Copyright (C) 2004-2005, 2007, 2009, 2011-2019, 2021-2022 Free # Software Foundation, Inc. # Written by Scott James Remnant, 2004. # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 5 lt~obsolete.m4 # These exist entirely to fool aclocal when bootstrapping libtool. # # In the past libtool.m4 has provided macros via AC_DEFUN (or AU_DEFUN), # which have later been changed to m4_define as they aren't part of the # exported API, or moved to Autoconf or Automake where they belong. # # The trouble is, aclocal is a bit thick. It'll see the old AC_DEFUN # in /usr/share/aclocal/libtool.m4 and remember it, then when it sees us # using a macro with the same name in our local m4/libtool.m4 it'll # pull the old libtool.m4 in (it doesn't see our shiny new m4_define # and doesn't know about Autoconf macros at all.) # # So we provide this file, which has a silly filename so it's always # included after everything else. This provides aclocal with the # AC_DEFUNs it wants, but when m4 processes it, it doesn't do anything # because those macros already exist, or will be overwritten later. # We use AC_DEFUN over AU_DEFUN for compatibility with aclocal-1.6. # # Anytime we withdraw an AC_DEFUN or AU_DEFUN, remember to add it here. # Yes, that means every name once taken will need to remain here until # we give up compatibility with versions before 1.7, at which point # we need to keep only those names which we still refer to. # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTOBSOLETE_VERSION], [m4_if([1])]) m4_ifndef([AC_LIBTOOL_LINKER_OPTION], [AC_DEFUN([AC_LIBTOOL_LINKER_OPTION])]) m4_ifndef([AC_PROG_EGREP], [AC_DEFUN([AC_PROG_EGREP])]) m4_ifndef([_LT_AC_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_AC_PROG_ECHO_BACKSLASH])]) m4_ifndef([_LT_AC_SHELL_INIT], [AC_DEFUN([_LT_AC_SHELL_INIT])]) m4_ifndef([_LT_AC_SYS_LIBPATH_AIX], [AC_DEFUN([_LT_AC_SYS_LIBPATH_AIX])]) m4_ifndef([_LT_PROG_LTMAIN], [AC_DEFUN([_LT_PROG_LTMAIN])]) m4_ifndef([_LT_AC_TAGVAR], [AC_DEFUN([_LT_AC_TAGVAR])]) m4_ifndef([AC_LTDL_ENABLE_INSTALL], [AC_DEFUN([AC_LTDL_ENABLE_INSTALL])]) m4_ifndef([AC_LTDL_PREOPEN], [AC_DEFUN([AC_LTDL_PREOPEN])]) m4_ifndef([_LT_AC_SYS_COMPILER], [AC_DEFUN([_LT_AC_SYS_COMPILER])]) m4_ifndef([_LT_AC_LOCK], [AC_DEFUN([_LT_AC_LOCK])]) m4_ifndef([AC_LIBTOOL_SYS_OLD_ARCHIVE], [AC_DEFUN([AC_LIBTOOL_SYS_OLD_ARCHIVE])]) m4_ifndef([_LT_AC_TRY_DLOPEN_SELF], [AC_DEFUN([_LT_AC_TRY_DLOPEN_SELF])]) m4_ifndef([AC_LIBTOOL_PROG_CC_C_O], [AC_DEFUN([AC_LIBTOOL_PROG_CC_C_O])]) m4_ifndef([AC_LIBTOOL_SYS_HARD_LINK_LOCKS], [AC_DEFUN([AC_LIBTOOL_SYS_HARD_LINK_LOCKS])]) m4_ifndef([AC_LIBTOOL_OBJDIR], [AC_DEFUN([AC_LIBTOOL_OBJDIR])]) m4_ifndef([AC_LTDL_OBJDIR], [AC_DEFUN([AC_LTDL_OBJDIR])]) m4_ifndef([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH], [AC_DEFUN([AC_LIBTOOL_PROG_LD_HARDCODE_LIBPATH])]) m4_ifndef([AC_LIBTOOL_SYS_LIB_STRIP], [AC_DEFUN([AC_LIBTOOL_SYS_LIB_STRIP])]) m4_ifndef([AC_PATH_MAGIC], [AC_DEFUN([AC_PATH_MAGIC])]) m4_ifndef([AC_PROG_LD_GNU], [AC_DEFUN([AC_PROG_LD_GNU])]) m4_ifndef([AC_PROG_LD_RELOAD_FLAG], [AC_DEFUN([AC_PROG_LD_RELOAD_FLAG])]) m4_ifndef([AC_DEPLIBS_CHECK_METHOD], [AC_DEFUN([AC_DEPLIBS_CHECK_METHOD])]) m4_ifndef([AC_LIBTOOL_PROG_COMPILER_NO_RTTI], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_NO_RTTI])]) m4_ifndef([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE], [AC_DEFUN([AC_LIBTOOL_SYS_GLOBAL_SYMBOL_PIPE])]) m4_ifndef([AC_LIBTOOL_PROG_COMPILER_PIC], [AC_DEFUN([AC_LIBTOOL_PROG_COMPILER_PIC])]) m4_ifndef([AC_LIBTOOL_PROG_LD_SHLIBS], [AC_DEFUN([AC_LIBTOOL_PROG_LD_SHLIBS])]) m4_ifndef([AC_LIBTOOL_POSTDEP_PREDEP], [AC_DEFUN([AC_LIBTOOL_POSTDEP_PREDEP])]) m4_ifndef([LT_AC_PROG_EGREP], [AC_DEFUN([LT_AC_PROG_EGREP])]) m4_ifndef([LT_AC_PROG_SED], [AC_DEFUN([LT_AC_PROG_SED])]) m4_ifndef([_LT_CC_BASENAME], [AC_DEFUN([_LT_CC_BASENAME])]) m4_ifndef([_LT_COMPILER_BOILERPLATE], [AC_DEFUN([_LT_COMPILER_BOILERPLATE])]) m4_ifndef([_LT_LINKER_BOILERPLATE], [AC_DEFUN([_LT_LINKER_BOILERPLATE])]) m4_ifndef([_AC_PROG_LIBTOOL], [AC_DEFUN([_AC_PROG_LIBTOOL])]) m4_ifndef([AC_LIBTOOL_SETUP], [AC_DEFUN([AC_LIBTOOL_SETUP])]) m4_ifndef([_LT_AC_CHECK_DLFCN], [AC_DEFUN([_LT_AC_CHECK_DLFCN])]) m4_ifndef([AC_LIBTOOL_SYS_DYNAMIC_LINKER], [AC_DEFUN([AC_LIBTOOL_SYS_DYNAMIC_LINKER])]) m4_ifndef([_LT_AC_TAGCONFIG], [AC_DEFUN([_LT_AC_TAGCONFIG])]) m4_ifndef([AC_DISABLE_FAST_INSTALL], [AC_DEFUN([AC_DISABLE_FAST_INSTALL])]) m4_ifndef([_LT_AC_LANG_CXX], [AC_DEFUN([_LT_AC_LANG_CXX])]) m4_ifndef([_LT_AC_LANG_F77], [AC_DEFUN([_LT_AC_LANG_F77])]) m4_ifndef([_LT_AC_LANG_GCJ], [AC_DEFUN([_LT_AC_LANG_GCJ])]) m4_ifndef([AC_LIBTOOL_LANG_C_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_C_CONFIG])]) m4_ifndef([_LT_AC_LANG_C_CONFIG], [AC_DEFUN([_LT_AC_LANG_C_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_CXX_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_CXX_CONFIG])]) m4_ifndef([_LT_AC_LANG_CXX_CONFIG], [AC_DEFUN([_LT_AC_LANG_CXX_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_F77_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_F77_CONFIG])]) m4_ifndef([_LT_AC_LANG_F77_CONFIG], [AC_DEFUN([_LT_AC_LANG_F77_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_GCJ_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_GCJ_CONFIG])]) m4_ifndef([_LT_AC_LANG_GCJ_CONFIG], [AC_DEFUN([_LT_AC_LANG_GCJ_CONFIG])]) m4_ifndef([AC_LIBTOOL_LANG_RC_CONFIG], [AC_DEFUN([AC_LIBTOOL_LANG_RC_CONFIG])]) m4_ifndef([_LT_AC_LANG_RC_CONFIG], [AC_DEFUN([_LT_AC_LANG_RC_CONFIG])]) m4_ifndef([AC_LIBTOOL_CONFIG], [AC_DEFUN([AC_LIBTOOL_CONFIG])]) m4_ifndef([_LT_AC_FILE_LTDLL_C], [AC_DEFUN([_LT_AC_FILE_LTDLL_C])]) m4_ifndef([_LT_REQUIRED_DARWIN_CHECKS], [AC_DEFUN([_LT_REQUIRED_DARWIN_CHECKS])]) m4_ifndef([_LT_AC_PROG_CXXCPP], [AC_DEFUN([_LT_AC_PROG_CXXCPP])]) m4_ifndef([_LT_PREPARE_SED_QUOTE_VARS], [AC_DEFUN([_LT_PREPARE_SED_QUOTE_VARS])]) m4_ifndef([_LT_PROG_ECHO_BACKSLASH], [AC_DEFUN([_LT_PROG_ECHO_BACKSLASH])]) m4_ifndef([_LT_PROG_F77], [AC_DEFUN([_LT_PROG_F77])]) m4_ifndef([_LT_PROG_FC], [AC_DEFUN([_LT_PROG_FC])]) m4_ifndef([_LT_PROG_CXX], [AC_DEFUN([_LT_PROG_CXX])]) libcaes-20240413/m4/lib-link.m40000644000175000017500000010376214533041421016504 0ustar00lordyestalordyesta# lib-link.m4 serial 31 dnl Copyright (C) 2001-2020 Free Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. AC_PREREQ([2.61]) dnl AC_LIB_LINKFLAGS(name [, dependencies]) searches for libname and dnl the libraries corresponding to explicit and implicit dependencies. dnl Sets and AC_SUBSTs the LIB${NAME} and LTLIB${NAME} variables and dnl augments the CPPFLAGS variable. dnl Sets and AC_SUBSTs the LIB${NAME}_PREFIX variable to nonempty if libname dnl was found in ${LIB${NAME}_PREFIX}/$acl_libdirstem. AC_DEFUN([AC_LIB_LINKFLAGS], [ AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) AC_REQUIRE([AC_LIB_RPATH]) pushdef([Name],[m4_translit([$1],[./+-], [____])]) pushdef([NAME],[m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./+-], [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])]) AC_CACHE_CHECK([how to link with lib[]$1], [ac_cv_lib[]Name[]_libs], [ AC_LIB_LINKFLAGS_BODY([$1], [$2]) ac_cv_lib[]Name[]_libs="$LIB[]NAME" ac_cv_lib[]Name[]_ltlibs="$LTLIB[]NAME" ac_cv_lib[]Name[]_cppflags="$INC[]NAME" ac_cv_lib[]Name[]_prefix="$LIB[]NAME[]_PREFIX" ]) LIB[]NAME="$ac_cv_lib[]Name[]_libs" LTLIB[]NAME="$ac_cv_lib[]Name[]_ltlibs" INC[]NAME="$ac_cv_lib[]Name[]_cppflags" LIB[]NAME[]_PREFIX="$ac_cv_lib[]Name[]_prefix" AC_LIB_APPENDTOVAR([CPPFLAGS], [$INC]NAME) AC_SUBST([LIB]NAME) AC_SUBST([LTLIB]NAME) AC_SUBST([LIB]NAME[_PREFIX]) dnl Also set HAVE_LIB[]NAME so that AC_LIB_HAVE_LINKFLAGS can reuse the dnl results of this search when this library appears as a dependency. HAVE_LIB[]NAME=yes popdef([NAME]) popdef([Name]) ]) dnl AC_LIB_HAVE_LINKFLAGS(name, dependencies, includes, testcode, [missing-message]) dnl searches for libname and the libraries corresponding to explicit and dnl implicit dependencies, together with the specified include files and dnl the ability to compile and link the specified testcode. The missing-message dnl defaults to 'no' and may contain additional hints for the user. dnl If found, it sets and AC_SUBSTs HAVE_LIB${NAME}=yes and the LIB${NAME} dnl and LTLIB${NAME} variables and augments the CPPFLAGS variable, and dnl #defines HAVE_LIB${NAME} to 1. Otherwise, it sets and AC_SUBSTs dnl HAVE_LIB${NAME}=no and LIB${NAME} and LTLIB${NAME} to empty. dnl Sets and AC_SUBSTs the LIB${NAME}_PREFIX variable to nonempty if libname dnl was found in ${LIB${NAME}_PREFIX}/$acl_libdirstem. AC_DEFUN([AC_LIB_HAVE_LINKFLAGS], [ AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) AC_REQUIRE([AC_LIB_RPATH]) pushdef([Name],[m4_translit([$1],[./+-], [____])]) pushdef([NAME],[m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./+-], [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])]) dnl Search for lib[]Name and define LIB[]NAME, LTLIB[]NAME and INC[]NAME dnl accordingly. AC_LIB_LINKFLAGS_BODY([$1], [$2]) dnl Add $INC[]NAME to CPPFLAGS before performing the following checks, dnl because if the user has installed lib[]Name and not disabled its use dnl via --without-lib[]Name-prefix, he wants to use it. ac_save_CPPFLAGS="$CPPFLAGS" AC_LIB_APPENDTOVAR([CPPFLAGS], [$INC]NAME) AC_CACHE_CHECK([for lib[]$1], [ac_cv_lib[]Name], [ ac_save_LIBS="$LIBS" dnl If $LIB[]NAME contains some -l options, add it to the end of LIBS, dnl because these -l options might require -L options that are present in dnl LIBS. -l options benefit only from the -L options listed before it. dnl Otherwise, add it to the front of LIBS, because it may be a static dnl library that depends on another static library that is present in LIBS. dnl Static libraries benefit only from the static libraries listed after dnl it. case " $LIB[]NAME" in *" -l"*) LIBS="$LIBS $LIB[]NAME" ;; *) LIBS="$LIB[]NAME $LIBS" ;; esac AC_LINK_IFELSE( [AC_LANG_PROGRAM([[$3]], [[$4]])], [ac_cv_lib[]Name=yes], [ac_cv_lib[]Name='m4_if([$5], [], [no], [[$5]])']) LIBS="$ac_save_LIBS" ]) if test "$ac_cv_lib[]Name" = yes; then HAVE_LIB[]NAME=yes AC_DEFINE([HAVE_LIB]NAME, 1, [Define if you have the lib][$1 library.]) AC_MSG_CHECKING([how to link with lib[]$1]) AC_MSG_RESULT([$LIB[]NAME]) else HAVE_LIB[]NAME=no dnl If $LIB[]NAME didn't lead to a usable library, we don't need dnl $INC[]NAME either. CPPFLAGS="$ac_save_CPPFLAGS" LIB[]NAME= LTLIB[]NAME= LIB[]NAME[]_PREFIX= fi AC_SUBST([HAVE_LIB]NAME) AC_SUBST([LIB]NAME) AC_SUBST([LTLIB]NAME) AC_SUBST([LIB]NAME[_PREFIX]) popdef([NAME]) popdef([Name]) ]) dnl Determine the platform dependent parameters needed to use rpath: dnl acl_libext, dnl acl_shlibext, dnl acl_libname_spec, dnl acl_library_names_spec, dnl acl_hardcode_libdir_flag_spec, dnl acl_hardcode_libdir_separator, dnl acl_hardcode_direct, dnl acl_hardcode_minus_L. AC_DEFUN([AC_LIB_RPATH], [ dnl Complain if config.rpath is missing. AC_REQUIRE_AUX_FILE([config.rpath]) AC_REQUIRE([AC_PROG_CC]) dnl we use $CC, $GCC, $LDFLAGS AC_REQUIRE([AC_LIB_PROG_LD]) dnl we use $LD, $with_gnu_ld AC_REQUIRE([AC_CANONICAL_HOST]) dnl we use $host AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT]) dnl we use $ac_aux_dir AC_CACHE_CHECK([for shared library run path origin], [acl_cv_rpath], [ CC="$CC" GCC="$GCC" LDFLAGS="$LDFLAGS" LD="$LD" with_gnu_ld="$with_gnu_ld" \ ${CONFIG_SHELL-/bin/sh} "$ac_aux_dir/config.rpath" "$host" > conftest.sh . ./conftest.sh rm -f ./conftest.sh acl_cv_rpath=done ]) wl="$acl_cv_wl" acl_libext="$acl_cv_libext" acl_shlibext="$acl_cv_shlibext" acl_libname_spec="$acl_cv_libname_spec" acl_library_names_spec="$acl_cv_library_names_spec" acl_hardcode_libdir_flag_spec="$acl_cv_hardcode_libdir_flag_spec" acl_hardcode_libdir_separator="$acl_cv_hardcode_libdir_separator" acl_hardcode_direct="$acl_cv_hardcode_direct" acl_hardcode_minus_L="$acl_cv_hardcode_minus_L" dnl Determine whether the user wants rpath handling at all. AC_ARG_ENABLE([rpath], [ --disable-rpath do not hardcode runtime library paths], :, enable_rpath=yes) ]) dnl AC_LIB_FROMPACKAGE(name, package) dnl declares that libname comes from the given package. The configure file dnl will then not have a --with-libname-prefix option but a dnl --with-package-prefix option. Several libraries can come from the same dnl package. This declaration must occur before an AC_LIB_LINKFLAGS or similar dnl macro call that searches for libname. AC_DEFUN([AC_LIB_FROMPACKAGE], [ pushdef([NAME],[m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./+-], [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])]) define([acl_frompackage_]NAME, [$2]) popdef([NAME]) pushdef([PACK],[$2]) pushdef([PACKUP],[m4_translit(PACK,[abcdefghijklmnopqrstuvwxyz./+-], [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])]) define([acl_libsinpackage_]PACKUP, m4_ifdef([acl_libsinpackage_]PACKUP, [m4_defn([acl_libsinpackage_]PACKUP)[, ]],)[lib$1]) popdef([PACKUP]) popdef([PACK]) ]) dnl AC_LIB_LINKFLAGS_BODY(name [, dependencies]) searches for libname and dnl the libraries corresponding to explicit and implicit dependencies. dnl Sets the LIB${NAME}, LTLIB${NAME} and INC${NAME} variables. dnl Also, sets the LIB${NAME}_PREFIX variable to nonempty if libname was found dnl in ${LIB${NAME}_PREFIX}/$acl_libdirstem. AC_DEFUN([AC_LIB_LINKFLAGS_BODY], [ AC_REQUIRE([AC_LIB_PREPARE_MULTILIB]) pushdef([NAME],[m4_translit([$1],[abcdefghijklmnopqrstuvwxyz./+-], [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])]) pushdef([PACK],[m4_ifdef([acl_frompackage_]NAME, [acl_frompackage_]NAME, lib[$1])]) pushdef([PACKUP],[m4_translit(PACK,[abcdefghijklmnopqrstuvwxyz./+-], [ABCDEFGHIJKLMNOPQRSTUVWXYZ____])]) pushdef([PACKLIBS],[m4_ifdef([acl_frompackage_]NAME, [acl_libsinpackage_]PACKUP, lib[$1])]) dnl By default, look in $includedir and $libdir. use_additional=yes AC_LIB_WITH_FINAL_PREFIX([ eval additional_includedir=\"$includedir\" eval additional_libdir=\"$libdir\" eval additional_libdir2=\"$exec_prefix/$acl_libdirstem2\" eval additional_libdir3=\"$exec_prefix/$acl_libdirstem3\" ]) AC_ARG_WITH(PACK[-prefix], [[ --with-]]PACK[[-prefix[=DIR] search for ]PACKLIBS[ in DIR/include and DIR/lib --without-]]PACK[[-prefix don't search for ]PACKLIBS[ in includedir and libdir]], [ if test "X$withval" = "Xno"; then use_additional=no else if test "X$withval" = "X"; then AC_LIB_WITH_FINAL_PREFIX([ eval additional_includedir=\"$includedir\" eval additional_libdir=\"$libdir\" eval additional_libdir2=\"$exec_prefix/$acl_libdirstem2\" eval additional_libdir3=\"$exec_prefix/$acl_libdirstem3\" ]) else additional_includedir="$withval/include" additional_libdir="$withval/$acl_libdirstem" additional_libdir2="$withval/$acl_libdirstem2" additional_libdir3="$withval/$acl_libdirstem3" fi fi ]) if test "X$additional_libdir2" = "X$additional_libdir"; then additional_libdir2= fi if test "X$additional_libdir3" = "X$additional_libdir"; then additional_libdir3= fi dnl Search the library and its dependencies in $additional_libdir and dnl $LDFLAGS. Using breadth-first-seach. LIB[]NAME= LTLIB[]NAME= INC[]NAME= LIB[]NAME[]_PREFIX= dnl HAVE_LIB${NAME} is an indicator that LIB${NAME}, LTLIB${NAME} have been dnl computed. So it has to be reset here. HAVE_LIB[]NAME= rpathdirs= ltrpathdirs= names_already_handled= names_next_round='$1 $2' while test -n "$names_next_round"; do names_this_round="$names_next_round" names_next_round= for name in $names_this_round; do already_handled= for n in $names_already_handled; do if test "$n" = "$name"; then already_handled=yes break fi done if test -z "$already_handled"; then names_already_handled="$names_already_handled $name" dnl See if it was already located by an earlier AC_LIB_LINKFLAGS dnl or AC_LIB_HAVE_LINKFLAGS call. uppername=`echo "$name" | sed -e 'y|abcdefghijklmnopqrstuvwxyz./+-|ABCDEFGHIJKLMNOPQRSTUVWXYZ____|'` eval value=\"\$HAVE_LIB$uppername\" if test -n "$value"; then if test "$value" = yes; then eval value=\"\$LIB$uppername\" test -z "$value" || LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$value" eval value=\"\$LTLIB$uppername\" test -z "$value" || LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }$value" else dnl An earlier call to AC_LIB_HAVE_LINKFLAGS has determined dnl that this library doesn't exist. So just drop it. : fi else dnl Search the library lib$name in $additional_libdir and $LDFLAGS dnl and the already constructed $LIBNAME/$LTLIBNAME. found_dir= found_la= found_so= found_a= eval libname=\"$acl_libname_spec\" # typically: libname=lib$name if test -n "$acl_shlibext"; then shrext=".$acl_shlibext" # typically: shrext=.so else shrext= fi if test $use_additional = yes; then for additional_libdir_variable in additional_libdir additional_libdir2 additional_libdir3; do if test "X$found_dir" = "X"; then eval dir=\$$additional_libdir_variable if test -n "$dir"; then dnl The same code as in the loop below: dnl First look for a shared library. if test -n "$acl_shlibext"; then if test -f "$dir/$libname$shrext" && acl_is_expected_elfclass < "$dir/$libname$shrext"; then found_dir="$dir" found_so="$dir/$libname$shrext" else if test "$acl_library_names_spec" = '$libname$shrext$versuffix'; then ver=`(cd "$dir" && \ for f in "$libname$shrext".*; do echo "$f"; done \ | sed -e "s,^$libname$shrext\\\\.,," \ | sort -t '.' -n -r -k1,1 -k2,2 -k3,3 -k4,4 -k5,5 \ | sed 1q ) 2>/dev/null` if test -n "$ver" && test -f "$dir/$libname$shrext.$ver" && acl_is_expected_elfclass < "$dir/$libname$shrext.$ver"; then found_dir="$dir" found_so="$dir/$libname$shrext.$ver" fi else eval library_names=\"$acl_library_names_spec\" for f in $library_names; do if test -f "$dir/$f" && acl_is_expected_elfclass < "$dir/$f"; then found_dir="$dir" found_so="$dir/$f" break fi done fi fi fi dnl Then look for a static library. if test "X$found_dir" = "X"; then if test -f "$dir/$libname.$acl_libext" && ${AR-ar} -p "$dir/$libname.$acl_libext" | acl_is_expected_elfclass; then found_dir="$dir" found_a="$dir/$libname.$acl_libext" fi fi if test "X$found_dir" != "X"; then if test -f "$dir/$libname.la"; then found_la="$dir/$libname.la" fi fi fi fi done fi if test "X$found_dir" = "X"; then for x in $LDFLAGS $LTLIB[]NAME; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) case "$x" in -L*) dir=`echo "X$x" | sed -e 's/^X-L//'` dnl First look for a shared library. if test -n "$acl_shlibext"; then if test -f "$dir/$libname$shrext" && acl_is_expected_elfclass < "$dir/$libname$shrext"; then found_dir="$dir" found_so="$dir/$libname$shrext" else if test "$acl_library_names_spec" = '$libname$shrext$versuffix'; then ver=`(cd "$dir" && \ for f in "$libname$shrext".*; do echo "$f"; done \ | sed -e "s,^$libname$shrext\\\\.,," \ | sort -t '.' -n -r -k1,1 -k2,2 -k3,3 -k4,4 -k5,5 \ | sed 1q ) 2>/dev/null` if test -n "$ver" && test -f "$dir/$libname$shrext.$ver" && acl_is_expected_elfclass < "$dir/$libname$shrext.$ver"; then found_dir="$dir" found_so="$dir/$libname$shrext.$ver" fi else eval library_names=\"$acl_library_names_spec\" for f in $library_names; do if test -f "$dir/$f" && acl_is_expected_elfclass < "$dir/$f"; then found_dir="$dir" found_so="$dir/$f" break fi done fi fi fi dnl Then look for a static library. if test "X$found_dir" = "X"; then if test -f "$dir/$libname.$acl_libext" && ${AR-ar} -p "$dir/$libname.$acl_libext" | acl_is_expected_elfclass; then found_dir="$dir" found_a="$dir/$libname.$acl_libext" fi fi if test "X$found_dir" != "X"; then if test -f "$dir/$libname.la"; then found_la="$dir/$libname.la" fi fi ;; esac if test "X$found_dir" != "X"; then break fi done fi if test "X$found_dir" != "X"; then dnl Found the library. LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-L$found_dir -l$name" if test "X$found_so" != "X"; then dnl Linking with a shared library. We attempt to hardcode its dnl directory into the executable's runpath, unless it's the dnl standard /usr/lib. if test "$enable_rpath" = no \ || test "X$found_dir" = "X/usr/$acl_libdirstem" \ || test "X$found_dir" = "X/usr/$acl_libdirstem2" \ || test "X$found_dir" = "X/usr/$acl_libdirstem3"; then dnl No hardcoding is needed. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so" else dnl Use an explicit option to hardcode DIR into the resulting dnl binary. dnl Potentially add DIR to ltrpathdirs. dnl The ltrpathdirs will be appended to $LTLIBNAME at the end. haveit= for x in $ltrpathdirs; do if test "X$x" = "X$found_dir"; then haveit=yes break fi done if test -z "$haveit"; then ltrpathdirs="$ltrpathdirs $found_dir" fi dnl The hardcoding into $LIBNAME is system dependent. if test "$acl_hardcode_direct" = yes; then dnl Using DIR/libNAME.so during linking hardcodes DIR into the dnl resulting binary. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so" else if test -n "$acl_hardcode_libdir_flag_spec" && test "$acl_hardcode_minus_L" = no; then dnl Use an explicit option to hardcode DIR into the resulting dnl binary. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so" dnl Potentially add DIR to rpathdirs. dnl The rpathdirs will be appended to $LIBNAME at the end. haveit= for x in $rpathdirs; do if test "X$x" = "X$found_dir"; then haveit=yes break fi done if test -z "$haveit"; then rpathdirs="$rpathdirs $found_dir" fi else dnl Rely on "-L$found_dir". dnl But don't add it if it's already contained in the LDFLAGS dnl or the already constructed $LIBNAME haveit= for x in $LDFLAGS $LIB[]NAME; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) if test "X$x" = "X-L$found_dir"; then haveit=yes break fi done if test -z "$haveit"; then LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-L$found_dir" fi if test "$acl_hardcode_minus_L" != no; then dnl FIXME: Not sure whether we should use dnl "-L$found_dir -l$name" or "-L$found_dir $found_so" dnl here. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_so" else dnl We cannot use $acl_hardcode_runpath_var and LD_RUN_PATH dnl here, because this doesn't fit in flags passed to the dnl compiler. So give up. No hardcoding. This affects only dnl very old systems. dnl FIXME: Not sure whether we should use dnl "-L$found_dir -l$name" or "-L$found_dir $found_so" dnl here. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-l$name" fi fi fi fi else if test "X$found_a" != "X"; then dnl Linking with a static library. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$found_a" else dnl We shouldn't come here, but anyway it's good to have a dnl fallback. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-L$found_dir -l$name" fi fi dnl Assume the include files are nearby. additional_includedir= case "$found_dir" in */$acl_libdirstem | */$acl_libdirstem/) basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e "s,/$acl_libdirstem/"'*$,,'` if test "$name" = '$1'; then LIB[]NAME[]_PREFIX="$basedir" fi additional_includedir="$basedir/include" ;; */$acl_libdirstem2 | */$acl_libdirstem2/) basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e "s,/$acl_libdirstem2/"'*$,,'` if test "$name" = '$1'; then LIB[]NAME[]_PREFIX="$basedir" fi additional_includedir="$basedir/include" ;; */$acl_libdirstem3 | */$acl_libdirstem3/) basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e "s,/$acl_libdirstem3/"'*$,,'` if test "$name" = '$1'; then LIB[]NAME[]_PREFIX="$basedir" fi additional_includedir="$basedir/include" ;; esac if test "X$additional_includedir" != "X"; then dnl Potentially add $additional_includedir to $INCNAME. dnl But don't add it dnl 1. if it's the standard /usr/include, dnl 2. if it's /usr/local/include and we are using GCC on Linux, dnl 3. if it's already present in $CPPFLAGS or the already dnl constructed $INCNAME, dnl 4. if it doesn't exist as a directory. if test "X$additional_includedir" != "X/usr/include"; then haveit= if test "X$additional_includedir" = "X/usr/local/include"; then if test -n "$GCC"; then case $host_os in linux* | gnu* | k*bsd*-gnu) haveit=yes;; esac fi fi if test -z "$haveit"; then for x in $CPPFLAGS $INC[]NAME; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) if test "X$x" = "X-I$additional_includedir"; then haveit=yes break fi done if test -z "$haveit"; then if test -d "$additional_includedir"; then dnl Really add $additional_includedir to $INCNAME. INC[]NAME="${INC[]NAME}${INC[]NAME:+ }-I$additional_includedir" fi fi fi fi fi dnl Look for dependencies. if test -n "$found_la"; then dnl Read the .la file. It defines the variables dnl dlname, library_names, old_library, dependency_libs, current, dnl age, revision, installed, dlopen, dlpreopen, libdir. save_libdir="$libdir" case "$found_la" in */* | *\\*) . "$found_la" ;; *) . "./$found_la" ;; esac libdir="$save_libdir" dnl We use only dependency_libs. for dep in $dependency_libs; do case "$dep" in -L*) dependency_libdir=`echo "X$dep" | sed -e 's/^X-L//'` dnl Potentially add $dependency_libdir to $LIBNAME and $LTLIBNAME. dnl But don't add it dnl 1. if it's the standard /usr/lib, dnl 2. if it's /usr/local/lib and we are using GCC on Linux, dnl 3. if it's already present in $LDFLAGS or the already dnl constructed $LIBNAME, dnl 4. if it doesn't exist as a directory. if test "X$dependency_libdir" != "X/usr/$acl_libdirstem" \ && test "X$dependency_libdir" != "X/usr/$acl_libdirstem2" \ && test "X$dependency_libdir" != "X/usr/$acl_libdirstem3"; then haveit= if test "X$dependency_libdir" = "X/usr/local/$acl_libdirstem" \ || test "X$dependency_libdir" = "X/usr/local/$acl_libdirstem2" \ || test "X$dependency_libdir" = "X/usr/local/$acl_libdirstem3"; then if test -n "$GCC"; then case $host_os in linux* | gnu* | k*bsd*-gnu) haveit=yes;; esac fi fi if test -z "$haveit"; then haveit= for x in $LDFLAGS $LIB[]NAME; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) if test "X$x" = "X-L$dependency_libdir"; then haveit=yes break fi done if test -z "$haveit"; then if test -d "$dependency_libdir"; then dnl Really add $dependency_libdir to $LIBNAME. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-L$dependency_libdir" fi fi haveit= for x in $LDFLAGS $LTLIB[]NAME; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) if test "X$x" = "X-L$dependency_libdir"; then haveit=yes break fi done if test -z "$haveit"; then if test -d "$dependency_libdir"; then dnl Really add $dependency_libdir to $LTLIBNAME. LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-L$dependency_libdir" fi fi fi fi ;; -R*) dir=`echo "X$dep" | sed -e 's/^X-R//'` if test "$enable_rpath" != no; then dnl Potentially add DIR to rpathdirs. dnl The rpathdirs will be appended to $LIBNAME at the end. haveit= for x in $rpathdirs; do if test "X$x" = "X$dir"; then haveit=yes break fi done if test -z "$haveit"; then rpathdirs="$rpathdirs $dir" fi dnl Potentially add DIR to ltrpathdirs. dnl The ltrpathdirs will be appended to $LTLIBNAME at the end. haveit= for x in $ltrpathdirs; do if test "X$x" = "X$dir"; then haveit=yes break fi done if test -z "$haveit"; then ltrpathdirs="$ltrpathdirs $dir" fi fi ;; -l*) dnl Handle this in the next round. names_next_round="$names_next_round "`echo "X$dep" | sed -e 's/^X-l//'` ;; *.la) dnl Handle this in the next round. Throw away the .la's dnl directory; it is already contained in a preceding -L dnl option. names_next_round="$names_next_round "`echo "X$dep" | sed -e 's,^X.*/,,' -e 's,^lib,,' -e 's,\.la$,,'` ;; *) dnl Most likely an immediate library name. LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$dep" LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }$dep" ;; esac done fi else dnl Didn't find the library; assume it is in the system directories dnl known to the linker and runtime loader. (All the system dnl directories known to the linker should also be known to the dnl runtime loader, otherwise the system is severely misconfigured.) LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }-l$name" LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-l$name" fi fi fi done done if test "X$rpathdirs" != "X"; then if test -n "$acl_hardcode_libdir_separator"; then dnl Weird platform: only the last -rpath option counts, the user must dnl pass all path elements in one option. We can arrange that for a dnl single library, but not when more than one $LIBNAMEs are used. alldirs= for found_dir in $rpathdirs; do alldirs="${alldirs}${alldirs:+$acl_hardcode_libdir_separator}$found_dir" done dnl Note: acl_hardcode_libdir_flag_spec uses $libdir and $wl. acl_save_libdir="$libdir" libdir="$alldirs" eval flag=\"$acl_hardcode_libdir_flag_spec\" libdir="$acl_save_libdir" LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$flag" else dnl The -rpath options are cumulative. for found_dir in $rpathdirs; do acl_save_libdir="$libdir" libdir="$found_dir" eval flag=\"$acl_hardcode_libdir_flag_spec\" libdir="$acl_save_libdir" LIB[]NAME="${LIB[]NAME}${LIB[]NAME:+ }$flag" done fi fi if test "X$ltrpathdirs" != "X"; then dnl When using libtool, the option that works for both libraries and dnl executables is -R. The -R options are cumulative. for found_dir in $ltrpathdirs; do LTLIB[]NAME="${LTLIB[]NAME}${LTLIB[]NAME:+ }-R$found_dir" done fi popdef([PACKLIBS]) popdef([PACKUP]) popdef([PACK]) popdef([NAME]) ]) dnl AC_LIB_APPENDTOVAR(VAR, CONTENTS) appends the elements of CONTENTS to VAR, dnl unless already present in VAR. dnl Works only for CPPFLAGS, not for LIB* variables because that sometimes dnl contains two or three consecutive elements that belong together. AC_DEFUN([AC_LIB_APPENDTOVAR], [ for element in [$2]; do haveit= for x in $[$1]; do AC_LIB_WITH_FINAL_PREFIX([eval x=\"$x\"]) if test "X$x" = "X$element"; then haveit=yes break fi done if test -z "$haveit"; then [$1]="${[$1]}${[$1]:+ }$element" fi done ]) dnl For those cases where a variable contains several -L and -l options dnl referring to unknown libraries and directories, this macro determines the dnl necessary additional linker options for the runtime path. dnl AC_LIB_LINKFLAGS_FROM_LIBS([LDADDVAR], [LIBSVALUE], [USE-LIBTOOL]) dnl sets LDADDVAR to linker options needed together with LIBSVALUE. dnl If USE-LIBTOOL evaluates to non-empty, linking with libtool is assumed, dnl otherwise linking without libtool is assumed. AC_DEFUN([AC_LIB_LINKFLAGS_FROM_LIBS], [ AC_REQUIRE([AC_LIB_RPATH]) AC_REQUIRE([AC_LIB_PREPARE_MULTILIB]) $1= if test "$enable_rpath" != no; then if test -n "$acl_hardcode_libdir_flag_spec" && test "$acl_hardcode_minus_L" = no; then dnl Use an explicit option to hardcode directories into the resulting dnl binary. rpathdirs= next= for opt in $2; do if test -n "$next"; then dir="$next" dnl No need to hardcode the standard /usr/lib. if test "X$dir" != "X/usr/$acl_libdirstem" \ && test "X$dir" != "X/usr/$acl_libdirstem2" \ && test "X$dir" != "X/usr/$acl_libdirstem3"; then rpathdirs="$rpathdirs $dir" fi next= else case $opt in -L) next=yes ;; -L*) dir=`echo "X$opt" | sed -e 's,^X-L,,'` dnl No need to hardcode the standard /usr/lib. if test "X$dir" != "X/usr/$acl_libdirstem" \ && test "X$dir" != "X/usr/$acl_libdirstem2" \ && test "X$dir" != "X/usr/$acl_libdirstem3"; then rpathdirs="$rpathdirs $dir" fi next= ;; *) next= ;; esac fi done if test "X$rpathdirs" != "X"; then if test -n ""$3""; then dnl libtool is used for linking. Use -R options. for dir in $rpathdirs; do $1="${$1}${$1:+ }-R$dir" done else dnl The linker is used for linking directly. if test -n "$acl_hardcode_libdir_separator"; then dnl Weird platform: only the last -rpath option counts, the user dnl must pass all path elements in one option. alldirs= for dir in $rpathdirs; do alldirs="${alldirs}${alldirs:+$acl_hardcode_libdir_separator}$dir" done acl_save_libdir="$libdir" libdir="$alldirs" eval flag=\"$acl_hardcode_libdir_flag_spec\" libdir="$acl_save_libdir" $1="$flag" else dnl The -rpath options are cumulative. for dir in $rpathdirs; do acl_save_libdir="$libdir" libdir="$dir" eval flag=\"$acl_hardcode_libdir_flag_spec\" libdir="$acl_save_libdir" $1="${$1}${$1:+ }$flag" done fi fi fi fi fi AC_SUBST([$1]) ]) libcaes-20240413/m4/iconv.m40000644000175000017500000002300314533041421016106 0ustar00lordyestalordyesta# iconv.m4 serial 21 dnl Copyright (C) 2000-2002, 2007-2014, 2016-2020 Free Software Foundation, dnl Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl From Bruno Haible. AC_DEFUN([AM_ICONV_LINKFLAGS_BODY], [ dnl Prerequisites of AC_LIB_LINKFLAGS_BODY. AC_REQUIRE([AC_LIB_PREPARE_PREFIX]) AC_REQUIRE([AC_LIB_RPATH]) dnl Search for libiconv and define LIBICONV, LTLIBICONV and INCICONV dnl accordingly. AC_LIB_LINKFLAGS_BODY([iconv]) ]) AC_DEFUN([AM_ICONV_LINK], [ dnl Some systems have iconv in libc, some have it in libiconv (OSF/1 and dnl those with the standalone portable GNU libiconv installed). AC_REQUIRE([AC_CANONICAL_HOST]) dnl for cross-compiles dnl Search for libiconv and define LIBICONV, LTLIBICONV and INCICONV dnl accordingly. AC_REQUIRE([AM_ICONV_LINKFLAGS_BODY]) dnl Add $INCICONV to CPPFLAGS before performing the following checks, dnl because if the user has installed libiconv and not disabled its use dnl via --without-libiconv-prefix, he wants to use it. The first dnl AC_LINK_IFELSE will then fail, the second AC_LINK_IFELSE will succeed. am_save_CPPFLAGS="$CPPFLAGS" AC_LIB_APPENDTOVAR([CPPFLAGS], [$INCICONV]) AC_CACHE_CHECK([for iconv], [am_cv_func_iconv], [ am_cv_func_iconv="no, consider installing GNU libiconv" am_cv_lib_iconv=no AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[ #include #include ]], [[iconv_t cd = iconv_open("",""); iconv(cd,NULL,NULL,NULL,NULL); iconv_close(cd);]])], [am_cv_func_iconv=yes]) if test "$am_cv_func_iconv" != yes; then am_save_LIBS="$LIBS" LIBS="$LIBS $LIBICONV" AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[ #include #include ]], [[iconv_t cd = iconv_open("",""); iconv(cd,NULL,NULL,NULL,NULL); iconv_close(cd);]])], [am_cv_lib_iconv=yes] [am_cv_func_iconv=yes]) LIBS="$am_save_LIBS" fi ]) if test "$am_cv_func_iconv" = yes; then AC_CACHE_CHECK([for working iconv], [am_cv_func_iconv_works], [ dnl This tests against bugs in AIX 5.1, AIX 6.1..7.1, HP-UX 11.11, dnl Solaris 10. am_save_LIBS="$LIBS" if test $am_cv_lib_iconv = yes; then LIBS="$LIBS $LIBICONV" fi am_cv_func_iconv_works=no for ac_iconv_const in '' 'const'; do AC_RUN_IFELSE( [AC_LANG_PROGRAM( [[ #include #include #ifndef ICONV_CONST # define ICONV_CONST $ac_iconv_const #endif ]], [[int result = 0; /* Test against AIX 5.1 bug: Failures are not distinguishable from successful returns. */ { iconv_t cd_utf8_to_88591 = iconv_open ("ISO8859-1", "UTF-8"); if (cd_utf8_to_88591 != (iconv_t)(-1)) { static ICONV_CONST char input[] = "\342\202\254"; /* EURO SIGN */ char buf[10]; ICONV_CONST char *inptr = input; size_t inbytesleft = strlen (input); char *outptr = buf; size_t outbytesleft = sizeof (buf); size_t res = iconv (cd_utf8_to_88591, &inptr, &inbytesleft, &outptr, &outbytesleft); if (res == 0) result |= 1; iconv_close (cd_utf8_to_88591); } } /* Test against Solaris 10 bug: Failures are not distinguishable from successful returns. */ { iconv_t cd_ascii_to_88591 = iconv_open ("ISO8859-1", "646"); if (cd_ascii_to_88591 != (iconv_t)(-1)) { static ICONV_CONST char input[] = "\263"; char buf[10]; ICONV_CONST char *inptr = input; size_t inbytesleft = strlen (input); char *outptr = buf; size_t outbytesleft = sizeof (buf); size_t res = iconv (cd_ascii_to_88591, &inptr, &inbytesleft, &outptr, &outbytesleft); if (res == 0) result |= 2; iconv_close (cd_ascii_to_88591); } } /* Test against AIX 6.1..7.1 bug: Buffer overrun. */ { iconv_t cd_88591_to_utf8 = iconv_open ("UTF-8", "ISO-8859-1"); if (cd_88591_to_utf8 != (iconv_t)(-1)) { static ICONV_CONST char input[] = "\304"; static char buf[2] = { (char)0xDE, (char)0xAD }; ICONV_CONST char *inptr = input; size_t inbytesleft = 1; char *outptr = buf; size_t outbytesleft = 1; size_t res = iconv (cd_88591_to_utf8, &inptr, &inbytesleft, &outptr, &outbytesleft); if (res != (size_t)(-1) || outptr - buf > 1 || buf[1] != (char)0xAD) result |= 4; iconv_close (cd_88591_to_utf8); } } #if 0 /* This bug could be worked around by the caller. */ /* Test against HP-UX 11.11 bug: Positive return value instead of 0. */ { iconv_t cd_88591_to_utf8 = iconv_open ("utf8", "iso88591"); if (cd_88591_to_utf8 != (iconv_t)(-1)) { static ICONV_CONST char input[] = "\304rger mit b\366sen B\374bchen ohne Augenma\337"; char buf[50]; ICONV_CONST char *inptr = input; size_t inbytesleft = strlen (input); char *outptr = buf; size_t outbytesleft = sizeof (buf); size_t res = iconv (cd_88591_to_utf8, &inptr, &inbytesleft, &outptr, &outbytesleft); if ((int)res > 0) result |= 8; iconv_close (cd_88591_to_utf8); } } #endif /* Test against HP-UX 11.11 bug: No converter from EUC-JP to UTF-8 is provided. */ { /* Try standardized names. */ iconv_t cd1 = iconv_open ("UTF-8", "EUC-JP"); /* Try IRIX, OSF/1 names. */ iconv_t cd2 = iconv_open ("UTF-8", "eucJP"); /* Try AIX names. */ iconv_t cd3 = iconv_open ("UTF-8", "IBM-eucJP"); /* Try HP-UX names. */ iconv_t cd4 = iconv_open ("utf8", "eucJP"); if (cd1 == (iconv_t)(-1) && cd2 == (iconv_t)(-1) && cd3 == (iconv_t)(-1) && cd4 == (iconv_t)(-1)) result |= 16; if (cd1 != (iconv_t)(-1)) iconv_close (cd1); if (cd2 != (iconv_t)(-1)) iconv_close (cd2); if (cd3 != (iconv_t)(-1)) iconv_close (cd3); if (cd4 != (iconv_t)(-1)) iconv_close (cd4); } return result; ]])], [am_cv_func_iconv_works=yes], , [case "$host_os" in aix* | hpux*) am_cv_func_iconv_works="guessing no" ;; *) am_cv_func_iconv_works="guessing yes" ;; esac]) test "$am_cv_func_iconv_works" = no || break done LIBS="$am_save_LIBS" ]) case "$am_cv_func_iconv_works" in *no) am_func_iconv=no am_cv_lib_iconv=no ;; *) am_func_iconv=yes ;; esac else am_func_iconv=no am_cv_lib_iconv=no fi if test "$am_func_iconv" = yes; then AC_DEFINE([HAVE_ICONV], [1], [Define if you have the iconv() function and it works.]) fi if test "$am_cv_lib_iconv" = yes; then AC_MSG_CHECKING([how to link with libiconv]) AC_MSG_RESULT([$LIBICONV]) else dnl If $LIBICONV didn't lead to a usable library, we don't need $INCICONV dnl either. CPPFLAGS="$am_save_CPPFLAGS" LIBICONV= LTLIBICONV= fi AC_SUBST([LIBICONV]) AC_SUBST([LTLIBICONV]) ]) dnl Define AM_ICONV using AC_DEFUN_ONCE for Autoconf >= 2.64, in order to dnl avoid warnings like dnl "warning: AC_REQUIRE: `AM_ICONV' was expanded before it was required". dnl This is tricky because of the way 'aclocal' is implemented: dnl - It requires defining an auxiliary macro whose name ends in AC_DEFUN. dnl Otherwise aclocal's initial scan pass would miss the macro definition. dnl - It requires a line break inside the AC_DEFUN_ONCE and AC_DEFUN expansions. dnl Otherwise aclocal would emit many "Use of uninitialized value $1" dnl warnings. m4_define([gl_iconv_AC_DEFUN], m4_version_prereq([2.64], [[AC_DEFUN_ONCE( [$1], [$2])]], [m4_ifdef([gl_00GNULIB], [[AC_DEFUN_ONCE( [$1], [$2])]], [[AC_DEFUN( [$1], [$2])]])])) gl_iconv_AC_DEFUN([AM_ICONV], [ AM_ICONV_LINK if test "$am_cv_func_iconv" = yes; then AC_MSG_CHECKING([for iconv declaration]) AC_CACHE_VAL([am_cv_proto_iconv], [ AC_COMPILE_IFELSE( [AC_LANG_PROGRAM( [[ #include #include extern #ifdef __cplusplus "C" #endif #if defined(__STDC__) || defined(_MSC_VER) || defined(__cplusplus) size_t iconv (iconv_t cd, char * *inbuf, size_t *inbytesleft, char * *outbuf, size_t *outbytesleft); #else size_t iconv(); #endif ]], [[]])], [am_cv_proto_iconv_arg1=""], [am_cv_proto_iconv_arg1="const"]) am_cv_proto_iconv="extern size_t iconv (iconv_t cd, $am_cv_proto_iconv_arg1 char * *inbuf, size_t *inbytesleft, char * *outbuf, size_t *outbytesleft);"]) am_cv_proto_iconv=`echo "[$]am_cv_proto_iconv" | tr -s ' ' | sed -e 's/( /(/'` AC_MSG_RESULT([ $am_cv_proto_iconv]) else dnl When compiling GNU libiconv on a system that does not have iconv yet, dnl pick the POSIX compliant declaration without 'const'. am_cv_proto_iconv_arg1="" fi AC_DEFINE_UNQUOTED([ICONV_CONST], [$am_cv_proto_iconv_arg1], [Define as const if the declaration of iconv() needs const.]) dnl Also substitute ICONV_CONST in the gnulib generated . m4_ifdef([gl_ICONV_H_DEFAULTS], [AC_REQUIRE([gl_ICONV_H_DEFAULTS]) if test -n "$am_cv_proto_iconv_arg1"; then ICONV_CONST="const" fi ]) ]) libcaes-20240413/m4/ltoptions.m40000644000175000017500000003427514606477623017062 0ustar00lordyestalordyesta# Helper functions for option handling. -*- Autoconf -*- # # Copyright (C) 2004-2005, 2007-2009, 2011-2019, 2021-2022 Free # Software Foundation, Inc. # Written by Gary V. Vaughan, 2004 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # serial 8 ltoptions.m4 # This is to help aclocal find these macros, as it can't see m4_define. AC_DEFUN([LTOPTIONS_VERSION], [m4_if([1])]) # _LT_MANGLE_OPTION(MACRO-NAME, OPTION-NAME) # ------------------------------------------ m4_define([_LT_MANGLE_OPTION], [[_LT_OPTION_]m4_bpatsubst($1__$2, [[^a-zA-Z0-9_]], [_])]) # _LT_SET_OPTION(MACRO-NAME, OPTION-NAME) # --------------------------------------- # Set option OPTION-NAME for macro MACRO-NAME, and if there is a # matching handler defined, dispatch to it. Other OPTION-NAMEs are # saved as a flag. m4_define([_LT_SET_OPTION], [m4_define(_LT_MANGLE_OPTION([$1], [$2]))dnl m4_ifdef(_LT_MANGLE_DEFUN([$1], [$2]), _LT_MANGLE_DEFUN([$1], [$2]), [m4_warning([Unknown $1 option '$2'])])[]dnl ]) # _LT_IF_OPTION(MACRO-NAME, OPTION-NAME, IF-SET, [IF-NOT-SET]) # ------------------------------------------------------------ # Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. m4_define([_LT_IF_OPTION], [m4_ifdef(_LT_MANGLE_OPTION([$1], [$2]), [$3], [$4])]) # _LT_UNLESS_OPTIONS(MACRO-NAME, OPTION-LIST, IF-NOT-SET) # ------------------------------------------------------- # Execute IF-NOT-SET unless all options in OPTION-LIST for MACRO-NAME # are set. m4_define([_LT_UNLESS_OPTIONS], [m4_foreach([_LT_Option], m4_split(m4_normalize([$2])), [m4_ifdef(_LT_MANGLE_OPTION([$1], _LT_Option), [m4_define([$0_found])])])[]dnl m4_ifdef([$0_found], [m4_undefine([$0_found])], [$3 ])[]dnl ]) # _LT_SET_OPTIONS(MACRO-NAME, OPTION-LIST) # ---------------------------------------- # OPTION-LIST is a space-separated list of Libtool options associated # with MACRO-NAME. If any OPTION has a matching handler declared with # LT_OPTION_DEFINE, dispatch to that macro; otherwise complain about # the unknown option and exit. m4_defun([_LT_SET_OPTIONS], [# Set options m4_foreach([_LT_Option], m4_split(m4_normalize([$2])), [_LT_SET_OPTION([$1], _LT_Option)]) m4_if([$1],[LT_INIT],[ dnl dnl Simply set some default values (i.e off) if boolean options were not dnl specified: _LT_UNLESS_OPTIONS([LT_INIT], [dlopen], [enable_dlopen=no ]) _LT_UNLESS_OPTIONS([LT_INIT], [win32-dll], [enable_win32_dll=no ]) dnl dnl If no reference was made to various pairs of opposing options, then dnl we run the default mode handler for the pair. For example, if neither dnl 'shared' nor 'disable-shared' was passed, we enable building of shared dnl archives by default: _LT_UNLESS_OPTIONS([LT_INIT], [shared disable-shared], [_LT_ENABLE_SHARED]) _LT_UNLESS_OPTIONS([LT_INIT], [static disable-static], [_LT_ENABLE_STATIC]) _LT_UNLESS_OPTIONS([LT_INIT], [pic-only no-pic], [_LT_WITH_PIC]) _LT_UNLESS_OPTIONS([LT_INIT], [fast-install disable-fast-install], [_LT_ENABLE_FAST_INSTALL]) _LT_UNLESS_OPTIONS([LT_INIT], [aix-soname=aix aix-soname=both aix-soname=svr4], [_LT_WITH_AIX_SONAME([aix])]) ]) ])# _LT_SET_OPTIONS ## --------------------------------- ## ## Macros to handle LT_INIT options. ## ## --------------------------------- ## # _LT_MANGLE_DEFUN(MACRO-NAME, OPTION-NAME) # ----------------------------------------- m4_define([_LT_MANGLE_DEFUN], [[_LT_OPTION_DEFUN_]m4_bpatsubst(m4_toupper([$1__$2]), [[^A-Z0-9_]], [_])]) # LT_OPTION_DEFINE(MACRO-NAME, OPTION-NAME, CODE) # ----------------------------------------------- m4_define([LT_OPTION_DEFINE], [m4_define(_LT_MANGLE_DEFUN([$1], [$2]), [$3])[]dnl ])# LT_OPTION_DEFINE # dlopen # ------ LT_OPTION_DEFINE([LT_INIT], [dlopen], [enable_dlopen=yes ]) AU_DEFUN([AC_LIBTOOL_DLOPEN], [_LT_SET_OPTION([LT_INIT], [dlopen]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'dlopen' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_DLOPEN], []) # win32-dll # --------- # Declare package support for building win32 dll's. LT_OPTION_DEFINE([LT_INIT], [win32-dll], [enable_win32_dll=yes case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-cegcc*) AC_CHECK_TOOL(AS, as, false) AC_CHECK_TOOL(DLLTOOL, dlltool, false) AC_CHECK_TOOL(OBJDUMP, objdump, false) ;; esac test -z "$AS" && AS=as _LT_DECL([], [AS], [1], [Assembler program])dnl test -z "$DLLTOOL" && DLLTOOL=dlltool _LT_DECL([], [DLLTOOL], [1], [DLL creation program])dnl test -z "$OBJDUMP" && OBJDUMP=objdump _LT_DECL([], [OBJDUMP], [1], [Object dumper program])dnl ])# win32-dll AU_DEFUN([AC_LIBTOOL_WIN32_DLL], [AC_REQUIRE([AC_CANONICAL_HOST])dnl _LT_SET_OPTION([LT_INIT], [win32-dll]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'win32-dll' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_WIN32_DLL], []) # _LT_ENABLE_SHARED([DEFAULT]) # ---------------------------- # implement the --enable-shared flag, and supports the 'shared' and # 'disable-shared' LT_INIT options. # DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. m4_define([_LT_ENABLE_SHARED], [m4_define([_LT_ENABLE_SHARED_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([shared], [AS_HELP_STRING([--enable-shared@<:@=PKGS@:>@], [build shared libraries @<:@default=]_LT_ENABLE_SHARED_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_shared=yes ;; no) enable_shared=no ;; *) enable_shared=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_shared=yes fi done IFS=$lt_save_ifs ;; esac], [enable_shared=]_LT_ENABLE_SHARED_DEFAULT) _LT_DECL([build_libtool_libs], [enable_shared], [0], [Whether or not to build shared libraries]) ])# _LT_ENABLE_SHARED LT_OPTION_DEFINE([LT_INIT], [shared], [_LT_ENABLE_SHARED([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-shared], [_LT_ENABLE_SHARED([no])]) # Old names: AC_DEFUN([AC_ENABLE_SHARED], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[shared]) ]) AC_DEFUN([AC_DISABLE_SHARED], [_LT_SET_OPTION([LT_INIT], [disable-shared]) ]) AU_DEFUN([AM_ENABLE_SHARED], [AC_ENABLE_SHARED($@)]) AU_DEFUN([AM_DISABLE_SHARED], [AC_DISABLE_SHARED($@)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_ENABLE_SHARED], []) dnl AC_DEFUN([AM_DISABLE_SHARED], []) # _LT_ENABLE_STATIC([DEFAULT]) # ---------------------------- # implement the --enable-static flag, and support the 'static' and # 'disable-static' LT_INIT options. # DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. m4_define([_LT_ENABLE_STATIC], [m4_define([_LT_ENABLE_STATIC_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([static], [AS_HELP_STRING([--enable-static@<:@=PKGS@:>@], [build static libraries @<:@default=]_LT_ENABLE_STATIC_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_static=yes ;; no) enable_static=no ;; *) enable_static=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_static=yes fi done IFS=$lt_save_ifs ;; esac], [enable_static=]_LT_ENABLE_STATIC_DEFAULT) _LT_DECL([build_old_libs], [enable_static], [0], [Whether or not to build static libraries]) ])# _LT_ENABLE_STATIC LT_OPTION_DEFINE([LT_INIT], [static], [_LT_ENABLE_STATIC([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-static], [_LT_ENABLE_STATIC([no])]) # Old names: AC_DEFUN([AC_ENABLE_STATIC], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[static]) ]) AC_DEFUN([AC_DISABLE_STATIC], [_LT_SET_OPTION([LT_INIT], [disable-static]) ]) AU_DEFUN([AM_ENABLE_STATIC], [AC_ENABLE_STATIC($@)]) AU_DEFUN([AM_DISABLE_STATIC], [AC_DISABLE_STATIC($@)]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AM_ENABLE_STATIC], []) dnl AC_DEFUN([AM_DISABLE_STATIC], []) # _LT_ENABLE_FAST_INSTALL([DEFAULT]) # ---------------------------------- # implement the --enable-fast-install flag, and support the 'fast-install' # and 'disable-fast-install' LT_INIT options. # DEFAULT is either 'yes' or 'no'. If omitted, it defaults to 'yes'. m4_define([_LT_ENABLE_FAST_INSTALL], [m4_define([_LT_ENABLE_FAST_INSTALL_DEFAULT], [m4_if($1, no, no, yes)])dnl AC_ARG_ENABLE([fast-install], [AS_HELP_STRING([--enable-fast-install@<:@=PKGS@:>@], [optimize for fast installation @<:@default=]_LT_ENABLE_FAST_INSTALL_DEFAULT[@:>@])], [p=${PACKAGE-default} case $enableval in yes) enable_fast_install=yes ;; no) enable_fast_install=no ;; *) enable_fast_install=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_fast_install=yes fi done IFS=$lt_save_ifs ;; esac], [enable_fast_install=]_LT_ENABLE_FAST_INSTALL_DEFAULT) _LT_DECL([fast_install], [enable_fast_install], [0], [Whether or not to optimize for fast installation])dnl ])# _LT_ENABLE_FAST_INSTALL LT_OPTION_DEFINE([LT_INIT], [fast-install], [_LT_ENABLE_FAST_INSTALL([yes])]) LT_OPTION_DEFINE([LT_INIT], [disable-fast-install], [_LT_ENABLE_FAST_INSTALL([no])]) # Old names: AU_DEFUN([AC_ENABLE_FAST_INSTALL], [_LT_SET_OPTION([LT_INIT], m4_if([$1], [no], [disable-])[fast-install]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'fast-install' option into LT_INIT's first parameter.]) ]) AU_DEFUN([AC_DISABLE_FAST_INSTALL], [_LT_SET_OPTION([LT_INIT], [disable-fast-install]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'disable-fast-install' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_ENABLE_FAST_INSTALL], []) dnl AC_DEFUN([AM_DISABLE_FAST_INSTALL], []) # _LT_WITH_AIX_SONAME([DEFAULT]) # ---------------------------------- # implement the --with-aix-soname flag, and support the `aix-soname=aix' # and `aix-soname=both' and `aix-soname=svr4' LT_INIT options. DEFAULT # is either `aix', `both' or `svr4'. If omitted, it defaults to `aix'. m4_define([_LT_WITH_AIX_SONAME], [m4_define([_LT_WITH_AIX_SONAME_DEFAULT], [m4_if($1, svr4, svr4, m4_if($1, both, both, aix))])dnl shared_archive_member_spec= case $host,$enable_shared in power*-*-aix[[5-9]]*,yes) AC_MSG_CHECKING([which variant of shared library versioning to provide]) AC_ARG_WITH([aix-soname], [AS_HELP_STRING([--with-aix-soname=aix|svr4|both], [shared library versioning (aka "SONAME") variant to provide on AIX, @<:@default=]_LT_WITH_AIX_SONAME_DEFAULT[@:>@.])], [case $withval in aix|svr4|both) ;; *) AC_MSG_ERROR([Unknown argument to --with-aix-soname]) ;; esac lt_cv_with_aix_soname=$with_aix_soname], [AC_CACHE_VAL([lt_cv_with_aix_soname], [lt_cv_with_aix_soname=]_LT_WITH_AIX_SONAME_DEFAULT) with_aix_soname=$lt_cv_with_aix_soname]) AC_MSG_RESULT([$with_aix_soname]) if test aix != "$with_aix_soname"; then # For the AIX way of multilib, we name the shared archive member # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o', # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File. # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag, # the AIX toolchain works better with OBJECT_MODE set (default 32). if test 64 = "${OBJECT_MODE-32}"; then shared_archive_member_spec=shr_64 else shared_archive_member_spec=shr fi fi ;; *) with_aix_soname=aix ;; esac _LT_DECL([], [shared_archive_member_spec], [0], [Shared archive member basename, for filename based shared library versioning on AIX])dnl ])# _LT_WITH_AIX_SONAME LT_OPTION_DEFINE([LT_INIT], [aix-soname=aix], [_LT_WITH_AIX_SONAME([aix])]) LT_OPTION_DEFINE([LT_INIT], [aix-soname=both], [_LT_WITH_AIX_SONAME([both])]) LT_OPTION_DEFINE([LT_INIT], [aix-soname=svr4], [_LT_WITH_AIX_SONAME([svr4])]) # _LT_WITH_PIC([MODE]) # -------------------- # implement the --with-pic flag, and support the 'pic-only' and 'no-pic' # LT_INIT options. # MODE is either 'yes' or 'no'. If omitted, it defaults to 'both'. m4_define([_LT_WITH_PIC], [AC_ARG_WITH([pic], [AS_HELP_STRING([--with-pic@<:@=PKGS@:>@], [try to use only PIC/non-PIC objects @<:@default=use both@:>@])], [lt_p=${PACKAGE-default} case $withval in yes|no) pic_mode=$withval ;; *) pic_mode=default # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for lt_pkg in $withval; do IFS=$lt_save_ifs if test "X$lt_pkg" = "X$lt_p"; then pic_mode=yes fi done IFS=$lt_save_ifs ;; esac], [pic_mode=m4_default([$1], [default])]) _LT_DECL([], [pic_mode], [0], [What type of objects to build])dnl ])# _LT_WITH_PIC LT_OPTION_DEFINE([LT_INIT], [pic-only], [_LT_WITH_PIC([yes])]) LT_OPTION_DEFINE([LT_INIT], [no-pic], [_LT_WITH_PIC([no])]) # Old name: AU_DEFUN([AC_LIBTOOL_PICMODE], [_LT_SET_OPTION([LT_INIT], [pic-only]) AC_DIAGNOSE([obsolete], [$0: Remove this warning and the call to _LT_SET_OPTION when you put the 'pic-only' option into LT_INIT's first parameter.]) ]) dnl aclocal-1.4 backwards compatibility: dnl AC_DEFUN([AC_LIBTOOL_PICMODE], []) ## ----------------- ## ## LTDL_INIT Options ## ## ----------------- ## m4_define([_LTDL_MODE], []) LT_OPTION_DEFINE([LTDL_INIT], [nonrecursive], [m4_define([_LTDL_MODE], [nonrecursive])]) LT_OPTION_DEFINE([LTDL_INIT], [recursive], [m4_define([_LTDL_MODE], [recursive])]) LT_OPTION_DEFINE([LTDL_INIT], [subproject], [m4_define([_LTDL_MODE], [subproject])]) m4_define([_LTDL_TYPE], []) LT_OPTION_DEFINE([LTDL_INIT], [installable], [m4_define([_LTDL_TYPE], [installable])]) LT_OPTION_DEFINE([LTDL_INIT], [convenience], [m4_define([_LTDL_TYPE], [convenience])]) libcaes-20240413/m4/nls.m40000644000175000017500000000232214533041421015565 0ustar00lordyestalordyesta# nls.m4 serial 6 (gettext-0.20.2) dnl Copyright (C) 1995-2003, 2005-2006, 2008-2014, 2016, 2019-2020 Free dnl Software Foundation, Inc. dnl This file is free software; the Free Software Foundation dnl gives unlimited permission to copy and/or distribute it, dnl with or without modifications, as long as this notice is preserved. dnl dnl This file can be used in projects which are not available under dnl the GNU General Public License or the GNU Lesser General Public dnl License but which still want to provide support for the GNU gettext dnl functionality. dnl Please note that the actual code of the GNU gettext library is covered dnl by the GNU Lesser General Public License, and the rest of the GNU dnl gettext package is covered by the GNU General Public License. dnl They are *not* in the public domain. dnl Authors: dnl Ulrich Drepper , 1995-2000. dnl Bruno Haible , 2000-2003. AC_PREREQ([2.50]) AC_DEFUN([AM_NLS], [ AC_MSG_CHECKING([whether NLS is requested]) dnl Default is enabled NLS AC_ARG_ENABLE([nls], [ --disable-nls do not use Native Language Support], USE_NLS=$enableval, USE_NLS=yes) AC_MSG_RESULT([$USE_NLS]) AC_SUBST([USE_NLS]) ]) libcaes-20240413/m4/python.m40000644000175000017500000001426314533041421016321 0ustar00lordyestalordyestadnl Functions for Python bindings dnl dnl Version: 20231119 dnl Function to check if the python binary is available dnl "python${PYTHON_VERSION} python python# python#.#" AC_DEFUN([AX_PROG_PYTHON], [AS_IF( [test "x${PYTHON_VERSION}" != x], [ax_python_progs="python${PYTHON_VERSION}"], [ax_python_progs="python python3 python3.12 python3.11 python3.10 python3.9 python3.8 python3.7 python3.6 python3.5 python3.4 python3.3 python3.2 python3.1 python3.0 python2 python2.7 python2.6 python2.5"]) AC_CHECK_PROGS( [PYTHON], [$ax_python_progs]) AS_IF( [test "x${PYTHON}" != x], [ax_prog_python_version=`${PYTHON} -c "import sys; sys.stdout.write('%d.%d' % (sys.version_info[[0]], sys.version_info[[1]]))" 2>/dev/null`; ax_prog_python_platform=`${PYTHON} -c "import sys; sys.stdout.write(sys.platform)" 2>/dev/null`; AC_SUBST( [PYTHON_PLATFORM], [$ax_prog_python_platform]) ], [AC_MSG_ERROR( [Unable to find python]) ]) AC_SUBST( [PYTHON], [$PYTHON]) ]) dnl Function to check if the python-config binary is available dnl "python${PYTHON_VERSION}-config python-config" AC_DEFUN([AX_PROG_PYTHON_CONFIG], [AS_IF( [test "x${PYTHON_CONFIG}" = x && test "x${PYTHON_VERSION}" != x], [AC_CHECK_PROGS( [PYTHON_CONFIG], [python${PYTHON_VERSION}-config]) ]) AS_IF( [test "x${PYTHON_CONFIG}" = x], [AC_CHECK_PROGS( [PYTHON_CONFIG], [python-config python3-config python3.12-config python3.11-config python3.10-config python3.9-config python3.8-config python3.7-config python3.6-config python3.5-config python3.4-config python3.3-config python3.2-config python3.1-config python3.0-config python2-config python2.7-config python2.6-config python2.5-config]) ]) AS_IF( [test "x${PYTHON_CONFIG}" = x], [AC_MSG_ERROR( [Unable to find python-config]) ]) AC_SUBST( [PYTHON_CONFIG], [$PYTHON_CONFIG]) ]) dnl Function to detect if a Python build environment is available AC_DEFUN([AX_PYTHON_CHECK], [AX_PROG_PYTHON AX_PROG_PYTHON_CONFIG AS_IF( [test "x${PYTHON_CONFIG}" != x], [dnl Check for Python includes PYTHON_INCLUDES=`${PYTHON_CONFIG} --includes 2>/dev/null`; AC_MSG_CHECKING( [for Python includes]) AC_MSG_RESULT( [$PYTHON_INCLUDES]) dnl Check for Python libraries PYTHON_LDFLAGS=`${PYTHON_CONFIG} --ldflags 2>/dev/null`; AC_MSG_CHECKING( [for Python libraries]) AC_MSG_RESULT( [$PYTHON_LDFLAGS]) dnl For CygWin add the -no-undefined linker flag AS_CASE( [$host_os], [cygwin*],[PYTHON_LDFLAGS="${PYTHON_LDFLAGS} -no-undefined"], [*],[]) dnl Check for the existence of Python.h BACKUP_CPPFLAGS="${CPPFLAGS}" CPPFLAGS="${CPPFLAGS} ${PYTHON_INCLUDES}" AC_CHECK_HEADERS( [Python.h], [ac_cv_header_python_h=yes], [ac_cv_header_python_h=no]) CPPFLAGS="${BACKUP_CPPFLAGS}" ]) AS_IF( [test "x${ac_cv_header_python_h}" != xyes], [ac_cv_enable_python=no], [ac_cv_enable_python=${ax_prog_python_version} AC_SUBST( [PYTHON_CPPFLAGS], [$PYTHON_INCLUDES]) AC_SUBST( [PYTHON_LDFLAGS], [$PYTHON_LDFLAGS]) dnl Check for Python prefix AS_IF( [test "x${ac_cv_with_pyprefix}" = x || test "x${ac_cv_with_pyprefix}" = xno], [ax_python_prefix="\${prefix}"], [ax_python_prefix=`${PYTHON_CONFIG} --prefix 2>/dev/null`]) AC_SUBST( [PYTHON_PREFIX], [$ax_python_prefix]) dnl Check for Python exec-prefix AS_IF( [test "x${ac_cv_with_pyprefix}" = x || test "x${ac_cv_with_pyprefix}" = xno], [ax_python_exec_prefix="\${exec_prefix}"], [ax_python_exec_prefix=`${PYTHON_CONFIG} --exec-prefix 2>/dev/null`]) AC_SUBST( [PYTHON_EXEC_PREFIX], [$ax_python_exec_prefix]) dnl Check for Python library directory ax_python_pythondir_suffix=`${PYTHON} -c "import sys; import distutils.sysconfig; sys.stdout.write(distutils.sysconfig.get_python_lib(0, 0, prefix=''))" 2>/dev/null`; AS_IF( [test "x${ac_cv_with_pythondir}" = x || test "x${ac_cv_with_pythondir}" = xno], [AS_IF( [test "x${ac_cv_with_pyprefix}" = x || test "x${ac_cv_with_pyprefix}" = xno], [ax_python_pythondir="${ax_python_prefix}/${ax_python_pythondir_suffix}"], [ax_python_pythondir=`${PYTHON} -c "import sys; import distutils.sysconfig; sys.stdout.write(distutils.sysconfig.get_python_lib()) " 2>/dev/null`])], [ax_python_pythondir=$ac_cv_with_pythondir]) AC_SUBST( [pythondir], [$ax_python_pythondir]) dnl Check for Python platform specific library directory ax_python_pyexecdir_suffix=`${PYTHON} -c "import sys; import distutils.sysconfig; sys.stdout.write(distutils.sysconfig.get_python_lib(1, 0, prefix=''))" 2>/dev/null`; ax_python_library_dir=`${PYTHON} -c "import sys; import distutils.sysconfig; sys.stdout.write(distutils.sysconfig.get_python_lib(True)) " 2>/dev/null`; AS_IF( [test "x${ac_cv_with_pyprefix}" = x || test "x${ac_cv_with_pyprefix}" = xno], [ax_python_pyexecdir="${ax_python_exec_prefix}/${ax_python_pyexecdir_suffix}"], [ax_python_pyexecdir=$ax_python_library_dir]) AC_SUBST( [pyexecdir], [$ax_python_pyexecdir]) AC_SUBST( [PYTHON_LIBRARY_DIR], [$ax_python_pyexecdir_suffix]) AC_SUBST( [PYTHON_PACKAGE_DIR], [$ax_python_library_dir]) ]) ]) dnl Function to determine the prefix of pythondir AC_DEFUN([AX_PYTHON_CHECK_PYPREFIX], [AX_COMMON_ARG_WITH( [pyprefix], [pyprefix], [use `python-config --prefix' to determine the prefix of pythondir instead of --prefix], [no], [no]) ]) dnl Function to detect if to enable Python AC_DEFUN([AX_PYTHON_CHECK_ENABLE], [AX_PYTHON_CHECK_PYPREFIX AX_COMMON_ARG_ENABLE( [python], [python], [build Python bindings], [no]) AX_COMMON_ARG_WITH( [pythondir], [pythondir], [use to specify the Python directory (pythondir)], [no], [no]) AS_IF( [test "x${ac_cv_enable_python}" != xno], [AX_PYTHON_CHECK]) AM_CONDITIONAL( HAVE_PYTHON, [test "x${ac_cv_enable_python}" != xno]) AM_CONDITIONAL( HAVE_PYTHON_TESTS, [test "x${ac_cv_enable_python}" != xno]) ]) ]) libcaes-20240413/m4/libcrypto.m40000644000175000017500000006577714601173432017033 0ustar00lordyestalordyestadnl Checks for libcrypto required headers and functions dnl dnl Version: 20240308 dnl Function to detect whether openssl/evp.h can be used in combination with zlib.h AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_EVP_ZLIB_COMPATIBILE], [AC_CACHE_CHECK( [if openssl/evp.h can be used in combination with zlib.h], [ac_cv_openssl_evp_zlib_compatible], [AC_LANG_PUSH(C) AC_LINK_IFELSE( [AC_LANG_PROGRAM( [[#include #include ]], [[ ]] )], [ac_cv_openssl_evp_zlib_compatible=yes], [ac_cv_openssl_evp_zlib_compatible=no]) AC_LANG_POP(C)]) ]) dnl Function to detect whether EVP_CipherInit_ex can be used with duplicate keys. AC_DEFUN([AX_LIBCRYPTO_CHECK_XTS_DUPLICATE_KEYS_SUPPORT], [AC_CACHE_CHECK( [if `EVP_CipherInit_ex' can be used with duplicate keys], [ac_cv_openssl_xts_duplicate_keys], [AC_LANG_PUSH(C) ac_cv_libcrypto_backup_LIBS="$LIBS" LIBS="$LIBS $ac_cv_libcrypto_LIBADD" AC_RUN_IFELSE( [AC_LANG_PROGRAM( [[#include #include #include ]], [[unsigned char key[ 16 ] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 }; int result = 0; #if defined( HAVE_EVP_CIPHER_CTX_INIT ) EVP_CIPHER_CTX ctx; EVP_CIPHER_CTX_init( &ctx ); #else EVP_CIPHER_CTX *ctx = EVP_CIPHER_CTX_new(); #endif result = EVP_CipherInit_ex(ctx, EVP_aes_128_xts(), NULL, key, key, 0); #if defined( HAVE_EVP_CIPHER_CTX_INIT ) EVP_CIPHER_CTX_cleanup( &ctx ); #else EVP_CIPHER_CTX_free( ctx ); #endif if( result != 1 ) return( EXIT_FAILURE ); return( EXIT_SUCCESS ); ]] )], [ac_cv_openssl_xts_duplicate_keys=yes], [ac_cv_openssl_xts_duplicate_keys=no]) LIBS="$ac_cv_libcrypto_backup_LIBS" AC_LANG_POP(C)]) ]) dnl Function to detect if libcrypto (openssl) EVP functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_EVP], [AC_CHECK_HEADERS([openssl/evp.h]) AS_IF( [test "x$ac_cv_header_openssl_evp_h" = xno], [ac_cv_libcrypto=no ac_cv_libcrypto_evp=no], [AX_LIBCRYPTO_CHECK_OPENSSL_EVP_ZLIB_COMPATIBILE AS_IF( [test "x$ac_cv_openssl_evp_zlib_compatible" = xyes], [ac_cv_libcrypto=yes ac_cv_libcrypto_evp=yes], [ac_cv_libcrypto=no ac_cv_libcrypto_evp=no]) ]) ]) dnl Function to detect if libcrypto (openssl) EVP MD functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_EVP_MD], [ac_cv_libcrypto_evp_md=yes AC_CHECK_LIB( crypto, EVP_MD_CTX_new, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_dummy=no]) AS_IF( [test "x$ac_cv_lib_crypto_EVP_MD_CTX_new" = xyes], [dnl Check for the new EVP API functions AC_CHECK_LIB( crypto, EVP_MD_CTX_free, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_md=no]) ], [dnl Check for the old EVP API functions AC_CHECK_LIB( crypto, EVP_MD_CTX_init, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_md=no]) AC_CHECK_LIB( crypto, EVP_MD_CTX_cleanup, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_md=no]) AC_CHECK_LIB( crypto, ERR_remove_thread_state, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_md=no]) ]) AC_CHECK_LIB( crypto, EVP_DigestInit_ex2, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_dummy=no]) AS_IF( [test "x$ac_cv_lib_crypto_EVP_DigestInit_ex2" = xyes], [dnl Check for OpenSSL 3 API functions AC_CHECK_LIB( crypto, EVP_MD_CTX_reset, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_md=no]) AC_CHECK_LIB( crypto, EVP_MD_fetch, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_md=no]) AC_CHECK_LIB( crypto, EVP_MD_free, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_md=no]) ], [AC_CHECK_LIB( crypto, EVP_DigestInit_ex, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_md=no]) ]) AC_CHECK_LIB( crypto, EVP_DigestUpdate, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_md=no]) AC_CHECK_LIB( crypto, EVP_DigestFinal_ex, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_md=no]) AS_IF( [test "x$ac_cv_enable_openssl_evp_md" = xyes && test "x$ac_cv_libcrypto_evp_md" = xno], [AC_MSG_FAILURE( [Missing OpenSSL EVP MD support], [1]) ]) AS_IF( [test "x$ac_cv_lib_crypto_EVP_MD_CTX_init" = xyes], [AC_DEFINE( [HAVE_EVP_MD_CTX_INIT], [1], [Define to 1 if you have the `EVP_MD_CTX_init' function".]) ]) AS_IF( [test "x$ac_cv_lib_crypto_EVP_MD_CTX_cleanup" = xyes], [AC_DEFINE( [HAVE_EVP_MD_CTX_CLEANUP], [1], [Define to 1 if you have the `EVP_MD_CTX_cleanup' function".]) ]) AS_IF( [test "x$ac_cv_lib_crypto_EVP_DigestInit_ex2" = xyes], [AC_DEFINE( [HAVE_EVP_DIGESTINIT_EX2], [1], [Define to 1 if you have the `EVP_DigestInit_ex2' function".]) ]) ]) dnl Function to detect if openssl EVP MD5 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_EVP_MD5], [AC_CHECK_LIB( crypto, EVP_md5, [ac_cv_libcrypto_md5=libcrypto_evp], [ac_cv_libcrypto_md5=no]) AS_IF( [test "x$ac_cv_libcrypto_md5" = xlibcrypto_evp], [AC_DEFINE( [HAVE_EVP_MD5], [1], [Define to 1 if you have the `EVP_md5' function".]) ]) ]) dnl Function to detect if openssl EVP SHA1 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_EVP_SHA1], [AC_CHECK_LIB( crypto, EVP_sha1, [ac_cv_libcrypto_sha1=libcrypto_evp], [ac_cv_libcrypto_sha1=no]) AS_IF( [test "x$ac_cv_libcrypto_sha1" = xlibcrypto_evp], [AC_DEFINE( [HAVE_EVP_SHA1], [1], [Define to 1 if you have the `EVP_sha1' function".]) ]) ]) dnl Function to detect if openssl EVP SHA224 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_EVP_SHA224], [AC_CHECK_LIB( crypto, EVP_sha224, [ac_cv_libcrypto_sha224=libcrypto_evp], [ac_cv_libcrypto_sha224=no]) AS_IF( [test "x$ac_cv_libcrypto_sha224" = xlibcrypto_evp], [AC_DEFINE( [HAVE_EVP_SHA224], [1], [Define to 1 if you have the `EVP_sha224' function".]) ]) ]) dnl Function to detect if openssl EVP SHA256 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_EVP_SHA256], [AC_CHECK_LIB( crypto, EVP_sha256, [ac_cv_libcrypto_sha256=libcrypto_evp], [ac_cv_libcrypto_sha256=no]) AS_IF( [test "x$ac_cv_libcrypto_sha256" = xlibcrypto_evp], [AC_DEFINE( [HAVE_EVP_SHA256], [1], [Define to 1 if you have the `EVP_sha256' function".]) ]) ]) dnl Function to detect if openssl EVP SHA512 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_EVP_SHA512], [AC_CHECK_LIB( crypto, EVP_sha512, [ac_cv_libcrypto_sha512=libcrypto_evp], [ac_cv_libcrypto_sha512=no]) AS_IF( [test "x$ac_cv_libcrypto_sha512" = xlibcrypto_evp], [AC_DEFINE( [HAVE_EVP_SHA512], [1], [Define to 1 if you have the `EVP_sha512' function".]) ]) ]) dnl Function to detect if openssl MD5 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_MD5], [AC_CHECK_HEADERS([openssl/md5.h]) AS_IF( [test "x$ac_cv_header_openssl_md5_h" = xno], [ac_cv_libcrypto_md5=no], [ac_cv_libcrypto_md5=libcrypto AC_CHECK_LIB( crypto, MD5_Init, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_md5=no]) AC_CHECK_LIB( crypto, MD5_Update, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_md5=no]) AC_CHECK_LIB( crypto, MD5_Final, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_md5=no]) ]) AS_IF( [test "x$ac_cv_libcrypto" = xno && test "x$ac_cv_libcrypto_md5" = xlibcrypto], [ac_cv_libcrypto=yes]) ]) dnl Function to detect if openssl SHA1 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_SHA1], [AC_CHECK_HEADERS([openssl/sha.h]) AS_IF( [test "x$ac_cv_header_openssl_sha_h" = xno], [ac_cv_libcrypto_sha1=no], [ac_cv_libcrypto_sha1=libcrypto AC_CHECK_LIB( crypto, SHA1_Init, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_sha1=no]) AC_CHECK_LIB( crypto, SHA1_Update, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_sha1=no]) AC_CHECK_LIB( crypto, SHA1_Final, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_sha1=no]) ]) AS_IF( [test "x$ac_cv_libcrypto" = xno && test "x$ac_cv_libcrypto_sha1" = xlibcrypto], [ac_cv_libcrypto=yes]) ]) dnl Function to detect if openssl SHA224 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_SHA224], [AC_CHECK_HEADERS([openssl/sha.h]) AS_IF( [test "x$ac_cv_header_openssl_sha_h" = xno], [ac_cv_libcrypto_sha224=no], [ac_cv_libcrypto_sha224=libcrypto AC_CHECK_LIB( crypto, SHA224_Init, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_sha224=no]) AC_CHECK_LIB( crypto, SHA224_Update, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_sha224=no]) AC_CHECK_LIB( crypto, SHA224_Final, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_sha224=no]) ]) AS_IF( [test "x$ac_cv_libcrypto" = xno && test "x$ac_cv_libcrypto_sha224" = xlibcrypto], [ac_cv_libcrypto=yes]) ]) dnl Function to detect if openssl SHA256 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_SHA256], [AC_CHECK_HEADERS([openssl/sha.h]) AS_IF( [test "x$ac_cv_header_openssl_sha_h" = xno], [ac_cv_libcrypto_sha256=no], [ac_cv_libcrypto_sha256=libcrypto AC_CHECK_LIB( crypto, SHA256_Init, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_sha256=no]) AC_CHECK_LIB( crypto, SHA256_Update, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_sha256=no]) AC_CHECK_LIB( crypto, SHA256_Final, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_sha256=no]) ]) AS_IF( [test "x$ac_cv_libcrypto" = xno && test "x$ac_cv_libcrypto_sha256" = xlibcrypto], [ac_cv_libcrypto=yes]) ]) dnl Function to detect if openssl SHA512 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_SHA512], [AC_CHECK_HEADERS([openssl/sha.h]) AS_IF( [test "x$ac_cv_header_openssl_sha_h" = xno], [ac_cv_libcrypto_sha512=no], [ac_cv_libcrypto_sha512=libcrypto AC_CHECK_LIB( crypto, SHA512_Init, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_sha512=no]) AC_CHECK_LIB( crypto, SHA512_Update, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_sha512=no]) AC_CHECK_LIB( crypto, SHA512_Final, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_sha512=no]) ]) AS_IF( [test "x$ac_cv_libcrypto" = xno && test "x$ac_cv_libcrypto_sha512" = xlibcrypto], [ac_cv_libcrypto=yes]) ]) dnl Function to detect if openssl EVP CIPHER functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_EVP_CIPHER], [ac_cv_libcrypto_evp_cipher=yes dnl Check if all required libcrypto (openssl) EVP CIPHER functions are available AC_CHECK_LIB( crypto, EVP_CIPHER_CTX_new, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_dummy=no]) AS_IF( [test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_new" = xyes], [dnl Check for the new EVP API functions AC_CHECK_LIB( crypto, EVP_CIPHER_CTX_free, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_cipher=no]) ], [dnl Check for the old EVP API functions AC_CHECK_LIB( crypto, EVP_CIPHER_CTX_init, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_cipher=no]) AC_CHECK_LIB( crypto, EVP_CIPHER_CTX_cleanup, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_cipher=no]) AC_CHECK_LIB( crypto, ERR_remove_thread_state, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_cipher=no]) ]) AC_CHECK_LIB( crypto, EVP_CipherInit_ex2, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_dummy=no]) AS_IF( [test "x$ac_cv_lib_crypto_EVP_CipherInit_ex2" = xyes], [dnl Check for OpenSSL 3 API functions AC_CHECK_LIB( crypto, EVP_CIPHER_CTX_reset, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_cipher=no]) AC_CHECK_LIB( crypto, EVP_CIPHER_fetch, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_cipher=no]) AC_CHECK_LIB( crypto, EVP_CIPHER_free, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_cipher=no]) ], [AC_CHECK_LIB( crypto, EVP_CipherInit_ex, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_cipher=no]) AC_CHECK_LIB( crypto, EVP_CIPHER_CTX_set_padding, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_cipher=no]) ]) AC_CHECK_LIB( crypto, EVP_CipherUpdate, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_cipher=no]) AC_CHECK_LIB( crypto, EVP_CipherFinal_ex, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_evp_cipher=no]) AS_IF( [test "x$ac_cv_enable_openssl_evp_cipher" = xyes && test "x$ac_cv_libcrypto_evp_cipher" = xno], [AC_MSG_FAILURE( [Missing OpenSSL EVP CIPHER support], [1]) ]) AS_IF( [test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_init" = xyes], [AC_DEFINE( [HAVE_EVP_CIPHER_CTX_INIT], [1], [Define to 1 if you have the `EVP_CIPHER_CTX_init' function".]) ]) AS_IF( [test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup" = xyes], [AC_DEFINE( [HAVE_EVP_CIPHER_CTX_CLEANUP], [1], [Define to 1 if you have the `EVP_CIPHER_CTX_cleanup' function".]) ]) AS_IF( [test "x$ac_cv_lib_crypto_EVP_CipherInit_ex2" = xyes], [AC_DEFINE( [HAVE_EVP_CIPHERINIT_EX2], [1], [Define to 1 if you have the `EVP_CipherInit_ex2' function".]) ]) ]) dnl Function to detect if openssl AES-CBC and AES-ECB functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_OPENSSL_AES], [AC_CHECK_HEADERS([openssl/aes.h]) AS_IF( [test "x$ac_cv_header_openssl_aes_h" = xno], [ac_cv_libcrypto_aes_cbc=no ac_cv_libcrypto_aes_ecb=no], [ac_cv_libcrypto_aes_cbc=libcrypto ac_cv_libcrypto_aes_ecb=libcrypto AC_CHECK_LIB( crypto, AES_set_decrypt_key, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_aes_cbc=no, ac_cv_libcrypto_aes_ecb=no]) AC_CHECK_LIB( crypto, AES_set_encrypt_key, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_aes_cbc=no, ac_cv_libcrypto_aes_ecb=no]) AC_CHECK_LIB( crypto, AES_cbc_encrypt, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_aes_cbc=no]) AC_CHECK_LIB( crypto, AES_ecb_encrypt, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_aes_ecb=no]) AS_IF( [test "x$ac_cv_lib_crypto_AES_cbc_encrypt" = xyes], [AC_DEFINE( [HAVE_AES_CBC_ENCRYPT], [1], [Define to 1 if you have the `AES_cbc_encrypt' function".]) ]) AS_IF( [test "x$ac_cv_lib_crypto_AES_ecb_encrypt" = xyes], [AC_DEFINE( [HAVE_AES_ECB_ENCRYPT], [1], [Define to 1 if you have the `AES_ecb_encrypt' function".]) ]) ]) AS_IF( [test "x$ac_cv_libcrypto" = xno], [AS_IF( [test "x$ac_cv_libcrypto_aes_cbc" = xno || test "x$ac_cv_libcrypto_aes_ecb" = xno], [ac_cv_libcrypto=yes]) ]) dnl ac_cv_libcrypto_aes is deprecated but kept for backwards compatibility AS_IF( [test "x$ac_cv_libcrypto_aes_cbc" = xno || test "x$ac_cv_libcrypto_aes_ecb" = xno], [ac_cv_libcrypto_aes=no], [ac_cv_libcrypto_aes=libcrypto]) ]) dnl Function to detect if libcrypto (openssl) dependencies are available AC_DEFUN([AX_LIBCRYPTO_CHECK_LIB], [AS_IF( [test "x$ac_cv_enable_shared_libs" = xno || test "x$ac_cv_with_openssl" = xno], [ac_cv_libcrypto=no], [dnl Check if the directory provided as parameter exists dnl For both --with-openssl which returns "yes" and --with-openssl= which returns "" dnl treat them as auto-detection. AS_IF( [test "x$ac_cv_with_openssl" != x && test "x$ac_cv_with_openssl" != xauto-detect && test "x$ac_cv_with_openssl" != xyes], [AS_IF( [test -d "$ac_cv_with_openssl"], [CFLAGS="$CFLAGS -I${ac_cv_with_openssl}/include" LDFLAGS="$LDFLAGS -L${ac_cv_with_openssl}/lib"], [AC_MSG_FAILURE( [no such directory: $ac_cv_with_openssl], [1]) ])], [dnl Check for a pkg-config file AS_IF( [test "x$cross_compiling" != "xyes" && test "x$PKGCONFIG" != "x"], [PKG_CHECK_MODULES( [openssl], [openssl >= 1.0], [ac_cv_libcrypto=yes ac_cv_libcrypto_evp=yes], [ac_cv_libcrypto=no ac_cv_libcrypto_evp=no]) ]) AS_IF( [test "x$ac_cv_libcrypto" = xyes], [ac_cv_libcrypto_CPPFLAGS="$pkg_cv_openssl_CFLAGS" ac_cv_libcrypto_LIBADD="$pkg_cv_openssl_LIBS"]) ]) AS_IF( [test "x$ac_cv_libcrypto" != xyes], [dnl Check for headers AC_CHECK_HEADERS([openssl/opensslv.h]) AX_LIBCRYPTO_CHECK_OPENSSL_EVP AS_IF( [test "x$ac_cv_libcrypto_evp" != xyes && test "$ac_cv_header_openssl_opensslv" = xyes], [ac_cv_libcrypto=yes]) ]) dnl Setup libcrypto (openssl) parameters AS_IF( [test "x$ac_cv_libcrypto" = xyes && test "x$ac_cv_libcrypto_evp" = xyes], [AC_DEFINE( [HAVE_OPENSSL_EVP_H], [1], [Define to 1 if you have the header file.]) AC_SUBST( [HAVE_OPENSSL_EVP_H], [1]) ], [AC_SUBST( [HAVE_OPENSSL_EVP_H], [0]) ]) AS_IF( [test "x$ac_cv_libcrypto" != xno], [AC_DEFINE( [HAVE_LIBCRYPTO], [1], [Define to 1 if you have the 'crypto' library (-lcrypto).]) ac_cv_libcrypto_CPPFLAGS="$openssl_CFLAGS" ac_cv_libcrypto_LIBADD="$openssl_LIBS" AS_IF( [test "x$ac_cv_libcrypto_LIBADD" = x], [ac_cv_libcrypto_LIBADD="-lcrypto"]) dnl On Cygwin also link zlib since libcrypto relies on it AS_CASE( [$host], [*cygwin*], [ac_cv_libcrypto_LIBADD="$ac_cv_libcrypto_LIBADD -lz"]) dnl Enforce the dynamic loader library to be included if available AC_CHECK_LIB( dl, dlopen, [AC_SUBST( [LIBDL_LIBADD], ["-ldl"])], []) ]) ]) ]) dnl Function to detect if libcrypto MD5 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_MD5], [ac_cv_libcrypto_md5=no dnl Check for libcrypto (openssl) EVP MD support AS_IF( [test "x$ac_cv_libcrypto_evp" = xyes && test "x$ac_cv_libcrypto_evp_md" != xyes], [AX_LIBCRYPTO_CHECK_OPENSSL_EVP_MD]) dnl Check for libcrypto (openssl) EVP MD5 support AS_IF( [test "x$ac_cv_libcrypto_evp_md" = xyes], [AX_LIBCRYPTO_CHECK_OPENSSL_EVP_MD5]) dnl Check for libcrypto (openssl) MD5 support AS_IF( [test "x$ac_cv_libcrypto_md5" = xno], [AX_LIBCRYPTO_CHECK_OPENSSL_MD5]) ]) dnl Function to detect if libcrypto SHA1 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_SHA1], [ac_cv_libcrypto_sha1=no dnl Check for libcrypto (openssl) EVP MD support AS_IF( [test "x$ac_cv_libcrypto_evp" = xyes && test "x$ac_cv_enable_openssl_evp_md" != xno && test "x$ac_cv_libcrypto_evp_md" != xyes], [AX_LIBCRYPTO_CHECK_OPENSSL_EVP_MD]) dnl Check for libcrypto (openssl) EVP SHA1 support AS_IF( [test "x$ac_cv_libcrypto_evp_md" = xyes], [AX_LIBCRYPTO_CHECK_OPENSSL_EVP_SHA1]) dnl Check for libcrypto (openssl) SHA1 support AS_IF( [test "x$ac_cv_libcrypto_sha1" = xno], [AX_LIBCRYPTO_CHECK_OPENSSL_SHA1]) ]) dnl Function to detect if libcrypto SHA224 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_SHA224], [ac_cv_libcrypto_sha224=no dnl Check for libcrypto (openssl) EVP MD support AS_IF( [test "x$ac_cv_libcrypto_evp" = xyes && test "x$ac_cv_enable_openssl_evp_md" != xno && test "x$ac_cv_libcrypto_evp_md" != xyes], [AX_LIBCRYPTO_CHECK_OPENSSL_EVP_MD]) dnl Check for libcrypto (openssl) EVP SHA224 support AS_IF( [test "x$ac_cv_libcrypto_evp_md" = xyes], [AX_LIBCRYPTO_CHECK_OPENSSL_EVP_SHA224]) dnl Check for libcrypto (openssl) SHA224 support AS_IF( [test "x$ac_cv_libcrypto_sha224" = xno], [AX_LIBCRYPTO_CHECK_OPENSSL_SHA224]) ]) dnl Function to detect if libcrypto SHA256 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_SHA256], [ac_cv_libcrypto_sha256=no dnl Check for libcrypto (openssl) EVP MD support AS_IF( [test "x$ac_cv_libcrypto_evp" = xyes && test "x$ac_cv_enable_openssl_evp_md" != xno && test "x$ac_cv_libcrypto_evp_md" != xyes], [AX_LIBCRYPTO_CHECK_OPENSSL_EVP_MD]) dnl Check for libcrypto (openssl) EVP SHA256 support AS_IF( [test "x$ac_cv_libcrypto_evp_md" = xyes], [AX_LIBCRYPTO_CHECK_OPENSSL_EVP_SHA256]) dnl Check for libcrypto (openssl) SHA256 support AS_IF( [test "x$ac_cv_libcrypto_sha256" = xno], [AX_LIBCRYPTO_CHECK_OPENSSL_SHA256]) ]) dnl Function to detect if libcrypto SHA512 functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_SHA512], [ac_cv_libcrypto_sha512=no dnl Check for libcrypto (openssl) EVP MD support AS_IF( [test "x$ac_cv_libcrypto_evp" = xyes && test "x$ac_cv_enable_openssl_evp_md" != xno && test "x$ac_cv_libcrypto_evp_md" != xyes], [AX_LIBCRYPTO_CHECK_OPENSSL_EVP_MD]) dnl Check for libcrypto (openssl) EVP SHA512 support AS_IF( [test "x$ac_cv_libcrypto_evp_md" = xyes], [AX_LIBCRYPTO_CHECK_OPENSSL_EVP_SHA512]) dnl Check for libcrypto (openssl) SHA512 support AS_IF( [test "x$ac_cv_libcrypto_sha512" = xno], [AX_LIBCRYPTO_CHECK_OPENSSL_SHA512]) ]) dnl Function to detect if libcrypto AES-CBC and AES-ECB functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_AES], [dnl Check for libcrypto (openssl) EVP CIPHER AES-CBC and AES-ECB support AX_LIBCRYPTO_CHECK_AES_CBC AX_LIBCRYPTO_CHECK_AES_ECB dnl ac_cv_libcrypto_aes is deprecated but kept for backwards compatibility AS_IF( [test "x$ac_cv_libcrypto_aes_cbc" = xno || test "x$ac_cv_libcrypto_aes_ecb" = xno], [ac_cv_libcrypto_aes=no], [ac_cv_libcrypto_aes=libcrypto_evp]) dnl Check for libcrypto (openssl) AES-CBC and AES-ECB support AS_IF( [test "x$ac_cv_libcrypto_aes_cbc" = xno || test "x$ac_cv_libcrypto_aes_ecb" = xno], [AX_LIBCRYPTO_CHECK_OPENSSL_AES]) ]) dnl Function to detect if libcrypto AES-CBC functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_AES_CBC], [AS_IF( [test "x$ac_cv_libcrypto_evp" = xyes && test "x$ac_cv_enable_openssl_evp_cipher" != xno && test "x$ac_cv_libcrypto_evp_cipher" != xyes], [AX_LIBCRYPTO_CHECK_OPENSSL_EVP_CIPHER]) AS_IF( [test "x$ac_cv_libcrypto_evp_cipher" != xyes], [ac_cv_libcrypto_aes_cbc=no], [ac_cv_libcrypto_aes_cbc=libcrypto_evp AC_CHECK_LIB( crypto, EVP_aes_128_cbc, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_aes_cbc=no]) AC_CHECK_LIB( crypto, EVP_aes_192_cbc, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_aes_cbc=no]) AC_CHECK_LIB( crypto, EVP_aes_256_cbc, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_aes_cbc=no]) AS_IF( [test "x$ac_cv_lib_crypto_EVP_aes_128_cbc" = xyes && test "x$ac_cv_lib_crypto_EVP_aes_192_cbc" = xyes && test "x$ac_cv_lib_crypto_EVP_aes_256_cbc" = xyes], [AC_DEFINE( [HAVE_EVP_CRYPTO_AES_CBC], [1], [Define to 1 if you have the `EVP_aes_128_cbc', `EVP_aes_192_cbc' and `EVP_aes_256_cbc' functions".]) ]) ]) ]) dnl Function to detect if libcrypto AES-ECB functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_AES_ECB], [AS_IF( [test "x$ac_cv_libcrypto_evp" = xyes && test "x$ac_cv_enable_openssl_evp_cipher" != xno && test "x$ac_cv_libcrypto_evp_cipher" != xyes], [AX_LIBCRYPTO_CHECK_OPENSSL_EVP_CIPHER]) AS_IF( [test "x$ac_cv_libcrypto_evp_cipher" != xyes], [ac_cv_libcrypto_aes_ecb=no], [ac_cv_libcrypto_aes_ecb=libcrypto_evp AC_CHECK_LIB( crypto, EVP_aes_128_ecb, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_aes_ecb=no]) AC_CHECK_LIB( crypto, EVP_aes_192_ecb, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_aes_ecb=no]) AC_CHECK_LIB( crypto, EVP_aes_256_ecb, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_aes_ecb=no]) AS_IF( [test "x$ac_cv_lib_crypto_EVP_aes_128_ecb" = xyes && test "x$ac_cv_lib_crypto_EVP_aes_192_ecb" = xyes && test "x$ac_cv_lib_crypto_EVP_aes_256_ecb" = xyes], [AC_DEFINE( [HAVE_EVP_CRYPTO_AES_ECB], [1], [Define to 1 if you have the `EVP_aes_128_ecb', `EVP_aes_192_ecb' and `EVP_aes_256_ecb' functions".]) ]) ]) ]) dnl Function to detect if libcrypto AES-XTS functions are available AC_DEFUN([AX_LIBCRYPTO_CHECK_AES_XTS], [AS_IF( [test "x$ac_cv_libcrypto_evp" = xyes && test "x$ac_cv_enable_openssl_evp_cipher" != xno && test "x$ac_cv_libcrypto_evp_cipher" != xyes], [AX_LIBCRYPTO_CHECK_OPENSSL_EVP_CIPHER]) AS_IF( [test "x$ac_cv_libcrypto_evp_cipher" != xyes], [ac_cv_libcrypto_aes_xts=no], [ac_cv_libcrypto_aes_xts=libcrypto_evp AC_CHECK_LIB( crypto, EVP_aes_128_xts, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_aes_xts=no]) AC_CHECK_LIB( crypto, EVP_aes_256_xts, [ac_cv_libcrypto_dummy=yes], [ac_cv_libcrypto_aes_xts=no]) dnl OpenSSL 1.1.1c will error with "xts duplicated keys". AX_LIBCRYPTO_CHECK_XTS_DUPLICATE_KEYS_SUPPORT AS_IF( [test "x$ac_cv_openssl_xts_duplicate_keys" = xno], [ac_cv_libcrypto_aes_xts=no], [AS_IF( [test "x$ac_cv_lib_crypto_EVP_aes_128_xts" = xyes && test "x$ac_cv_lib_crypto_EVP_aes_256_xts" = xyes], [AC_DEFINE( [HAVE_EVP_CRYPTO_AES_XTS], [1], [Define to 1 if you have the `EVP_aes_128_xts' and `EVP_aes_256_xts' functions".]) ]) ]) ]) ]) dnl Function to detect how to enable libcrypto (openssl) AC_DEFUN([AX_LIBCRYPTO_CHECK_ENABLE], [AX_COMMON_ARG_WITH( [openssl], [openssl], [search for OpenSSL in includedir and libdir or in the specified DIR, or no if not to use OpenSSL], [auto-detect], [DIR]) AX_COMMON_ARG_ENABLE( [openssl-evp-cipher], [openssl_evp_cipher], [enable OpenSSL EVP CIPHER support, or no to disable], [auto-detect]) AX_COMMON_ARG_ENABLE( [openssl-evp-md], [openssl_evp_md], [enable OpenSSL EVP MD support, or no to disable], [auto-detect]) AS_IF( [test "x$ac_cv_enable_static_executables" != xyes], [dnl Check for a shared library version AX_LIBCRYPTO_CHECK_LIB]) AS_IF( [test "x$ac_cv_libcrypto_CPPFLAGS" != "x"], [AC_SUBST( [LIBCRYPTO_CPPFLAGS], [$ac_cv_libcrypto_CPPFLAGS]) ]) AS_IF( [test "x$ac_cv_libcrypto_LIBADD" != "x"], [AC_SUBST( [LIBCRYPTO_LIBADD], [$ac_cv_libcrypto_LIBADD]) ]) AS_IF( [test "x$ac_cv_libcrypto" != xno], [AC_SUBST( [ax_libcrypto_pc_libs_private], [-lcrypto]) ]) AS_IF( [test "x$ac_cv_libcrypto" != xno], [AC_SUBST( [ax_libcrypto_spec_requires], [openssl]) AC_SUBST( [ax_libcrypto_spec_build_requires], [openssl-devel]) ]) ]) libcaes-20240413/m4/types.m40000644000175000017500000000401214533041421016133 0ustar00lordyestalordyestadnl Functions for type definitions dnl dnl Version: 20180727 dnl Function to detect if type definitions are available AC_DEFUN([AX_TYPES_CHECK_LOCAL], [AS_IF( [test "x$ac_cv_enable_winapi" = xyes], [ac_cv_enable_wide_character_type=yes]) AS_IF( [test "x$ac_cv_enable_wide_character_type" = xyes], [AC_DEFINE( [HAVE_WIDE_CHARACTER_TYPE], [1], [Define to 1 if wide character type should be used.]) AC_SUBST( [HAVE_WIDE_CHARACTER_TYPE], [1]) ], [AC_SUBST( [HAVE_WIDE_CHARACTER_TYPE], [0]) ]) AC_CHECK_HEADERS([sys/types.h inttypes.h stdint.h wchar.h]) AS_IF( [test "x$ac_cv_header_sys_types_h" = xyes], [AC_SUBST( [HAVE_SYS_TYPES_H], [1])], [AC_SUBST( [HAVE_SYS_TYPES_H], [0]) ]) AS_IF( [test "x$ac_cv_header_inttypes_h" = xyes], [AC_SUBST( [HAVE_INTTYPES_H], [1])], [AC_SUBST( [HAVE_INTTYPES_H], [0]) ]) AS_IF( [test "x$ac_cv_header_stdint_h" = xyes], [AC_SUBST( [HAVE_STDINT_H], [1])], [AC_SUBST( [HAVE_STDINT_H], [0]) ]) AS_IF( [test "x$ac_cv_header_wchar_h" = xyes], [AC_SUBST( [HAVE_WCHAR_H], [1]) ], [AC_SUBST( [HAVE_WCHAR_H], [0]) ]) AC_TYPE_MODE_T AC_TYPE_OFF_T AC_TYPE_SIZE_T AC_CHECK_TYPE( [size32_t], [AC_SUBST( [HAVE_SIZE32_T], [1])], [AC_SUBST( [HAVE_SIZE32_T], [0]) ]) AC_CHECK_TYPE( [ssize32_t], [AC_SUBST( [HAVE_SSIZE32_T], [1])], [AC_SUBST( [HAVE_SSIZE32_T], [0]) ]) AC_CHECK_TYPE( [size64_t], [AC_SUBST( [HAVE_SIZE64_T], [1])], [AC_SUBST( [HAVE_SIZE64_T], [0]) ]) AC_CHECK_TYPE( [ssize64_t], [AC_SUBST( [HAVE_SSIZE64_T], [1])], [AC_SUBST( [HAVE_SSIZE64_T], [0]) ]) AC_CHECK_TYPE( [off64_t], [AC_SUBST( [HAVE_OFF64_T], [1])], [AC_SUBST( [HAVE_OFF64_T], [0]) ]) AC_CHECK_TYPE([ssize_t]) AC_CHECK_TYPE([u64]) AC_CHECK_SIZEOF([int]) AC_CHECK_SIZEOF([long]) AC_CHECK_SIZEOF([off_t]) AC_CHECK_SIZEOF([size_t]) AS_IF( [test "x$ac_cv_header_wchar_h" = xyes], [AC_CHECK_SIZEOF([wchar_t])]) ]) libcaes-20240413/include/0000755000175000017500000000000014606477653015660 5ustar00lordyestalordyestalibcaes-20240413/include/libcaes.h0000644000175000017500000001500314606477645017433 0ustar00lordyestalordyesta/* * Library to support support file format date and time values * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_H ) #define _LIBCAES_H #include #include #include #include #include #include #if defined( __cplusplus ) extern "C" { #endif /* ------------------------------------------------------------------------- * Support functions * ------------------------------------------------------------------------- */ /* Returns the library version */ LIBCAES_EXTERN \ const char *libcaes_get_version( void ); /* ------------------------------------------------------------------------- * Error functions * ------------------------------------------------------------------------- */ /* Frees an error */ LIBCAES_EXTERN \ void libcaes_error_free( libcaes_error_t **error ); /* Prints a descriptive string of the error to the stream * Returns the amount of printed characters if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_error_fprint( libcaes_error_t *error, FILE *stream ); /* Prints a descriptive string of the error to the string * The end-of-string character is not included in the return value * Returns the amount of printed characters if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_error_sprint( libcaes_error_t *error, char *string, size_t size ); /* Prints a backtrace of the error to the stream * Returns the amount of printed characters if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_error_backtrace_fprint( libcaes_error_t *error, FILE *stream ); /* Prints a backtrace of the error to the string * The end-of-string character is not included in the return value * Returns the amount of printed characters if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_error_backtrace_sprint( libcaes_error_t *error, char *string, size_t size ); /* ------------------------------------------------------------------------- * Context functions * ------------------------------------------------------------------------- */ /* Creates a context * Make sure the value context is referencing, is set to NULL * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_context_initialize( libcaes_context_t **context, libcaes_error_t **error ); /* Frees a context * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_context_free( libcaes_context_t **context, libcaes_error_t **error ); /* Sets the key * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_context_set_key( libcaes_context_t *context, int mode, const uint8_t *key, size_t key_bit_size, libcaes_error_t **error ); /* De- or encrypts a block of data using AES-CBC (Cipher Block Chaining) * The size must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_crypt_cbc( libcaes_context_t *context, int mode, const uint8_t *initialization_vector, size_t initialization_vector_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcaes_error_t **error ); /* De- or encrypts a block of data using AES-CCM (Counter with CBC-MAC) * Note that the key must be set in encryption mode (LIBCAES_CRYPT_MODE_ENCRYPT) for both de- and encryption. * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_crypt_ccm( libcaes_context_t *context, int mode, const uint8_t *nonce, size_t nonce_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcaes_error_t **error ); /* De- or encrypts a block of data using AES-ECB (Electronic CodeBook) * The size must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_crypt_ecb( libcaes_context_t *context, int mode, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcaes_error_t **error ); /* ------------------------------------------------------------------------- * Tweaked context functions * ------------------------------------------------------------------------- */ /* Creates a tweaked context * Make sure the value tweaked context is referencing, is set to NULL * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_tweaked_context_initialize( libcaes_tweaked_context_t **tweaked_context, libcaes_error_t **error ); /* Frees a tweaked context * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_tweaked_context_free( libcaes_tweaked_context_t **tweaked_context, libcaes_error_t **error ); /* Sets the keys * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_tweaked_context_set_keys( libcaes_tweaked_context_t *tweaked_context, int mode, const uint8_t *key, size_t key_bit_size, const uint8_t *tweak_key, size_t tweak_key_bit_size, libcaes_error_t **error ); /* De- or encrypts a block of data using AES-XTS (XEX-based tweaked-codebook mode with ciphertext stealing) * The size must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_crypt_xts( libcaes_tweaked_context_t *tweaked_context, int mode, const uint8_t *tweak_value, size_t tweak_value_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcaes_error_t **error ); #if defined( __cplusplus ) } #endif #endif /* !defined( _LIBCAES_H ) */ libcaes-20240413/include/libcaes/0000755000175000017500000000000014606477653017262 5ustar00lordyestalordyestalibcaes-20240413/include/libcaes/definitions.h.in0000644000175000017500000000224414606473412022342 0ustar00lordyestalordyesta/* * Definitions for libcaes * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_DEFINITIONS_H ) #define _LIBCAES_DEFINITIONS_H #include #define LIBCAES_VERSION @VERSION@ /* The version string */ #define LIBCAES_VERSION_STRING "@VERSION@" /* The crypt modes */ enum LIBCAES_CRYPT_MODES { LIBCAES_CRYPT_MODE_DECRYPT = 0, LIBCAES_CRYPT_MODE_ENCRYPT = 1 }; #endif /* !defined( _LIBCAES_DEFINITIONS_H ) */ libcaes-20240413/include/libcaes/definitions.h0000644000175000017500000000224214606477645021747 0ustar00lordyestalordyesta/* * Definitions for libcaes * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_DEFINITIONS_H ) #define _LIBCAES_DEFINITIONS_H #include #define LIBCAES_VERSION 20240413 /* The version string */ #define LIBCAES_VERSION_STRING "20240413" /* The crypt modes */ enum LIBCAES_CRYPT_MODES { LIBCAES_CRYPT_MODE_DECRYPT = 0, LIBCAES_CRYPT_MODE_ENCRYPT = 1 }; #endif /* !defined( _LIBCAES_DEFINITIONS_H ) */ libcaes-20240413/include/libcaes/types.h.in0000644000175000017500000001156414606473412021200 0ustar00lordyestalordyesta/* * Type definitions for libcaes * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_TYPES_H ) #define _LIBCAES_TYPES_H #include /* Integer type definitions */ #if ( defined( _MSC_VER ) && ( _MSC_VER < 1600 ) ) || ( defined( __BORLANDC__ ) && ( __BORLANDC__ <= 0x0560 ) ) #ifdef __cplusplus extern "C" { #endif /* Microsoft Visual Studio C++ before Visual Studio 2010 or earlier versions of the Borland C++ Builder * do not support the (u)int#_t type definitions but have __int# definitions instead */ #if !defined( HAVE_INT8_T ) #define HAVE_INT8_T typedef __int8 int8_t; #endif #if !defined( HAVE_UINT8_T ) #define HAVE_UINT8_T typedef unsigned __int8 uint8_t; #endif #if !defined( HAVE_INT16_T ) #define HAVE_INT16_T typedef __int16 int16_t; #endif #if !defined( HAVE_UINT16_T ) #define HAVE_UINT16_T typedef unsigned __int16 uint16_t; #endif #if !defined( HAVE_INT32_T ) #define HAVE_INT32_T typedef __int32 int32_t; #endif #if !defined( HAVE_UINT32_T ) #define HAVE_UINT32_T typedef unsigned __int32 uint32_t; #endif #if !defined( HAVE_INT64_T ) #define HAVE_INT64_T typedef __int64 int64_t; #endif #if !defined( HAVE_UINT64_T ) #define HAVE_UINT64_T typedef unsigned __int64 uint64_t; #endif #ifdef __cplusplus } #endif #elif defined( _MSC_VER ) || defined( __BORLANDC__ ) /* Later versions of Microsoft Visual Studio C++ and Borland C/C++ define the types in */ #include #else #if @HAVE_SYS_TYPES_H@ || defined( HAVE_SYS_TYPES_H ) #include #else #error Missing system type definitions (sys/types.h) #endif /* Type definitions for compilers that have access to * or */ #if @HAVE_INTTYPES_H@ || defined( HAVE_INTTYPES_H ) #include #elif @HAVE_STDINT_H@ || defined( HAVE_STDINT_H ) #include #else #error Missing integer type definitions (inttypes.h, stdint.h) #endif #endif #ifdef __cplusplus extern "C" { #endif #if defined( _MSC_VER ) || ( defined( __BORLANDC__ ) && ( __BORLANDC__ <= 0x0560 ) ) /* Microsoft Visual Studio C++ or earlier versions of the Borland C++ Builder * do not support the ssize_t type definition */ #if !defined( HAVE_SSIZE_T ) #define HAVE_SSIZE_T #if defined( _WIN64 ) typedef __int64 ssize_t; #else typedef __int32 ssize_t; #endif #endif /* !defined( HAVE_SSIZE_T ) */ #endif /* defined( _MSC_VER ) || ( defined( __BORLANDC__ ) && ( __BORLANDC__ <= 0x0560 ) ) */ #if defined( __BORLANDC__ ) && ( __BORLANDC__ <= 0x0560 ) /* Earlier versions of Borland C++ Builder do not support the intptr_t type definition */ #if !defined( HAVE_INTPTR_T ) #define HAVE_INTPTR_T #if defined( _WIN64 ) typedef __int64 intptr_t; #else typedef __int32 intptr_t; #endif #endif /* !defined( HAVE_INTPTR_T ) */ #endif /* defined( __BORLANDC__ ) && ( __BORLANDC__ <= 0x0560 ) */ #if ( !defined( HAVE_SIZE32_T ) && ! @HAVE_SIZE32_T@ ) || HAVE_SIZE32_T == 0 #define HAVE_SIZE32_T 1 typedef uint32_t size32_t; #endif #if ( !defined( HAVE_SSIZE32_T ) && ! @HAVE_SSIZE32_T@ ) || HAVE_SSIZE32_T == 0 #define HAVE_SSIZE32_T 1 typedef int32_t ssize32_t; #endif #if ( !defined( HAVE_SIZE64_T ) && ! @HAVE_SIZE64_T@ ) || HAVE_SIZE64_T == 0 #define HAVE_SIZE64_T 1 typedef uint64_t size64_t; #endif #if ( !defined( HAVE_SSIZE64_T ) && ! @HAVE_SSIZE64_T@ ) || HAVE_SSIZE64_T == 0 #define HAVE_SSIZE64_T 1 typedef int64_t ssize64_t; #endif #if ( !defined( HAVE_OFF64_T ) && ! @HAVE_OFF64_T@ ) || HAVE_OFF64_T == 0 #define HAVE_OFF64_T 1 typedef int64_t off64_t; #endif /* Wide character definition */ #if defined( __BORLANDC__ ) && ( __BORLANDC__ <= 0x0520 ) #include #elif defined( WINAPI ) #include #elif @HAVE_WCHAR_H@ || defined( HAVE_WCHAR_H ) /* __USE_UNIX98 is required to add swprintf definition */ #if !defined( __USE_UNIX98 ) #define __USE_UNIX98 #define LIBCAES_DEFINITION_UNIX98 #endif #include #if defined( LIBCAES_DEFINITION_UNIX98 ) #undef __USE_UNIX98 #undef LIBCAES_DEFINITION_UNIX98 #endif #endif /* The following type definitions hide internal data structures */ typedef intptr_t libcaes_context_t; typedef intptr_t libcaes_tweaked_context_t; #ifdef __cplusplus } #endif #endif /* !defined( _LIBCAES_TYPES_H ) */ libcaes-20240413/include/libcaes/types.h0000644000175000017500000001136114606477645020602 0ustar00lordyestalordyesta/* * Type definitions for libcaes * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_TYPES_H ) #define _LIBCAES_TYPES_H #include /* Integer type definitions */ #if ( defined( _MSC_VER ) && ( _MSC_VER < 1600 ) ) || ( defined( __BORLANDC__ ) && ( __BORLANDC__ <= 0x0560 ) ) #ifdef __cplusplus extern "C" { #endif /* Microsoft Visual Studio C++ before Visual Studio 2010 or earlier versions of the Borland C++ Builder * do not support the (u)int#_t type definitions but have __int# definitions instead */ #if !defined( HAVE_INT8_T ) #define HAVE_INT8_T typedef __int8 int8_t; #endif #if !defined( HAVE_UINT8_T ) #define HAVE_UINT8_T typedef unsigned __int8 uint8_t; #endif #if !defined( HAVE_INT16_T ) #define HAVE_INT16_T typedef __int16 int16_t; #endif #if !defined( HAVE_UINT16_T ) #define HAVE_UINT16_T typedef unsigned __int16 uint16_t; #endif #if !defined( HAVE_INT32_T ) #define HAVE_INT32_T typedef __int32 int32_t; #endif #if !defined( HAVE_UINT32_T ) #define HAVE_UINT32_T typedef unsigned __int32 uint32_t; #endif #if !defined( HAVE_INT64_T ) #define HAVE_INT64_T typedef __int64 int64_t; #endif #if !defined( HAVE_UINT64_T ) #define HAVE_UINT64_T typedef unsigned __int64 uint64_t; #endif #ifdef __cplusplus } #endif #elif defined( _MSC_VER ) || defined( __BORLANDC__ ) /* Later versions of Microsoft Visual Studio C++ and Borland C/C++ define the types in */ #include #else #if 1 || defined( HAVE_SYS_TYPES_H ) #include #else #error Missing system type definitions (sys/types.h) #endif /* Type definitions for compilers that have access to * or */ #if 1 || defined( HAVE_INTTYPES_H ) #include #elif 1 || defined( HAVE_STDINT_H ) #include #else #error Missing integer type definitions (inttypes.h, stdint.h) #endif #endif #ifdef __cplusplus extern "C" { #endif #if defined( _MSC_VER ) || ( defined( __BORLANDC__ ) && ( __BORLANDC__ <= 0x0560 ) ) /* Microsoft Visual Studio C++ or earlier versions of the Borland C++ Builder * do not support the ssize_t type definition */ #if !defined( HAVE_SSIZE_T ) #define HAVE_SSIZE_T #if defined( _WIN64 ) typedef __int64 ssize_t; #else typedef __int32 ssize_t; #endif #endif /* !defined( HAVE_SSIZE_T ) */ #endif /* defined( _MSC_VER ) || ( defined( __BORLANDC__ ) && ( __BORLANDC__ <= 0x0560 ) ) */ #if defined( __BORLANDC__ ) && ( __BORLANDC__ <= 0x0560 ) /* Earlier versions of Borland C++ Builder do not support the intptr_t type definition */ #if !defined( HAVE_INTPTR_T ) #define HAVE_INTPTR_T #if defined( _WIN64 ) typedef __int64 intptr_t; #else typedef __int32 intptr_t; #endif #endif /* !defined( HAVE_INTPTR_T ) */ #endif /* defined( __BORLANDC__ ) && ( __BORLANDC__ <= 0x0560 ) */ #if ( !defined( HAVE_SIZE32_T ) && ! 0 ) || HAVE_SIZE32_T == 0 #define HAVE_SIZE32_T 1 typedef uint32_t size32_t; #endif #if ( !defined( HAVE_SSIZE32_T ) && ! 0 ) || HAVE_SSIZE32_T == 0 #define HAVE_SSIZE32_T 1 typedef int32_t ssize32_t; #endif #if ( !defined( HAVE_SIZE64_T ) && ! 0 ) || HAVE_SIZE64_T == 0 #define HAVE_SIZE64_T 1 typedef uint64_t size64_t; #endif #if ( !defined( HAVE_SSIZE64_T ) && ! 0 ) || HAVE_SSIZE64_T == 0 #define HAVE_SSIZE64_T 1 typedef int64_t ssize64_t; #endif #if ( !defined( HAVE_OFF64_T ) && ! 0 ) || HAVE_OFF64_T == 0 #define HAVE_OFF64_T 1 typedef int64_t off64_t; #endif /* Wide character definition */ #if defined( __BORLANDC__ ) && ( __BORLANDC__ <= 0x0520 ) #include #elif defined( WINAPI ) #include #elif 1 || defined( HAVE_WCHAR_H ) /* __USE_UNIX98 is required to add swprintf definition */ #if !defined( __USE_UNIX98 ) #define __USE_UNIX98 #define LIBCAES_DEFINITION_UNIX98 #endif #include #if defined( LIBCAES_DEFINITION_UNIX98 ) #undef __USE_UNIX98 #undef LIBCAES_DEFINITION_UNIX98 #endif #endif /* The following type definitions hide internal data structures */ typedef intptr_t libcaes_context_t; typedef intptr_t libcaes_tweaked_context_t; #ifdef __cplusplus } #endif #endif /* !defined( _LIBCAES_TYPES_H ) */ libcaes-20240413/include/libcaes/features.h.in0000644000175000017500000000230514606473412021643 0ustar00lordyestalordyesta/* * Features of libcaes * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_FEATURES_H ) #define _LIBCAES_FEATURES_H /* The libcaes type support features */ #if !defined( LIBCAES_DEPRECATED ) #if defined( __GNUC__ ) && __GNUC__ >= 3 #define LIBCAES_DEPRECATED __attribute__ ((__deprecated__)) #elif defined( _MSC_VER ) #define LIBCAES_DEPRECATED __declspec(deprecated) #else #define LIBCAES_DEPRECATED #endif #endif #endif /* !defined( _LIBCAES_FEATURES_H ) */ libcaes-20240413/include/libcaes/error.h0000644000175000017500000001504114606473412020552 0ustar00lordyestalordyesta/* * The error code definitions for libcaes * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_ERROR_H ) #define _LIBCAES_ERROR_H #include /* External error type definition hides internal structure */ typedef intptr_t libcaes_error_t; /* The error domains */ enum LIBCAES_ERROR_DOMAINS { LIBCAES_ERROR_DOMAIN_ARGUMENTS = (int) 'a', LIBCAES_ERROR_DOMAIN_CONVERSION = (int) 'c', LIBCAES_ERROR_DOMAIN_COMPRESSION = (int) 'C', LIBCAES_ERROR_DOMAIN_IO = (int) 'I', LIBCAES_ERROR_DOMAIN_INPUT = (int) 'i', LIBCAES_ERROR_DOMAIN_MEMORY = (int) 'm', LIBCAES_ERROR_DOMAIN_OUTPUT = (int) 'o', LIBCAES_ERROR_DOMAIN_RUNTIME = (int) 'r' }; /* The argument error codes * to signify errors regarding arguments passed to a function */ enum LIBCAES_ARGUMENT_ERROR { LIBCAES_ARGUMENT_ERROR_GENERIC = 0, /* The argument contains an invalid value */ LIBCAES_ARGUMENT_ERROR_INVALID_VALUE = 1, /* The argument contains a value less than zero */ LIBCAES_ARGUMENT_ERROR_VALUE_LESS_THAN_ZERO = 2, /* The argument contains a value zero or less */ LIBCAES_ARGUMENT_ERROR_VALUE_ZERO_OR_LESS = 3, /* The argument contains a value that exceeds the maximum * for the specific type */ LIBCAES_ARGUMENT_ERROR_VALUE_EXCEEDS_MAXIMUM = 4, /* The argument contains a value that is too small */ LIBCAES_ARGUMENT_ERROR_VALUE_TOO_SMALL = 5, /* The argument contains a value that is too large */ LIBCAES_ARGUMENT_ERROR_VALUE_TOO_LARGE = 6, /* The argument contains a value that is out of bounds */ LIBCAES_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS = 7, /* The argument contains a value that is not supported */ LIBCAES_ARGUMENT_ERROR_UNSUPPORTED_VALUE = 8, /* The argument contains a value that conficts with another argument */ LIBCAES_ARGUMENT_ERROR_CONFLICTING_VALUE = 9 }; /* The conversion error codes * to signify errors regarding conversions */ enum LIBCAES_CONVERSION_ERROR { LIBCAES_CONVERSION_ERROR_GENERIC = 0, /* The conversion failed on the input */ LIBCAES_CONVERSION_ERROR_INPUT_FAILED = 1, /* The conversion failed on the output */ LIBCAES_CONVERSION_ERROR_OUTPUT_FAILED = 2 }; /* The compression error codes * to signify errors regarding compression */ enum LIBCAES_COMPRESSION_ERROR { LIBCAES_COMPRESSION_ERROR_GENERIC = 0, /* The compression failed */ LIBCAES_COMPRESSION_ERROR_COMPRESS_FAILED = 1, /* The decompression failed */ LIBCAES_COMPRESSION_ERROR_DECOMPRESS_FAILED = 2 }; /* The input/output error codes * to signify errors regarding input/output */ enum LIBCAES_IO_ERROR { LIBCAES_IO_ERROR_GENERIC = 0, /* The open failed */ LIBCAES_IO_ERROR_OPEN_FAILED = 1, /* The close failed */ LIBCAES_IO_ERROR_CLOSE_FAILED = 2, /* The seek failed */ LIBCAES_IO_ERROR_SEEK_FAILED = 3, /* The read failed */ LIBCAES_IO_ERROR_READ_FAILED = 4, /* The write failed */ LIBCAES_IO_ERROR_WRITE_FAILED = 5, /* Access denied */ LIBCAES_IO_ERROR_ACCESS_DENIED = 6, /* The resource is invalid i.e. a missing file */ LIBCAES_IO_ERROR_INVALID_RESOURCE = 7, /* The ioctl failed */ LIBCAES_IO_ERROR_IOCTL_FAILED = 8, /* The unlink failed */ LIBCAES_IO_ERROR_UNLINK_FAILED = 9 }; /* The input error codes * to signify errors regarding handing input data */ enum LIBCAES_INPUT_ERROR { LIBCAES_INPUT_ERROR_GENERIC = 0, /* The input contains invalid data */ LIBCAES_INPUT_ERROR_INVALID_DATA = 1, /* The input contains an unsupported signature */ LIBCAES_INPUT_ERROR_SIGNATURE_MISMATCH = 2, /* A checksum in the input did not match */ LIBCAES_INPUT_ERROR_CHECKSUM_MISMATCH = 3, /* A value in the input did not match a previously * read value or calculated value */ LIBCAES_INPUT_ERROR_VALUE_MISMATCH = 4 }; /* The memory error codes * to signify errors regarding memory */ enum LIBCAES_MEMORY_ERROR { LIBCAES_MEMORY_ERROR_GENERIC = 0, /* There is insufficient memory available */ LIBCAES_MEMORY_ERROR_INSUFFICIENT = 1, /* The memory failed to be copied */ LIBCAES_MEMORY_ERROR_COPY_FAILED = 2, /* The memory failed to be set */ LIBCAES_MEMORY_ERROR_SET_FAILED = 3 }; /* The output error codes */ enum LIBCAES_OUTPUT_ERROR { LIBCAES_OUTPUT_ERROR_GENERIC = 0, /* There is insuficient space to write the output */ LIBCAES_OUTPUT_ERROR_INSUFFICIENT_SPACE = 1 }; /* The runtime error codes * to signify errors regarding runtime processing */ enum LIBCAES_RUNTIME_ERROR { LIBCAES_RUNTIME_ERROR_GENERIC = 0, /* The value is missing */ LIBCAES_RUNTIME_ERROR_VALUE_MISSING = 1, /* The value was already set */ LIBCAES_RUNTIME_ERROR_VALUE_ALREADY_SET = 2, /* The creation and/or initialization of an internal structure failed */ LIBCAES_RUNTIME_ERROR_INITIALIZE_FAILED = 3, /* The resize of an internal structure failed */ LIBCAES_RUNTIME_ERROR_RESIZE_FAILED = 4, /* The free and/or finalization of an internal structure failed */ LIBCAES_RUNTIME_ERROR_FINALIZE_FAILED = 5, /* The value could not be determined */ LIBCAES_RUNTIME_ERROR_GET_FAILED = 6, /* The value could not be set */ LIBCAES_RUNTIME_ERROR_SET_FAILED = 7, /* The value could not be appended/prepended */ LIBCAES_RUNTIME_ERROR_APPEND_FAILED = 8, /* The value could not be copied */ LIBCAES_RUNTIME_ERROR_COPY_FAILED = 9, /* The value could not be removed */ LIBCAES_RUNTIME_ERROR_REMOVE_FAILED = 10, /* The value could not be printed */ LIBCAES_RUNTIME_ERROR_PRINT_FAILED = 11, /* The value was out of bounds */ LIBCAES_RUNTIME_ERROR_VALUE_OUT_OF_BOUNDS = 12, /* The value exceeds the maximum for its specific type */ LIBCAES_RUNTIME_ERROR_VALUE_EXCEEDS_MAXIMUM = 13, /* The value is unsupported */ LIBCAES_RUNTIME_ERROR_UNSUPPORTED_VALUE = 14, /* An abort was requested */ LIBCAES_RUNTIME_ERROR_ABORT_REQUESTED = 15 }; #endif /* !defined( _LIBCAES_ERROR_H ) */ libcaes-20240413/include/libcaes/extern.h0000644000175000017500000000260414606473412020727 0ustar00lordyestalordyesta/* * The extern definition * * This header should be included in header files that export or import * library functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_EXTERN_H ) #define _LIBCAES_EXTERN_H /* To export functions from the libcaes DLL define LIBCAES_DLL_EXPORT * To import functions from the libcaes DLL define LIBCAES_DLL_IMPORT * Otherwise use default extern statement */ #if defined( LIBCAES_DLL_EXPORT ) #define LIBCAES_EXTERN __declspec(dllexport) #elif defined( LIBCAES_DLL_IMPORT ) #define LIBCAES_EXTERN extern __declspec(dllimport) #else #define LIBCAES_EXTERN extern #endif #endif /* !defined( _LIBCAES_EXTERN_H ) */ libcaes-20240413/include/libcaes/features.h0000644000175000017500000000230514606477645021252 0ustar00lordyestalordyesta/* * Features of libcaes * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_FEATURES_H ) #define _LIBCAES_FEATURES_H /* The libcaes type support features */ #if !defined( LIBCAES_DEPRECATED ) #if defined( __GNUC__ ) && __GNUC__ >= 3 #define LIBCAES_DEPRECATED __attribute__ ((__deprecated__)) #elif defined( _MSC_VER ) #define LIBCAES_DEPRECATED __declspec(deprecated) #else #define LIBCAES_DEPRECATED #endif #endif #endif /* !defined( _LIBCAES_FEATURES_H ) */ libcaes-20240413/include/Makefile.am0000644000175000017500000000060414606474144017704 0ustar00lordyestalordyestainclude_HEADERS = \ libcaes.h pkginclude_HEADERS = \ libcaes/definitions.h \ libcaes/error.h \ libcaes/extern.h \ libcaes/features.h \ libcaes/types.h EXTRA_DIST = \ libcaes.h.in \ libcaes/definitions.h.in \ libcaes/features.h.in \ libcaes/types.h.in DISTCLEANFILES = \ libcaes.h \ libcaes/definitions.h \ libcaes/features.h \ libcaes/types.h \ Makefile \ Makefile.in libcaes-20240413/include/libcaes.h.in0000644000175000017500000001500314606473412020024 0ustar00lordyestalordyesta/* * Library to support support file format date and time values * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCAES_H ) #define _LIBCAES_H #include #include #include #include #include #include #if defined( __cplusplus ) extern "C" { #endif /* ------------------------------------------------------------------------- * Support functions * ------------------------------------------------------------------------- */ /* Returns the library version */ LIBCAES_EXTERN \ const char *libcaes_get_version( void ); /* ------------------------------------------------------------------------- * Error functions * ------------------------------------------------------------------------- */ /* Frees an error */ LIBCAES_EXTERN \ void libcaes_error_free( libcaes_error_t **error ); /* Prints a descriptive string of the error to the stream * Returns the amount of printed characters if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_error_fprint( libcaes_error_t *error, FILE *stream ); /* Prints a descriptive string of the error to the string * The end-of-string character is not included in the return value * Returns the amount of printed characters if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_error_sprint( libcaes_error_t *error, char *string, size_t size ); /* Prints a backtrace of the error to the stream * Returns the amount of printed characters if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_error_backtrace_fprint( libcaes_error_t *error, FILE *stream ); /* Prints a backtrace of the error to the string * The end-of-string character is not included in the return value * Returns the amount of printed characters if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_error_backtrace_sprint( libcaes_error_t *error, char *string, size_t size ); /* ------------------------------------------------------------------------- * Context functions * ------------------------------------------------------------------------- */ /* Creates a context * Make sure the value context is referencing, is set to NULL * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_context_initialize( libcaes_context_t **context, libcaes_error_t **error ); /* Frees a context * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_context_free( libcaes_context_t **context, libcaes_error_t **error ); /* Sets the key * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_context_set_key( libcaes_context_t *context, int mode, const uint8_t *key, size_t key_bit_size, libcaes_error_t **error ); /* De- or encrypts a block of data using AES-CBC (Cipher Block Chaining) * The size must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_crypt_cbc( libcaes_context_t *context, int mode, const uint8_t *initialization_vector, size_t initialization_vector_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcaes_error_t **error ); /* De- or encrypts a block of data using AES-CCM (Counter with CBC-MAC) * Note that the key must be set in encryption mode (LIBCAES_CRYPT_MODE_ENCRYPT) for both de- and encryption. * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_crypt_ccm( libcaes_context_t *context, int mode, const uint8_t *nonce, size_t nonce_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcaes_error_t **error ); /* De- or encrypts a block of data using AES-ECB (Electronic CodeBook) * The size must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_crypt_ecb( libcaes_context_t *context, int mode, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcaes_error_t **error ); /* ------------------------------------------------------------------------- * Tweaked context functions * ------------------------------------------------------------------------- */ /* Creates a tweaked context * Make sure the value tweaked context is referencing, is set to NULL * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_tweaked_context_initialize( libcaes_tweaked_context_t **tweaked_context, libcaes_error_t **error ); /* Frees a tweaked context * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_tweaked_context_free( libcaes_tweaked_context_t **tweaked_context, libcaes_error_t **error ); /* Sets the keys * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_tweaked_context_set_keys( libcaes_tweaked_context_t *tweaked_context, int mode, const uint8_t *key, size_t key_bit_size, const uint8_t *tweak_key, size_t tweak_key_bit_size, libcaes_error_t **error ); /* De- or encrypts a block of data using AES-XTS (XEX-based tweaked-codebook mode with ciphertext stealing) * The size must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ LIBCAES_EXTERN \ int libcaes_crypt_xts( libcaes_tweaked_context_t *tweaked_context, int mode, const uint8_t *tweak_value, size_t tweak_value_size, const uint8_t *input_data, size_t input_data_size, uint8_t *output_data, size_t output_data_size, libcaes_error_t **error ); #if defined( __cplusplus ) } #endif #endif /* !defined( _LIBCAES_H ) */ libcaes-20240413/include/Makefile.in0000644000175000017500000005154514606477627017740 0ustar00lordyestalordyesta# Makefile.in generated by automake 1.16.5 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2021 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = include ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/common.m4 \ $(top_srcdir)/m4/gettext.m4 $(top_srcdir)/m4/host-cpu-c-abi.m4 \ $(top_srcdir)/m4/iconv.m4 $(top_srcdir)/m4/intlmacosx.m4 \ $(top_srcdir)/m4/lib-ld.m4 $(top_srcdir)/m4/lib-link.m4 \ $(top_srcdir)/m4/lib-prefix.m4 $(top_srcdir)/m4/libcerror.m4 \ $(top_srcdir)/m4/libcrypto.m4 $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/nls.m4 $(top_srcdir)/m4/po.m4 \ $(top_srcdir)/m4/progtest.m4 $(top_srcdir)/m4/python.m4 \ $(top_srcdir)/m4/tests.m4 $(top_srcdir)/m4/types.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(include_HEADERS) \ $(pkginclude_HEADERS) $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/common/config.h CONFIG_CLEAN_FILES = libcaes.h CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(includedir)" \ "$(DESTDIR)$(pkgincludedir)" HEADERS = $(include_HEADERS) $(pkginclude_HEADERS) am__extra_recursive_targets = sources-recursive splint-recursive am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/libcaes.h.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CSCOPE = @CSCOPE@ CTAGS = @CTAGS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DPKG_DATE = @DPKG_DATE@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ ETAGS = @ETAGS@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ FILECMD = @FILECMD@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GREP = @GREP@ HAVE_DLLMAIN = @HAVE_DLLMAIN@ HAVE_INTTYPES_H = @HAVE_INTTYPES_H@ HAVE_LIBCERROR = @HAVE_LIBCERROR@ HAVE_LOCAL_LIBCERROR = @HAVE_LOCAL_LIBCERROR@ HAVE_OFF64_T = @HAVE_OFF64_T@ HAVE_OPENSSL_EVP_H = @HAVE_OPENSSL_EVP_H@ HAVE_SIZE32_T = @HAVE_SIZE32_T@ HAVE_SIZE64_T = @HAVE_SIZE64_T@ HAVE_SSIZE32_T = @HAVE_SSIZE32_T@ HAVE_SSIZE64_T = @HAVE_SSIZE64_T@ HAVE_STDINT_H = @HAVE_STDINT_H@ HAVE_SYS_TYPES_H = @HAVE_SYS_TYPES_H@ HAVE_WCHAR_H = @HAVE_WCHAR_H@ HAVE_WIDE_CHARACTER_TYPE = @HAVE_WIDE_CHARACTER_TYPE@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBCAES_DLL_EXPORT = @LIBCAES_DLL_EXPORT@ LIBCAES_DLL_IMPORT = @LIBCAES_DLL_IMPORT@ LIBCERROR_CPPFLAGS = @LIBCERROR_CPPFLAGS@ LIBCERROR_LIBADD = @LIBCERROR_LIBADD@ LIBCRYPTO_CPPFLAGS = @LIBCRYPTO_CPPFLAGS@ LIBCRYPTO_LIBADD = @LIBCRYPTO_LIBADD@ LIBDL_LIBADD = @LIBDL_LIBADD@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIB_FUZZING_ENGINE = @LIB_FUZZING_ENGINE@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGMERGE = @MSGMERGE@ MSGMERGE_FOR_MSGFMT_OPTION = @MSGMERGE_FOR_MSGFMT_OPTION@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ PKGCONFIG = @PKGCONFIG@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ PYTHON = @PYTHON@ PYTHON_CONFIG = @PYTHON_CONFIG@ PYTHON_CPPFLAGS = @PYTHON_CPPFLAGS@ PYTHON_EXEC_PREFIX = @PYTHON_EXEC_PREFIX@ PYTHON_LDFLAGS = @PYTHON_LDFLAGS@ PYTHON_LIBRARY_DIR = @PYTHON_LIBRARY_DIR@ PYTHON_PACKAGE_DIR = @PYTHON_PACKAGE_DIR@ PYTHON_PLATFORM = @PYTHON_PLATFORM@ PYTHON_PREFIX = @PYTHON_PREFIX@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ SPEC_DATE = @SPEC_DATE@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ ax_libcerror_pc_libs_private = @ax_libcerror_pc_libs_private@ ax_libcerror_spec_build_requires = @ax_libcerror_spec_build_requires@ ax_libcerror_spec_requires = @ax_libcerror_spec_requires@ ax_libcrypto_pc_libs_private = @ax_libcrypto_pc_libs_private@ ax_libcrypto_spec_build_requires = @ax_libcrypto_spec_build_requires@ ax_libcrypto_spec_requires = @ax_libcrypto_spec_requires@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libcaes_spec_requires = @libcaes_spec_requires@ libcerror_CFLAGS = @libcerror_CFLAGS@ libcerror_LIBS = @libcerror_LIBS@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ openssl_CFLAGS = @openssl_CFLAGS@ openssl_LIBS = @openssl_LIBS@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ pyexecdir = @pyexecdir@ pythondir = @pythondir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ include_HEADERS = \ libcaes.h pkginclude_HEADERS = \ libcaes/definitions.h \ libcaes/error.h \ libcaes/extern.h \ libcaes/features.h \ libcaes/types.h EXTRA_DIST = \ libcaes.h.in \ libcaes/definitions.h.in \ libcaes/features.h.in \ libcaes/types.h.in DISTCLEANFILES = \ libcaes.h \ libcaes/definitions.h \ libcaes/features.h \ libcaes/types.h \ Makefile \ Makefile.in all: all-am .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu include/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu include/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): libcaes.h: $(top_builddir)/config.status $(srcdir)/libcaes.h.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-includeHEADERS: $(include_HEADERS) @$(NORMAL_INSTALL) @list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(includedir)'"; \ $(MKDIR_P) "$(DESTDIR)$(includedir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_HEADER) $$files '$(DESTDIR)$(includedir)'"; \ $(INSTALL_HEADER) $$files "$(DESTDIR)$(includedir)" || exit $$?; \ done uninstall-includeHEADERS: @$(NORMAL_UNINSTALL) @list='$(include_HEADERS)'; test -n "$(includedir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(includedir)'; $(am__uninstall_files_from_dir) install-pkgincludeHEADERS: $(pkginclude_HEADERS) @$(NORMAL_INSTALL) @list='$(pkginclude_HEADERS)'; test -n "$(pkgincludedir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(pkgincludedir)'"; \ $(MKDIR_P) "$(DESTDIR)$(pkgincludedir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_HEADER) $$files '$(DESTDIR)$(pkgincludedir)'"; \ $(INSTALL_HEADER) $$files "$(DESTDIR)$(pkgincludedir)" || exit $$?; \ done uninstall-pkgincludeHEADERS: @$(NORMAL_UNINSTALL) @list='$(pkginclude_HEADERS)'; test -n "$(pkgincludedir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(pkgincludedir)'; $(am__uninstall_files_from_dir) sources-local: splint-local: ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(HEADERS) installdirs: for dir in "$(DESTDIR)$(includedir)" "$(DESTDIR)$(pkgincludedir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) -test -z "$(DISTCLEANFILES)" || rm -f $(DISTCLEANFILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-includeHEADERS install-pkgincludeHEADERS install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: sources: sources-am sources-am: sources-local splint: splint-am splint-am: splint-local uninstall-am: uninstall-includeHEADERS uninstall-pkgincludeHEADERS .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool cscopelist-am ctags ctags-am distclean \ distclean-generic distclean-libtool distclean-tags distdir dvi \ dvi-am html html-am info info-am install install-am \ install-data install-data-am install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-includeHEADERS install-info install-info-am \ install-man install-pdf install-pdf-am \ install-pkgincludeHEADERS install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ sources-am sources-local splint-am splint-local tags tags-am \ uninstall uninstall-am uninstall-includeHEADERS \ uninstall-pkgincludeHEADERS .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: libcaes-20240413/common/0000755000175000017500000000000014606477653015525 5ustar00lordyestalordyestalibcaes-20240413/common/config_borlandc.h0000644000175000017500000000167514606473412021005 0ustar00lordyestalordyesta/* * Configuration for the Borland/CodeGear C++ Builder compiler * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _CONFIG_BORLANDC_H ) #define _CONFIG_BORLANDC_H #endif /* !defined( _CONFIG_BORLANDC_H ) */ libcaes-20240413/common/file_stream.h0000644000175000017500000000744614606473412020170 0ustar00lordyestalordyesta/* * FILE stream functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _FILE_STREAM_H ) #define _FILE_STREAM_H #include "common.h" #if defined( HAVE_GLIB_H ) #include #include #endif #include #if defined( __cplusplus ) extern "C" { #endif #define FILE_STREAM_OPEN_APPEND "a" #define FILE_STREAM_OPEN_READ "r" #define FILE_STREAM_OPEN_WRITE "w" #if defined( WINAPI ) #define FILE_STREAM_BINARY_OPEN_APPEND "ab" #define FILE_STREAM_BINARY_OPEN_READ "rb" #define FILE_STREAM_BINARY_OPEN_WRITE "wb" #else #define FILE_STREAM_BINARY_OPEN_APPEND "a" #define FILE_STREAM_BINARY_OPEN_READ "r" #define FILE_STREAM_BINARY_OPEN_WRITE "w" #endif /* narrow character FILE stream open */ #if defined( HAVE_GLIB_H ) #define file_stream_open( filename, mode ) \ g_fopen( filename, mode ) #elif defined( HAVE_FOPEN ) || defined( WINAPI ) #define file_stream_open( filename, mode ) \ fopen( filename, mode ) #endif /* wide character FILE stream open */ #if defined( WINAPI ) #define file_stream_open_wide( filename, mode ) \ _wfopen( filename, mode ) #endif /* FILE stream close */ #if defined( HAVE_FCLOSE ) || defined( WINAPI ) #define file_stream_close( stream ) \ fclose( stream ) #endif /* FILE stream read */ #if defined( HAVE_FREAD ) || defined( WINAPI ) #define file_stream_read( stream, data, size ) \ fread( data, 1, size, stream ) #endif /* FILE stream write */ #if defined( HAVE_FWRITE ) || defined( WINAPI ) #define file_stream_write( stream, data, size ) \ fwrite( data, 1, size, stream ) #endif /* FILE stream seek */ #if defined( WINAPI ) #define file_stream_seek_offset( stream, offset, whence ) \ fseek( stream, offset, whence ) #elif defined( HAVE_FSEEKO ) #define file_stream_seek_offset( stream, offset, whence ) \ fseeko( stream, offset, whence ) #elif defined( HAVE_FSEEKO64 ) #define file_stream_seek_offset( stream, offset, whence ) \ fseeko64( stream, offset, whence ) #endif /* End of FILE stream */ #if defined( HAVE_FEOF ) || defined( WINAPI ) #define file_stream_at_end( stream ) \ feof( stream ) #endif /* Get narrow character string from FILE stream */ #if defined( HAVE_FGETS ) || defined( WINAPI ) #define file_stream_get_string( stream, string, size ) \ fgets( string, size, stream ) #endif /* Get wide characters string from FILE stream */ #if defined( HAVE_FGETWS ) || defined( WINAPI ) #define file_stream_get_string_wide( stream, string, size ) \ fgetws( string, size, stream ) #endif /* Variable arguments formatted print to stream function */ #if defined( HAVE_GLIB_H ) #define file_stream_vfprintf( stream, format, ... ) \ g_vfprintf( stream, format, __VA_ARGS__ ) /* Borland BCC previous to version 5.6.0 cannot handle the macro form: MACRO( ... ) */ #elif defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define file_stream_vfprintf \ vfprintf #elif defined( HAVE_VFPRINTF ) || defined( WINAPI ) #define file_stream_vfprintf( stream, format, ... ) \ vfprintf( stream, format, __VA_ARGS__ ) #endif #if defined( __cplusplus ) } #endif #endif /* !defined( _FILE_STREAM_H ) */ libcaes-20240413/common/memory.h0000644000175000017500000000627314606473412017203 0ustar00lordyestalordyesta/* * Memory functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _MEMORY_H ) #define _MEMORY_H #include "common.h" #if defined( HAVE_GLIB_H ) #include #endif #if defined( HAVE_STDLIB_H ) || defined( WINAPI ) #include #endif #if defined( HAVE_STRING_H ) || defined( WINAPI ) #include #endif #if defined( __cplusplus ) extern "C" { #endif /* Note that 128 MiB is an arbitrary selected upper limit here */ #define MEMORY_MAXIMUM_ALLOCATION_SIZE \ ( 128 * 1024 * 1024 ) /* Memory allocation */ #if defined( HAVE_GLIB_H ) #define memory_allocate( size ) \ g_malloc( (gsize) size ) #elif defined( WINAPI ) #define memory_allocate( size ) \ HeapAlloc( GetProcessHeap(), 0, (SIZE_T) size ) #elif defined( HAVE_MALLOC ) #define memory_allocate( size ) \ malloc( size ) #endif #define memory_allocate_structure( type ) \ (type *) memory_allocate( sizeof( type ) ) #define memory_allocate_structure_as_value( type ) \ (intptr_t *) memory_allocate( sizeof( type ) ) /* Memory reallocation */ #if defined( HAVE_GLIB_H ) #define memory_reallocate( buffer, size ) \ g_realloc( (gpointer) buffer, (gsize) size ) #elif defined( WINAPI ) /* HeapReAlloc does not allocate empty (NULL) buffers as realloc does */ #define memory_reallocate( buffer, size ) \ ( buffer == NULL ) ? \ HeapAlloc( GetProcessHeap(), 0, (SIZE_T) size ) : \ HeapReAlloc( GetProcessHeap(), 0, (LPVOID) buffer, (SIZE_T) size ) #elif defined( HAVE_REALLOC ) #define memory_reallocate( buffer, size ) \ realloc( (void *) buffer, size ) #endif /* Memory free */ #if defined( HAVE_GLIB_H ) #define memory_free( buffer ) \ g_free( (gpointer) buffer ) #elif defined( WINAPI ) #define memory_free( buffer ) \ ( buffer == NULL ) ? TRUE : HeapFree( GetProcessHeap(), 0, (LPVOID) buffer ) #elif defined( HAVE_FREE ) #define memory_free( buffer ) \ free( (void *) buffer ) #endif /* Memory compare */ #if defined( HAVE_MEMCMP ) || defined( WINAPI ) #define memory_compare( buffer1, buffer2, size ) \ memcmp( (const void *) buffer1, (const void *) buffer2, size ) #endif /* Memory copy */ #if defined( HAVE_MEMCPY ) || defined( WINAPI ) #define memory_copy( destination, source, count ) \ memcpy( (void *) destination, (void *) source, count ) #endif /* Memory set */ #if defined( HAVE_MEMSET ) || defined( WINAPI ) #define memory_set( buffer, value, count ) \ memset( (void *) buffer, (int) value, count ) #endif #if defined( __cplusplus ) } #endif #endif /* !defined( _MEMORY_H ) */ libcaes-20240413/common/byte_stream.h0000644000175000017500000002430514606473412020205 0ustar00lordyestalordyesta/* * Byte stream functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _BYTE_STREAM_H ) #define _BYTE_STREAM_H #include "common.h" #include "types.h" #if defined( __cplusplus ) extern "C" { #endif #define _BYTE_STREAM_HOST_IS_ENDIAN_BIG ( *((uint32_t *) "\x01\x02\x03\x04" ) == 0x01020304 ) #define _BYTE_STREAM_HOST_IS_ENDIAN_LITTLE ( *((uint32_t *) "\x01\x02\x03\x04" ) == 0x04030201 ) #define _BYTE_STREAM_HOST_IS_ENDIAN_MIDDLE ( *((uint32_t *) "\x01\x02\x03\x04" ) == 0x02010403 ) #define _BYTE_STREAM_ENDIAN_BIG (uint8_t) 'b' #define _BYTE_STREAM_ENDIAN_LITTLE (uint8_t) 'l' #define _BYTE_STREAM_ENDIAN_MIDDLE (uint8_t) 'm' typedef union byte_stream_float32 { float floating_point; uint32_t integer; } byte_stream_float32_t; typedef union byte_stream_float64 { double floating_point; uint64_t integer; } byte_stream_float64_t; #define byte_stream_copy_to_uint16_big_endian( byte_stream, value ) \ ( value ) = ( byte_stream )[ 0 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 1 ]; #define byte_stream_copy_to_uint16_little_endian( byte_stream, value ) \ ( value ) = ( byte_stream )[ 1 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 0 ]; #define byte_stream_copy_to_uint24_big_endian( byte_stream, value ) \ ( value ) = ( byte_stream )[ 0 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 1 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 2 ]; #define byte_stream_copy_to_uint24_little_endian( byte_stream, value ) \ ( value ) = ( byte_stream )[ 2 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 1 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 0 ]; #define byte_stream_copy_to_uint32_big_endian( byte_stream, value ) \ ( value ) = ( byte_stream )[ 0 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 1 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 2 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 3 ]; #define byte_stream_copy_to_uint32_little_endian( byte_stream, value ) \ ( value ) = ( byte_stream )[ 3 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 2 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 1 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 0 ]; #define byte_stream_copy_to_uint48_big_endian( byte_stream, value ) \ ( value ) = ( byte_stream )[ 0 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 1 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 2 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 3 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 4 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 5 ]; #define byte_stream_copy_to_uint48_little_endian( byte_stream, value ) \ ( value ) |= ( byte_stream )[ 5 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 4 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 3 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 2 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 1 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 0 ]; #define byte_stream_copy_to_uint64_big_endian( byte_stream, value ) \ ( value ) = ( byte_stream )[ 0 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 1 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 2 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 3 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 4 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 5 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 6 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 7 ]; #define byte_stream_copy_to_uint64_little_endian( byte_stream, value ) \ ( value ) = ( byte_stream )[ 7 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 6 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 5 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 4 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 3 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 2 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 1 ]; \ ( value ) <<= 8; \ ( value ) |= ( byte_stream )[ 0 ]; #define byte_stream_copy_from_uint16_big_endian( byte_stream, value ) \ ( byte_stream )[ 0 ] = (uint8_t) ( ( ( value ) >> 8 ) & 0x0ff ); \ ( byte_stream )[ 1 ] = (uint8_t) ( ( value ) & 0x0ff ) #define byte_stream_copy_from_uint16_little_endian( byte_stream, value ) \ ( byte_stream )[ 1 ] = (uint8_t) ( ( ( value ) >> 8 ) & 0x0ff ); \ ( byte_stream )[ 0 ] = (uint8_t) ( ( value ) & 0x0ff ) #define byte_stream_copy_from_uint24_big_endian( byte_stream, value ) \ ( byte_stream )[ 0 ] = (uint8_t) ( ( ( value ) >> 16 ) & 0x0ff ); \ ( byte_stream )[ 1 ] = (uint8_t) ( ( ( value ) >> 8 ) & 0x0ff ); \ ( byte_stream )[ 2 ] = (uint8_t) ( ( value ) & 0x0ff ) #define byte_stream_copy_from_uint24_little_endian( byte_stream, value ) \ ( byte_stream )[ 2 ] = (uint8_t) ( ( ( value ) >> 16 ) & 0x0ff ); \ ( byte_stream )[ 1 ] = (uint8_t) ( ( ( value ) >> 8 ) & 0x0ff ); \ ( byte_stream )[ 0 ] = (uint8_t) ( ( value ) & 0x0ff ) #define byte_stream_copy_from_uint32_big_endian( byte_stream, value ) \ ( byte_stream )[ 0 ] = (uint8_t) ( ( ( value ) >> 24 ) & 0x0ff ); \ ( byte_stream )[ 1 ] = (uint8_t) ( ( ( value ) >> 16 ) & 0x0ff ); \ ( byte_stream )[ 2 ] = (uint8_t) ( ( ( value ) >> 8 ) & 0x0ff ); \ ( byte_stream )[ 3 ] = (uint8_t) ( ( value ) & 0x0ff ) #define byte_stream_copy_from_uint32_little_endian( byte_stream, value ) \ ( byte_stream )[ 3 ] = (uint8_t) ( ( ( value ) >> 24 ) & 0x0ff ); \ ( byte_stream )[ 2 ] = (uint8_t) ( ( ( value ) >> 16 ) & 0x0ff ); \ ( byte_stream )[ 1 ] = (uint8_t) ( ( ( value ) >> 8 ) & 0x0ff ); \ ( byte_stream )[ 0 ] = (uint8_t) ( ( value ) & 0x0ff ) #define byte_stream_copy_from_uint48_big_endian( byte_stream, value ) \ ( byte_stream )[ 0 ] = (uint8_t) ( ( ( value ) >> 40 ) & 0x0ff ); \ ( byte_stream )[ 1 ] = (uint8_t) ( ( ( value ) >> 32 ) & 0x0ff ); \ ( byte_stream )[ 2 ] = (uint8_t) ( ( ( value ) >> 24 ) & 0x0ff ); \ ( byte_stream )[ 3 ] = (uint8_t) ( ( ( value ) >> 16 ) & 0x0ff ); \ ( byte_stream )[ 4 ] = (uint8_t) ( ( ( value ) >> 8 ) & 0x0ff ); \ ( byte_stream )[ 5 ] = (uint8_t) ( ( value ) & 0x0ff ) #define byte_stream_copy_from_uint48_little_endian( byte_stream, value ) \ ( byte_stream )[ 5 ] = (uint8_t) ( ( ( value ) >> 40 ) & 0x0ff ); \ ( byte_stream )[ 4 ] = (uint8_t) ( ( ( value ) >> 32 ) & 0x0ff ); \ ( byte_stream )[ 3 ] = (uint8_t) ( ( ( value ) >> 24 ) & 0x0ff ); \ ( byte_stream )[ 2 ] = (uint8_t) ( ( ( value ) >> 16 ) & 0x0ff ); \ ( byte_stream )[ 1 ] = (uint8_t) ( ( ( value ) >> 8 ) & 0x0ff ); \ ( byte_stream )[ 0 ] = (uint8_t) ( ( value ) & 0x0ff ) #define byte_stream_copy_from_uint64_big_endian( byte_stream, value ) \ ( byte_stream )[ 0 ] = (uint8_t) ( ( ( value ) >> 56 ) & 0x0ff ); \ ( byte_stream )[ 1 ] = (uint8_t) ( ( ( value ) >> 48 ) & 0x0ff ); \ ( byte_stream )[ 2 ] = (uint8_t) ( ( ( value ) >> 40 ) & 0x0ff ); \ ( byte_stream )[ 3 ] = (uint8_t) ( ( ( value ) >> 32 ) & 0x0ff ); \ ( byte_stream )[ 4 ] = (uint8_t) ( ( ( value ) >> 24 ) & 0x0ff ); \ ( byte_stream )[ 5 ] = (uint8_t) ( ( ( value ) >> 16 ) & 0x0ff ); \ ( byte_stream )[ 6 ] = (uint8_t) ( ( ( value ) >> 8 ) & 0x0ff ); \ ( byte_stream )[ 7 ] = (uint8_t) ( ( value ) & 0x0ff ) #define byte_stream_copy_from_uint64_little_endian( byte_stream, value ) \ ( byte_stream )[ 7 ] = (uint8_t) ( ( ( value ) >> 56 ) & 0x0ff ); \ ( byte_stream )[ 6 ] = (uint8_t) ( ( ( value ) >> 48 ) & 0x0ff ); \ ( byte_stream )[ 5 ] = (uint8_t) ( ( ( value ) >> 40 ) & 0x0ff ); \ ( byte_stream )[ 4 ] = (uint8_t) ( ( ( value ) >> 32 ) & 0x0ff ); \ ( byte_stream )[ 3 ] = (uint8_t) ( ( ( value ) >> 24 ) & 0x0ff ); \ ( byte_stream )[ 2 ] = (uint8_t) ( ( ( value ) >> 16 ) & 0x0ff ); \ ( byte_stream )[ 1 ] = (uint8_t) ( ( ( value ) >> 8 ) & 0x0ff ); \ ( byte_stream )[ 0 ] = (uint8_t) ( ( value ) & 0x0ff ) #define byte_stream_bit_rotate_left_8bit( byte_stream, number_of_bits ) \ ( ( ( byte_stream ) << ( number_of_bits ) ) | ( ( byte_stream ) >> ( 8 - ( number_of_bits ) ) ) ) #define byte_stream_bit_rotate_right_8bit( byte_stream, number_of_bits ) \ ( ( ( byte_stream ) >> ( number_of_bits ) ) | ( ( byte_stream ) << ( 8 - ( number_of_bits ) ) ) ) #define byte_stream_bit_rotate_left_16bit( byte_stream, number_of_bits ) \ ( ( ( byte_stream ) << ( number_of_bits ) ) | ( ( byte_stream ) >> ( 16 - ( number_of_bits ) ) ) ) #define byte_stream_bit_rotate_right_16bit( byte_stream, number_of_bits ) \ ( ( ( byte_stream ) >> ( number_of_bits ) ) | ( ( byte_stream ) << ( 16 - ( number_of_bits ) ) ) ) #define byte_stream_bit_rotate_left_32bit( byte_stream, number_of_bits ) \ ( ( ( byte_stream ) << ( number_of_bits ) ) | ( ( byte_stream ) >> ( 32 - ( number_of_bits ) ) ) ) #define byte_stream_bit_rotate_right_32bit( byte_stream, number_of_bits ) \ ( ( ( byte_stream ) >> ( number_of_bits ) ) | ( ( byte_stream ) << ( 32 - ( number_of_bits ) ) ) ) #define byte_stream_bit_rotate_left_64bit( byte_stream, number_of_bits ) \ ( ( ( byte_stream ) << ( number_of_bits ) ) | ( ( byte_stream ) >> ( 64 - ( number_of_bits ) ) ) ) #define byte_stream_bit_rotate_right_64bit( byte_stream, number_of_bits ) \ ( ( ( byte_stream ) >> ( number_of_bits ) ) | ( ( byte_stream ) << ( 64 - ( number_of_bits ) ) ) ) #define byte_stream_bit_rotate_left( value, number_of_bits ) \ ( ( ( value ) << ( number_of_bits ) ) | ( ( value ) >> ( ( sizeof( value ) << 3 ) - ( number_of_bits ) ) ) ) #define byte_stream_bit_rotate_right( value, number_of_bits ) \ ( ( ( value ) >> ( number_of_bits ) ) | ( ( value ) << ( ( sizeof( value ) << 3 ) - ( number_of_bits ) ) ) ) #if defined( __cplusplus ) } #endif #endif /* !defined( _BYTE_STREAM_H ) */ libcaes-20240413/common/common.h0000644000175000017500000000234214606473412017154 0ustar00lordyestalordyesta/* * Common include file * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _COMMON_H ) #define _COMMON_H #if defined( HAVE_CONFIG_H ) #include "config.h" #endif /* Include the Borland/CodeGear C++ Builder compiler specific configuration */ #if defined( __BORLANDC__ ) #include "config_borlandc.h" /* Include the Microsoft Visual Studio C++ compiler specific configuration */ #elif defined( _MSC_VER ) #include "config_msc.h" #endif #include "config_winapi.h" #endif /* !defined( _COMMON_H ) */ libcaes-20240413/common/config_winapi.h0000644000175000017500000000451614606473412020505 0ustar00lordyestalordyesta/* * Configuration file for WINAPI * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _CONFIG_WINAPI_H ) #define _CONFIG_WINAPI_H /* Define the earliest supported WINAPI version #define WINVER 0x0501 */ /* If necessary make sure WINAPI is defined */ #if defined( HAVE_WINDOWS_H ) || defined( __BORLANDC__ ) || defined( _MSC_VER ) #include #endif #if defined( WINAPI ) /* Define to the address where bug reports for this package should be sent. */ #define PACKAGE_BUGREPORT "joachim.metz@gmail.com" /* Define the size of the integer for WINAPI */ #if !defined( SIZEOF_INT ) #define SIZEOF_INT 4 #endif /* Define the size of size_t for WINAPI * Do not define when pyconfig.h has been included via python.h */ #if !defined( HAVE_PYCONFIG_H ) #if !defined( SIZEOF_SIZE_T ) #if __WORDSIZE == 64 #define SIZEOF_SIZE_T 8 #else #define SIZEOF_SIZE_T 4 #endif #endif #endif /* !defined( HAVE_PYCONFIG_H ) */ /* Define the size of the wide character for WINAPI */ #if !defined( SIZEOF_WCHAR_T ) #define SIZEOF_WCHAR_T 2 #endif /* Enable the DllMain function */ #define HAVE_DLLMAIN 1 /* Enable verbose output #define HAVE_VERBOSE_OUTPUT 1 */ /* Enable debug output #define HAVE_DEBUG_OUTPUT 1 */ /* Enable both the narrow and wide character functions */ #if !defined( HAVE_WIDE_CHARACTER_TYPE ) #define HAVE_WIDE_CHARACTER_TYPE 1 #endif /* If not controlled by config.h enable multi-thread support */ #if !defined( HAVE_CONFIG_H ) && !defined( HAVE_MULTI_THREAD_SUPPORT ) #define HAVE_MULTI_THREAD_SUPPORT 1 #endif #endif /* defined( WINAPI ) */ #endif /* !defined( _CONFIG_WINAPI_H ) */ libcaes-20240413/common/system_string.h0000644000175000017500000001100314606473412020570 0ustar00lordyestalordyesta/* * System character string functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _SYSTEM_STRING_H ) #define _SYSTEM_STRING_H #include "common.h" #include "narrow_string.h" #include "types.h" #include "wide_string.h" #if defined( _cplusplus ) extern "C" { #endif #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) #if SIZEOF_WCHAR_T != 2 #error Unsupported wide system character size #endif /* Intermediate version of the macro required * for correct evaluation predefined string */ #define _SYSTEM_STRING_INTERMEDIATE( string ) \ L ## string #define _SYSTEM_STRING( string ) \ _SYSTEM_STRING_INTERMEDIATE( string ) #define system_string_allocate( size ) \ wide_string_allocate( size ) #define system_string_reallocate( string, size ) \ wide_string_reallocate( string, size ) #define system_string_compare( destination, source, size ) \ wide_string_compare( destination, source, size ) #define system_string_compare_no_case( destination, source, size ) \ wide_string_compare_no_case( destination, source, size ) #define system_string_copy( destination, source, size ) \ wide_string_copy( destination, source, size ) #define system_string_length( string ) \ wide_string_length( string ) #define system_string_search_character( string, character, size ) \ wide_string_search_character( string, character, size ) #define system_string_search_character_reverse( string, character, size ) \ wide_string_search_character_reverse( string, character, size ) #define system_string_search_string( string, substring, size ) \ wide_string_search_string( string, substring, size ) #if defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define system_string_sprintf \ wide_string_snwprintf #else #define system_string_sprintf( string, size, format, ... ) \ wide_string_snwprintf( string, size, format, __VA_ARGS__ ) #endif #if defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define system_string_vsnprintf \ wide_string_vsnwprintf #else #define system_string_vsnprintf( string, size, format, ... ) \ wide_string_vsnwprintf( string, size, format, __VA_ARGS__ ) #endif #else #define _SYSTEM_STRING( string ) \ string #define system_string_allocate( size ) \ narrow_string_allocate( size ) #define system_string_reallocate( string, size ) \ narrow_string_reallocate( string, size ) #define system_string_compare( destination, source, size ) \ narrow_string_compare( destination, source, size ) #define system_string_compare_no_case( destination, source, size ) \ narrow_string_compare_no_case( destination, source, size ) #define system_string_copy( destination, source, size ) \ narrow_string_copy( destination, source, size ) #define system_string_length( string ) \ narrow_string_length( string ) #define system_string_search_character( string, character, size ) \ narrow_string_search_character( string, character, size ) #define system_string_search_character_reverse( string, character, size ) \ narrow_string_search_character_reverse( string, character, size ) #define system_string_search_string( string, substring, size ) \ narrow_string_search_string( string, substring, size ) #if defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define system_string_sprintf \ narrow_string_snprintf #else #define system_string_sprintf( string, size, format, ... ) \ narrow_string_snprintf( string, size, format, __VA_ARGS__ ) #endif #if defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define system_string_vsnprintf \ narrow_string_vsnprintf #else #define system_string_vsnprintf( string, size, format, ... ) \ narrow_string_vsnprintf( string, size, format, __VA_ARGS__ ) #endif #endif /* defined( HAVE_WIDE_SYSTEM_CHARACTER ) */ /* For backwards compatibility */ #define system_string_vsprintf system_string_vsnprintf #if defined( _cplusplus ) } #endif #endif /* !defined( _SYSTEM_STRING_H ) */ libcaes-20240413/common/Makefile.am0000644000175000017500000000052714606475333017556 0ustar00lordyestalordyestaAM_CPPFLAGS = \ -I../include -I$(top_srcdir)/include EXTRA_DIST = \ byte_stream.h \ common.h \ config.h \ config_borlandc.h \ config_msc.h \ config_winapi.h \ file_stream.h \ memory.h \ narrow_string.h \ system_string.h \ types.h \ types.h.in \ wide_string.h DISTCLEANFILES = \ config.h \ types.h \ Makefile \ Makefile.in libcaes-20240413/common/types.h.in0000644000175000017500000001631714606473412017444 0ustar00lordyestalordyesta/* * Type and type-support definitions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _TYPES_H ) #define _TYPES_H #include "common.h" #if defined( HAVE_LIMITS_H ) || defined( WINAPI ) #include #endif /* Make sure to include inttypes.h or stdint.h before * PRI definitions are defined */ #include <@PACKAGE@/types.h> #if defined( WINAPI ) && ( defined( _UNICODE ) || defined( UNICODE ) ) #define HAVE_WIDE_SYSTEM_CHARACTER 1 /* The system character type is wide * A system string contains either UTF-16 or UTF-32 */ typedef wchar_t system_character_t; typedef wint_t system_integer_t; #define PRIc_SYSTEM "lc" #define PRIs_SYSTEM "ls" #else /* The system character type is narrow * A system string contains either UTF-8 or extended ASCII with a codepage */ typedef char system_character_t; typedef int system_integer_t; #define PRIc_SYSTEM "c" #define PRIs_SYSTEM "s" #endif /* defined( WINAPI ) && ( defined( _UNICODE ) || defined( UNICODE ) ) */ /* Fallback for systems without PRI definitions * Do not define when pyconfig.h has been included via python.h */ #if !defined( HAVE_PYCONFIG_H ) #if !defined( PRId8 ) #define PRId8 "d" #endif #if !defined( PRId16 ) #define PRId16 "d" #endif #if !defined( PRId32 ) #if defined( WINAPI ) #define PRId32 "I32d" #else #define PRId32 "d" #endif #endif /* !defined( PRId32 ) */ #if !defined( PRId64 ) #if defined( WINAPI ) #define PRId64 "I64d" #elif __WORDSIZE == 64 #define PRId64 "ld" #else #define PRId64 "lld" #endif #endif /* !defined( PRId64 ) */ #if !defined( PRIi8 ) #define PRIi8 "i" #endif #if !defined( PRIi16 ) #define PRIi16 "i" #endif #if !defined( PRIi32 ) #if defined( WINAPI ) #define PRIi32 "I32i" #else #define PRIi32 "i" #endif #endif /* !defined( PRIi32 ) */ #if !defined( PRIi64 ) #if defined( WINAPI ) #define PRIi64 "I64i" #elif __WORDSIZE == 64 #define PRIi64 "li" #else #define PRIi64 "lli" #endif #endif /* !defined( PRIi64 ) */ #if !defined( PRIu8 ) #define PRIu8 "u" #endif #if !defined( PRIu16 ) #define PRIu16 "u" #endif #if !defined( PRIu32 ) #if defined( WINAPI ) #define PRIu32 "I32u" #else #define PRIu32 "u" #endif #endif /* !defined( PRIu32 ) */ #if !defined( PRIu64 ) #if defined( WINAPI ) #define PRIu64 "I64u" #elif __WORDSIZE == 64 #define PRIu64 "lu" #else #define PRIu64 "llu" #endif #endif /* !defined( PRIu64 ) */ #if !defined( PRIo8 ) #define PRIo8 "o" #endif #if !defined( PRIo16 ) #define PRIo16 "o" #endif #if !defined( PRIo32 ) #if defined( WINAPI ) #define PRIo32 "I32o" #else #define PRIo32 "o" #endif #endif /* !defined( PRIo32 ) */ #if !defined( PRIo64 ) #if defined( WINAPI ) #define PRIo64 "I64o" #elif __WORDSIZE == 64 #define PRIo64 "lo" #else #define PRIo64 "llo" #endif #endif /* !defined( PRIo64 ) */ #if !defined( PRIx8 ) #define PRIx8 "x" #endif #if !defined( PRIx16 ) #define PRIx16 "x" #endif #if !defined( PRIx32 ) #if defined( WINAPI ) #define PRIx32 "I32x" #else #define PRIx32 "x" #endif #endif /* !defined( PRIx32 ) */ #if !defined( PRIx64 ) #if defined( WINAPI ) #define PRIx64 "I64x" #elif __WORDSIZE == 64 #define PRIx64 "lx" #else #define PRIx64 "llx" #endif #endif /* !defined( PRIx64 ) */ #endif /* !defined( HAVE_PYCONFIG_H ) */ /* Fallback for systems without printf %jd definition */ #if defined( HAVE_PRINTF_JD ) #define PRIjd "jd" #define PRIji "ji" #define PRIju "ju" #define PRIjx "jx" #elif SIZEOF_OFF_T == 8 #define PRIjd PRId64 #define PRIji PRIi64 #define PRIju PRIu64 #define PRIjx PRIx64 #else #define PRIjd PRId32 #define PRIji PRIi32 #define PRIju PRIu32 #define PRIjx PRIx32 #endif /* defined( HAVE_PRINTF_JD ) */ /* Fallback for systems without printf %zd definition */ #if defined( HAVE_PRINTF_ZD ) #define PRIzd "zd" #define PRIzi "zi" #define PRIzu "zu" #define PRIzx "zx" #elif defined( _MSC_VER ) #define PRIzd "Id" #define PRIzi "Ii" #define PRIzu "Iu" #define PRIzx "Ix" #elif SIZEOF_SIZE_T == 8 #define PRIzd PRId64 #define PRIzi PRIi64 #define PRIzu PRIu64 #define PRIzx PRIx64 #else #define PRIzd PRId32 #define PRIzi PRIi32 #define PRIzu PRIu32 #define PRIzx PRIx32 #endif /* defined( HAVE_PRINTF_ZD ) */ /* Fallback for systems without (U)INTx_MAX definitions */ /* The maximum signed 8-bit integer is 127 (0x7f) */ #if !defined( INT8_MAX ) #define INT8_MAX (0x7f) #endif /* The maximum unsigned 8-bit integer is 256 (0xff) */ #if !defined( UINT8_MAX ) #define UINT8_MAX (0xff) #endif /* The maximum signed 16-bit integer is 32767 (0x7ffff) */ #if !defined( INT16_MAX ) #define INT16_MAX (0x7fff) #endif /* The maximum unsigned 16-bit integer is 65535 (0xffff) */ #if !defined( UINT16_MAX ) #define UINT16_MAX (0xffff) #endif /* The maximum signed 32-bit integer is 2147483647 (0x7fffffff) */ #if !defined( INT32_MAX ) #define INT32_MAX (0x7fffffffL) #endif /* The maximum unsigned 32-bit integer is 4294967295 (0xffffffff) */ #if !defined( UINT32_MAX ) #define UINT32_MAX (0xffffffffUL) #endif /* The minimum signed 64-bit integer is -9223372036854775808 (0x8000000000000000) */ #if !defined( INT64_MIN ) #if defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define INT64_MIN (0x8000000000000000UL) #else #define INT64_MIN (0x8000000000000000ULL) #endif #endif /* !defined( INT64_MIN ) */ /* The maximum signed 64-bit integer is 9223372036854775807 (0x7fffffffffffffff) */ #if !defined( INT64_MAX ) #if defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define INT64_MAX (0x7fffffffffffffffUL) #else #define INT64_MAX (0x7fffffffffffffffULL) #endif #endif /* !defined( INT64_MAX ) */ /* The maximum unsigned 64-bit integer is 18446744073709551615 (0xffffffffffffffff) */ #if !defined( UINT64_MAX ) #if defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define UINT64_MAX (0xffffffffffffffffUL) #else #define UINT64_MAX (0xffffffffffffffffULL) #endif #endif /* !defined( UINT64_MAX ) */ /* The maximum signed integer */ #if !defined( INT_MAX ) #define INT_MAX INT32_MAX #endif /* The maximum unsigned integer */ #if !defined( UINT_MAX ) #define UINT_MAX UINT32_MAX #endif /* The maximum signed long integer */ #if !defined( LONG_MAX ) #define LONG_MAX INT32_MAX #endif /* The maximum unsigned long integer */ #if !defined( ULONG_MAX ) #define ULONG_MAX UINT32_MAX #endif /* The maximum signed size type is platform dependent */ #if !defined( SSIZE_MAX ) #if defined( WINAPI ) #if defined( _WIN64 ) #define SSIZE_MAX INT64_MAX #else #define SSIZE_MAX INT32_MAX #endif #else #if __WORDSIZE == 64 #define SSIZE_MAX INT64_MAX #else #define SSIZE_MAX INT32_MAX #endif #endif /* WINAPI */ #endif /* SSIZE_MAX */ #endif /* !defined( _TYPES_H ) */ libcaes-20240413/common/types.h0000644000175000017500000001631514606477645017051 0ustar00lordyestalordyesta/* * Type and type-support definitions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _TYPES_H ) #define _TYPES_H #include "common.h" #if defined( HAVE_LIMITS_H ) || defined( WINAPI ) #include #endif /* Make sure to include inttypes.h or stdint.h before * PRI definitions are defined */ #include #if defined( WINAPI ) && ( defined( _UNICODE ) || defined( UNICODE ) ) #define HAVE_WIDE_SYSTEM_CHARACTER 1 /* The system character type is wide * A system string contains either UTF-16 or UTF-32 */ typedef wchar_t system_character_t; typedef wint_t system_integer_t; #define PRIc_SYSTEM "lc" #define PRIs_SYSTEM "ls" #else /* The system character type is narrow * A system string contains either UTF-8 or extended ASCII with a codepage */ typedef char system_character_t; typedef int system_integer_t; #define PRIc_SYSTEM "c" #define PRIs_SYSTEM "s" #endif /* defined( WINAPI ) && ( defined( _UNICODE ) || defined( UNICODE ) ) */ /* Fallback for systems without PRI definitions * Do not define when pyconfig.h has been included via python.h */ #if !defined( HAVE_PYCONFIG_H ) #if !defined( PRId8 ) #define PRId8 "d" #endif #if !defined( PRId16 ) #define PRId16 "d" #endif #if !defined( PRId32 ) #if defined( WINAPI ) #define PRId32 "I32d" #else #define PRId32 "d" #endif #endif /* !defined( PRId32 ) */ #if !defined( PRId64 ) #if defined( WINAPI ) #define PRId64 "I64d" #elif __WORDSIZE == 64 #define PRId64 "ld" #else #define PRId64 "lld" #endif #endif /* !defined( PRId64 ) */ #if !defined( PRIi8 ) #define PRIi8 "i" #endif #if !defined( PRIi16 ) #define PRIi16 "i" #endif #if !defined( PRIi32 ) #if defined( WINAPI ) #define PRIi32 "I32i" #else #define PRIi32 "i" #endif #endif /* !defined( PRIi32 ) */ #if !defined( PRIi64 ) #if defined( WINAPI ) #define PRIi64 "I64i" #elif __WORDSIZE == 64 #define PRIi64 "li" #else #define PRIi64 "lli" #endif #endif /* !defined( PRIi64 ) */ #if !defined( PRIu8 ) #define PRIu8 "u" #endif #if !defined( PRIu16 ) #define PRIu16 "u" #endif #if !defined( PRIu32 ) #if defined( WINAPI ) #define PRIu32 "I32u" #else #define PRIu32 "u" #endif #endif /* !defined( PRIu32 ) */ #if !defined( PRIu64 ) #if defined( WINAPI ) #define PRIu64 "I64u" #elif __WORDSIZE == 64 #define PRIu64 "lu" #else #define PRIu64 "llu" #endif #endif /* !defined( PRIu64 ) */ #if !defined( PRIo8 ) #define PRIo8 "o" #endif #if !defined( PRIo16 ) #define PRIo16 "o" #endif #if !defined( PRIo32 ) #if defined( WINAPI ) #define PRIo32 "I32o" #else #define PRIo32 "o" #endif #endif /* !defined( PRIo32 ) */ #if !defined( PRIo64 ) #if defined( WINAPI ) #define PRIo64 "I64o" #elif __WORDSIZE == 64 #define PRIo64 "lo" #else #define PRIo64 "llo" #endif #endif /* !defined( PRIo64 ) */ #if !defined( PRIx8 ) #define PRIx8 "x" #endif #if !defined( PRIx16 ) #define PRIx16 "x" #endif #if !defined( PRIx32 ) #if defined( WINAPI ) #define PRIx32 "I32x" #else #define PRIx32 "x" #endif #endif /* !defined( PRIx32 ) */ #if !defined( PRIx64 ) #if defined( WINAPI ) #define PRIx64 "I64x" #elif __WORDSIZE == 64 #define PRIx64 "lx" #else #define PRIx64 "llx" #endif #endif /* !defined( PRIx64 ) */ #endif /* !defined( HAVE_PYCONFIG_H ) */ /* Fallback for systems without printf %jd definition */ #if defined( HAVE_PRINTF_JD ) #define PRIjd "jd" #define PRIji "ji" #define PRIju "ju" #define PRIjx "jx" #elif SIZEOF_OFF_T == 8 #define PRIjd PRId64 #define PRIji PRIi64 #define PRIju PRIu64 #define PRIjx PRIx64 #else #define PRIjd PRId32 #define PRIji PRIi32 #define PRIju PRIu32 #define PRIjx PRIx32 #endif /* defined( HAVE_PRINTF_JD ) */ /* Fallback for systems without printf %zd definition */ #if defined( HAVE_PRINTF_ZD ) #define PRIzd "zd" #define PRIzi "zi" #define PRIzu "zu" #define PRIzx "zx" #elif defined( _MSC_VER ) #define PRIzd "Id" #define PRIzi "Ii" #define PRIzu "Iu" #define PRIzx "Ix" #elif SIZEOF_SIZE_T == 8 #define PRIzd PRId64 #define PRIzi PRIi64 #define PRIzu PRIu64 #define PRIzx PRIx64 #else #define PRIzd PRId32 #define PRIzi PRIi32 #define PRIzu PRIu32 #define PRIzx PRIx32 #endif /* defined( HAVE_PRINTF_ZD ) */ /* Fallback for systems without (U)INTx_MAX definitions */ /* The maximum signed 8-bit integer is 127 (0x7f) */ #if !defined( INT8_MAX ) #define INT8_MAX (0x7f) #endif /* The maximum unsigned 8-bit integer is 256 (0xff) */ #if !defined( UINT8_MAX ) #define UINT8_MAX (0xff) #endif /* The maximum signed 16-bit integer is 32767 (0x7ffff) */ #if !defined( INT16_MAX ) #define INT16_MAX (0x7fff) #endif /* The maximum unsigned 16-bit integer is 65535 (0xffff) */ #if !defined( UINT16_MAX ) #define UINT16_MAX (0xffff) #endif /* The maximum signed 32-bit integer is 2147483647 (0x7fffffff) */ #if !defined( INT32_MAX ) #define INT32_MAX (0x7fffffffL) #endif /* The maximum unsigned 32-bit integer is 4294967295 (0xffffffff) */ #if !defined( UINT32_MAX ) #define UINT32_MAX (0xffffffffUL) #endif /* The minimum signed 64-bit integer is -9223372036854775808 (0x8000000000000000) */ #if !defined( INT64_MIN ) #if defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define INT64_MIN (0x8000000000000000UL) #else #define INT64_MIN (0x8000000000000000ULL) #endif #endif /* !defined( INT64_MIN ) */ /* The maximum signed 64-bit integer is 9223372036854775807 (0x7fffffffffffffff) */ #if !defined( INT64_MAX ) #if defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define INT64_MAX (0x7fffffffffffffffUL) #else #define INT64_MAX (0x7fffffffffffffffULL) #endif #endif /* !defined( INT64_MAX ) */ /* The maximum unsigned 64-bit integer is 18446744073709551615 (0xffffffffffffffff) */ #if !defined( UINT64_MAX ) #if defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define UINT64_MAX (0xffffffffffffffffUL) #else #define UINT64_MAX (0xffffffffffffffffULL) #endif #endif /* !defined( UINT64_MAX ) */ /* The maximum signed integer */ #if !defined( INT_MAX ) #define INT_MAX INT32_MAX #endif /* The maximum unsigned integer */ #if !defined( UINT_MAX ) #define UINT_MAX UINT32_MAX #endif /* The maximum signed long integer */ #if !defined( LONG_MAX ) #define LONG_MAX INT32_MAX #endif /* The maximum unsigned long integer */ #if !defined( ULONG_MAX ) #define ULONG_MAX UINT32_MAX #endif /* The maximum signed size type is platform dependent */ #if !defined( SSIZE_MAX ) #if defined( WINAPI ) #if defined( _WIN64 ) #define SSIZE_MAX INT64_MAX #else #define SSIZE_MAX INT32_MAX #endif #else #if __WORDSIZE == 64 #define SSIZE_MAX INT64_MAX #else #define SSIZE_MAX INT32_MAX #endif #endif /* WINAPI */ #endif /* SSIZE_MAX */ #endif /* !defined( _TYPES_H ) */ libcaes-20240413/common/config.h.in0000644000175000017500000002436414606477626017561 0ustar00lordyestalordyesta/* common/config.h.in. Generated from configure.ac by autoheader. */ /* Define to 1 if translation of program messages to the user's native language is requested. */ #undef ENABLE_NLS /* Define to 1 if you have the `AES_cbc_encrypt' function". */ #undef HAVE_AES_CBC_ENCRYPT /* Define to 1 if you have the `AES_ecb_encrypt' function". */ #undef HAVE_AES_ECB_ENCRYPT /* Define to 1 if you have the Mac OS X function CFLocaleCopyPreferredLanguages in the CoreFoundation framework. */ #undef HAVE_CFLOCALECOPYPREFERREDLANGUAGES /* Define to 1 if you have the Mac OS X function CFPreferencesCopyAppValue in the CoreFoundation framework. */ #undef HAVE_CFPREFERENCESCOPYAPPVALUE /* Define if the GNU dcgettext() function is already present or preinstalled. */ #undef HAVE_DCGETTEXT /* Define to 1 if you have the declaration of `memrchr', and to 0 if you don't. */ #undef HAVE_DECL_MEMRCHR /* Define to 1 if you have the declaration of `strerror_r', and to 0 if you don't. */ #undef HAVE_DECL_STRERROR_R /* Define to 1 if you have the header file. */ #undef HAVE_DLFCN_H /* Define to 1 to enable the DllMain function. */ #undef HAVE_DLLMAIN /* Define to 1 if you have the `EVP_CipherInit_ex2' function". */ #undef HAVE_EVP_CIPHERINIT_EX2 /* Define to 1 if you have the `EVP_CIPHER_CTX_cleanup' function". */ #undef HAVE_EVP_CIPHER_CTX_CLEANUP /* Define to 1 if you have the `EVP_CIPHER_CTX_init' function". */ #undef HAVE_EVP_CIPHER_CTX_INIT /* Define to 1 if you have the `EVP_aes_128_cbc', `EVP_aes_192_cbc' and `EVP_aes_256_cbc' functions". */ #undef HAVE_EVP_CRYPTO_AES_CBC /* Define to 1 if you have the `EVP_aes_128_ecb', `EVP_aes_192_ecb' and `EVP_aes_256_ecb' functions". */ #undef HAVE_EVP_CRYPTO_AES_ECB /* Define to 1 if you have the `EVP_aes_128_xts' and `EVP_aes_256_xts' functions". */ #undef HAVE_EVP_CRYPTO_AES_XTS /* Define to 1 if you have the `fclose' function. */ #undef HAVE_FCLOSE /* Define to 1 if you have the `feof' function. */ #undef HAVE_FEOF /* Define to 1 if you have the `fgets' function. */ #undef HAVE_FGETS /* Define to 1 if you have the `fgetws' function. */ #undef HAVE_FGETWS /* Define to 1 if you have the `fmemopen' function. */ #undef HAVE_FMEMOPEN /* Define to 1 if you have the `fopen' function. */ #undef HAVE_FOPEN /* Define to 1 if you have the `fread' function. */ #undef HAVE_FREAD /* Define to 1 if you have the `free' function. */ #undef HAVE_FREE /* Define to 1 if you have the `fseeko' function. */ #undef HAVE_FSEEKO /* Define to 1 if you have the `fseeko64' function. */ #undef HAVE_FSEEKO64 /* Define to 1 if you have the `fwrite' function. */ #undef HAVE_FWRITE /* Define to 1 if you have the `getopt' function. */ #undef HAVE_GETOPT /* Define if the GNU gettext() function is already present or preinstalled. */ #undef HAVE_GETTEXT /* Define to 1 if dlsym function is available in GNU dl. */ #undef HAVE_GNU_DL_DLSYM /* Define if you have the iconv() function and it works. */ #undef HAVE_ICONV /* Define to 1 if you have the header file. */ #undef HAVE_INTTYPES_H /* Define to 1 if you have the `cerror' library (-lcerror). */ #undef HAVE_LIBCERROR /* Define to 1 if you have the header file. */ #undef HAVE_LIBCERROR_H /* Define to 1 if you have the 'crypto' library (-lcrypto). */ #undef HAVE_LIBCRYPTO /* Define to 1 if you have the `dl' library (-ldl). */ #undef HAVE_LIBDL /* Define to 1 if you have the header file. */ #undef HAVE_LIBINTL_H /* Define to 1 if you have the header file. */ #undef HAVE_LIMITS_H /* Define to 1 if the local version of libcerror is used. */ #undef HAVE_LOCAL_LIBCERROR /* Define to 1 if you have the `malloc' function. */ #undef HAVE_MALLOC /* Define to 1 if you have the `memchr' function. */ #undef HAVE_MEMCHR /* Define to 1 if you have the `memcmp' function. */ #undef HAVE_MEMCMP /* Define to 1 if you have the `memcpy' function. */ #undef HAVE_MEMCPY /* Define to 1 if you have the `memrchr' function. */ #undef HAVE_MEMRCHR /* Define to 1 if you have the `memset' function. */ #undef HAVE_MEMSET /* Define to 1 if you have the `mkstemp' function. */ #undef HAVE_MKSTEMP /* Define to 1 if you have the header file. */ #undef HAVE_OPENSSL_AES_H /* Define to 1 if you have the header file. */ #undef HAVE_OPENSSL_EVP_H /* Define to 1 if you have the header file. */ #undef HAVE_OPENSSL_OPENSSLV_H /* Define to 1 whether printf supports the conversion specifier "%jd". */ #undef HAVE_PRINTF_JD /* Define to 1 whether printf supports the conversion specifier "%zd". */ #undef HAVE_PRINTF_ZD /* Define to 1 if you have the header file. */ #undef HAVE_PYTHON_H /* Define to 1 if you have the `realloc' function. */ #undef HAVE_REALLOC /* Define to 1 if you have the `setenv' function. */ #undef HAVE_SETENV /* Define to 1 if you have the `snprintf' function. */ #undef HAVE_SNPRINTF /* Define to 1 if you have the `sscanf' function. */ #undef HAVE_SSCANF /* Define to 1 if you have the header file. */ #undef HAVE_STDARG_H /* Define to 1 if you have the header file. */ #undef HAVE_STDINT_H /* Define to 1 if you have the header file. */ #undef HAVE_STDIO_H /* Define to 1 if you have the header file. */ #undef HAVE_STDLIB_H /* Define to 1 if you have the `strcasecmp' function. */ #undef HAVE_STRCASECMP /* Define to 1 if you have the `strchr' function. */ #undef HAVE_STRCHR /* Define to 1 if you have the `strerror' function. */ #undef HAVE_STRERROR /* Define if you have `strerror_r'. */ #undef HAVE_STRERROR_R /* Define to 1 if you have the header file. */ #undef HAVE_STRINGS_H /* Define to 1 if you have the header file. */ #undef HAVE_STRING_H /* Define to 1 if you have the `strlen' function. */ #undef HAVE_STRLEN /* Define to 1 if you have the `strncasecmp' function. */ #undef HAVE_STRNCASECMP /* Define to 1 if you have the `strncmp' function. */ #undef HAVE_STRNCMP /* Define to 1 if you have the `strncpy' function. */ #undef HAVE_STRNCPY /* Define to 1 if you have the `strnicmp' function. */ #undef HAVE_STRNICMP /* Define to 1 if you have the `strrchr' function. */ #undef HAVE_STRRCHR /* Define to 1 if you have the `strstr' function. */ #undef HAVE_STRSTR /* Define to 1 if you have the `swprintf' function. */ #undef HAVE_SWPRINTF /* Define to 1 if you have the header file. */ #undef HAVE_SYS_STAT_H /* Define to 1 if you have the header file. */ #undef HAVE_SYS_TYPES_H /* Define to 1 if you have the `towlower' function. */ #undef HAVE_TOWLOWER /* Define to 1 if you have the `tzset' function. */ #undef HAVE_TZSET /* Define to 1 if you have the header file. */ #undef HAVE_UNISTD_H /* Define to 1 if you have the `unlink' function. */ #undef HAVE_UNLINK /* Define to 1 if you have the header file. */ #undef HAVE_VARARGS_H /* Define to 1 if you have the `vfprintf' function. */ #undef HAVE_VFPRINTF /* Define to 1 if you have the `vsnprintf' function. */ #undef HAVE_VSNPRINTF /* Define to 1 if you have the header file. */ #undef HAVE_WCHAR_H /* Define to 1 if you have the `wcscasecmp' function. */ #undef HAVE_WCSCASECMP /* Define to 1 if you have the `wcschr' function. */ #undef HAVE_WCSCHR /* Define to 1 if you have the `wcslen' function. */ #undef HAVE_WCSLEN /* Define to 1 if you have the `wcsncasecmp' function. */ #undef HAVE_WCSNCASECMP /* Define to 1 if you have the `wcsncmp' function. */ #undef HAVE_WCSNCMP /* Define to 1 if you have the `wcsncpy' function. */ #undef HAVE_WCSNCPY /* Define to 1 if you have the `wcsnicmp' function. */ #undef HAVE_WCSNICMP /* Define to 1 if you have the `wcsrchr' function. */ #undef HAVE_WCSRCHR /* Define to 1 if you have the `wcsstr' function. */ #undef HAVE_WCSSTR /* Define to 1 if you have the `wcstombs' function. */ #undef HAVE_WCSTOMBS /* Define to 1 if you have the header file. */ #undef HAVE_WCTYPE_H /* Define to 1 if wide character type should be used. */ #undef HAVE_WIDE_CHARACTER_TYPE /* Define to 1 if you have the header file. */ #undef HAVE_WINDOWS_H /* Define to 1 if you have the `wmemchr' function. */ #undef HAVE_WMEMCHR /* Define to 1 if you have the `wmemcmp' function. */ #undef HAVE_WMEMCMP /* Define to 1 if you have the `wmemcpy' function. */ #undef HAVE_WMEMCPY /* Define to 1 if you have the `wmemrchr' function. */ #undef HAVE_WMEMRCHR /* Define to the sub-directory where libtool stores uninstalled libraries. */ #undef LT_OBJDIR /* Name of package */ #undef PACKAGE /* Define to the address where bug reports for this package should be sent. */ #undef PACKAGE_BUGREPORT /* Define to the full name of this package. */ #undef PACKAGE_NAME /* Define to the full name and version of this package. */ #undef PACKAGE_STRING /* Define to the one symbol short name of this package. */ #undef PACKAGE_TARNAME /* Define to the home page for this package. */ #undef PACKAGE_URL /* Define to the version of this package. */ #undef PACKAGE_VERSION /* The size of `int', as computed by sizeof. */ #undef SIZEOF_INT /* The size of `long', as computed by sizeof. */ #undef SIZEOF_LONG /* The size of `off_t', as computed by sizeof. */ #undef SIZEOF_OFF_T /* The size of `size_t', as computed by sizeof. */ #undef SIZEOF_SIZE_T /* The size of `wchar_t', as computed by sizeof. */ #undef SIZEOF_WCHAR_T /* Define to 1 if all of the C90 standard headers exist (not just the ones required in a freestanding environment). This macro is provided for backward compatibility; new code need not use it. */ #undef STDC_HEADERS /* Define to 1 if strerror_r returns char *. */ #undef STRERROR_R_CHAR_P /* Version number of package */ #undef VERSION /* Number of bits in a file offset, on hosts where this is settable. */ #undef _FILE_OFFSET_BITS /* Define for large files, on AIX-style hosts. */ #undef _LARGE_FILES /* Define to empty if `const' does not conform to ANSI C. */ #undef const /* Define to `int' if does not define. */ #undef mode_t /* Define to `long int' if does not define. */ #undef off_t /* Define to `unsigned int' if does not define. */ #undef size_t /* Define to empty if the keyword `volatile' does not work. Warning: valid code using `volatile' can become incorrect without. Disable with care. */ #undef volatile libcaes-20240413/common/config.h0000644000175000017500000002553014606477600017140 0ustar00lordyestalordyesta/* common/config.h. Generated from config.h.in by configure. */ /* common/config.h.in. Generated from configure.ac by autoheader. */ /* Define to 1 if translation of program messages to the user's native language is requested. */ #define ENABLE_NLS 1 /* Define to 1 if you have the `AES_cbc_encrypt' function". */ /* #undef HAVE_AES_CBC_ENCRYPT */ /* Define to 1 if you have the `AES_ecb_encrypt' function". */ /* #undef HAVE_AES_ECB_ENCRYPT */ /* Define to 1 if you have the Mac OS X function CFLocaleCopyPreferredLanguages in the CoreFoundation framework. */ /* #undef HAVE_CFLOCALECOPYPREFERREDLANGUAGES */ /* Define to 1 if you have the Mac OS X function CFPreferencesCopyAppValue in the CoreFoundation framework. */ /* #undef HAVE_CFPREFERENCESCOPYAPPVALUE */ /* Define if the GNU dcgettext() function is already present or preinstalled. */ #define HAVE_DCGETTEXT 1 /* Define to 1 if you have the declaration of `memrchr', and to 0 if you don't. */ #define HAVE_DECL_MEMRCHR 0 /* Define to 1 if you have the declaration of `strerror_r', and to 0 if you don't. */ #define HAVE_DECL_STRERROR_R 1 /* Define to 1 if you have the header file. */ #define HAVE_DLFCN_H 1 /* Define to 1 to enable the DllMain function. */ /* #undef HAVE_DLLMAIN */ /* Define to 1 if you have the `EVP_CipherInit_ex2' function". */ #define HAVE_EVP_CIPHERINIT_EX2 1 /* Define to 1 if you have the `EVP_CIPHER_CTX_cleanup' function". */ /* #undef HAVE_EVP_CIPHER_CTX_CLEANUP */ /* Define to 1 if you have the `EVP_CIPHER_CTX_init' function". */ /* #undef HAVE_EVP_CIPHER_CTX_INIT */ /* Define to 1 if you have the `EVP_aes_128_cbc', `EVP_aes_192_cbc' and `EVP_aes_256_cbc' functions". */ #define HAVE_EVP_CRYPTO_AES_CBC 1 /* Define to 1 if you have the `EVP_aes_128_ecb', `EVP_aes_192_ecb' and `EVP_aes_256_ecb' functions". */ #define HAVE_EVP_CRYPTO_AES_ECB 1 /* Define to 1 if you have the `EVP_aes_128_xts' and `EVP_aes_256_xts' functions". */ #define HAVE_EVP_CRYPTO_AES_XTS 1 /* Define to 1 if you have the `fclose' function. */ #define HAVE_FCLOSE 1 /* Define to 1 if you have the `feof' function. */ #define HAVE_FEOF 1 /* Define to 1 if you have the `fgets' function. */ #define HAVE_FGETS 1 /* Define to 1 if you have the `fgetws' function. */ #define HAVE_FGETWS 1 /* Define to 1 if you have the `fmemopen' function. */ #define HAVE_FMEMOPEN 1 /* Define to 1 if you have the `fopen' function. */ #define HAVE_FOPEN 1 /* Define to 1 if you have the `fread' function. */ #define HAVE_FREAD 1 /* Define to 1 if you have the `free' function. */ #define HAVE_FREE 1 /* Define to 1 if you have the `fseeko' function. */ #define HAVE_FSEEKO 1 /* Define to 1 if you have the `fseeko64' function. */ #define HAVE_FSEEKO64 1 /* Define to 1 if you have the `fwrite' function. */ #define HAVE_FWRITE 1 /* Define to 1 if you have the `getopt' function. */ #define HAVE_GETOPT 1 /* Define if the GNU gettext() function is already present or preinstalled. */ #define HAVE_GETTEXT 1 /* Define to 1 if dlsym function is available in GNU dl. */ #define HAVE_GNU_DL_DLSYM 1 /* Define if you have the iconv() function and it works. */ /* #undef HAVE_ICONV */ /* Define to 1 if you have the header file. */ #define HAVE_INTTYPES_H 1 /* Define to 1 if you have the `cerror' library (-lcerror). */ /* #undef HAVE_LIBCERROR */ /* Define to 1 if you have the header file. */ /* #undef HAVE_LIBCERROR_H */ /* Define to 1 if you have the 'crypto' library (-lcrypto). */ #define HAVE_LIBCRYPTO 1 /* Define to 1 if you have the `dl' library (-ldl). */ #define HAVE_LIBDL 1 /* Define to 1 if you have the header file. */ #define HAVE_LIBINTL_H 1 /* Define to 1 if you have the header file. */ #define HAVE_LIMITS_H 1 /* Define to 1 if the local version of libcerror is used. */ #define HAVE_LOCAL_LIBCERROR 1 /* Define to 1 if you have the `malloc' function. */ #define HAVE_MALLOC 1 /* Define to 1 if you have the `memchr' function. */ #define HAVE_MEMCHR 1 /* Define to 1 if you have the `memcmp' function. */ #define HAVE_MEMCMP 1 /* Define to 1 if you have the `memcpy' function. */ #define HAVE_MEMCPY 1 /* Define to 1 if you have the `memrchr' function. */ #define HAVE_MEMRCHR 1 /* Define to 1 if you have the `memset' function. */ #define HAVE_MEMSET 1 /* Define to 1 if you have the `mkstemp' function. */ #define HAVE_MKSTEMP 1 /* Define to 1 if you have the header file. */ /* #undef HAVE_OPENSSL_AES_H */ /* Define to 1 if you have the header file. */ #define HAVE_OPENSSL_EVP_H 1 /* Define to 1 if you have the header file. */ /* #undef HAVE_OPENSSL_OPENSSLV_H */ /* Define to 1 whether printf supports the conversion specifier "%jd". */ #define HAVE_PRINTF_JD 1 /* Define to 1 whether printf supports the conversion specifier "%zd". */ #define HAVE_PRINTF_ZD 1 /* Define to 1 if you have the header file. */ /* #undef HAVE_PYTHON_H */ /* Define to 1 if you have the `realloc' function. */ #define HAVE_REALLOC 1 /* Define to 1 if you have the `setenv' function. */ #define HAVE_SETENV 1 /* Define to 1 if you have the `snprintf' function. */ #define HAVE_SNPRINTF 1 /* Define to 1 if you have the `sscanf' function. */ #define HAVE_SSCANF 1 /* Define to 1 if you have the header file. */ #define HAVE_STDARG_H 1 /* Define to 1 if you have the header file. */ #define HAVE_STDINT_H 1 /* Define to 1 if you have the header file. */ #define HAVE_STDIO_H 1 /* Define to 1 if you have the header file. */ #define HAVE_STDLIB_H 1 /* Define to 1 if you have the `strcasecmp' function. */ #define HAVE_STRCASECMP 1 /* Define to 1 if you have the `strchr' function. */ #define HAVE_STRCHR 1 /* Define to 1 if you have the `strerror' function. */ /* #undef HAVE_STRERROR */ /* Define if you have `strerror_r'. */ #define HAVE_STRERROR_R 1 /* Define to 1 if you have the header file. */ #define HAVE_STRINGS_H 1 /* Define to 1 if you have the header file. */ #define HAVE_STRING_H 1 /* Define to 1 if you have the `strlen' function. */ #define HAVE_STRLEN 1 /* Define to 1 if you have the `strncasecmp' function. */ #define HAVE_STRNCASECMP 1 /* Define to 1 if you have the `strncmp' function. */ #define HAVE_STRNCMP 1 /* Define to 1 if you have the `strncpy' function. */ #define HAVE_STRNCPY 1 /* Define to 1 if you have the `strnicmp' function. */ /* #undef HAVE_STRNICMP */ /* Define to 1 if you have the `strrchr' function. */ #define HAVE_STRRCHR 1 /* Define to 1 if you have the `strstr' function. */ #define HAVE_STRSTR 1 /* Define to 1 if you have the `swprintf' function. */ #define HAVE_SWPRINTF 1 /* Define to 1 if you have the header file. */ #define HAVE_SYS_STAT_H 1 /* Define to 1 if you have the header file. */ #define HAVE_SYS_TYPES_H 1 /* Define to 1 if you have the `towlower' function. */ #define HAVE_TOWLOWER 1 /* Define to 1 if you have the `tzset' function. */ #define HAVE_TZSET 1 /* Define to 1 if you have the header file. */ #define HAVE_UNISTD_H 1 /* Define to 1 if you have the `unlink' function. */ #define HAVE_UNLINK 1 /* Define to 1 if you have the header file. */ /* #undef HAVE_VARARGS_H */ /* Define to 1 if you have the `vfprintf' function. */ #define HAVE_VFPRINTF 1 /* Define to 1 if you have the `vsnprintf' function. */ #define HAVE_VSNPRINTF 1 /* Define to 1 if you have the header file. */ #define HAVE_WCHAR_H 1 /* Define to 1 if you have the `wcscasecmp' function. */ #define HAVE_WCSCASECMP 1 /* Define to 1 if you have the `wcschr' function. */ #define HAVE_WCSCHR 1 /* Define to 1 if you have the `wcslen' function. */ #define HAVE_WCSLEN 1 /* Define to 1 if you have the `wcsncasecmp' function. */ #define HAVE_WCSNCASECMP 1 /* Define to 1 if you have the `wcsncmp' function. */ #define HAVE_WCSNCMP 1 /* Define to 1 if you have the `wcsncpy' function. */ #define HAVE_WCSNCPY 1 /* Define to 1 if you have the `wcsnicmp' function. */ /* #undef HAVE_WCSNICMP */ /* Define to 1 if you have the `wcsrchr' function. */ #define HAVE_WCSRCHR 1 /* Define to 1 if you have the `wcsstr' function. */ #define HAVE_WCSSTR 1 /* Define to 1 if you have the `wcstombs' function. */ #define HAVE_WCSTOMBS 1 /* Define to 1 if you have the header file. */ #define HAVE_WCTYPE_H 1 /* Define to 1 if wide character type should be used. */ /* #undef HAVE_WIDE_CHARACTER_TYPE */ /* Define to 1 if you have the header file. */ /* #undef HAVE_WINDOWS_H */ /* Define to 1 if you have the `wmemchr' function. */ #define HAVE_WMEMCHR 1 /* Define to 1 if you have the `wmemcmp' function. */ #define HAVE_WMEMCMP 1 /* Define to 1 if you have the `wmemcpy' function. */ #define HAVE_WMEMCPY 1 /* Define to 1 if you have the `wmemrchr' function. */ /* #undef HAVE_WMEMRCHR */ /* Define to the sub-directory where libtool stores uninstalled libraries. */ #define LT_OBJDIR ".libs/" /* Name of package */ #define PACKAGE "libcaes" /* Define to the address where bug reports for this package should be sent. */ #define PACKAGE_BUGREPORT "joachim.metz@gmail.com" /* Define to the full name of this package. */ #define PACKAGE_NAME "libcaes" /* Define to the full name and version of this package. */ #define PACKAGE_STRING "libcaes 20240413" /* Define to the one symbol short name of this package. */ #define PACKAGE_TARNAME "libcaes" /* Define to the home page for this package. */ #define PACKAGE_URL "" /* Define to the version of this package. */ #define PACKAGE_VERSION "20240413" /* The size of `int', as computed by sizeof. */ #define SIZEOF_INT 4 /* The size of `long', as computed by sizeof. */ #define SIZEOF_LONG 8 /* The size of `off_t', as computed by sizeof. */ #define SIZEOF_OFF_T 8 /* The size of `size_t', as computed by sizeof. */ #define SIZEOF_SIZE_T 8 /* The size of `wchar_t', as computed by sizeof. */ #define SIZEOF_WCHAR_T 4 /* Define to 1 if all of the C90 standard headers exist (not just the ones required in a freestanding environment). This macro is provided for backward compatibility; new code need not use it. */ #define STDC_HEADERS 1 /* Define to 1 if strerror_r returns char *. */ /* #undef STRERROR_R_CHAR_P */ /* Version number of package */ #define VERSION "20240413" /* Number of bits in a file offset, on hosts where this is settable. */ /* #undef _FILE_OFFSET_BITS */ /* Define for large files, on AIX-style hosts. */ /* #undef _LARGE_FILES */ /* Define to empty if `const' does not conform to ANSI C. */ /* #undef const */ /* Define to `int' if does not define. */ /* #undef mode_t */ /* Define to `long int' if does not define. */ /* #undef off_t */ /* Define to `unsigned int' if does not define. */ /* #undef size_t */ /* Define to empty if the keyword `volatile' does not work. Warning: valid code using `volatile' can become incorrect without. Disable with care. */ /* #undef volatile */ libcaes-20240413/common/wide_string.h0000644000175000017500000001171014606473412020201 0ustar00lordyestalordyesta/* * Wide character string functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _WIDE_STRING_H ) #define _WIDE_STRING_H #include "common.h" #include "memory.h" #include "types.h" #if defined( HAVE_WCHAR_H ) || defined( WINAPI ) #include #endif #if defined( __cplusplus ) extern "C" { #endif /* Intermediate version of the macro required * for correct evaluation predefined string */ #define _WIDE_STRING_INTERMEDIATE( string ) \ L ## string #define _WIDE_STRING( string ) \ _WIDE_STRING_INTERMEDIATE( string ) /* String allocation */ #define wide_string_allocate( size ) \ (wchar_t *) memory_allocate( sizeof( wchar_t ) * ( size ) ) /* String reallocation */ #define wide_string_reallocate( string, size ) \ (wchar_t *) memory_reallocate( string, ( sizeof( wchar_t ) * ( size ) ) ) /* String length */ #if defined( HAVE_WCSLEN ) || defined( WINAPI ) #define wide_string_length( string ) \ wcslen( string ) #endif /* String compare */ #if defined( HAVE_WMEMCMP ) #define wide_string_compare( string1, string2, size ) \ wmemcmp( (void *) string1, (void *) string2, size ) #elif defined( HAVE_WCSNCMP ) || defined( WINAPI ) #define wide_string_compare( string1, string2, size ) \ wcsncmp( string1, string2, size ) #endif /* Caseless string compare */ #if defined( _MSC_VER ) || ( defined( __BORLANDC__ ) && ( __BORLANDC__ >= 0x0551 ) ) #define wide_string_compare_no_case( string1, string2, size ) \ _wcsnicmp( string1, string2, size ) #elif ( defined( WINAPI ) && !defined( __CYGWIN__ ) ) || defined( HAVE_WCSNICMP ) #define wide_string_compare_no_case( string1, string2, size ) \ wcsnicmp( string1, string2, size ) #elif defined( HAVE_WCSNCASECMP ) #define wide_string_compare_no_case( string1, string2, size ) \ wcsncasecmp( string1, string2, size ) #elif defined( HAVE_WCSCASECMP ) #define wide_string_compare_no_case( string1, string2, size ) \ wcscasecmp( string1, string2 ) #endif /* String copy */ #if defined( HAVE_WMEMCPY ) #define wide_string_copy( destination, source, size ) \ (wchar_t *) wmemcpy( (void *) destination, (void *) source, size ) #elif defined( HAVE_WCSNCPY ) || defined( WINAPI ) #define wide_string_copy( destination, source, size ) \ wcsncpy( destination, source, size ) #endif /* String character search */ #if defined( HAVE_WMEMCHR ) #define wide_string_search_character( string, character, size ) \ (wchar_t *) wmemchr( (void *) string, (wchar_t) character, size ) #elif defined( HAVE_WCSCHR ) || defined( WINAPI ) #define wide_string_search_character( string, character, size ) \ wcschr( string, (wchar_t) character ) #endif /* String reverse character search */ #if defined( HAVE_WMEMRCHR ) #define wide_string_search_character_reverse( string, character, size ) \ (wchar_t *) wmemrchr( (void *) string, (wchar_t) character, size ) #elif defined( HAVE_WCSRCHR ) || defined( WINAPI ) /* (void)(size) is used to suppress unused variable warnings */ #define wide_string_search_character_reverse( string, character, size ) \ wcsrchr( string, (wchar_t) character ); (void)(size) #endif /* String sub-string search */ #if defined( HAVE_WCSSTR ) || defined( WINAPI ) #define wide_string_search_string( string, substring, size ) \ wcsstr( string, substring ) #endif /* String formatted print (snwprintf) */ #if defined( _MSC_VER ) #define wide_string_snwprintf( target, size, ... ) \ swprintf_s( target, size, __VA_ARGS__ ) #elif defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define wide_string_snwprintf \ snwprintf #elif defined( WINAPI ) #define wide_string_snwprintf( target, size, ... ) \ snwprintf( target, size, __VA_ARGS__ ) #elif defined( HAVE_SWPRINTF ) #define wide_string_snwprintf( target, size, ... ) \ swprintf( target, size, __VA_ARGS__ ) #endif /* Variable arguments formatted print to string function (vsnwprintf) */ #if defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define wide_string_vsnwprintf \ _vsnwprintf #elif defined( WINAPI ) #define wide_string_vsnwprintf( string, size, format, ... ) \ _vsnwprintf( string, size, format, __VA_ARGS__ ) #elif defined( HAVE_VSWPRINTF ) #define wide_string_vsnwprintf( string, size, format, ... ) \ vswprintf( string, size, format, __VA_ARGS__ ) #endif #if defined( __cplusplus ) } #endif #endif /* !defined( _WIDE_STRING_H ) */ libcaes-20240413/common/narrow_string.h0000644000175000017500000001245314606473412020566 0ustar00lordyestalordyesta/* * Narrow character string functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _NARROW_STRING_H ) #define _NARROW_STRING_H #include "common.h" #include "memory.h" #include "types.h" #if defined( HAVE_GLIB_H ) #include #endif #if defined( HAVE_STDLIB_H ) || defined( WINAPI ) #include #endif #if defined( HAVE_STRING_H ) || defined( WINAPI ) #include #endif #if defined( __cplusplus ) extern "C" { #endif /* String allocation */ #define narrow_string_allocate( size ) \ (char *) memory_allocate( sizeof( char ) * ( size ) ) /* String reallocation */ #define narrow_string_reallocate( string, size ) \ (char *) memory_reallocate( string, ( sizeof( char ) * ( size ) ) ) /* String length */ #if defined( HAVE_STRLEN ) || defined( WINAPI ) #define narrow_string_length( string ) \ strlen( string ) #endif /* String compare */ #if defined( HAVE_MEMCMP ) || defined( WINAPI ) #define narrow_string_compare( string1, string2, size ) \ memcmp( (void *) string1, (void *) string2, size ) #elif defined( HAVE_STRNCMP ) #define narrow_string_compare( string1, string2, size ) \ strncmp( string1, string2, size ) #endif /* Caseless string compare */ #if defined( HAVE_GLIB_H ) #define narrow_string_compare_no_case( string1, string2, size ) \ g_ascii_strncasecmp( string1, string2, size ) #elif defined( _MSC_VER ) #define narrow_string_compare_no_case( string1, string2, size ) \ _strnicmp( string1, string2, size ) #elif ( defined( WINAPI ) && !defined( __CYGWIN__ ) ) || defined( HAVE_STRNICMP ) #define narrow_string_compare_no_case( string1, string2, size ) \ strnicmp( string1, string2, size ) #elif defined( HAVE_STRNCASECMP ) #define narrow_string_compare_no_case( string1, string2, size ) \ strncasecmp( string1, string2, size ) #elif defined( HAVE_STRCASECMP ) #define narrow_string_compare_no_case( string1, string2, size ) \ strcasecmp( string1, string2 ) #endif /* String copy */ #if defined( HAVE_MEMCPY ) || defined( WINAPI ) #define narrow_string_copy( destination, source, size ) \ (char *) memcpy( (void *) destination, (void *) source, size ) #elif defined( HAVE_STRNCPY ) #define narrow_string_copy( destination, source, size ) \ strncpy( destination, source, size ) #endif /* String character search */ #if defined( HAVE_MEMCHR ) || defined( WINAPI ) #define narrow_string_search_character( string, character, size ) \ (char *) memchr( (void *) string, (int) character, size ) #elif defined( HAVE_STRCHR ) #define narrow_string_search_character( string, character, size ) \ strchr( string, (int) character ) #endif /* String reverse character search */ #if defined( HAVE_MEMRCHR ) && ( HAVE_DECL_MEMRCHR == 1 ) #define narrow_string_search_character_reverse( string, character, size ) \ (char *) memrchr( (void *) string, (int) character, size ) #elif defined( HAVE_STRRCHR ) || defined( WINAPI ) /* (void)(size) is used to suppress unused variable warnings */ #define narrow_string_search_character_reverse( string, character, size ) \ strrchr( string, (int) character ); (void)(size) #endif /* String sub-string search */ #if defined( HAVE_STRSTR ) || defined( WINAPI ) #define narrow_string_search_string( string, substring, size ) \ strstr( string, substring ) #endif /* String formatted print (snprintf) */ #if defined( HAVE_GLIB_H ) #define narrow_string_snprintf( target, size, ... ) \ g_snprintf( target, size, __VA_ARGS__ ) #elif defined( _MSC_VER ) #define narrow_string_snprintf( target, size, ... ) \ sprintf_s( target, size, __VA_ARGS__ ) #elif defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define narrow_string_snprintf \ snprintf #elif defined( HAVE_SNPRINTF ) || defined( WINAPI ) #define narrow_string_snprintf( target, size, ... ) \ snprintf( target, size, __VA_ARGS__ ) #endif /* String input conversion (sscanf) */ #if defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define narrow_string_sscanf \ sscanf #elif defined( HAVE_SSCANF ) || defined( WINAPI ) #define narrow_string_sscanf( string, format, ... ) \ sscanf( string, format, __VA_ARGS__ ) #endif /* Variable arguments formatted print to string function (vsnprintf) */ #if defined( HAVE_GLIB_H ) #define narrow_string_vsnprintf( string, size, format, ... ) \ g_vsnprintf( string, size, format, __VA_ARGS__ ) #elif defined( __BORLANDC__ ) && ( __BORLANDC__ < 0x0560 ) #define narrow_string_vsnprintf \ vsnprintf #elif defined( HAVE_VSNPRINTF ) || defined( WINAPI ) #define narrow_string_vsnprintf( string, size, format, ... ) \ vsnprintf( string, size, format, __VA_ARGS__ ) #endif #if defined( __cplusplus ) } #endif #endif /* !defined( _NARROW_STRING_H ) */ libcaes-20240413/common/config_msc.h0000644000175000017500000000220514606473412017771 0ustar00lordyestalordyesta/* * Configuration for the Microsoft Visual Studio C++ compiler * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _CONFIG_MSC_H ) #define _CONFIG_MSC_H /* Disable warning C4127: conditional expression is constant */ #pragma warning( disable : 4127 ) /* Disable warning C4201: nonstandard extension used : nameless struct/union */ #pragma warning( disable : 4201 ) #endif /* !defined( _CONFIG_MSC_H ) */ libcaes-20240413/common/Makefile.in0000644000175000017500000004377014606477627017606 0ustar00lordyestalordyesta# Makefile.in generated by automake 1.16.5 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2021 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = common ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/common.m4 \ $(top_srcdir)/m4/gettext.m4 $(top_srcdir)/m4/host-cpu-c-abi.m4 \ $(top_srcdir)/m4/iconv.m4 $(top_srcdir)/m4/intlmacosx.m4 \ $(top_srcdir)/m4/lib-ld.m4 $(top_srcdir)/m4/lib-link.m4 \ $(top_srcdir)/m4/lib-prefix.m4 $(top_srcdir)/m4/libcerror.m4 \ $(top_srcdir)/m4/libcrypto.m4 $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/nls.m4 $(top_srcdir)/m4/po.m4 \ $(top_srcdir)/m4/progtest.m4 $(top_srcdir)/m4/python.m4 \ $(top_srcdir)/m4/tests.m4 $(top_srcdir)/m4/types.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = config.h CONFIG_CLEAN_FILES = types.h CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__extra_recursive_targets = sources-recursive splint-recursive am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) \ config.h.in # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/config.h.in \ $(srcdir)/types.h.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CSCOPE = @CSCOPE@ CTAGS = @CTAGS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DPKG_DATE = @DPKG_DATE@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ ETAGS = @ETAGS@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ FILECMD = @FILECMD@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GREP = @GREP@ HAVE_DLLMAIN = @HAVE_DLLMAIN@ HAVE_INTTYPES_H = @HAVE_INTTYPES_H@ HAVE_LIBCERROR = @HAVE_LIBCERROR@ HAVE_LOCAL_LIBCERROR = @HAVE_LOCAL_LIBCERROR@ HAVE_OFF64_T = @HAVE_OFF64_T@ HAVE_OPENSSL_EVP_H = @HAVE_OPENSSL_EVP_H@ HAVE_SIZE32_T = @HAVE_SIZE32_T@ HAVE_SIZE64_T = @HAVE_SIZE64_T@ HAVE_SSIZE32_T = @HAVE_SSIZE32_T@ HAVE_SSIZE64_T = @HAVE_SSIZE64_T@ HAVE_STDINT_H = @HAVE_STDINT_H@ HAVE_SYS_TYPES_H = @HAVE_SYS_TYPES_H@ HAVE_WCHAR_H = @HAVE_WCHAR_H@ HAVE_WIDE_CHARACTER_TYPE = @HAVE_WIDE_CHARACTER_TYPE@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBCAES_DLL_EXPORT = @LIBCAES_DLL_EXPORT@ LIBCAES_DLL_IMPORT = @LIBCAES_DLL_IMPORT@ LIBCERROR_CPPFLAGS = @LIBCERROR_CPPFLAGS@ LIBCERROR_LIBADD = @LIBCERROR_LIBADD@ LIBCRYPTO_CPPFLAGS = @LIBCRYPTO_CPPFLAGS@ LIBCRYPTO_LIBADD = @LIBCRYPTO_LIBADD@ LIBDL_LIBADD = @LIBDL_LIBADD@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIB_FUZZING_ENGINE = @LIB_FUZZING_ENGINE@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGMERGE = @MSGMERGE@ MSGMERGE_FOR_MSGFMT_OPTION = @MSGMERGE_FOR_MSGFMT_OPTION@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ PKGCONFIG = @PKGCONFIG@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ PYTHON = @PYTHON@ PYTHON_CONFIG = @PYTHON_CONFIG@ PYTHON_CPPFLAGS = @PYTHON_CPPFLAGS@ PYTHON_EXEC_PREFIX = @PYTHON_EXEC_PREFIX@ PYTHON_LDFLAGS = @PYTHON_LDFLAGS@ PYTHON_LIBRARY_DIR = @PYTHON_LIBRARY_DIR@ PYTHON_PACKAGE_DIR = @PYTHON_PACKAGE_DIR@ PYTHON_PLATFORM = @PYTHON_PLATFORM@ PYTHON_PREFIX = @PYTHON_PREFIX@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ SPEC_DATE = @SPEC_DATE@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ ax_libcerror_pc_libs_private = @ax_libcerror_pc_libs_private@ ax_libcerror_spec_build_requires = @ax_libcerror_spec_build_requires@ ax_libcerror_spec_requires = @ax_libcerror_spec_requires@ ax_libcrypto_pc_libs_private = @ax_libcrypto_pc_libs_private@ ax_libcrypto_spec_build_requires = @ax_libcrypto_spec_build_requires@ ax_libcrypto_spec_requires = @ax_libcrypto_spec_requires@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libcaes_spec_requires = @libcaes_spec_requires@ libcerror_CFLAGS = @libcerror_CFLAGS@ libcerror_LIBS = @libcerror_LIBS@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ openssl_CFLAGS = @openssl_CFLAGS@ openssl_LIBS = @openssl_LIBS@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ pyexecdir = @pyexecdir@ pythondir = @pythondir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ AM_CPPFLAGS = \ -I../include -I$(top_srcdir)/include EXTRA_DIST = \ byte_stream.h \ common.h \ config.h \ config_borlandc.h \ config_msc.h \ config_winapi.h \ file_stream.h \ memory.h \ narrow_string.h \ system_string.h \ types.h \ types.h.in \ wide_string.h DISTCLEANFILES = \ config.h \ types.h \ Makefile \ Makefile.in all: config.h $(MAKE) $(AM_MAKEFLAGS) all-am .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu common/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu common/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): config.h: stamp-h1 @test -f $@ || rm -f stamp-h1 @test -f $@ || $(MAKE) $(AM_MAKEFLAGS) stamp-h1 stamp-h1: $(srcdir)/config.h.in $(top_builddir)/config.status @rm -f stamp-h1 cd $(top_builddir) && $(SHELL) ./config.status common/config.h $(srcdir)/config.h.in: $(am__configure_deps) ($(am__cd) $(top_srcdir) && $(AUTOHEADER)) rm -f stamp-h1 touch $@ distclean-hdr: -rm -f config.h stamp-h1 types.h: $(top_builddir)/config.status $(srcdir)/types.h.in cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs sources-local: splint-local: ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile config.h installdirs: install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) -test -z "$(DISTCLEANFILES)" || rm -f $(DISTCLEANFILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic distclean-hdr distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: sources: sources-am sources-am: sources-local splint: splint-am splint-am: splint-local uninstall-am: .MAKE: all install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am check check-am clean clean-generic \ clean-libtool cscopelist-am ctags ctags-am distclean \ distclean-generic distclean-hdr distclean-libtool \ distclean-tags distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am install-dvi \ install-dvi-am install-exec install-exec-am install-html \ install-html-am install-info install-info-am install-man \ install-pdf install-pdf-am install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ sources-am sources-local splint-am splint-local tags tags-am \ uninstall uninstall-am .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: libcaes-20240413/Makefile.am0000644000175000017500000000224714606476523016271 0ustar00lordyestalordyestaACLOCAL_AMFLAGS = -I m4 SUBDIRS = \ include \ common \ libcerror \ libcaes \ pycaes \ po \ manuals \ tests \ ossfuzz \ msvscpp DPKG_FILES = \ dpkg/changelog \ dpkg/changelog.in \ dpkg/compat \ dpkg/control \ dpkg/copyright \ dpkg/rules \ dpkg/libcaes.install \ dpkg/libcaes-dev.install \ dpkg/libcaes-python3.install \ dpkg/source/format GETTEXT_FILES = \ config.rpath \ po/Makevars.in PKGCONFIG_FILES = \ libcaes.pc.in SETUP_PY_FILES = \ pyproject.toml \ setup.cfg \ setup.cfg.in \ setup.py SPEC_FILES = \ libcaes.spec \ libcaes.spec.in EXTRA_DIST = \ $(DPKG_FILES) \ $(GETTEXT_FILES) \ $(PKGCONFIG_FILES) \ $(SETUP_PY_FILES) \ $(SPEC_FILES) DISTCLEANFILES = \ config.status \ config.cache \ config.log \ libcaes.pc \ libcaes.spec \ Makefile \ Makefile.in \ po/Makevars pkgconfigdir = $(libdir)/pkgconfig pkgconfig_DATA = \ libcaes.pc libtool: @LIBTOOL_DEPS@ cd $(srcdir) && $(SHELL) ./config.status --recheck lib: library library: (cd $(srcdir)/common && $(MAKE) $(AM_MAKEFLAGS)) (cd $(srcdir)/libcerror && $(MAKE) $(AM_MAKEFLAGS)) (cd $(srcdir)/libcaes && $(MAKE) $(AM_MAKEFLAGS)) (cd $(srcdir)/po && $(MAKE) $(AM_MAKEFLAGS)) libcaes-20240413/ABOUT-NLS0000644000175000017500000000010314533041420015430 0ustar00lordyestalordyesta libcaes-20240413/config.guess0000755000175000017500000014142314606477627016563 0ustar00lordyestalordyesta#!/usr/bin/sh # Attempt to guess a canonical system name. # Copyright 1992-2023 Free Software Foundation, Inc. # shellcheck disable=SC2006,SC2268 # see below for rationale timestamp='2023-06-23' # This file 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 3 of the License, or # (at your option) any later version. # # This program 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 this program; if not, see . # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that # program. This Exception is an additional permission under section 7 # of the GNU General Public License, version 3 ("GPLv3"). # # Originally written by Per Bothner; maintained since 2000 by Ben Elliston. # # You can get the latest version of this script from: # https://git.savannah.gnu.org/cgit/config.git/plain/config.guess # # Please send patches to . # The "shellcheck disable" line above the timestamp inhibits complaints # about features and limitations of the classic Bourne shell that were # superseded or lifted in POSIX. However, this script identifies a wide # variety of pre-POSIX systems that do not have POSIX shells at all, and # even some reasonably current systems (Solaris 10 as case-in-point) still # have a pre-POSIX /bin/sh. me=`echo "$0" | sed -e 's,.*/,,'` usage="\ Usage: $0 [OPTION] Output the configuration name of the system '$me' is run on. Options: -h, --help print this help, then exit -t, --time-stamp print date of last modification, then exit -v, --version print version number, then exit Report bugs and patches to ." version="\ GNU config.guess ($timestamp) Originally written by Per Bothner. Copyright 1992-2023 Free Software Foundation, Inc. This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." help=" Try '$me --help' for more information." # Parse command line while test $# -gt 0 ; do case $1 in --time-stamp | --time* | -t ) echo "$timestamp" ; exit ;; --version | -v ) echo "$version" ; exit ;; --help | --h* | -h ) echo "$usage"; exit ;; -- ) # Stop option processing shift; break ;; - ) # Use stdin as input. break ;; -* ) echo "$me: invalid option $1$help" >&2 exit 1 ;; * ) break ;; esac done if test $# != 0; then echo "$me: too many arguments$help" >&2 exit 1 fi # Just in case it came from the environment. GUESS= # CC_FOR_BUILD -- compiler used by this script. Note that the use of a # compiler to aid in system detection is discouraged as it requires # temporary files to be created and, as you can see below, it is a # headache to deal with in a portable fashion. # Historically, 'CC_FOR_BUILD' used to be named 'HOST_CC'. We still # use 'HOST_CC' if defined, but it is deprecated. # Portable tmp directory creation inspired by the Autoconf team. tmp= # shellcheck disable=SC2172 trap 'test -z "$tmp" || rm -fr "$tmp"' 0 1 2 13 15 set_cc_for_build() { # prevent multiple calls if $tmp is already set test "$tmp" && return 0 : "${TMPDIR=/tmp}" # shellcheck disable=SC2039,SC3028 { tmp=`(umask 077 && mktemp -d "$TMPDIR/cgXXXXXX") 2>/dev/null` && test -n "$tmp" && test -d "$tmp" ; } || { test -n "$RANDOM" && tmp=$TMPDIR/cg$$-$RANDOM && (umask 077 && mkdir "$tmp" 2>/dev/null) ; } || { tmp=$TMPDIR/cg-$$ && (umask 077 && mkdir "$tmp" 2>/dev/null) && echo "Warning: creating insecure temp directory" >&2 ; } || { echo "$me: cannot create a temporary directory in $TMPDIR" >&2 ; exit 1 ; } dummy=$tmp/dummy case ${CC_FOR_BUILD-},${HOST_CC-},${CC-} in ,,) echo "int x;" > "$dummy.c" for driver in cc gcc c89 c99 ; do if ($driver -c -o "$dummy.o" "$dummy.c") >/dev/null 2>&1 ; then CC_FOR_BUILD=$driver break fi done if test x"$CC_FOR_BUILD" = x ; then CC_FOR_BUILD=no_compiler_found fi ;; ,,*) CC_FOR_BUILD=$CC ;; ,*,*) CC_FOR_BUILD=$HOST_CC ;; esac } # This is needed to find uname on a Pyramid OSx when run in the BSD universe. # (ghazi@noc.rutgers.edu 1994-08-24) if test -f /.attbin/uname ; then PATH=$PATH:/.attbin ; export PATH fi UNAME_MACHINE=`(uname -m) 2>/dev/null` || UNAME_MACHINE=unknown UNAME_RELEASE=`(uname -r) 2>/dev/null` || UNAME_RELEASE=unknown UNAME_SYSTEM=`(uname -s) 2>/dev/null` || UNAME_SYSTEM=unknown UNAME_VERSION=`(uname -v) 2>/dev/null` || UNAME_VERSION=unknown case $UNAME_SYSTEM in Linux|GNU|GNU/*) LIBC=unknown set_cc_for_build cat <<-EOF > "$dummy.c" #include #if defined(__UCLIBC__) LIBC=uclibc #elif defined(__dietlibc__) LIBC=dietlibc #elif defined(__GLIBC__) LIBC=gnu #else #include /* First heuristic to detect musl libc. */ #ifdef __DEFINED_va_list LIBC=musl #endif #endif EOF cc_set_libc=`$CC_FOR_BUILD -E "$dummy.c" 2>/dev/null | grep '^LIBC' | sed 's, ,,g'` eval "$cc_set_libc" # Second heuristic to detect musl libc. if [ "$LIBC" = unknown ] && command -v ldd >/dev/null && ldd --version 2>&1 | grep -q ^musl; then LIBC=musl fi # If the system lacks a compiler, then just pick glibc. # We could probably try harder. if [ "$LIBC" = unknown ]; then LIBC=gnu fi ;; esac # Note: order is significant - the case branches are not exclusive. case $UNAME_MACHINE:$UNAME_SYSTEM:$UNAME_RELEASE:$UNAME_VERSION in *:NetBSD:*:*) # NetBSD (nbsd) targets should (where applicable) match one or # more of the tuples: *-*-netbsdelf*, *-*-netbsdaout*, # *-*-netbsdecoff* and *-*-netbsd*. For targets that recently # switched to ELF, *-*-netbsd* would select the old # object file format. This provides both forward # compatibility and a consistent mechanism for selecting the # object file format. # # Note: NetBSD doesn't particularly care about the vendor # portion of the name. We always set it to "unknown". UNAME_MACHINE_ARCH=`(uname -p 2>/dev/null || \ /sbin/sysctl -n hw.machine_arch 2>/dev/null || \ /usr/sbin/sysctl -n hw.machine_arch 2>/dev/null || \ echo unknown)` case $UNAME_MACHINE_ARCH in aarch64eb) machine=aarch64_be-unknown ;; armeb) machine=armeb-unknown ;; arm*) machine=arm-unknown ;; sh3el) machine=shl-unknown ;; sh3eb) machine=sh-unknown ;; sh5el) machine=sh5le-unknown ;; earmv*) arch=`echo "$UNAME_MACHINE_ARCH" | sed -e 's,^e\(armv[0-9]\).*$,\1,'` endian=`echo "$UNAME_MACHINE_ARCH" | sed -ne 's,^.*\(eb\)$,\1,p'` machine=${arch}${endian}-unknown ;; *) machine=$UNAME_MACHINE_ARCH-unknown ;; esac # The Operating System including object format, if it has switched # to ELF recently (or will in the future) and ABI. case $UNAME_MACHINE_ARCH in earm*) os=netbsdelf ;; arm*|i386|m68k|ns32k|sh3*|sparc|vax) set_cc_for_build if echo __ELF__ | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ELF__ then # Once all utilities can be ECOFF (netbsdecoff) or a.out (netbsdaout). # Return netbsd for either. FIX? os=netbsd else os=netbsdelf fi ;; *) os=netbsd ;; esac # Determine ABI tags. case $UNAME_MACHINE_ARCH in earm*) expr='s/^earmv[0-9]/-eabi/;s/eb$//' abi=`echo "$UNAME_MACHINE_ARCH" | sed -e "$expr"` ;; esac # The OS release # Debian GNU/NetBSD machines have a different userland, and # thus, need a distinct triplet. However, they do not need # kernel version information, so it can be replaced with a # suitable tag, in the style of linux-gnu. case $UNAME_VERSION in Debian*) release='-gnu' ;; *) release=`echo "$UNAME_RELEASE" | sed -e 's/[-_].*//' | cut -d. -f1,2` ;; esac # Since CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM: # contains redundant information, the shorter form: # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM is used. GUESS=$machine-${os}${release}${abi-} ;; *:Bitrig:*:*) UNAME_MACHINE_ARCH=`arch | sed 's/Bitrig.//'` GUESS=$UNAME_MACHINE_ARCH-unknown-bitrig$UNAME_RELEASE ;; *:OpenBSD:*:*) UNAME_MACHINE_ARCH=`arch | sed 's/OpenBSD.//'` GUESS=$UNAME_MACHINE_ARCH-unknown-openbsd$UNAME_RELEASE ;; *:SecBSD:*:*) UNAME_MACHINE_ARCH=`arch | sed 's/SecBSD.//'` GUESS=$UNAME_MACHINE_ARCH-unknown-secbsd$UNAME_RELEASE ;; *:LibertyBSD:*:*) UNAME_MACHINE_ARCH=`arch | sed 's/^.*BSD\.//'` GUESS=$UNAME_MACHINE_ARCH-unknown-libertybsd$UNAME_RELEASE ;; *:MidnightBSD:*:*) GUESS=$UNAME_MACHINE-unknown-midnightbsd$UNAME_RELEASE ;; *:ekkoBSD:*:*) GUESS=$UNAME_MACHINE-unknown-ekkobsd$UNAME_RELEASE ;; *:SolidBSD:*:*) GUESS=$UNAME_MACHINE-unknown-solidbsd$UNAME_RELEASE ;; *:OS108:*:*) GUESS=$UNAME_MACHINE-unknown-os108_$UNAME_RELEASE ;; macppc:MirBSD:*:*) GUESS=powerpc-unknown-mirbsd$UNAME_RELEASE ;; *:MirBSD:*:*) GUESS=$UNAME_MACHINE-unknown-mirbsd$UNAME_RELEASE ;; *:Sortix:*:*) GUESS=$UNAME_MACHINE-unknown-sortix ;; *:Twizzler:*:*) GUESS=$UNAME_MACHINE-unknown-twizzler ;; *:Redox:*:*) GUESS=$UNAME_MACHINE-unknown-redox ;; mips:OSF1:*.*) GUESS=mips-dec-osf1 ;; alpha:OSF1:*:*) # Reset EXIT trap before exiting to avoid spurious non-zero exit code. trap '' 0 case $UNAME_RELEASE in *4.0) UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $3}'` ;; *5.*) UNAME_RELEASE=`/usr/sbin/sizer -v | awk '{print $4}'` ;; esac # According to Compaq, /usr/sbin/psrinfo has been available on # OSF/1 and Tru64 systems produced since 1995. I hope that # covers most systems running today. This code pipes the CPU # types through head -n 1, so we only detect the type of CPU 0. ALPHA_CPU_TYPE=`/usr/sbin/psrinfo -v | sed -n -e 's/^ The alpha \(.*\) processor.*$/\1/p' | head -n 1` case $ALPHA_CPU_TYPE in "EV4 (21064)") UNAME_MACHINE=alpha ;; "EV4.5 (21064)") UNAME_MACHINE=alpha ;; "LCA4 (21066/21068)") UNAME_MACHINE=alpha ;; "EV5 (21164)") UNAME_MACHINE=alphaev5 ;; "EV5.6 (21164A)") UNAME_MACHINE=alphaev56 ;; "EV5.6 (21164PC)") UNAME_MACHINE=alphapca56 ;; "EV5.7 (21164PC)") UNAME_MACHINE=alphapca57 ;; "EV6 (21264)") UNAME_MACHINE=alphaev6 ;; "EV6.7 (21264A)") UNAME_MACHINE=alphaev67 ;; "EV6.8CB (21264C)") UNAME_MACHINE=alphaev68 ;; "EV6.8AL (21264B)") UNAME_MACHINE=alphaev68 ;; "EV6.8CX (21264D)") UNAME_MACHINE=alphaev68 ;; "EV6.9A (21264/EV69A)") UNAME_MACHINE=alphaev69 ;; "EV7 (21364)") UNAME_MACHINE=alphaev7 ;; "EV7.9 (21364A)") UNAME_MACHINE=alphaev79 ;; esac # A Pn.n version is a patched version. # A Vn.n version is a released version. # A Tn.n version is a released field test version. # A Xn.n version is an unreleased experimental baselevel. # 1.2 uses "1.2" for uname -r. OSF_REL=`echo "$UNAME_RELEASE" | sed -e 's/^[PVTX]//' | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz` GUESS=$UNAME_MACHINE-dec-osf$OSF_REL ;; Amiga*:UNIX_System_V:4.0:*) GUESS=m68k-unknown-sysv4 ;; *:[Aa]miga[Oo][Ss]:*:*) GUESS=$UNAME_MACHINE-unknown-amigaos ;; *:[Mm]orph[Oo][Ss]:*:*) GUESS=$UNAME_MACHINE-unknown-morphos ;; *:OS/390:*:*) GUESS=i370-ibm-openedition ;; *:z/VM:*:*) GUESS=s390-ibm-zvmoe ;; *:OS400:*:*) GUESS=powerpc-ibm-os400 ;; arm:RISC*:1.[012]*:*|arm:riscix:1.[012]*:*) GUESS=arm-acorn-riscix$UNAME_RELEASE ;; arm*:riscos:*:*|arm*:RISCOS:*:*) GUESS=arm-unknown-riscos ;; SR2?01:HI-UX/MPP:*:* | SR8000:HI-UX/MPP:*:*) GUESS=hppa1.1-hitachi-hiuxmpp ;; Pyramid*:OSx*:*:* | MIS*:OSx*:*:* | MIS*:SMP_DC-OSx*:*:*) # akee@wpdis03.wpafb.af.mil (Earle F. Ake) contributed MIS and NILE. case `(/bin/universe) 2>/dev/null` in att) GUESS=pyramid-pyramid-sysv3 ;; *) GUESS=pyramid-pyramid-bsd ;; esac ;; NILE*:*:*:dcosx) GUESS=pyramid-pyramid-svr4 ;; DRS?6000:unix:4.0:6*) GUESS=sparc-icl-nx6 ;; DRS?6000:UNIX_SV:4.2*:7* | DRS?6000:isis:4.2*:7*) case `/usr/bin/uname -p` in sparc) GUESS=sparc-icl-nx7 ;; esac ;; s390x:SunOS:*:*) SUN_REL=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'` GUESS=$UNAME_MACHINE-ibm-solaris2$SUN_REL ;; sun4H:SunOS:5.*:*) SUN_REL=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'` GUESS=sparc-hal-solaris2$SUN_REL ;; sun4*:SunOS:5.*:* | tadpole*:SunOS:5.*:*) SUN_REL=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'` GUESS=sparc-sun-solaris2$SUN_REL ;; i86pc:AuroraUX:5.*:* | i86xen:AuroraUX:5.*:*) GUESS=i386-pc-auroraux$UNAME_RELEASE ;; i86pc:SunOS:5.*:* | i86xen:SunOS:5.*:*) set_cc_for_build SUN_ARCH=i386 # If there is a compiler, see if it is configured for 64-bit objects. # Note that the Sun cc does not turn __LP64__ into 1 like gcc does. # This test works for both compilers. if test "$CC_FOR_BUILD" != no_compiler_found; then if (echo '#ifdef __amd64'; echo IS_64BIT_ARCH; echo '#endif') | \ (CCOPTS="" $CC_FOR_BUILD -m64 -E - 2>/dev/null) | \ grep IS_64BIT_ARCH >/dev/null then SUN_ARCH=x86_64 fi fi SUN_REL=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'` GUESS=$SUN_ARCH-pc-solaris2$SUN_REL ;; sun4*:SunOS:6*:*) # According to config.sub, this is the proper way to canonicalize # SunOS6. Hard to guess exactly what SunOS6 will be like, but # it's likely to be more like Solaris than SunOS4. SUN_REL=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'` GUESS=sparc-sun-solaris3$SUN_REL ;; sun4*:SunOS:*:*) case `/usr/bin/arch -k` in Series*|S4*) UNAME_RELEASE=`uname -v` ;; esac # Japanese Language versions have a version number like '4.1.3-JL'. SUN_REL=`echo "$UNAME_RELEASE" | sed -e 's/-/_/'` GUESS=sparc-sun-sunos$SUN_REL ;; sun3*:SunOS:*:*) GUESS=m68k-sun-sunos$UNAME_RELEASE ;; sun*:*:4.2BSD:*) UNAME_RELEASE=`(sed 1q /etc/motd | awk '{print substr($5,1,3)}') 2>/dev/null` test "x$UNAME_RELEASE" = x && UNAME_RELEASE=3 case `/bin/arch` in sun3) GUESS=m68k-sun-sunos$UNAME_RELEASE ;; sun4) GUESS=sparc-sun-sunos$UNAME_RELEASE ;; esac ;; aushp:SunOS:*:*) GUESS=sparc-auspex-sunos$UNAME_RELEASE ;; # The situation for MiNT is a little confusing. The machine name # can be virtually everything (everything which is not # "atarist" or "atariste" at least should have a processor # > m68000). The system name ranges from "MiNT" over "FreeMiNT" # to the lowercase version "mint" (or "freemint"). Finally # the system name "TOS" denotes a system which is actually not # MiNT. But MiNT is downward compatible to TOS, so this should # be no problem. atarist[e]:*MiNT:*:* | atarist[e]:*mint:*:* | atarist[e]:*TOS:*:*) GUESS=m68k-atari-mint$UNAME_RELEASE ;; atari*:*MiNT:*:* | atari*:*mint:*:* | atarist[e]:*TOS:*:*) GUESS=m68k-atari-mint$UNAME_RELEASE ;; *falcon*:*MiNT:*:* | *falcon*:*mint:*:* | *falcon*:*TOS:*:*) GUESS=m68k-atari-mint$UNAME_RELEASE ;; milan*:*MiNT:*:* | milan*:*mint:*:* | *milan*:*TOS:*:*) GUESS=m68k-milan-mint$UNAME_RELEASE ;; hades*:*MiNT:*:* | hades*:*mint:*:* | *hades*:*TOS:*:*) GUESS=m68k-hades-mint$UNAME_RELEASE ;; *:*MiNT:*:* | *:*mint:*:* | *:*TOS:*:*) GUESS=m68k-unknown-mint$UNAME_RELEASE ;; m68k:machten:*:*) GUESS=m68k-apple-machten$UNAME_RELEASE ;; powerpc:machten:*:*) GUESS=powerpc-apple-machten$UNAME_RELEASE ;; RISC*:Mach:*:*) GUESS=mips-dec-mach_bsd4.3 ;; RISC*:ULTRIX:*:*) GUESS=mips-dec-ultrix$UNAME_RELEASE ;; VAX*:ULTRIX*:*:*) GUESS=vax-dec-ultrix$UNAME_RELEASE ;; 2020:CLIX:*:* | 2430:CLIX:*:*) GUESS=clipper-intergraph-clix$UNAME_RELEASE ;; mips:*:*:UMIPS | mips:*:*:RISCos) set_cc_for_build sed 's/^ //' << EOF > "$dummy.c" #ifdef __cplusplus #include /* for printf() prototype */ int main (int argc, char *argv[]) { #else int main (argc, argv) int argc; char *argv[]; { #endif #if defined (host_mips) && defined (MIPSEB) #if defined (SYSTYPE_SYSV) printf ("mips-mips-riscos%ssysv\\n", argv[1]); exit (0); #endif #if defined (SYSTYPE_SVR4) printf ("mips-mips-riscos%ssvr4\\n", argv[1]); exit (0); #endif #if defined (SYSTYPE_BSD43) || defined(SYSTYPE_BSD) printf ("mips-mips-riscos%sbsd\\n", argv[1]); exit (0); #endif #endif exit (-1); } EOF $CC_FOR_BUILD -o "$dummy" "$dummy.c" && dummyarg=`echo "$UNAME_RELEASE" | sed -n 's/\([0-9]*\).*/\1/p'` && SYSTEM_NAME=`"$dummy" "$dummyarg"` && { echo "$SYSTEM_NAME"; exit; } GUESS=mips-mips-riscos$UNAME_RELEASE ;; Motorola:PowerMAX_OS:*:*) GUESS=powerpc-motorola-powermax ;; Motorola:*:4.3:PL8-*) GUESS=powerpc-harris-powermax ;; Night_Hawk:*:*:PowerMAX_OS | Synergy:PowerMAX_OS:*:*) GUESS=powerpc-harris-powermax ;; Night_Hawk:Power_UNIX:*:*) GUESS=powerpc-harris-powerunix ;; m88k:CX/UX:7*:*) GUESS=m88k-harris-cxux7 ;; m88k:*:4*:R4*) GUESS=m88k-motorola-sysv4 ;; m88k:*:3*:R3*) GUESS=m88k-motorola-sysv3 ;; AViiON:dgux:*:*) # DG/UX returns AViiON for all architectures UNAME_PROCESSOR=`/usr/bin/uname -p` if test "$UNAME_PROCESSOR" = mc88100 || test "$UNAME_PROCESSOR" = mc88110 then if test "$TARGET_BINARY_INTERFACE"x = m88kdguxelfx || \ test "$TARGET_BINARY_INTERFACE"x = x then GUESS=m88k-dg-dgux$UNAME_RELEASE else GUESS=m88k-dg-dguxbcs$UNAME_RELEASE fi else GUESS=i586-dg-dgux$UNAME_RELEASE fi ;; M88*:DolphinOS:*:*) # DolphinOS (SVR3) GUESS=m88k-dolphin-sysv3 ;; M88*:*:R3*:*) # Delta 88k system running SVR3 GUESS=m88k-motorola-sysv3 ;; XD88*:*:*:*) # Tektronix XD88 system running UTekV (SVR3) GUESS=m88k-tektronix-sysv3 ;; Tek43[0-9][0-9]:UTek:*:*) # Tektronix 4300 system running UTek (BSD) GUESS=m68k-tektronix-bsd ;; *:IRIX*:*:*) IRIX_REL=`echo "$UNAME_RELEASE" | sed -e 's/-/_/g'` GUESS=mips-sgi-irix$IRIX_REL ;; ????????:AIX?:[12].1:2) # AIX 2.2.1 or AIX 2.1.1 is RT/PC AIX. GUESS=romp-ibm-aix # uname -m gives an 8 hex-code CPU id ;; # Note that: echo "'`uname -s`'" gives 'AIX ' i*86:AIX:*:*) GUESS=i386-ibm-aix ;; ia64:AIX:*:*) if test -x /usr/bin/oslevel ; then IBM_REV=`/usr/bin/oslevel` else IBM_REV=$UNAME_VERSION.$UNAME_RELEASE fi GUESS=$UNAME_MACHINE-ibm-aix$IBM_REV ;; *:AIX:2:3) if grep bos325 /usr/include/stdio.h >/dev/null 2>&1; then set_cc_for_build sed 's/^ //' << EOF > "$dummy.c" #include main() { if (!__power_pc()) exit(1); puts("powerpc-ibm-aix3.2.5"); exit(0); } EOF if $CC_FOR_BUILD -o "$dummy" "$dummy.c" && SYSTEM_NAME=`"$dummy"` then GUESS=$SYSTEM_NAME else GUESS=rs6000-ibm-aix3.2.5 fi elif grep bos324 /usr/include/stdio.h >/dev/null 2>&1; then GUESS=rs6000-ibm-aix3.2.4 else GUESS=rs6000-ibm-aix3.2 fi ;; *:AIX:*:[4567]) IBM_CPU_ID=`/usr/sbin/lsdev -C -c processor -S available | sed 1q | awk '{ print $1 }'` if /usr/sbin/lsattr -El "$IBM_CPU_ID" | grep ' POWER' >/dev/null 2>&1; then IBM_ARCH=rs6000 else IBM_ARCH=powerpc fi if test -x /usr/bin/lslpp ; then IBM_REV=`/usr/bin/lslpp -Lqc bos.rte.libc | \ awk -F: '{ print $3 }' | sed s/[0-9]*$/0/` else IBM_REV=$UNAME_VERSION.$UNAME_RELEASE fi GUESS=$IBM_ARCH-ibm-aix$IBM_REV ;; *:AIX:*:*) GUESS=rs6000-ibm-aix ;; ibmrt:4.4BSD:*|romp-ibm:4.4BSD:*) GUESS=romp-ibm-bsd4.4 ;; ibmrt:*BSD:*|romp-ibm:BSD:*) # covers RT/PC BSD and GUESS=romp-ibm-bsd$UNAME_RELEASE # 4.3 with uname added to ;; # report: romp-ibm BSD 4.3 *:BOSX:*:*) GUESS=rs6000-bull-bosx ;; DPX/2?00:B.O.S.:*:*) GUESS=m68k-bull-sysv3 ;; 9000/[34]??:4.3bsd:1.*:*) GUESS=m68k-hp-bsd ;; hp300:4.4BSD:*:* | 9000/[34]??:4.3bsd:2.*:*) GUESS=m68k-hp-bsd4.4 ;; 9000/[34678]??:HP-UX:*:*) HPUX_REV=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*.[0B]*//'` case $UNAME_MACHINE in 9000/31?) HP_ARCH=m68000 ;; 9000/[34]??) HP_ARCH=m68k ;; 9000/[678][0-9][0-9]) if test -x /usr/bin/getconf; then sc_cpu_version=`/usr/bin/getconf SC_CPU_VERSION 2>/dev/null` sc_kernel_bits=`/usr/bin/getconf SC_KERNEL_BITS 2>/dev/null` case $sc_cpu_version in 523) HP_ARCH=hppa1.0 ;; # CPU_PA_RISC1_0 528) HP_ARCH=hppa1.1 ;; # CPU_PA_RISC1_1 532) # CPU_PA_RISC2_0 case $sc_kernel_bits in 32) HP_ARCH=hppa2.0n ;; 64) HP_ARCH=hppa2.0w ;; '') HP_ARCH=hppa2.0 ;; # HP-UX 10.20 esac ;; esac fi if test "$HP_ARCH" = ""; then set_cc_for_build sed 's/^ //' << EOF > "$dummy.c" #define _HPUX_SOURCE #include #include int main () { #if defined(_SC_KERNEL_BITS) long bits = sysconf(_SC_KERNEL_BITS); #endif long cpu = sysconf (_SC_CPU_VERSION); switch (cpu) { case CPU_PA_RISC1_0: puts ("hppa1.0"); break; case CPU_PA_RISC1_1: puts ("hppa1.1"); break; case CPU_PA_RISC2_0: #if defined(_SC_KERNEL_BITS) switch (bits) { case 64: puts ("hppa2.0w"); break; case 32: puts ("hppa2.0n"); break; default: puts ("hppa2.0"); break; } break; #else /* !defined(_SC_KERNEL_BITS) */ puts ("hppa2.0"); break; #endif default: puts ("hppa1.0"); break; } exit (0); } EOF (CCOPTS="" $CC_FOR_BUILD -o "$dummy" "$dummy.c" 2>/dev/null) && HP_ARCH=`"$dummy"` test -z "$HP_ARCH" && HP_ARCH=hppa fi ;; esac if test "$HP_ARCH" = hppa2.0w then set_cc_for_build # hppa2.0w-hp-hpux* has a 64-bit kernel and a compiler generating # 32-bit code. hppa64-hp-hpux* has the same kernel and a compiler # generating 64-bit code. GNU and HP use different nomenclature: # # $ CC_FOR_BUILD=cc ./config.guess # => hppa2.0w-hp-hpux11.23 # $ CC_FOR_BUILD="cc +DA2.0w" ./config.guess # => hppa64-hp-hpux11.23 if echo __LP64__ | (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | grep -q __LP64__ then HP_ARCH=hppa2.0w else HP_ARCH=hppa64 fi fi GUESS=$HP_ARCH-hp-hpux$HPUX_REV ;; ia64:HP-UX:*:*) HPUX_REV=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*.[0B]*//'` GUESS=ia64-hp-hpux$HPUX_REV ;; 3050*:HI-UX:*:*) set_cc_for_build sed 's/^ //' << EOF > "$dummy.c" #include int main () { long cpu = sysconf (_SC_CPU_VERSION); /* The order matters, because CPU_IS_HP_MC68K erroneously returns true for CPU_PA_RISC1_0. CPU_IS_PA_RISC returns correct results, however. */ if (CPU_IS_PA_RISC (cpu)) { switch (cpu) { case CPU_PA_RISC1_0: puts ("hppa1.0-hitachi-hiuxwe2"); break; case CPU_PA_RISC1_1: puts ("hppa1.1-hitachi-hiuxwe2"); break; case CPU_PA_RISC2_0: puts ("hppa2.0-hitachi-hiuxwe2"); break; default: puts ("hppa-hitachi-hiuxwe2"); break; } } else if (CPU_IS_HP_MC68K (cpu)) puts ("m68k-hitachi-hiuxwe2"); else puts ("unknown-hitachi-hiuxwe2"); exit (0); } EOF $CC_FOR_BUILD -o "$dummy" "$dummy.c" && SYSTEM_NAME=`"$dummy"` && { echo "$SYSTEM_NAME"; exit; } GUESS=unknown-hitachi-hiuxwe2 ;; 9000/7??:4.3bsd:*:* | 9000/8?[79]:4.3bsd:*:*) GUESS=hppa1.1-hp-bsd ;; 9000/8??:4.3bsd:*:*) GUESS=hppa1.0-hp-bsd ;; *9??*:MPE/iX:*:* | *3000*:MPE/iX:*:*) GUESS=hppa1.0-hp-mpeix ;; hp7??:OSF1:*:* | hp8?[79]:OSF1:*:*) GUESS=hppa1.1-hp-osf ;; hp8??:OSF1:*:*) GUESS=hppa1.0-hp-osf ;; i*86:OSF1:*:*) if test -x /usr/sbin/sysversion ; then GUESS=$UNAME_MACHINE-unknown-osf1mk else GUESS=$UNAME_MACHINE-unknown-osf1 fi ;; parisc*:Lites*:*:*) GUESS=hppa1.1-hp-lites ;; C1*:ConvexOS:*:* | convex:ConvexOS:C1*:*) GUESS=c1-convex-bsd ;; C2*:ConvexOS:*:* | convex:ConvexOS:C2*:*) if getsysinfo -f scalar_acc then echo c32-convex-bsd else echo c2-convex-bsd fi exit ;; C34*:ConvexOS:*:* | convex:ConvexOS:C34*:*) GUESS=c34-convex-bsd ;; C38*:ConvexOS:*:* | convex:ConvexOS:C38*:*) GUESS=c38-convex-bsd ;; C4*:ConvexOS:*:* | convex:ConvexOS:C4*:*) GUESS=c4-convex-bsd ;; CRAY*Y-MP:*:*:*) CRAY_REL=`echo "$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'` GUESS=ymp-cray-unicos$CRAY_REL ;; CRAY*[A-Z]90:*:*:*) echo "$UNAME_MACHINE"-cray-unicos"$UNAME_RELEASE" \ | sed -e 's/CRAY.*\([A-Z]90\)/\1/' \ -e y/ABCDEFGHIJKLMNOPQRSTUVWXYZ/abcdefghijklmnopqrstuvwxyz/ \ -e 's/\.[^.]*$/.X/' exit ;; CRAY*TS:*:*:*) CRAY_REL=`echo "$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'` GUESS=t90-cray-unicos$CRAY_REL ;; CRAY*T3E:*:*:*) CRAY_REL=`echo "$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'` GUESS=alphaev5-cray-unicosmk$CRAY_REL ;; CRAY*SV1:*:*:*) CRAY_REL=`echo "$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'` GUESS=sv1-cray-unicos$CRAY_REL ;; *:UNICOS/mp:*:*) CRAY_REL=`echo "$UNAME_RELEASE" | sed -e 's/\.[^.]*$/.X/'` GUESS=craynv-cray-unicosmp$CRAY_REL ;; F30[01]:UNIX_System_V:*:* | F700:UNIX_System_V:*:*) FUJITSU_PROC=`uname -m | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz` FUJITSU_SYS=`uname -p | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/\///'` FUJITSU_REL=`echo "$UNAME_RELEASE" | sed -e 's/ /_/'` GUESS=${FUJITSU_PROC}-fujitsu-${FUJITSU_SYS}${FUJITSU_REL} ;; 5000:UNIX_System_V:4.*:*) FUJITSU_SYS=`uname -p | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/\///'` FUJITSU_REL=`echo "$UNAME_RELEASE" | tr ABCDEFGHIJKLMNOPQRSTUVWXYZ abcdefghijklmnopqrstuvwxyz | sed -e 's/ /_/'` GUESS=sparc-fujitsu-${FUJITSU_SYS}${FUJITSU_REL} ;; i*86:BSD/386:*:* | i*86:BSD/OS:*:* | *:Ascend\ Embedded/OS:*:*) GUESS=$UNAME_MACHINE-pc-bsdi$UNAME_RELEASE ;; sparc*:BSD/OS:*:*) GUESS=sparc-unknown-bsdi$UNAME_RELEASE ;; *:BSD/OS:*:*) GUESS=$UNAME_MACHINE-unknown-bsdi$UNAME_RELEASE ;; arm:FreeBSD:*:*) UNAME_PROCESSOR=`uname -p` set_cc_for_build if echo __ARM_PCS_VFP | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ARM_PCS_VFP then FREEBSD_REL=`echo "$UNAME_RELEASE" | sed -e 's/[-(].*//'` GUESS=$UNAME_PROCESSOR-unknown-freebsd$FREEBSD_REL-gnueabi else FREEBSD_REL=`echo "$UNAME_RELEASE" | sed -e 's/[-(].*//'` GUESS=$UNAME_PROCESSOR-unknown-freebsd$FREEBSD_REL-gnueabihf fi ;; *:FreeBSD:*:*) UNAME_PROCESSOR=`/usr/bin/uname -p` case $UNAME_PROCESSOR in amd64) UNAME_PROCESSOR=x86_64 ;; i386) UNAME_PROCESSOR=i586 ;; esac FREEBSD_REL=`echo "$UNAME_RELEASE" | sed -e 's/[-(].*//'` GUESS=$UNAME_PROCESSOR-unknown-freebsd$FREEBSD_REL ;; i*:CYGWIN*:*) GUESS=$UNAME_MACHINE-pc-cygwin ;; *:MINGW64*:*) GUESS=$UNAME_MACHINE-pc-mingw64 ;; *:MINGW*:*) GUESS=$UNAME_MACHINE-pc-mingw32 ;; *:MSYS*:*) GUESS=$UNAME_MACHINE-pc-msys ;; i*:PW*:*) GUESS=$UNAME_MACHINE-pc-pw32 ;; *:SerenityOS:*:*) GUESS=$UNAME_MACHINE-pc-serenity ;; *:Interix*:*) case $UNAME_MACHINE in x86) GUESS=i586-pc-interix$UNAME_RELEASE ;; authenticamd | genuineintel | EM64T) GUESS=x86_64-unknown-interix$UNAME_RELEASE ;; IA64) GUESS=ia64-unknown-interix$UNAME_RELEASE ;; esac ;; i*:UWIN*:*) GUESS=$UNAME_MACHINE-pc-uwin ;; amd64:CYGWIN*:*:* | x86_64:CYGWIN*:*:*) GUESS=x86_64-pc-cygwin ;; prep*:SunOS:5.*:*) SUN_REL=`echo "$UNAME_RELEASE" | sed -e 's/[^.]*//'` GUESS=powerpcle-unknown-solaris2$SUN_REL ;; *:GNU:*:*) # the GNU system GNU_ARCH=`echo "$UNAME_MACHINE" | sed -e 's,[-/].*$,,'` GNU_REL=`echo "$UNAME_RELEASE" | sed -e 's,/.*$,,'` GUESS=$GNU_ARCH-unknown-$LIBC$GNU_REL ;; *:GNU/*:*:*) # other systems with GNU libc and userland GNU_SYS=`echo "$UNAME_SYSTEM" | sed 's,^[^/]*/,,' | tr "[:upper:]" "[:lower:]"` GNU_REL=`echo "$UNAME_RELEASE" | sed -e 's/[-(].*//'` GUESS=$UNAME_MACHINE-unknown-$GNU_SYS$GNU_REL-$LIBC ;; x86_64:[Mm]anagarm:*:*|i?86:[Mm]anagarm:*:*) GUESS="$UNAME_MACHINE-pc-managarm-mlibc" ;; *:[Mm]anagarm:*:*) GUESS="$UNAME_MACHINE-unknown-managarm-mlibc" ;; *:Minix:*:*) GUESS=$UNAME_MACHINE-unknown-minix ;; aarch64:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; aarch64_be:Linux:*:*) UNAME_MACHINE=aarch64_be GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; alpha:Linux:*:*) case `sed -n '/^cpu model/s/^.*: \(.*\)/\1/p' /proc/cpuinfo 2>/dev/null` in EV5) UNAME_MACHINE=alphaev5 ;; EV56) UNAME_MACHINE=alphaev56 ;; PCA56) UNAME_MACHINE=alphapca56 ;; PCA57) UNAME_MACHINE=alphapca56 ;; EV6) UNAME_MACHINE=alphaev6 ;; EV67) UNAME_MACHINE=alphaev67 ;; EV68*) UNAME_MACHINE=alphaev68 ;; esac objdump --private-headers /bin/sh | grep -q ld.so.1 if test "$?" = 0 ; then LIBC=gnulibc1 ; fi GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; arc:Linux:*:* | arceb:Linux:*:* | arc32:Linux:*:* | arc64:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; arm*:Linux:*:*) set_cc_for_build if echo __ARM_EABI__ | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ARM_EABI__ then GUESS=$UNAME_MACHINE-unknown-linux-$LIBC else if echo __ARM_PCS_VFP | $CC_FOR_BUILD -E - 2>/dev/null \ | grep -q __ARM_PCS_VFP then GUESS=$UNAME_MACHINE-unknown-linux-${LIBC}eabi else GUESS=$UNAME_MACHINE-unknown-linux-${LIBC}eabihf fi fi ;; avr32*:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; cris:Linux:*:*) GUESS=$UNAME_MACHINE-axis-linux-$LIBC ;; crisv32:Linux:*:*) GUESS=$UNAME_MACHINE-axis-linux-$LIBC ;; e2k:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; frv:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; hexagon:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; i*86:Linux:*:*) GUESS=$UNAME_MACHINE-pc-linux-$LIBC ;; ia64:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; k1om:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; loongarch32:Linux:*:* | loongarch64:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; m32r*:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; m68*:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; mips:Linux:*:* | mips64:Linux:*:*) set_cc_for_build IS_GLIBC=0 test x"${LIBC}" = xgnu && IS_GLIBC=1 sed 's/^ //' << EOF > "$dummy.c" #undef CPU #undef mips #undef mipsel #undef mips64 #undef mips64el #if ${IS_GLIBC} && defined(_ABI64) LIBCABI=gnuabi64 #else #if ${IS_GLIBC} && defined(_ABIN32) LIBCABI=gnuabin32 #else LIBCABI=${LIBC} #endif #endif #if ${IS_GLIBC} && defined(__mips64) && defined(__mips_isa_rev) && __mips_isa_rev>=6 CPU=mipsisa64r6 #else #if ${IS_GLIBC} && !defined(__mips64) && defined(__mips_isa_rev) && __mips_isa_rev>=6 CPU=mipsisa32r6 #else #if defined(__mips64) CPU=mips64 #else CPU=mips #endif #endif #endif #if defined(__MIPSEL__) || defined(__MIPSEL) || defined(_MIPSEL) || defined(MIPSEL) MIPS_ENDIAN=el #else #if defined(__MIPSEB__) || defined(__MIPSEB) || defined(_MIPSEB) || defined(MIPSEB) MIPS_ENDIAN= #else MIPS_ENDIAN= #endif #endif EOF cc_set_vars=`$CC_FOR_BUILD -E "$dummy.c" 2>/dev/null | grep '^CPU\|^MIPS_ENDIAN\|^LIBCABI'` eval "$cc_set_vars" test "x$CPU" != x && { echo "$CPU${MIPS_ENDIAN}-unknown-linux-$LIBCABI"; exit; } ;; mips64el:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; openrisc*:Linux:*:*) GUESS=or1k-unknown-linux-$LIBC ;; or32:Linux:*:* | or1k*:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; padre:Linux:*:*) GUESS=sparc-unknown-linux-$LIBC ;; parisc64:Linux:*:* | hppa64:Linux:*:*) GUESS=hppa64-unknown-linux-$LIBC ;; parisc:Linux:*:* | hppa:Linux:*:*) # Look for CPU level case `grep '^cpu[^a-z]*:' /proc/cpuinfo 2>/dev/null | cut -d' ' -f2` in PA7*) GUESS=hppa1.1-unknown-linux-$LIBC ;; PA8*) GUESS=hppa2.0-unknown-linux-$LIBC ;; *) GUESS=hppa-unknown-linux-$LIBC ;; esac ;; ppc64:Linux:*:*) GUESS=powerpc64-unknown-linux-$LIBC ;; ppc:Linux:*:*) GUESS=powerpc-unknown-linux-$LIBC ;; ppc64le:Linux:*:*) GUESS=powerpc64le-unknown-linux-$LIBC ;; ppcle:Linux:*:*) GUESS=powerpcle-unknown-linux-$LIBC ;; riscv32:Linux:*:* | riscv32be:Linux:*:* | riscv64:Linux:*:* | riscv64be:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; s390:Linux:*:* | s390x:Linux:*:*) GUESS=$UNAME_MACHINE-ibm-linux-$LIBC ;; sh64*:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; sh*:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; sparc:Linux:*:* | sparc64:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; tile*:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; vax:Linux:*:*) GUESS=$UNAME_MACHINE-dec-linux-$LIBC ;; x86_64:Linux:*:*) set_cc_for_build CPU=$UNAME_MACHINE LIBCABI=$LIBC if test "$CC_FOR_BUILD" != no_compiler_found; then ABI=64 sed 's/^ //' << EOF > "$dummy.c" #ifdef __i386__ ABI=x86 #else #ifdef __ILP32__ ABI=x32 #endif #endif EOF cc_set_abi=`$CC_FOR_BUILD -E "$dummy.c" 2>/dev/null | grep '^ABI' | sed 's, ,,g'` eval "$cc_set_abi" case $ABI in x86) CPU=i686 ;; x32) LIBCABI=${LIBC}x32 ;; esac fi GUESS=$CPU-pc-linux-$LIBCABI ;; xtensa*:Linux:*:*) GUESS=$UNAME_MACHINE-unknown-linux-$LIBC ;; i*86:DYNIX/ptx:4*:*) # ptx 4.0 does uname -s correctly, with DYNIX/ptx in there. # earlier versions are messed up and put the nodename in both # sysname and nodename. GUESS=i386-sequent-sysv4 ;; i*86:UNIX_SV:4.2MP:2.*) # Unixware is an offshoot of SVR4, but it has its own version # number series starting with 2... # I am not positive that other SVR4 systems won't match this, # I just have to hope. -- rms. # Use sysv4.2uw... so that sysv4* matches it. GUESS=$UNAME_MACHINE-pc-sysv4.2uw$UNAME_VERSION ;; i*86:OS/2:*:*) # If we were able to find 'uname', then EMX Unix compatibility # is probably installed. GUESS=$UNAME_MACHINE-pc-os2-emx ;; i*86:XTS-300:*:STOP) GUESS=$UNAME_MACHINE-unknown-stop ;; i*86:atheos:*:*) GUESS=$UNAME_MACHINE-unknown-atheos ;; i*86:syllable:*:*) GUESS=$UNAME_MACHINE-pc-syllable ;; i*86:LynxOS:2.*:* | i*86:LynxOS:3.[01]*:* | i*86:LynxOS:4.[02]*:*) GUESS=i386-unknown-lynxos$UNAME_RELEASE ;; i*86:*DOS:*:*) GUESS=$UNAME_MACHINE-pc-msdosdjgpp ;; i*86:*:4.*:*) UNAME_REL=`echo "$UNAME_RELEASE" | sed 's/\/MP$//'` if grep Novell /usr/include/link.h >/dev/null 2>/dev/null; then GUESS=$UNAME_MACHINE-univel-sysv$UNAME_REL else GUESS=$UNAME_MACHINE-pc-sysv$UNAME_REL fi ;; i*86:*:5:[678]*) # UnixWare 7.x, OpenUNIX and OpenServer 6. case `/bin/uname -X | grep "^Machine"` in *486*) UNAME_MACHINE=i486 ;; *Pentium) UNAME_MACHINE=i586 ;; *Pent*|*Celeron) UNAME_MACHINE=i686 ;; esac GUESS=$UNAME_MACHINE-unknown-sysv${UNAME_RELEASE}${UNAME_SYSTEM}${UNAME_VERSION} ;; i*86:*:3.2:*) if test -f /usr/options/cb.name; then UNAME_REL=`sed -n 's/.*Version //p' /dev/null >/dev/null ; then UNAME_REL=`(/bin/uname -X|grep Release|sed -e 's/.*= //')` (/bin/uname -X|grep i80486 >/dev/null) && UNAME_MACHINE=i486 (/bin/uname -X|grep '^Machine.*Pentium' >/dev/null) \ && UNAME_MACHINE=i586 (/bin/uname -X|grep '^Machine.*Pent *II' >/dev/null) \ && UNAME_MACHINE=i686 (/bin/uname -X|grep '^Machine.*Pentium Pro' >/dev/null) \ && UNAME_MACHINE=i686 GUESS=$UNAME_MACHINE-pc-sco$UNAME_REL else GUESS=$UNAME_MACHINE-pc-sysv32 fi ;; pc:*:*:*) # Left here for compatibility: # uname -m prints for DJGPP always 'pc', but it prints nothing about # the processor, so we play safe by assuming i586. # Note: whatever this is, it MUST be the same as what config.sub # prints for the "djgpp" host, or else GDB configure will decide that # this is a cross-build. GUESS=i586-pc-msdosdjgpp ;; Intel:Mach:3*:*) GUESS=i386-pc-mach3 ;; paragon:*:*:*) GUESS=i860-intel-osf1 ;; i860:*:4.*:*) # i860-SVR4 if grep Stardent /usr/include/sys/uadmin.h >/dev/null 2>&1 ; then GUESS=i860-stardent-sysv$UNAME_RELEASE # Stardent Vistra i860-SVR4 else # Add other i860-SVR4 vendors below as they are discovered. GUESS=i860-unknown-sysv$UNAME_RELEASE # Unknown i860-SVR4 fi ;; mini*:CTIX:SYS*5:*) # "miniframe" GUESS=m68010-convergent-sysv ;; mc68k:UNIX:SYSTEM5:3.51m) GUESS=m68k-convergent-sysv ;; M680?0:D-NIX:5.3:*) GUESS=m68k-diab-dnix ;; M68*:*:R3V[5678]*:*) test -r /sysV68 && { echo 'm68k-motorola-sysv'; exit; } ;; 3[345]??:*:4.0:3.0 | 3[34]??A:*:4.0:3.0 | 3[34]??,*:*:4.0:3.0 | 3[34]??/*:*:4.0:3.0 | 4400:*:4.0:3.0 | 4850:*:4.0:3.0 | SKA40:*:4.0:3.0 | SDS2:*:4.0:3.0 | SHG2:*:4.0:3.0 | S7501*:*:4.0:3.0) OS_REL='' test -r /etc/.relid \ && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4.3"$OS_REL"; exit; } /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ && { echo i586-ncr-sysv4.3"$OS_REL"; exit; } ;; 3[34]??:*:4.0:* | 3[34]??,*:*:4.0:*) /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4; exit; } ;; NCR*:*:4.2:* | MPRAS*:*:4.2:*) OS_REL='.3' test -r /etc/.relid \ && OS_REL=.`sed -n 's/[^ ]* [^ ]* \([0-9][0-9]\).*/\1/p' < /etc/.relid` /bin/uname -p 2>/dev/null | grep 86 >/dev/null \ && { echo i486-ncr-sysv4.3"$OS_REL"; exit; } /bin/uname -p 2>/dev/null | /bin/grep entium >/dev/null \ && { echo i586-ncr-sysv4.3"$OS_REL"; exit; } /bin/uname -p 2>/dev/null | /bin/grep pteron >/dev/null \ && { echo i586-ncr-sysv4.3"$OS_REL"; exit; } ;; m68*:LynxOS:2.*:* | m68*:LynxOS:3.0*:*) GUESS=m68k-unknown-lynxos$UNAME_RELEASE ;; mc68030:UNIX_System_V:4.*:*) GUESS=m68k-atari-sysv4 ;; TSUNAMI:LynxOS:2.*:*) GUESS=sparc-unknown-lynxos$UNAME_RELEASE ;; rs6000:LynxOS:2.*:*) GUESS=rs6000-unknown-lynxos$UNAME_RELEASE ;; PowerPC:LynxOS:2.*:* | PowerPC:LynxOS:3.[01]*:* | PowerPC:LynxOS:4.[02]*:*) GUESS=powerpc-unknown-lynxos$UNAME_RELEASE ;; SM[BE]S:UNIX_SV:*:*) GUESS=mips-dde-sysv$UNAME_RELEASE ;; RM*:ReliantUNIX-*:*:*) GUESS=mips-sni-sysv4 ;; RM*:SINIX-*:*:*) GUESS=mips-sni-sysv4 ;; *:SINIX-*:*:*) if uname -p 2>/dev/null >/dev/null ; then UNAME_MACHINE=`(uname -p) 2>/dev/null` GUESS=$UNAME_MACHINE-sni-sysv4 else GUESS=ns32k-sni-sysv fi ;; PENTIUM:*:4.0*:*) # Unisys 'ClearPath HMP IX 4000' SVR4/MP effort # says GUESS=i586-unisys-sysv4 ;; *:UNIX_System_V:4*:FTX*) # From Gerald Hewes . # How about differentiating between stratus architectures? -djm GUESS=hppa1.1-stratus-sysv4 ;; *:*:*:FTX*) # From seanf@swdc.stratus.com. GUESS=i860-stratus-sysv4 ;; i*86:VOS:*:*) # From Paul.Green@stratus.com. GUESS=$UNAME_MACHINE-stratus-vos ;; *:VOS:*:*) # From Paul.Green@stratus.com. GUESS=hppa1.1-stratus-vos ;; mc68*:A/UX:*:*) GUESS=m68k-apple-aux$UNAME_RELEASE ;; news*:NEWS-OS:6*:*) GUESS=mips-sony-newsos6 ;; R[34]000:*System_V*:*:* | R4000:UNIX_SYSV:*:* | R*000:UNIX_SV:*:*) if test -d /usr/nec; then GUESS=mips-nec-sysv$UNAME_RELEASE else GUESS=mips-unknown-sysv$UNAME_RELEASE fi ;; BeBox:BeOS:*:*) # BeOS running on hardware made by Be, PPC only. GUESS=powerpc-be-beos ;; BeMac:BeOS:*:*) # BeOS running on Mac or Mac clone, PPC only. GUESS=powerpc-apple-beos ;; BePC:BeOS:*:*) # BeOS running on Intel PC compatible. GUESS=i586-pc-beos ;; BePC:Haiku:*:*) # Haiku running on Intel PC compatible. GUESS=i586-pc-haiku ;; ppc:Haiku:*:*) # Haiku running on Apple PowerPC GUESS=powerpc-apple-haiku ;; *:Haiku:*:*) # Haiku modern gcc (not bound by BeOS compat) GUESS=$UNAME_MACHINE-unknown-haiku ;; SX-4:SUPER-UX:*:*) GUESS=sx4-nec-superux$UNAME_RELEASE ;; SX-5:SUPER-UX:*:*) GUESS=sx5-nec-superux$UNAME_RELEASE ;; SX-6:SUPER-UX:*:*) GUESS=sx6-nec-superux$UNAME_RELEASE ;; SX-7:SUPER-UX:*:*) GUESS=sx7-nec-superux$UNAME_RELEASE ;; SX-8:SUPER-UX:*:*) GUESS=sx8-nec-superux$UNAME_RELEASE ;; SX-8R:SUPER-UX:*:*) GUESS=sx8r-nec-superux$UNAME_RELEASE ;; SX-ACE:SUPER-UX:*:*) GUESS=sxace-nec-superux$UNAME_RELEASE ;; Power*:Rhapsody:*:*) GUESS=powerpc-apple-rhapsody$UNAME_RELEASE ;; *:Rhapsody:*:*) GUESS=$UNAME_MACHINE-apple-rhapsody$UNAME_RELEASE ;; arm64:Darwin:*:*) GUESS=aarch64-apple-darwin$UNAME_RELEASE ;; *:Darwin:*:*) UNAME_PROCESSOR=`uname -p` case $UNAME_PROCESSOR in unknown) UNAME_PROCESSOR=powerpc ;; esac if command -v xcode-select > /dev/null 2> /dev/null && \ ! xcode-select --print-path > /dev/null 2> /dev/null ; then # Avoid executing cc if there is no toolchain installed as # cc will be a stub that puts up a graphical alert # prompting the user to install developer tools. CC_FOR_BUILD=no_compiler_found else set_cc_for_build fi if test "$CC_FOR_BUILD" != no_compiler_found; then if (echo '#ifdef __LP64__'; echo IS_64BIT_ARCH; echo '#endif') | \ (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | \ grep IS_64BIT_ARCH >/dev/null then case $UNAME_PROCESSOR in i386) UNAME_PROCESSOR=x86_64 ;; powerpc) UNAME_PROCESSOR=powerpc64 ;; esac fi # On 10.4-10.6 one might compile for PowerPC via gcc -arch ppc if (echo '#ifdef __POWERPC__'; echo IS_PPC; echo '#endif') | \ (CCOPTS="" $CC_FOR_BUILD -E - 2>/dev/null) | \ grep IS_PPC >/dev/null then UNAME_PROCESSOR=powerpc fi elif test "$UNAME_PROCESSOR" = i386 ; then # uname -m returns i386 or x86_64 UNAME_PROCESSOR=$UNAME_MACHINE fi GUESS=$UNAME_PROCESSOR-apple-darwin$UNAME_RELEASE ;; *:procnto*:*:* | *:QNX:[0123456789]*:*) UNAME_PROCESSOR=`uname -p` if test "$UNAME_PROCESSOR" = x86; then UNAME_PROCESSOR=i386 UNAME_MACHINE=pc fi GUESS=$UNAME_PROCESSOR-$UNAME_MACHINE-nto-qnx$UNAME_RELEASE ;; *:QNX:*:4*) GUESS=i386-pc-qnx ;; NEO-*:NONSTOP_KERNEL:*:*) GUESS=neo-tandem-nsk$UNAME_RELEASE ;; NSE-*:NONSTOP_KERNEL:*:*) GUESS=nse-tandem-nsk$UNAME_RELEASE ;; NSR-*:NONSTOP_KERNEL:*:*) GUESS=nsr-tandem-nsk$UNAME_RELEASE ;; NSV-*:NONSTOP_KERNEL:*:*) GUESS=nsv-tandem-nsk$UNAME_RELEASE ;; NSX-*:NONSTOP_KERNEL:*:*) GUESS=nsx-tandem-nsk$UNAME_RELEASE ;; *:NonStop-UX:*:*) GUESS=mips-compaq-nonstopux ;; BS2000:POSIX*:*:*) GUESS=bs2000-siemens-sysv ;; DS/*:UNIX_System_V:*:*) GUESS=$UNAME_MACHINE-$UNAME_SYSTEM-$UNAME_RELEASE ;; *:Plan9:*:*) # "uname -m" is not consistent, so use $cputype instead. 386 # is converted to i386 for consistency with other x86 # operating systems. if test "${cputype-}" = 386; then UNAME_MACHINE=i386 elif test "x${cputype-}" != x; then UNAME_MACHINE=$cputype fi GUESS=$UNAME_MACHINE-unknown-plan9 ;; *:TOPS-10:*:*) GUESS=pdp10-unknown-tops10 ;; *:TENEX:*:*) GUESS=pdp10-unknown-tenex ;; KS10:TOPS-20:*:* | KL10:TOPS-20:*:* | TYPE4:TOPS-20:*:*) GUESS=pdp10-dec-tops20 ;; XKL-1:TOPS-20:*:* | TYPE5:TOPS-20:*:*) GUESS=pdp10-xkl-tops20 ;; *:TOPS-20:*:*) GUESS=pdp10-unknown-tops20 ;; *:ITS:*:*) GUESS=pdp10-unknown-its ;; SEI:*:*:SEIUX) GUESS=mips-sei-seiux$UNAME_RELEASE ;; *:DragonFly:*:*) DRAGONFLY_REL=`echo "$UNAME_RELEASE" | sed -e 's/[-(].*//'` GUESS=$UNAME_MACHINE-unknown-dragonfly$DRAGONFLY_REL ;; *:*VMS:*:*) UNAME_MACHINE=`(uname -p) 2>/dev/null` case $UNAME_MACHINE in A*) GUESS=alpha-dec-vms ;; I*) GUESS=ia64-dec-vms ;; V*) GUESS=vax-dec-vms ;; esac ;; *:XENIX:*:SysV) GUESS=i386-pc-xenix ;; i*86:skyos:*:*) SKYOS_REL=`echo "$UNAME_RELEASE" | sed -e 's/ .*$//'` GUESS=$UNAME_MACHINE-pc-skyos$SKYOS_REL ;; i*86:rdos:*:*) GUESS=$UNAME_MACHINE-pc-rdos ;; i*86:Fiwix:*:*) GUESS=$UNAME_MACHINE-pc-fiwix ;; *:AROS:*:*) GUESS=$UNAME_MACHINE-unknown-aros ;; x86_64:VMkernel:*:*) GUESS=$UNAME_MACHINE-unknown-esx ;; amd64:Isilon\ OneFS:*:*) GUESS=x86_64-unknown-onefs ;; *:Unleashed:*:*) GUESS=$UNAME_MACHINE-unknown-unleashed$UNAME_RELEASE ;; esac # Do we have a guess based on uname results? if test "x$GUESS" != x; then echo "$GUESS" exit fi # No uname command or uname output not recognized. set_cc_for_build cat > "$dummy.c" < #include #endif #if defined(ultrix) || defined(_ultrix) || defined(__ultrix) || defined(__ultrix__) #if defined (vax) || defined (__vax) || defined (__vax__) || defined(mips) || defined(__mips) || defined(__mips__) || defined(MIPS) || defined(__MIPS__) #include #if defined(_SIZE_T_) || defined(SIGLOST) #include #endif #endif #endif main () { #if defined (sony) #if defined (MIPSEB) /* BFD wants "bsd" instead of "newsos". Perhaps BFD should be changed, I don't know.... */ printf ("mips-sony-bsd\n"); exit (0); #else #include printf ("m68k-sony-newsos%s\n", #ifdef NEWSOS4 "4" #else "" #endif ); exit (0); #endif #endif #if defined (NeXT) #if !defined (__ARCHITECTURE__) #define __ARCHITECTURE__ "m68k" #endif int version; version=`(hostinfo | sed -n 's/.*NeXT Mach \([0-9]*\).*/\1/p') 2>/dev/null`; if (version < 4) printf ("%s-next-nextstep%d\n", __ARCHITECTURE__, version); else printf ("%s-next-openstep%d\n", __ARCHITECTURE__, version); exit (0); #endif #if defined (MULTIMAX) || defined (n16) #if defined (UMAXV) printf ("ns32k-encore-sysv\n"); exit (0); #else #if defined (CMU) printf ("ns32k-encore-mach\n"); exit (0); #else printf ("ns32k-encore-bsd\n"); exit (0); #endif #endif #endif #if defined (__386BSD__) printf ("i386-pc-bsd\n"); exit (0); #endif #if defined (sequent) #if defined (i386) printf ("i386-sequent-dynix\n"); exit (0); #endif #if defined (ns32000) printf ("ns32k-sequent-dynix\n"); exit (0); #endif #endif #if defined (_SEQUENT_) struct utsname un; uname(&un); if (strncmp(un.version, "V2", 2) == 0) { printf ("i386-sequent-ptx2\n"); exit (0); } if (strncmp(un.version, "V1", 2) == 0) { /* XXX is V1 correct? */ printf ("i386-sequent-ptx1\n"); exit (0); } printf ("i386-sequent-ptx\n"); exit (0); #endif #if defined (vax) #if !defined (ultrix) #include #if defined (BSD) #if BSD == 43 printf ("vax-dec-bsd4.3\n"); exit (0); #else #if BSD == 199006 printf ("vax-dec-bsd4.3reno\n"); exit (0); #else printf ("vax-dec-bsd\n"); exit (0); #endif #endif #else printf ("vax-dec-bsd\n"); exit (0); #endif #else #if defined(_SIZE_T_) || defined(SIGLOST) struct utsname un; uname (&un); printf ("vax-dec-ultrix%s\n", un.release); exit (0); #else printf ("vax-dec-ultrix\n"); exit (0); #endif #endif #endif #if defined(ultrix) || defined(_ultrix) || defined(__ultrix) || defined(__ultrix__) #if defined(mips) || defined(__mips) || defined(__mips__) || defined(MIPS) || defined(__MIPS__) #if defined(_SIZE_T_) || defined(SIGLOST) struct utsname *un; uname (&un); printf ("mips-dec-ultrix%s\n", un.release); exit (0); #else printf ("mips-dec-ultrix\n"); exit (0); #endif #endif #endif #if defined (alliant) && defined (i860) printf ("i860-alliant-bsd\n"); exit (0); #endif exit (1); } EOF $CC_FOR_BUILD -o "$dummy" "$dummy.c" 2>/dev/null && SYSTEM_NAME=`"$dummy"` && { echo "$SYSTEM_NAME"; exit; } # Apollos put the system type in the environment. test -d /usr/apollo && { echo "$ISP-apollo-$SYSTYPE"; exit; } echo "$0: unable to guess system type" >&2 case $UNAME_MACHINE:$UNAME_SYSTEM in mips:Linux | mips64:Linux) # If we got here on MIPS GNU/Linux, output extra information. cat >&2 <&2 <&2 </dev/null || echo unknown` uname -r = `(uname -r) 2>/dev/null || echo unknown` uname -s = `(uname -s) 2>/dev/null || echo unknown` uname -v = `(uname -v) 2>/dev/null || echo unknown` /usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null` /bin/uname -X = `(/bin/uname -X) 2>/dev/null` hostinfo = `(hostinfo) 2>/dev/null` /bin/universe = `(/bin/universe) 2>/dev/null` /usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null` /bin/arch = `(/bin/arch) 2>/dev/null` /usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null` /usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null` UNAME_MACHINE = "$UNAME_MACHINE" UNAME_RELEASE = "$UNAME_RELEASE" UNAME_SYSTEM = "$UNAME_SYSTEM" UNAME_VERSION = "$UNAME_VERSION" EOF fi exit 1 # Local variables: # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-start: "timestamp='" # time-stamp-format: "%:y-%02m-%02d" # time-stamp-end: "'" # End: libcaes-20240413/dpkg/0000755000175000017500000000000014606477653015162 5ustar00lordyestalordyestalibcaes-20240413/dpkg/copyright0000644000175000017500000000200014606473413017073 0ustar00lordyestalordyestaFormat: http://www.debian.org/doc/packaging-manuals/copyright-format/1.0/ Upstream-Name: libcaes Source: https://github.com/libyal/libcaes Files: * Copyright: 2011-2024, Joachim Metz License: LGPL-3.0+ License: LGPL-3.0+ This package is free software; you can redistribute it and/or modify it under the terms of the GNU Lesser General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. . This package 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 Lesser General Public License for more details. . You should have received a copy of the GNU General Public License along with this program. If not, see . . On Debian systems, the complete text of the GNU Lesser General Public License can be found in "/usr/share/common-licenses/LGPL-3". libcaes-20240413/dpkg/libcaes-python3.install0000644000175000017500000000002214606473411021534 0ustar00lordyestalordyesta/usr/lib/python3* libcaes-20240413/dpkg/source/0000755000175000017500000000000014606477653016462 5ustar00lordyestalordyestalibcaes-20240413/dpkg/source/format0000644000175000017500000000001414606473411017654 0ustar00lordyestalordyesta3.0 (quilt) libcaes-20240413/dpkg/control0000644000175000017500000000302314606473411016547 0ustar00lordyestalordyestaSource: libcaes Priority: extra Maintainer: Joachim Metz Build-Depends: debhelper (>= 9), dh-autoreconf, dh-python, pkg-config, libssl-dev, python3-dev, python3-setuptools Standards-Version: 4.1.4 Section: libs Homepage: https://github.com/libyal/libcaes Vcs-Git: https://github.com/libyal/libcaes.git Package: libcaes Architecture: any Depends: ${shlibs:Depends}, ${misc:Depends} Conflicts: libcaes1 Replaces: libcaes1 Suggests: libcaes-dbg Description: Library to support cross-platform AES encryption libcaes is a library to support cross-platform AES encryption. Package: libcaes-dbg Architecture: any Section: debug Depends: libcaes (= ${binary:Version}), ${misc:Depends} Description: Debugging symbols for libcaes Debugging symbols for libcaes. Package: libcaes-dev Section: libdevel Architecture: any Depends: libcaes (= ${binary:Version}), ${misc:Depends} Description: Header files and libraries for developing applications for libcaes Header files and libraries for developing applications for libcaes. Package: libcaes-python3 Section: python Architecture: any Depends: libcaes (= ${binary:Version}), ${shlibs:Depends}, ${misc:Depends} Conflicts: python3-libcaes Replaces: python3-libcaes Suggests: libcaes-python3-dbg Description: Python 3 bindings for libcaes Python 3 bindings for libcaes. Package: libcaes-python3-dbg Section: debug Architecture: any Depends: libcaes-python3 (= ${binary:Version}), ${misc:Depends} Description: Debugging symbols for libcaes-python3 Debugging symbols for libcaes-python3. libcaes-20240413/dpkg/rules0000644000175000017500000000127714606473411016232 0ustar00lordyestalordyesta#!/usr/bin/make -f # -*- makefile -*- # Uncomment for debhelper verbose output. # export DH_VERBOSE=1 export SKIP_PYTHON_TESTS=1 %: dh $@ --buildsystem=autoconf --with=autoreconf,python3 .PHONY: override_dh_auto_configure override_dh_auto_configure: dh_auto_configure -- --enable-python CFLAGS="-g" .PHONY: override_dh_install override_dh_install: dh_install --fail-missing -X.la -X/pycaes.a .PHONY: override_dh_missing override_dh_missing: dh_missing -X.la -X/pycaes.a --fail-missing .PHONY: override_dh_strip override_dh_strip: ifeq (,$(filter nostrip,$(DEB_BUILD_OPTIONS))) dh_strip -plibcaes --dbg-package=libcaes-dbg dh_strip -plibcaes-python3 --dbg-package=libcaes-python3-dbg endif libcaes-20240413/dpkg/libcaes.install0000644000175000017500000000002614606473411020136 0ustar00lordyestalordyestausr/lib/*-*/lib*.so.* libcaes-20240413/dpkg/changelog.in0000644000175000017500000000017014606473411017423 0ustar00lordyestalordyestalibcaes (@VERSION@-1) unstable; urgency=low * Auto-generated -- Joachim Metz @DPKG_DATE@ libcaes-20240413/dpkg/changelog0000644000175000017500000000021314606477645017031 0ustar00lordyestalordyestalibcaes (20240413-1) unstable; urgency=low * Auto-generated -- Joachim Metz Sat, 13 Apr 2024 14:50:43 +0200 libcaes-20240413/dpkg/compat0000644000175000017500000000000314606473411016345 0ustar00lordyestalordyesta10 libcaes-20240413/dpkg/libcaes-dev.install0000644000175000017500000000014014606473411020707 0ustar00lordyestalordyestausr/include/* usr/lib/*-*/lib*.a usr/lib/*-*/lib*.so usr/lib/*-*/pkgconfig/* usr/share/man/man3 libcaes-20240413/setup.cfg0000644000175000017500000000073714606477645016066 0ustar00lordyestalordyesta[metadata] name = libcaes-python version = 20240413 description = Python bindings module for libcaes long_description = Python bindings module for libcaes long_description_content_type = text/plain author = Joachim Metz author_email = joachim.metz@gmail.com license = GNU Lesser General Public License v3 or later (LGPLv3+) license_files = COPYING COPYING.LESSER classifiers = Development Status :: 3 - Alpha Programming Language :: Python [options] python_requires = >=3.7 libcaes-20240413/COPYING.LESSER0000644000175000017500000001674414606473411016264 0ustar00lordyestalordyesta GNU LESSER GENERAL PUBLIC LICENSE Version 3, 29 June 2007 Copyright (C) 2007 Free Software Foundation, Inc. Everyone is permitted to copy and distribute verbatim copies of this license document, but changing it is not allowed. This version of the GNU Lesser General Public License incorporates the terms and conditions of version 3 of the GNU General Public License, supplemented by the additional permissions listed below. 0. Additional Definitions. As used herein, "this License" refers to version 3 of the GNU Lesser General Public License, and the "GNU GPL" refers to version 3 of the GNU General Public License. "The Library" refers to a covered work governed by this License, other than an Application or a Combined Work as defined below. An "Application" is any work that makes use of an interface provided by the Library, but which is not otherwise based on the Library. Defining a subclass of a class defined by the Library is deemed a mode of using an interface provided by the Library. A "Combined Work" is a work produced by combining or linking an Application with the Library. The particular version of the Library with which the Combined Work was made is also called the "Linked Version". The "Minimal Corresponding Source" for a Combined Work means the Corresponding Source for the Combined Work, excluding any source code for portions of the Combined Work that, considered in isolation, are based on the Application, and not on the Linked Version. The "Corresponding Application Code" for a Combined Work means the object code and/or source code for the Application, including any data and utility programs needed for reproducing the Combined Work from the Application, but excluding the System Libraries of the Combined Work. 1. Exception to Section 3 of the GNU GPL. You may convey a covered work under sections 3 and 4 of this License without being bound by section 3 of the GNU GPL. 2. Conveying Modified Versions. If you modify a copy of the Library, and, in your modifications, a facility refers to a function or data to be supplied by an Application that uses the facility (other than as an argument passed when the facility is invoked), then you may convey a copy of the modified version: a) under this License, provided that you make a good faith effort to ensure that, in the event an Application does not supply the function or data, the facility still operates, and performs whatever part of its purpose remains meaningful, or b) under the GNU GPL, with none of the additional permissions of this License applicable to that copy. 3. Object Code Incorporating Material from Library Header Files. The object code form of an Application may incorporate material from a header file that is part of the Library. You may convey such object code under terms of your choice, provided that, if the incorporated material is not limited to numerical parameters, data structure layouts and accessors, or small macros, inline functions and templates (ten or fewer lines in length), you do both of the following: a) Give prominent notice with each copy of the object code that the Library is used in it and that the Library and its use are covered by this License. b) Accompany the object code with a copy of the GNU GPL and this license document. 4. Combined Works. You may convey a Combined Work under terms of your choice that, taken together, effectively do not restrict modification of the portions of the Library contained in the Combined Work and reverse engineering for debugging such modifications, if you also do each of the following: a) Give prominent notice with each copy of the Combined Work that the Library is used in it and that the Library and its use are covered by this License. b) Accompany the Combined Work with a copy of the GNU GPL and this license document. c) For a Combined Work that displays copyright notices during execution, include the copyright notice for the Library among these notices, as well as a reference directing the user to the copies of the GNU GPL and this license document. d) Do one of the following: 0) Convey the Minimal Corresponding Source under the terms of this License, and the Corresponding Application Code in a form suitable for, and under terms that permit, the user to recombine or relink the Application with a modified version of the Linked Version to produce a modified Combined Work, in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source. 1) Use a suitable shared library mechanism for linking with the Library. A suitable mechanism is one that (a) uses at run time a copy of the Library already present on the user's computer system, and (b) will operate properly with a modified version of the Library that is interface-compatible with the Linked Version. e) Provide Installation Information, but only if you would otherwise be required to provide such information under section 6 of the GNU GPL, and only to the extent that such information is necessary to install and execute a modified version of the Combined Work produced by recombining or relinking the Application with a modified version of the Linked Version. (If you use option 4d0, the Installation Information must accompany the Minimal Corresponding Source and Corresponding Application Code. If you use option 4d1, you must provide the Installation Information in the manner specified by section 6 of the GNU GPL for conveying Corresponding Source.) 5. Combined Libraries. You may place library facilities that are a work based on the Library side by side in a single library together with other library facilities that are not Applications and are not covered by this License, and convey such a combined library under terms of your choice, if you do both of the following: a) Accompany the combined library with a copy of the same work based on the Library, uncombined with any other library facilities, conveyed under the terms of this License. b) Give prominent notice with the combined library that part of it is a work based on the Library, and explaining where to find the accompanying uncombined form of the same work. 6. Revised Versions of the GNU Lesser General Public License. The Free Software Foundation may publish revised and/or new versions of the GNU Lesser General Public License from time to time. Such new versions will be similar in spirit to the present version, but may differ in detail to address new problems or concerns. Each version is given a distinguishing version number. If the Library as you received it specifies that a certain numbered version of the GNU Lesser General Public License "or any later version" applies to it, you have the option of following the terms and conditions either of that published version or of any later version published by the Free Software Foundation. If the Library as you received it does not specify a version number of the GNU Lesser General Public License, you may choose any version of the GNU Lesser General Public License ever published by the Free Software Foundation. If the Library as you received it specifies that a proxy can decide whether future versions of the GNU Lesser General Public License shall apply, that proxy's public statement of acceptance of any version is permanent authorization for you to choose that version for the Library. libcaes-20240413/configure0000755000175000017500000341001514606477626016150 0ustar00lordyestalordyesta#! /bin/sh # Guess values for system-dependent variables and create Makefiles. # Generated by GNU Autoconf 2.71 for libcaes 20240413. # # Report bugs to . # # # Copyright (C) 1992-1996, 1998-2017, 2020-2021 Free Software Foundation, # Inc. # # # This configure script is free software; the Free Software Foundation # gives unlimited permission to copy, distribute and modify it. ## -------------------- ## ## M4sh Initialization. ## ## -------------------- ## # Be more Bourne compatible DUALCASE=1; export DUALCASE # for MKS sh as_nop=: if test ${ZSH_VERSION+y} && (emulate sh) >/dev/null 2>&1 then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else $as_nop case `(set -o) 2>/dev/null` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi # Reset variables that may have inherited troublesome values from # the environment. # IFS needs to be set, to space, tab, and newline, in precisely that order. # (If _AS_PATH_WALK were called with IFS unset, it would have the # side effect of setting IFS to empty, thus disabling word splitting.) # Quoting is to prevent editors from complaining about space-tab. as_nl=' ' export as_nl IFS=" "" $as_nl" PS1='$ ' PS2='> ' PS4='+ ' # Ensure predictable behavior from utilities with locale-dependent output. LC_ALL=C export LC_ALL LANGUAGE=C export LANGUAGE # We cannot yet rely on "unset" to work, but we need these variables # to be unset--not just set to an empty or harmless value--now, to # avoid bugs in old shells (e.g. pre-3.0 UWIN ksh). This construct # also avoids known problems related to "unset" and subshell syntax # in other old shells (e.g. bash 2.01 and pdksh 5.2.14). for as_var in BASH_ENV ENV MAIL MAILPATH CDPATH do eval test \${$as_var+y} \ && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : done # Ensure that fds 0, 1, and 2 are open. if (exec 3>&0) 2>/dev/null; then :; else exec 0&1) 2>/dev/null; then :; else exec 1>/dev/null; fi if (exec 3>&2) ; then :; else exec 2>/dev/null; fi # The user is always right. if ${PATH_SEPARATOR+false} :; then PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || PATH_SEPARATOR=';' } fi # Find who we are. Look in the path if we contain no directory separator. as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac test -r "$as_dir$0" && as_myself=$as_dir$0 && break done IFS=$as_save_IFS ;; esac # We did not find ourselves, most probably we were run as `sh COMMAND' # in which case we are not to be found in the path. if test "x$as_myself" = x; then as_myself=$0 fi if test ! -f "$as_myself"; then printf "%s\n" "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 exit 1 fi # Use a proper internal environment variable to ensure we don't fall # into an infinite loop, continuously re-executing ourselves. if test x"${_as_can_reexec}" != xno && test "x$CONFIG_SHELL" != x; then _as_can_reexec=no; export _as_can_reexec; # We cannot yet assume a decent shell, so we have to provide a # neutralization value for shells without unset; and this also # works around shells that cannot unset nonexistent variables. # Preserve -v and -x to the replacement shell. BASH_ENV=/dev/null ENV=/dev/null (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV case $- in # (((( *v*x* | *x*v* ) as_opts=-vx ;; *v* ) as_opts=-v ;; *x* ) as_opts=-x ;; * ) as_opts= ;; esac exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} # Admittedly, this is quite paranoid, since all the known shells bail # out after a failed `exec'. printf "%s\n" "$0: could not re-execute with $CONFIG_SHELL" >&2 exit 255 fi # We don't want this to propagate to other subprocesses. { _as_can_reexec=; unset _as_can_reexec;} if test "x$CONFIG_SHELL" = x; then as_bourne_compatible="as_nop=: if test \${ZSH_VERSION+y} && (emulate sh) >/dev/null 2>&1 then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on \${1+\"\$@\"}, which # is contrary to our usage. Disable this feature. alias -g '\${1+\"\$@\"}'='\"\$@\"' setopt NO_GLOB_SUBST else \$as_nop case \`(set -o) 2>/dev/null\` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi " as_required="as_fn_return () { (exit \$1); } as_fn_success () { as_fn_return 0; } as_fn_failure () { as_fn_return 1; } as_fn_ret_success () { return 0; } as_fn_ret_failure () { return 1; } exitcode=0 as_fn_success || { exitcode=1; echo as_fn_success failed.; } as_fn_failure && { exitcode=1; echo as_fn_failure succeeded.; } as_fn_ret_success || { exitcode=1; echo as_fn_ret_success failed.; } as_fn_ret_failure && { exitcode=1; echo as_fn_ret_failure succeeded.; } if ( set x; as_fn_ret_success y && test x = \"\$1\" ) then : else \$as_nop exitcode=1; echo positional parameters were not saved. fi test x\$exitcode = x0 || exit 1 blah=\$(echo \$(echo blah)) test x\"\$blah\" = xblah || exit 1 test -x / || exit 1" as_suggested=" as_lineno_1=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_1a=\$LINENO as_lineno_2=";as_suggested=$as_suggested$LINENO;as_suggested=$as_suggested" as_lineno_2a=\$LINENO eval 'test \"x\$as_lineno_1'\$as_run'\" != \"x\$as_lineno_2'\$as_run'\" && test \"x\`expr \$as_lineno_1'\$as_run' + 1\`\" = \"x\$as_lineno_2'\$as_run'\"' || exit 1 test -n \"\${ZSH_VERSION+set}\${BASH_VERSION+set}\" || ( ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO ECHO=\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO\$ECHO PATH=/empty FPATH=/empty; export PATH FPATH test \"X\`printf %s \$ECHO\`\" = \"X\$ECHO\" \\ || test \"X\`print -r -- \$ECHO\`\" = \"X\$ECHO\" ) || exit 1 test \$(( 1 + 1 )) = 2 || exit 1" if (eval "$as_required") 2>/dev/null then : as_have_required=yes else $as_nop as_have_required=no fi if test x$as_have_required = xyes && (eval "$as_suggested") 2>/dev/null then : else $as_nop as_save_IFS=$IFS; IFS=$PATH_SEPARATOR as_found=false for as_dir in /bin$PATH_SEPARATOR/usr/bin$PATH_SEPARATOR$PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac as_found=: case $as_dir in #( /*) for as_base in sh bash ksh sh5; do # Try only shells that exist, to save several forks. as_shell=$as_dir$as_base if { test -f "$as_shell" || test -f "$as_shell.exe"; } && as_run=a "$as_shell" -c "$as_bourne_compatible""$as_required" 2>/dev/null then : CONFIG_SHELL=$as_shell as_have_required=yes if as_run=a "$as_shell" -c "$as_bourne_compatible""$as_suggested" 2>/dev/null then : break 2 fi fi done;; esac as_found=false done IFS=$as_save_IFS if $as_found then : else $as_nop if { test -f "$SHELL" || test -f "$SHELL.exe"; } && as_run=a "$SHELL" -c "$as_bourne_compatible""$as_required" 2>/dev/null then : CONFIG_SHELL=$SHELL as_have_required=yes fi fi if test "x$CONFIG_SHELL" != x then : export CONFIG_SHELL # We cannot yet assume a decent shell, so we have to provide a # neutralization value for shells without unset; and this also # works around shells that cannot unset nonexistent variables. # Preserve -v and -x to the replacement shell. BASH_ENV=/dev/null ENV=/dev/null (unset BASH_ENV) >/dev/null 2>&1 && unset BASH_ENV ENV case $- in # (((( *v*x* | *x*v* ) as_opts=-vx ;; *v* ) as_opts=-v ;; *x* ) as_opts=-x ;; * ) as_opts= ;; esac exec $CONFIG_SHELL $as_opts "$as_myself" ${1+"$@"} # Admittedly, this is quite paranoid, since all the known shells bail # out after a failed `exec'. printf "%s\n" "$0: could not re-execute with $CONFIG_SHELL" >&2 exit 255 fi if test x$as_have_required = xno then : printf "%s\n" "$0: This script requires a shell more modern than all" printf "%s\n" "$0: the shells that I found on your system." if test ${ZSH_VERSION+y} ; then printf "%s\n" "$0: In particular, zsh $ZSH_VERSION has bugs and should" printf "%s\n" "$0: be upgraded to zsh 4.3.4 or later." else printf "%s\n" "$0: Please tell bug-autoconf@gnu.org and $0: joachim.metz@gmail.com about your system, including any $0: error possibly output before this message. Then install $0: a modern shell, or manually run the script under such a $0: shell if you do have one." fi exit 1 fi fi fi SHELL=${CONFIG_SHELL-/bin/sh} export SHELL # Unset more variables known to interfere with behavior of common tools. CLICOLOR_FORCE= GREP_OPTIONS= unset CLICOLOR_FORCE GREP_OPTIONS ## --------------------- ## ## M4sh Shell Functions. ## ## --------------------- ## # as_fn_unset VAR # --------------- # Portably unset VAR. as_fn_unset () { { eval $1=; unset $1;} } as_unset=as_fn_unset # as_fn_set_status STATUS # ----------------------- # Set $? to STATUS, without forking. as_fn_set_status () { return $1 } # as_fn_set_status # as_fn_exit STATUS # ----------------- # Exit the shell with STATUS, even in a "trap 0" or "set -e" context. as_fn_exit () { set +e as_fn_set_status $1 exit $1 } # as_fn_exit # as_fn_nop # --------- # Do nothing but, unlike ":", preserve the value of $?. as_fn_nop () { return $? } as_nop=as_fn_nop # as_fn_mkdir_p # ------------- # Create "$as_dir" as a directory, including parents if necessary. as_fn_mkdir_p () { case $as_dir in #( -*) as_dir=./$as_dir;; esac test -d "$as_dir" || eval $as_mkdir_p || { as_dirs= while :; do case $as_dir in #( *\'*) as_qdir=`printf "%s\n" "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( *) as_qdir=$as_dir;; esac as_dirs="'$as_qdir' $as_dirs" as_dir=`$as_dirname -- "$as_dir" || $as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_dir" : 'X\(//\)[^/]' \| \ X"$as_dir" : 'X\(//\)$' \| \ X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || printf "%s\n" X"$as_dir" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` test -d "$as_dir" && break done test -z "$as_dirs" || eval "mkdir $as_dirs" } || test -d "$as_dir" || as_fn_error $? "cannot create directory $as_dir" } # as_fn_mkdir_p # as_fn_executable_p FILE # ----------------------- # Test if FILE is an executable regular file. as_fn_executable_p () { test -f "$1" && test -x "$1" } # as_fn_executable_p # as_fn_append VAR VALUE # ---------------------- # Append the text in VALUE to the end of the definition contained in VAR. Take # advantage of any shell optimizations that allow amortized linear growth over # repeated appends, instead of the typical quadratic growth present in naive # implementations. if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null then : eval 'as_fn_append () { eval $1+=\$2 }' else $as_nop as_fn_append () { eval $1=\$$1\$2 } fi # as_fn_append # as_fn_arith ARG... # ------------------ # Perform arithmetic evaluation on the ARGs, and store the result in the # global $as_val. Take advantage of shells that can avoid forks. The arguments # must be portable across $(()) and expr. if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null then : eval 'as_fn_arith () { as_val=$(( $* )) }' else $as_nop as_fn_arith () { as_val=`expr "$@" || test $? -eq 1` } fi # as_fn_arith # as_fn_nop # --------- # Do nothing but, unlike ":", preserve the value of $?. as_fn_nop () { return $? } as_nop=as_fn_nop # as_fn_error STATUS ERROR [LINENO LOG_FD] # ---------------------------------------- # Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are # provided, also output the error to LOG_FD, referencing LINENO. Then exit the # script with STATUS, using 1 if that was 0. as_fn_error () { as_status=$1; test $as_status -eq 0 && as_status=1 if test "$4"; then as_lineno=${as_lineno-"$3"} as_lineno_stack=as_lineno_stack=$as_lineno_stack printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: $2" >&$4 fi printf "%s\n" "$as_me: error: $2" >&2 as_fn_exit $as_status } # as_fn_error if expr a : '\(a\)' >/dev/null 2>&1 && test "X`expr 00001 : '.*\(...\)'`" = X001; then as_expr=expr else as_expr=false fi if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then as_basename=basename else as_basename=false fi if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then as_dirname=dirname else as_dirname=false fi as_me=`$as_basename -- "$0" || $as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ X"$0" : 'X\(//\)$' \| \ X"$0" : 'X\(/\)' \| . 2>/dev/null || printf "%s\n" X/"$0" | sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/ q } /^X\/\(\/\/\)$/{ s//\1/ q } /^X\/\(\/\).*/{ s//\1/ q } s/.*/./; q'` # Avoid depending upon Character Ranges. as_cr_letters='abcdefghijklmnopqrstuvwxyz' as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' as_cr_Letters=$as_cr_letters$as_cr_LETTERS as_cr_digits='0123456789' as_cr_alnum=$as_cr_Letters$as_cr_digits as_lineno_1=$LINENO as_lineno_1a=$LINENO as_lineno_2=$LINENO as_lineno_2a=$LINENO eval 'test "x$as_lineno_1'$as_run'" != "x$as_lineno_2'$as_run'" && test "x`expr $as_lineno_1'$as_run' + 1`" = "x$as_lineno_2'$as_run'"' || { # Blame Lee E. McMahon (1931-1989) for sed's syntax. :-) sed -n ' p /[$]LINENO/= ' <$as_myself | sed ' s/[$]LINENO.*/&-/ t lineno b :lineno N :loop s/[$]LINENO\([^'$as_cr_alnum'_].*\n\)\(.*\)/\2\1\2/ t loop s/-\n.*// ' >$as_me.lineno && chmod +x "$as_me.lineno" || { printf "%s\n" "$as_me: error: cannot create $as_me.lineno; rerun with a POSIX shell" >&2; as_fn_exit 1; } # If we had to re-execute with $CONFIG_SHELL, we're ensured to have # already done that, so ensure we don't try to do so again and fall # in an infinite loop. This has already happened in practice. _as_can_reexec=no; export _as_can_reexec # Don't try to exec as it changes $[0], causing all sort of problems # (the dirname of $[0] is not the place where we might find the # original and so on. Autoconf is especially sensitive to this). . "./$as_me.lineno" # Exit status is that of the last command. exit } # Determine whether it's possible to make 'echo' print without a newline. # These variables are no longer used directly by Autoconf, but are AC_SUBSTed # for compatibility with existing Makefiles. ECHO_C= ECHO_N= ECHO_T= case `echo -n x` in #((((( -n*) case `echo 'xy\c'` in *c*) ECHO_T=' ';; # ECHO_T is single tab character. xy) ECHO_C='\c';; *) echo `echo ksh88 bug on AIX 6.1` > /dev/null ECHO_T=' ';; esac;; *) ECHO_N='-n';; esac # For backward compatibility with old third-party macros, we provide # the shell variables $as_echo and $as_echo_n. New code should use # AS_ECHO(["message"]) and AS_ECHO_N(["message"]), respectively. as_echo='printf %s\n' as_echo_n='printf %s' rm -f conf$$ conf$$.exe conf$$.file if test -d conf$$.dir; then rm -f conf$$.dir/conf$$.file else rm -f conf$$.dir mkdir conf$$.dir 2>/dev/null fi if (echo >conf$$.file) 2>/dev/null; then if ln -s conf$$.file conf$$ 2>/dev/null; then as_ln_s='ln -s' # ... but there are two gotchas: # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. # In both cases, we have to default to `cp -pR'. ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || as_ln_s='cp -pR' elif ln conf$$.file conf$$ 2>/dev/null; then as_ln_s=ln else as_ln_s='cp -pR' fi else as_ln_s='cp -pR' fi rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file rmdir conf$$.dir 2>/dev/null if mkdir -p . 2>/dev/null; then as_mkdir_p='mkdir -p "$as_dir"' else test -d ./-p && rmdir ./-p as_mkdir_p=false fi as_test_x='test -x' as_executable_p=as_fn_executable_p # Sed expression to map a string onto a valid CPP name. as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" # Sed expression to map a string onto a valid variable name. as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" SHELL=${CONFIG_SHELL-/bin/sh} test -n "$DJDIR" || exec 7<&0 &1 # Name of the host. # hostname on some systems (SVR3.2, old GNU/Linux) returns a bogus exit status, # so uname gets run too. ac_hostname=`(hostname || uname -n) 2>/dev/null | sed 1q` # # Initializations. # ac_default_prefix=/usr/local ac_clean_files= ac_config_libobj_dir=. LIBOBJS= cross_compiling=no subdirs= MFLAGS= MAKEFLAGS= # Identity of this package. PACKAGE_NAME='libcaes' PACKAGE_TARNAME='libcaes' PACKAGE_VERSION='20240413' PACKAGE_STRING='libcaes 20240413' PACKAGE_BUGREPORT='joachim.metz@gmail.com' PACKAGE_URL='' ac_unique_file="include/libcaes.h.in" # Factoring default headers for most tests. ac_includes_default="\ #include #ifdef HAVE_STDIO_H # include #endif #ifdef HAVE_STDLIB_H # include #endif #ifdef HAVE_STRING_H # include #endif #ifdef HAVE_INTTYPES_H # include #endif #ifdef HAVE_STDINT_H # include #endif #ifdef HAVE_STRINGS_H # include #endif #ifdef HAVE_SYS_TYPES_H # include #endif #ifdef HAVE_SYS_STAT_H # include #endif #ifdef HAVE_UNISTD_H # include #endif" ac_header_c_list= gt_needs= ac_subst_vars='am__EXEEXT_FALSE am__EXEEXT_TRUE LTLIBOBJS LIBOBJS SPEC_DATE DPKG_DATE libcaes_spec_requires LIB_FUZZING_ENGINE HAVE_LIB_FUZZING_ENGINE_FALSE HAVE_LIB_FUZZING_ENGINE_TRUE LIBCAES_DLL_IMPORT LIBCAES_DLL_EXPORT HAVE_DLLMAIN HAVE_PYTHON_TESTS_FALSE HAVE_PYTHON_TESTS_TRUE HAVE_PYTHON_FALSE HAVE_PYTHON_TRUE PYTHON_PACKAGE_DIR PYTHON_LIBRARY_DIR pyexecdir pythondir PYTHON_EXEC_PREFIX PYTHON_PREFIX PYTHON_LDFLAGS PYTHON_CPPFLAGS PYTHON_CONFIG PYTHON_PLATFORM PYTHON ax_libcrypto_spec_build_requires ax_libcrypto_spec_requires ax_libcrypto_pc_libs_private LIBCRYPTO_LIBADD LIBCRYPTO_CPPFLAGS LIBDL_LIBADD HAVE_OPENSSL_EVP_H openssl_LIBS openssl_CFLAGS ax_libcerror_spec_build_requires ax_libcerror_spec_requires ax_libcerror_pc_libs_private LIBCERROR_LIBADD LIBCERROR_CPPFLAGS HAVE_LOCAL_LIBCERROR_FALSE HAVE_LOCAL_LIBCERROR_TRUE HAVE_LOCAL_LIBCERROR HAVE_LIBCERROR libcerror_LIBS libcerror_CFLAGS PKG_CONFIG_LIBDIR PKG_CONFIG_PATH PKG_CONFIG HAVE_OFF64_T HAVE_SSIZE64_T HAVE_SIZE64_T HAVE_SSIZE32_T HAVE_SIZE32_T HAVE_WCHAR_H HAVE_STDINT_H HAVE_INTTYPES_H HAVE_SYS_TYPES_H HAVE_WIDE_CHARACTER_TYPE POSUB LTLIBINTL LIBINTL INTLLIBS LTLIBICONV LIBICONV INTL_MACOSX_LIBS XGETTEXT_EXTRA_OPTIONS MSGMERGE_FOR_MSGFMT_OPTION MSGMERGE XGETTEXT_015 XGETTEXT GMSGFMT_015 GMSGFMT MSGFMT GETTEXT_MACRO_VERSION USE_NLS PKGCONFIG LIBTOOL_DEPS CXXCPP am__fastdepCXX_FALSE am__fastdepCXX_TRUE CXXDEPMODE ac_ct_CXX CXXFLAGS CXX CPP LT_SYS_LIBRARY_PATH OTOOL64 OTOOL LIPO NMEDIT DSYMUTIL MANIFEST_TOOL RANLIB ac_ct_AR AR FILECMD LN_S NM ac_ct_DUMPBIN DUMPBIN LD FGREP EGREP GREP SED am__fastdepCC_FALSE am__fastdepCC_TRUE CCDEPMODE am__nodep AMDEPBACKSLASH AMDEP_FALSE AMDEP_TRUE am__include DEPDIR OBJEXT EXEEXT ac_ct_CC CPPFLAGS LDFLAGS CFLAGS CC LIBTOOL OBJDUMP DLLTOOL AS host_os host_vendor host_cpu host build_os build_vendor build_cpu build AM_BACKSLASH AM_DEFAULT_VERBOSITY AM_DEFAULT_V AM_V CSCOPE ETAGS CTAGS am__untar am__tar AMTAR am__leading_dot SET_MAKE AWK mkdir_p MKDIR_P INSTALL_STRIP_PROGRAM STRIP install_sh MAKEINFO AUTOHEADER AUTOMAKE AUTOCONF ACLOCAL VERSION PACKAGE CYGPATH_W am__isrc INSTALL_DATA INSTALL_SCRIPT INSTALL_PROGRAM target_alias host_alias build_alias LIBS ECHO_T ECHO_N ECHO_C DEFS mandir localedir libdir psdir pdfdir dvidir htmldir infodir docdir oldincludedir includedir runstatedir localstatedir sharedstatedir sysconfdir datadir datarootdir libexecdir sbindir bindir program_transform_name prefix exec_prefix PACKAGE_URL PACKAGE_BUGREPORT PACKAGE_STRING PACKAGE_VERSION PACKAGE_TARNAME PACKAGE_NAME PATH_SEPARATOR SHELL am__quote' ac_subst_files='' ac_user_opts=' enable_option_checking enable_silent_rules enable_shared enable_static with_pic enable_fast_install with_aix_soname enable_dependency_tracking with_gnu_ld with_sysroot enable_libtool_lock enable_nls enable_rpath with_libiconv_prefix with_libintl_prefix enable_largefile enable_shared_libs enable_winapi with_libcerror with_openssl enable_openssl_evp_cipher enable_openssl_evp_md with_pyprefix enable_python with_pythondir ' ac_precious_vars='build_alias host_alias target_alias CC CFLAGS LDFLAGS LIBS CPPFLAGS LT_SYS_LIBRARY_PATH CPP CXX CXXFLAGS CCC CXXCPP PKG_CONFIG PKG_CONFIG_PATH PKG_CONFIG_LIBDIR libcerror_CFLAGS libcerror_LIBS openssl_CFLAGS openssl_LIBS' # Initialize some variables set by options. ac_init_help= ac_init_version=false ac_unrecognized_opts= ac_unrecognized_sep= # The variables have the same names as the options, with # dashes changed to underlines. cache_file=/dev/null exec_prefix=NONE no_create= no_recursion= prefix=NONE program_prefix=NONE program_suffix=NONE program_transform_name=s,x,x, silent= site= srcdir= verbose= x_includes=NONE x_libraries=NONE # Installation directory options. # These are left unexpanded so users can "make install exec_prefix=/foo" # and all the variables that are supposed to be based on exec_prefix # by default will actually change. # Use braces instead of parens because sh, perl, etc. also accept them. # (The list follows the same order as the GNU Coding Standards.) bindir='${exec_prefix}/bin' sbindir='${exec_prefix}/sbin' libexecdir='${exec_prefix}/libexec' datarootdir='${prefix}/share' datadir='${datarootdir}' sysconfdir='${prefix}/etc' sharedstatedir='${prefix}/com' localstatedir='${prefix}/var' runstatedir='${localstatedir}/run' includedir='${prefix}/include' oldincludedir='/usr/include' docdir='${datarootdir}/doc/${PACKAGE_TARNAME}' infodir='${datarootdir}/info' htmldir='${docdir}' dvidir='${docdir}' pdfdir='${docdir}' psdir='${docdir}' libdir='${exec_prefix}/lib' localedir='${datarootdir}/locale' mandir='${datarootdir}/man' ac_prev= ac_dashdash= for ac_option do # If the previous option needs an argument, assign it. if test -n "$ac_prev"; then eval $ac_prev=\$ac_option ac_prev= continue fi case $ac_option in *=?*) ac_optarg=`expr "X$ac_option" : '[^=]*=\(.*\)'` ;; *=) ac_optarg= ;; *) ac_optarg=yes ;; esac case $ac_dashdash$ac_option in --) ac_dashdash=yes ;; -bindir | --bindir | --bindi | --bind | --bin | --bi) ac_prev=bindir ;; -bindir=* | --bindir=* | --bindi=* | --bind=* | --bin=* | --bi=*) bindir=$ac_optarg ;; -build | --build | --buil | --bui | --bu) ac_prev=build_alias ;; -build=* | --build=* | --buil=* | --bui=* | --bu=*) build_alias=$ac_optarg ;; -cache-file | --cache-file | --cache-fil | --cache-fi \ | --cache-f | --cache- | --cache | --cach | --cac | --ca | --c) ac_prev=cache_file ;; -cache-file=* | --cache-file=* | --cache-fil=* | --cache-fi=* \ | --cache-f=* | --cache-=* | --cache=* | --cach=* | --cac=* | --ca=* | --c=*) cache_file=$ac_optarg ;; --config-cache | -C) cache_file=config.cache ;; -datadir | --datadir | --datadi | --datad) ac_prev=datadir ;; -datadir=* | --datadir=* | --datadi=* | --datad=*) datadir=$ac_optarg ;; -datarootdir | --datarootdir | --datarootdi | --datarootd | --dataroot \ | --dataroo | --dataro | --datar) ac_prev=datarootdir ;; -datarootdir=* | --datarootdir=* | --datarootdi=* | --datarootd=* \ | --dataroot=* | --dataroo=* | --dataro=* | --datar=*) datarootdir=$ac_optarg ;; -disable-* | --disable-*) ac_useropt=`expr "x$ac_option" : 'x-*disable-\(.*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid feature name: \`$ac_useropt'" ac_useropt_orig=$ac_useropt ac_useropt=`printf "%s\n" "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "enable_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--disable-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval enable_$ac_useropt=no ;; -docdir | --docdir | --docdi | --doc | --do) ac_prev=docdir ;; -docdir=* | --docdir=* | --docdi=* | --doc=* | --do=*) docdir=$ac_optarg ;; -dvidir | --dvidir | --dvidi | --dvid | --dvi | --dv) ac_prev=dvidir ;; -dvidir=* | --dvidir=* | --dvidi=* | --dvid=* | --dvi=* | --dv=*) dvidir=$ac_optarg ;; -enable-* | --enable-*) ac_useropt=`expr "x$ac_option" : 'x-*enable-\([^=]*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid feature name: \`$ac_useropt'" ac_useropt_orig=$ac_useropt ac_useropt=`printf "%s\n" "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "enable_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--enable-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval enable_$ac_useropt=\$ac_optarg ;; -exec-prefix | --exec_prefix | --exec-prefix | --exec-prefi \ | --exec-pref | --exec-pre | --exec-pr | --exec-p | --exec- \ | --exec | --exe | --ex) ac_prev=exec_prefix ;; -exec-prefix=* | --exec_prefix=* | --exec-prefix=* | --exec-prefi=* \ | --exec-pref=* | --exec-pre=* | --exec-pr=* | --exec-p=* | --exec-=* \ | --exec=* | --exe=* | --ex=*) exec_prefix=$ac_optarg ;; -gas | --gas | --ga | --g) # Obsolete; use --with-gas. with_gas=yes ;; -help | --help | --hel | --he | -h) ac_init_help=long ;; -help=r* | --help=r* | --hel=r* | --he=r* | -hr*) ac_init_help=recursive ;; -help=s* | --help=s* | --hel=s* | --he=s* | -hs*) ac_init_help=short ;; -host | --host | --hos | --ho) ac_prev=host_alias ;; -host=* | --host=* | --hos=* | --ho=*) host_alias=$ac_optarg ;; -htmldir | --htmldir | --htmldi | --htmld | --html | --htm | --ht) ac_prev=htmldir ;; -htmldir=* | --htmldir=* | --htmldi=* | --htmld=* | --html=* | --htm=* \ | --ht=*) htmldir=$ac_optarg ;; -includedir | --includedir | --includedi | --included | --include \ | --includ | --inclu | --incl | --inc) ac_prev=includedir ;; -includedir=* | --includedir=* | --includedi=* | --included=* | --include=* \ | --includ=* | --inclu=* | --incl=* | --inc=*) includedir=$ac_optarg ;; -infodir | --infodir | --infodi | --infod | --info | --inf) ac_prev=infodir ;; -infodir=* | --infodir=* | --infodi=* | --infod=* | --info=* | --inf=*) infodir=$ac_optarg ;; -libdir | --libdir | --libdi | --libd) ac_prev=libdir ;; -libdir=* | --libdir=* | --libdi=* | --libd=*) libdir=$ac_optarg ;; -libexecdir | --libexecdir | --libexecdi | --libexecd | --libexec \ | --libexe | --libex | --libe) ac_prev=libexecdir ;; -libexecdir=* | --libexecdir=* | --libexecdi=* | --libexecd=* | --libexec=* \ | --libexe=* | --libex=* | --libe=*) libexecdir=$ac_optarg ;; -localedir | --localedir | --localedi | --localed | --locale) ac_prev=localedir ;; -localedir=* | --localedir=* | --localedi=* | --localed=* | --locale=*) localedir=$ac_optarg ;; -localstatedir | --localstatedir | --localstatedi | --localstated \ | --localstate | --localstat | --localsta | --localst | --locals) ac_prev=localstatedir ;; -localstatedir=* | --localstatedir=* | --localstatedi=* | --localstated=* \ | --localstate=* | --localstat=* | --localsta=* | --localst=* | --locals=*) localstatedir=$ac_optarg ;; -mandir | --mandir | --mandi | --mand | --man | --ma | --m) ac_prev=mandir ;; -mandir=* | --mandir=* | --mandi=* | --mand=* | --man=* | --ma=* | --m=*) mandir=$ac_optarg ;; -nfp | --nfp | --nf) # Obsolete; use --without-fp. with_fp=no ;; -no-create | --no-create | --no-creat | --no-crea | --no-cre \ | --no-cr | --no-c | -n) no_create=yes ;; -no-recursion | --no-recursion | --no-recursio | --no-recursi \ | --no-recurs | --no-recur | --no-recu | --no-rec | --no-re | --no-r) no_recursion=yes ;; -oldincludedir | --oldincludedir | --oldincludedi | --oldincluded \ | --oldinclude | --oldinclud | --oldinclu | --oldincl | --oldinc \ | --oldin | --oldi | --old | --ol | --o) ac_prev=oldincludedir ;; -oldincludedir=* | --oldincludedir=* | --oldincludedi=* | --oldincluded=* \ | --oldinclude=* | --oldinclud=* | --oldinclu=* | --oldincl=* | --oldinc=* \ | --oldin=* | --oldi=* | --old=* | --ol=* | --o=*) oldincludedir=$ac_optarg ;; -prefix | --prefix | --prefi | --pref | --pre | --pr | --p) ac_prev=prefix ;; -prefix=* | --prefix=* | --prefi=* | --pref=* | --pre=* | --pr=* | --p=*) prefix=$ac_optarg ;; -program-prefix | --program-prefix | --program-prefi | --program-pref \ | --program-pre | --program-pr | --program-p) ac_prev=program_prefix ;; -program-prefix=* | --program-prefix=* | --program-prefi=* \ | --program-pref=* | --program-pre=* | --program-pr=* | --program-p=*) program_prefix=$ac_optarg ;; -program-suffix | --program-suffix | --program-suffi | --program-suff \ | --program-suf | --program-su | --program-s) ac_prev=program_suffix ;; -program-suffix=* | --program-suffix=* | --program-suffi=* \ | --program-suff=* | --program-suf=* | --program-su=* | --program-s=*) program_suffix=$ac_optarg ;; -program-transform-name | --program-transform-name \ | --program-transform-nam | --program-transform-na \ | --program-transform-n | --program-transform- \ | --program-transform | --program-transfor \ | --program-transfo | --program-transf \ | --program-trans | --program-tran \ | --progr-tra | --program-tr | --program-t) ac_prev=program_transform_name ;; -program-transform-name=* | --program-transform-name=* \ | --program-transform-nam=* | --program-transform-na=* \ | --program-transform-n=* | --program-transform-=* \ | --program-transform=* | --program-transfor=* \ | --program-transfo=* | --program-transf=* \ | --program-trans=* | --program-tran=* \ | --progr-tra=* | --program-tr=* | --program-t=*) program_transform_name=$ac_optarg ;; -pdfdir | --pdfdir | --pdfdi | --pdfd | --pdf | --pd) ac_prev=pdfdir ;; -pdfdir=* | --pdfdir=* | --pdfdi=* | --pdfd=* | --pdf=* | --pd=*) pdfdir=$ac_optarg ;; -psdir | --psdir | --psdi | --psd | --ps) ac_prev=psdir ;; -psdir=* | --psdir=* | --psdi=* | --psd=* | --ps=*) psdir=$ac_optarg ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil) silent=yes ;; -runstatedir | --runstatedir | --runstatedi | --runstated \ | --runstate | --runstat | --runsta | --runst | --runs \ | --run | --ru | --r) ac_prev=runstatedir ;; -runstatedir=* | --runstatedir=* | --runstatedi=* | --runstated=* \ | --runstate=* | --runstat=* | --runsta=* | --runst=* | --runs=* \ | --run=* | --ru=* | --r=*) runstatedir=$ac_optarg ;; -sbindir | --sbindir | --sbindi | --sbind | --sbin | --sbi | --sb) ac_prev=sbindir ;; -sbindir=* | --sbindir=* | --sbindi=* | --sbind=* | --sbin=* \ | --sbi=* | --sb=*) sbindir=$ac_optarg ;; -sharedstatedir | --sharedstatedir | --sharedstatedi \ | --sharedstated | --sharedstate | --sharedstat | --sharedsta \ | --sharedst | --shareds | --shared | --share | --shar \ | --sha | --sh) ac_prev=sharedstatedir ;; -sharedstatedir=* | --sharedstatedir=* | --sharedstatedi=* \ | --sharedstated=* | --sharedstate=* | --sharedstat=* | --sharedsta=* \ | --sharedst=* | --shareds=* | --shared=* | --share=* | --shar=* \ | --sha=* | --sh=*) sharedstatedir=$ac_optarg ;; -site | --site | --sit) ac_prev=site ;; -site=* | --site=* | --sit=*) site=$ac_optarg ;; -srcdir | --srcdir | --srcdi | --srcd | --src | --sr) ac_prev=srcdir ;; -srcdir=* | --srcdir=* | --srcdi=* | --srcd=* | --src=* | --sr=*) srcdir=$ac_optarg ;; -sysconfdir | --sysconfdir | --sysconfdi | --sysconfd | --sysconf \ | --syscon | --sysco | --sysc | --sys | --sy) ac_prev=sysconfdir ;; -sysconfdir=* | --sysconfdir=* | --sysconfdi=* | --sysconfd=* | --sysconf=* \ | --syscon=* | --sysco=* | --sysc=* | --sys=* | --sy=*) sysconfdir=$ac_optarg ;; -target | --target | --targe | --targ | --tar | --ta | --t) ac_prev=target_alias ;; -target=* | --target=* | --targe=* | --targ=* | --tar=* | --ta=* | --t=*) target_alias=$ac_optarg ;; -v | -verbose | --verbose | --verbos | --verbo | --verb) verbose=yes ;; -version | --version | --versio | --versi | --vers | -V) ac_init_version=: ;; -with-* | --with-*) ac_useropt=`expr "x$ac_option" : 'x-*with-\([^=]*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid package name: \`$ac_useropt'" ac_useropt_orig=$ac_useropt ac_useropt=`printf "%s\n" "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "with_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--with-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval with_$ac_useropt=\$ac_optarg ;; -without-* | --without-*) ac_useropt=`expr "x$ac_option" : 'x-*without-\(.*\)'` # Reject names that are not valid shell variable names. expr "x$ac_useropt" : ".*[^-+._$as_cr_alnum]" >/dev/null && as_fn_error $? "invalid package name: \`$ac_useropt'" ac_useropt_orig=$ac_useropt ac_useropt=`printf "%s\n" "$ac_useropt" | sed 's/[-+.]/_/g'` case $ac_user_opts in *" "with_$ac_useropt" "*) ;; *) ac_unrecognized_opts="$ac_unrecognized_opts$ac_unrecognized_sep--without-$ac_useropt_orig" ac_unrecognized_sep=', ';; esac eval with_$ac_useropt=no ;; --x) # Obsolete; use --with-x. with_x=yes ;; -x-includes | --x-includes | --x-include | --x-includ | --x-inclu \ | --x-incl | --x-inc | --x-in | --x-i) ac_prev=x_includes ;; -x-includes=* | --x-includes=* | --x-include=* | --x-includ=* | --x-inclu=* \ | --x-incl=* | --x-inc=* | --x-in=* | --x-i=*) x_includes=$ac_optarg ;; -x-libraries | --x-libraries | --x-librarie | --x-librari \ | --x-librar | --x-libra | --x-libr | --x-lib | --x-li | --x-l) ac_prev=x_libraries ;; -x-libraries=* | --x-libraries=* | --x-librarie=* | --x-librari=* \ | --x-librar=* | --x-libra=* | --x-libr=* | --x-lib=* | --x-li=* | --x-l=*) x_libraries=$ac_optarg ;; -*) as_fn_error $? "unrecognized option: \`$ac_option' Try \`$0 --help' for more information" ;; *=*) ac_envvar=`expr "x$ac_option" : 'x\([^=]*\)='` # Reject names that are not valid shell variable names. case $ac_envvar in #( '' | [0-9]* | *[!_$as_cr_alnum]* ) as_fn_error $? "invalid variable name: \`$ac_envvar'" ;; esac eval $ac_envvar=\$ac_optarg export $ac_envvar ;; *) # FIXME: should be removed in autoconf 3.0. printf "%s\n" "$as_me: WARNING: you should use --build, --host, --target" >&2 expr "x$ac_option" : ".*[^-._$as_cr_alnum]" >/dev/null && printf "%s\n" "$as_me: WARNING: invalid host type: $ac_option" >&2 : "${build_alias=$ac_option} ${host_alias=$ac_option} ${target_alias=$ac_option}" ;; esac done if test -n "$ac_prev"; then ac_option=--`echo $ac_prev | sed 's/_/-/g'` as_fn_error $? "missing argument to $ac_option" fi if test -n "$ac_unrecognized_opts"; then case $enable_option_checking in no) ;; fatal) as_fn_error $? "unrecognized options: $ac_unrecognized_opts" ;; *) printf "%s\n" "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2 ;; esac fi # Check all directory arguments for consistency. for ac_var in exec_prefix prefix bindir sbindir libexecdir datarootdir \ datadir sysconfdir sharedstatedir localstatedir includedir \ oldincludedir docdir infodir htmldir dvidir pdfdir psdir \ libdir localedir mandir runstatedir do eval ac_val=\$$ac_var # Remove trailing slashes. case $ac_val in */ ) ac_val=`expr "X$ac_val" : 'X\(.*[^/]\)' \| "X$ac_val" : 'X\(.*\)'` eval $ac_var=\$ac_val;; esac # Be sure to have absolute directory names. case $ac_val in [\\/$]* | ?:[\\/]* ) continue;; NONE | '' ) case $ac_var in *prefix ) continue;; esac;; esac as_fn_error $? "expected an absolute directory name for --$ac_var: $ac_val" done # There might be people who depend on the old broken behavior: `$host' # used to hold the argument of --host etc. # FIXME: To remove some day. build=$build_alias host=$host_alias target=$target_alias # FIXME: To remove some day. if test "x$host_alias" != x; then if test "x$build_alias" = x; then cross_compiling=maybe elif test "x$build_alias" != "x$host_alias"; then cross_compiling=yes fi fi ac_tool_prefix= test -n "$host_alias" && ac_tool_prefix=$host_alias- test "$silent" = yes && exec 6>/dev/null ac_pwd=`pwd` && test -n "$ac_pwd" && ac_ls_di=`ls -di .` && ac_pwd_ls_di=`cd "$ac_pwd" && ls -di .` || as_fn_error $? "working directory cannot be determined" test "X$ac_ls_di" = "X$ac_pwd_ls_di" || as_fn_error $? "pwd does not report name of working directory" # Find the source files, if location was not specified. if test -z "$srcdir"; then ac_srcdir_defaulted=yes # Try the directory containing this script, then the parent directory. ac_confdir=`$as_dirname -- "$as_myself" || $as_expr X"$as_myself" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_myself" : 'X\(//\)[^/]' \| \ X"$as_myself" : 'X\(//\)$' \| \ X"$as_myself" : 'X\(/\)' \| . 2>/dev/null || printf "%s\n" X"$as_myself" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` srcdir=$ac_confdir if test ! -r "$srcdir/$ac_unique_file"; then srcdir=.. fi else ac_srcdir_defaulted=no fi if test ! -r "$srcdir/$ac_unique_file"; then test "$ac_srcdir_defaulted" = yes && srcdir="$ac_confdir or .." as_fn_error $? "cannot find sources ($ac_unique_file) in $srcdir" fi ac_msg="sources are in $srcdir, but \`cd $srcdir' does not work" ac_abs_confdir=`( cd "$srcdir" && test -r "./$ac_unique_file" || as_fn_error $? "$ac_msg" pwd)` # When building in place, set srcdir=. if test "$ac_abs_confdir" = "$ac_pwd"; then srcdir=. fi # Remove unnecessary trailing slashes from srcdir. # Double slashes in file names in object file debugging info # mess up M-x gdb in Emacs. case $srcdir in */) srcdir=`expr "X$srcdir" : 'X\(.*[^/]\)' \| "X$srcdir" : 'X\(.*\)'`;; esac for ac_var in $ac_precious_vars; do eval ac_env_${ac_var}_set=\${${ac_var}+set} eval ac_env_${ac_var}_value=\$${ac_var} eval ac_cv_env_${ac_var}_set=\${${ac_var}+set} eval ac_cv_env_${ac_var}_value=\$${ac_var} done # # Report the --help message. # if test "$ac_init_help" = "long"; then # Omit some internal or obsolete options to make the list less imposing. # This message is too long to be a string in the A/UX 3.1 sh. cat <<_ACEOF \`configure' configures libcaes 20240413 to adapt to many kinds of systems. Usage: $0 [OPTION]... [VAR=VALUE]... To assign environment variables (e.g., CC, CFLAGS...), specify them as VAR=VALUE. See below for descriptions of some of the useful variables. Defaults for the options are specified in brackets. Configuration: -h, --help display this help and exit --help=short display options specific to this package --help=recursive display the short help of all the included packages -V, --version display version information and exit -q, --quiet, --silent do not print \`checking ...' messages --cache-file=FILE cache test results in FILE [disabled] -C, --config-cache alias for \`--cache-file=config.cache' -n, --no-create do not create output files --srcdir=DIR find the sources in DIR [configure dir or \`..'] Installation directories: --prefix=PREFIX install architecture-independent files in PREFIX [$ac_default_prefix] --exec-prefix=EPREFIX install architecture-dependent files in EPREFIX [PREFIX] By default, \`make install' will install all the files in \`$ac_default_prefix/bin', \`$ac_default_prefix/lib' etc. You can specify an installation prefix other than \`$ac_default_prefix' using \`--prefix', for instance \`--prefix=\$HOME'. For better control, use the options below. Fine tuning of the installation directories: --bindir=DIR user executables [EPREFIX/bin] --sbindir=DIR system admin executables [EPREFIX/sbin] --libexecdir=DIR program executables [EPREFIX/libexec] --sysconfdir=DIR read-only single-machine data [PREFIX/etc] --sharedstatedir=DIR modifiable architecture-independent data [PREFIX/com] --localstatedir=DIR modifiable single-machine data [PREFIX/var] --runstatedir=DIR modifiable per-process data [LOCALSTATEDIR/run] --libdir=DIR object code libraries [EPREFIX/lib] --includedir=DIR C header files [PREFIX/include] --oldincludedir=DIR C header files for non-gcc [/usr/include] --datarootdir=DIR read-only arch.-independent data root [PREFIX/share] --datadir=DIR read-only architecture-independent data [DATAROOTDIR] --infodir=DIR info documentation [DATAROOTDIR/info] --localedir=DIR locale-dependent data [DATAROOTDIR/locale] --mandir=DIR man documentation [DATAROOTDIR/man] --docdir=DIR documentation root [DATAROOTDIR/doc/libcaes] --htmldir=DIR html documentation [DOCDIR] --dvidir=DIR dvi documentation [DOCDIR] --pdfdir=DIR pdf documentation [DOCDIR] --psdir=DIR ps documentation [DOCDIR] _ACEOF cat <<\_ACEOF Program names: --program-prefix=PREFIX prepend PREFIX to installed program names --program-suffix=SUFFIX append SUFFIX to installed program names --program-transform-name=PROGRAM run sed PROGRAM on installed program names System types: --build=BUILD configure for building on BUILD [guessed] --host=HOST cross-compile to build programs to run on HOST [BUILD] _ACEOF fi if test -n "$ac_init_help"; then case $ac_init_help in short | recursive ) echo "Configuration of libcaes 20240413:";; esac cat <<\_ACEOF Optional Features: --disable-option-checking ignore unrecognized --enable/--with options --disable-FEATURE do not include FEATURE (same as --enable-FEATURE=no) --enable-FEATURE[=ARG] include FEATURE [ARG=yes] --enable-silent-rules less verbose build output (undo: "make V=1") --disable-silent-rules verbose build output (undo: "make V=0") --enable-shared[=PKGS] build shared libraries [default=yes] --enable-static[=PKGS] build static libraries [default=yes] --enable-fast-install[=PKGS] optimize for fast installation [default=yes] --enable-dependency-tracking do not reject slow dependency extractors --disable-dependency-tracking speeds up one-time build --disable-libtool-lock avoid locking (might break parallel builds) --disable-nls do not use Native Language Support --disable-rpath do not hardcode runtime library paths --disable-largefile omit support for large files --disable-shared-libs disable shared library support --enable-winapi enable WINAPI support for cross-compilation [default=auto-detect] --enable-openssl-evp-cipher enable OpenSSL EVP CIPHER support, or no to disable [default=auto-detect] --enable-openssl-evp-md enable OpenSSL EVP MD support, or no to disable [default=auto-detect] --enable-python build Python bindings [default=no] Optional Packages: --with-PACKAGE[=ARG] use PACKAGE [ARG=yes] --without-PACKAGE do not use PACKAGE (same as --with-PACKAGE=no) --with-pic[=PKGS] try to use only PIC/non-PIC objects [default=use both] --with-aix-soname=aix|svr4|both shared library versioning (aka "SONAME") variant to provide on AIX, [default=aix]. --with-gnu-ld assume the C compiler uses GNU ld [default=no] --with-sysroot[=DIR] Search for dependent libraries within DIR (or the compiler's sysroot if not specified). --with-gnu-ld assume the C compiler uses GNU ld [default=no] --with-libiconv-prefix[=DIR] search for libiconv in DIR/include and DIR/lib --without-libiconv-prefix don't search for libiconv in includedir and libdir --with-libintl-prefix[=DIR] search for libintl in DIR/include and DIR/lib --without-libintl-prefix don't search for libintl in includedir and libdir --with-libcerror[=DIR] search for libcerror in includedir and libdir or in the specified DIR, or no if to use local version [default=auto-detect] --with-openssl[=DIR] search for OpenSSL in includedir and libdir or in the specified DIR, or no if not to use OpenSSL [default=auto-detect] --with-pyprefix[=no] use `python-config --prefix' to determine the prefix of pythondir instead of --prefix [default=no] --with-pythondir[=no] use to specify the Python directory (pythondir) [default=no] Some influential environment variables: CC C compiler command CFLAGS C compiler flags LDFLAGS linker flags, e.g. -L if you have libraries in a nonstandard directory LIBS libraries to pass to the linker, e.g. -l CPPFLAGS (Objective) C/C++ preprocessor flags, e.g. -I if you have headers in a nonstandard directory LT_SYS_LIBRARY_PATH User-defined run-time library search path. CPP C preprocessor CXX C++ compiler command CXXFLAGS C++ compiler flags CXXCPP C++ preprocessor PKG_CONFIG path to pkg-config utility PKG_CONFIG_PATH directories to add to pkg-config's search path PKG_CONFIG_LIBDIR path overriding pkg-config's built-in search path libcerror_CFLAGS C compiler flags for libcerror, overriding pkg-config libcerror_LIBS linker flags for libcerror, overriding pkg-config openssl_CFLAGS C compiler flags for openssl, overriding pkg-config openssl_LIBS linker flags for openssl, overriding pkg-config Use these variables to override the choices made by `configure' or to help it to find libraries and programs with nonstandard names/locations. Report bugs to . _ACEOF ac_status=$? fi if test "$ac_init_help" = "recursive"; then # If there are subdirs, report their specific --help. for ac_dir in : $ac_subdirs_all; do test "x$ac_dir" = x: && continue test -d "$ac_dir" || { cd "$srcdir" && ac_pwd=`pwd` && srcdir=. && test -d "$ac_dir"; } || continue ac_builddir=. case "$ac_dir" in .) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_dir_suffix=/`printf "%s\n" "$ac_dir" | sed 's|^\.[\\/]||'` # A ".." for each directory in $ac_dir_suffix. ac_top_builddir_sub=`printf "%s\n" "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` case $ac_top_builddir_sub in "") ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; esac ;; esac ac_abs_top_builddir=$ac_pwd ac_abs_builddir=$ac_pwd$ac_dir_suffix # for backward compatibility: ac_top_builddir=$ac_top_build_prefix case $srcdir in .) # We are building in place. ac_srcdir=. ac_top_srcdir=$ac_top_builddir_sub ac_abs_top_srcdir=$ac_pwd ;; [\\/]* | ?:[\\/]* ) # Absolute name. ac_srcdir=$srcdir$ac_dir_suffix; ac_top_srcdir=$srcdir ac_abs_top_srcdir=$srcdir ;; *) # Relative name. ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix ac_top_srcdir=$ac_top_build_prefix$srcdir ac_abs_top_srcdir=$ac_pwd/$srcdir ;; esac ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix cd "$ac_dir" || { ac_status=$?; continue; } # Check for configure.gnu first; this name is used for a wrapper for # Metaconfig's "Configure" on case-insensitive file systems. if test -f "$ac_srcdir/configure.gnu"; then echo && $SHELL "$ac_srcdir/configure.gnu" --help=recursive elif test -f "$ac_srcdir/configure"; then echo && $SHELL "$ac_srcdir/configure" --help=recursive else printf "%s\n" "$as_me: WARNING: no configuration information is in $ac_dir" >&2 fi || ac_status=$? cd "$ac_pwd" || { ac_status=$?; break; } done fi test -n "$ac_init_help" && exit $ac_status if $ac_init_version; then cat <<\_ACEOF libcaes configure 20240413 generated by GNU Autoconf 2.71 Copyright (C) 2021 Free Software Foundation, Inc. This configure script is free software; the Free Software Foundation gives unlimited permission to copy, distribute and modify it. _ACEOF exit fi ## ------------------------ ## ## Autoconf initialization. ## ## ------------------------ ## # ac_fn_c_try_compile LINENO # -------------------------- # Try to compile conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_compile () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext conftest.beam if { { ac_try="$ac_compile" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_compile") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_c_werror_flag" || test ! -s conftest.err } && test -s conftest.$ac_objext then : ac_retval=0 else $as_nop printf "%s\n" "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_compile # ac_fn_c_try_link LINENO # ----------------------- # Try to link conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_link () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext conftest.beam conftest$ac_exeext if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_link") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_c_werror_flag" || test ! -s conftest.err } && test -s conftest$ac_exeext && { test "$cross_compiling" = yes || test -x conftest$ac_exeext } then : ac_retval=0 else $as_nop printf "%s\n" "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi # Delete the IPA/IPO (Inter Procedural Analysis/Optimization) information # created by the PGI compiler (conftest_ipa8_conftest.oo), as it would # interfere with the next link command; also delete a directory that is # left behind by Apple's compiler. We do this before executing the actions. rm -rf conftest.dSYM conftest_ipa8_conftest.oo eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_link # ac_fn_c_check_header_compile LINENO HEADER VAR INCLUDES # ------------------------------------------------------- # Tests whether HEADER exists and can be compiled using the include files in # INCLUDES, setting the cache variable VAR accordingly. ac_fn_c_check_header_compile () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 printf %s "checking for $2... " >&6; } if eval test \${$3+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 #include <$2> _ACEOF if ac_fn_c_try_compile "$LINENO" then : eval "$3=yes" else $as_nop eval "$3=no" fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi eval ac_res=\$$3 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 printf "%s\n" "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_check_header_compile # ac_fn_c_check_func LINENO FUNC VAR # ---------------------------------- # Tests whether FUNC exists, setting the cache variable VAR accordingly ac_fn_c_check_func () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 printf %s "checking for $2... " >&6; } if eval test \${$3+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Define $2 to an innocuous variant, in case declares $2. For example, HP-UX 11i declares gettimeofday. */ #define $2 innocuous_$2 /* System header to define __stub macros and hopefully few prototypes, which can conflict with char $2 (); below. */ #include #undef $2 /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ #ifdef __cplusplus extern "C" #endif char $2 (); /* The GNU C library defines this for functions which it implements to always fail with ENOSYS. Some functions are actually named something starting with __ and the normal name is an alias. */ #if defined __stub_$2 || defined __stub___$2 choke me #endif int main (void) { return $2 (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : eval "$3=yes" else $as_nop eval "$3=no" fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext fi eval ac_res=\$$3 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 printf "%s\n" "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_check_func # ac_fn_c_try_cpp LINENO # ---------------------- # Try to preprocess conftest.$ac_ext, and return whether this succeeded. ac_fn_c_try_cpp () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if { { ac_try="$ac_cpp conftest.$ac_ext" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_cpp conftest.$ac_ext") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } > conftest.i && { test -z "$ac_c_preproc_warn_flag$ac_c_werror_flag" || test ! -s conftest.err } then : ac_retval=0 else $as_nop printf "%s\n" "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_cpp # ac_fn_cxx_try_compile LINENO # ---------------------------- # Try to compile conftest.$ac_ext, and return whether this succeeded. ac_fn_cxx_try_compile () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext conftest.beam if { { ac_try="$ac_compile" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_compile") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_cxx_werror_flag" || test ! -s conftest.err } && test -s conftest.$ac_objext then : ac_retval=0 else $as_nop printf "%s\n" "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_compile # ac_fn_cxx_try_cpp LINENO # ------------------------ # Try to preprocess conftest.$ac_ext, and return whether this succeeded. ac_fn_cxx_try_cpp () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if { { ac_try="$ac_cpp conftest.$ac_ext" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_cpp conftest.$ac_ext") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } > conftest.i && { test -z "$ac_cxx_preproc_warn_flag$ac_cxx_werror_flag" || test ! -s conftest.err } then : ac_retval=0 else $as_nop printf "%s\n" "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_cpp # ac_fn_cxx_try_link LINENO # ------------------------- # Try to link conftest.$ac_ext, and return whether this succeeded. ac_fn_cxx_try_link () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack rm -f conftest.$ac_objext conftest.beam conftest$ac_exeext if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_link") 2>conftest.err ac_status=$? if test -s conftest.err; then grep -v '^ *+' conftest.err >conftest.er1 cat conftest.er1 >&5 mv -f conftest.er1 conftest.err fi printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { test -z "$ac_cxx_werror_flag" || test ! -s conftest.err } && test -s conftest$ac_exeext && { test "$cross_compiling" = yes || test -x conftest$ac_exeext } then : ac_retval=0 else $as_nop printf "%s\n" "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=1 fi # Delete the IPA/IPO (Inter Procedural Analysis/Optimization) information # created by the PGI compiler (conftest_ipa8_conftest.oo), as it would # interfere with the next link command; also delete a directory that is # left behind by Apple's compiler. We do this before executing the actions. rm -rf conftest.dSYM conftest_ipa8_conftest.oo eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_cxx_try_link # ac_fn_c_try_run LINENO # ---------------------- # Try to run conftest.$ac_ext, and return whether this succeeded. Assumes that # executables *can* be run. ac_fn_c_try_run () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && { ac_try='./conftest$ac_exeext' { { case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_try") 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; } then : ac_retval=0 else $as_nop printf "%s\n" "$as_me: program exited with status $ac_status" >&5 printf "%s\n" "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 ac_retval=$ac_status fi rm -rf conftest.dSYM conftest_ipa8_conftest.oo eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno as_fn_set_status $ac_retval } # ac_fn_c_try_run # ac_fn_c_check_type LINENO TYPE VAR INCLUDES # ------------------------------------------- # Tests whether TYPE exists after having included INCLUDES, setting cache # variable VAR accordingly. ac_fn_c_check_type () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $2" >&5 printf %s "checking for $2... " >&6; } if eval test \${$3+y} then : printf %s "(cached) " >&6 else $as_nop eval "$3=no" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 int main (void) { if (sizeof ($2)) return 0; ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 int main (void) { if (sizeof (($2))) return 0; ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : else $as_nop eval "$3=yes" fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi eval ac_res=\$$3 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 printf "%s\n" "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_c_check_type # ac_fn_c_compute_int LINENO EXPR VAR INCLUDES # -------------------------------------------- # Tries to find the compile-time value of EXPR in a program that includes # INCLUDES, setting VAR accordingly. Returns whether the value could be # computed ac_fn_c_compute_int () { as_lineno=${as_lineno-"$1"} as_lineno_stack=as_lineno_stack=$as_lineno_stack if test "$cross_compiling" = yes; then # Depending upon the size, compute the lo and hi bounds. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 int main (void) { static int test_array [1 - 2 * !(($2) >= 0)]; test_array [0] = 0; return test_array [0]; ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_lo=0 ac_mid=0 while :; do cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 int main (void) { static int test_array [1 - 2 * !(($2) <= $ac_mid)]; test_array [0] = 0; return test_array [0]; ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_hi=$ac_mid; break else $as_nop as_fn_arith $ac_mid + 1 && ac_lo=$as_val if test $ac_lo -le $ac_mid; then ac_lo= ac_hi= break fi as_fn_arith 2 '*' $ac_mid + 1 && ac_mid=$as_val fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext done else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 int main (void) { static int test_array [1 - 2 * !(($2) < 0)]; test_array [0] = 0; return test_array [0]; ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_hi=-1 ac_mid=-1 while :; do cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 int main (void) { static int test_array [1 - 2 * !(($2) >= $ac_mid)]; test_array [0] = 0; return test_array [0]; ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_lo=$ac_mid; break else $as_nop as_fn_arith '(' $ac_mid ')' - 1 && ac_hi=$as_val if test $ac_mid -le $ac_hi; then ac_lo= ac_hi= break fi as_fn_arith 2 '*' $ac_mid && ac_mid=$as_val fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext done else $as_nop ac_lo= ac_hi= fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext # Binary search between lo and hi bounds. while test "x$ac_lo" != "x$ac_hi"; do as_fn_arith '(' $ac_hi - $ac_lo ')' / 2 + $ac_lo && ac_mid=$as_val cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 int main (void) { static int test_array [1 - 2 * !(($2) <= $ac_mid)]; test_array [0] = 0; return test_array [0]; ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_hi=$ac_mid else $as_nop as_fn_arith '(' $ac_mid ')' + 1 && ac_lo=$as_val fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext done case $ac_lo in #(( ?*) eval "$3=\$ac_lo"; ac_retval=0 ;; '') ac_retval=1 ;; esac else cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 static long int longval (void) { return $2; } static unsigned long int ulongval (void) { return $2; } #include #include int main (void) { FILE *f = fopen ("conftest.val", "w"); if (! f) return 1; if (($2) < 0) { long int i = longval (); if (i != ($2)) return 1; fprintf (f, "%ld", i); } else { unsigned long int i = ulongval (); if (i != ($2)) return 1; fprintf (f, "%lu", i); } /* Do not output a trailing newline, as this causes \r\n confusion on some platforms. */ return ferror (f) || fclose (f) != 0; ; return 0; } _ACEOF if ac_fn_c_try_run "$LINENO" then : echo >>conftest.val; read $3 &5 printf %s "checking whether $as_decl_name is declared... " >&6; } if eval test \${$3+y} then : printf %s "(cached) " >&6 else $as_nop as_decl_use=`echo $2|sed -e 's/(/((/' -e 's/)/) 0&/' -e 's/,/) 0& (/g'` eval ac_save_FLAGS=\$$6 as_fn_append $6 " $5" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $4 int main (void) { #ifndef $as_decl_name #ifdef __cplusplus (void) $as_decl_use; #else (void) $as_decl_name; #endif #endif ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : eval "$3=yes" else $as_nop eval "$3=no" fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext eval $6=\$ac_save_FLAGS fi eval ac_res=\$$3 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 printf "%s\n" "$ac_res" >&6; } eval $as_lineno_stack; ${as_lineno_stack:+:} unset as_lineno } # ac_fn_check_decl ac_configure_args_raw= for ac_arg do case $ac_arg in *\'*) ac_arg=`printf "%s\n" "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; esac as_fn_append ac_configure_args_raw " '$ac_arg'" done case $ac_configure_args_raw in *$as_nl*) ac_safe_unquote= ;; *) ac_unsafe_z='|&;<>()$`\\"*?[ '' ' # This string ends in space, tab. ac_unsafe_a="$ac_unsafe_z#~" ac_safe_unquote="s/ '\\([^$ac_unsafe_a][^$ac_unsafe_z]*\\)'/ \\1/g" ac_configure_args_raw=` printf "%s\n" "$ac_configure_args_raw" | sed "$ac_safe_unquote"`;; esac cat >config.log <<_ACEOF This file contains any messages produced by compilers while running configure, to aid debugging if configure makes a mistake. It was created by libcaes $as_me 20240413, which was generated by GNU Autoconf 2.71. Invocation command line was $ $0$ac_configure_args_raw _ACEOF exec 5>>config.log { cat <<_ASUNAME ## --------- ## ## Platform. ## ## --------- ## hostname = `(hostname || uname -n) 2>/dev/null | sed 1q` uname -m = `(uname -m) 2>/dev/null || echo unknown` uname -r = `(uname -r) 2>/dev/null || echo unknown` uname -s = `(uname -s) 2>/dev/null || echo unknown` uname -v = `(uname -v) 2>/dev/null || echo unknown` /usr/bin/uname -p = `(/usr/bin/uname -p) 2>/dev/null || echo unknown` /bin/uname -X = `(/bin/uname -X) 2>/dev/null || echo unknown` /bin/arch = `(/bin/arch) 2>/dev/null || echo unknown` /usr/bin/arch -k = `(/usr/bin/arch -k) 2>/dev/null || echo unknown` /usr/convex/getsysinfo = `(/usr/convex/getsysinfo) 2>/dev/null || echo unknown` /usr/bin/hostinfo = `(/usr/bin/hostinfo) 2>/dev/null || echo unknown` /bin/machine = `(/bin/machine) 2>/dev/null || echo unknown` /usr/bin/oslevel = `(/usr/bin/oslevel) 2>/dev/null || echo unknown` /bin/universe = `(/bin/universe) 2>/dev/null || echo unknown` _ASUNAME as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac printf "%s\n" "PATH: $as_dir" done IFS=$as_save_IFS } >&5 cat >&5 <<_ACEOF ## ----------- ## ## Core tests. ## ## ----------- ## _ACEOF # Keep a trace of the command line. # Strip out --no-create and --no-recursion so they do not pile up. # Strip out --silent because we don't want to record it for future runs. # Also quote any args containing shell meta-characters. # Make two passes to allow for proper duplicate-argument suppression. ac_configure_args= ac_configure_args0= ac_configure_args1= ac_must_keep_next=false for ac_pass in 1 2 do for ac_arg do case $ac_arg in -no-create | --no-c* | -n | -no-recursion | --no-r*) continue ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil) continue ;; *\'*) ac_arg=`printf "%s\n" "$ac_arg" | sed "s/'/'\\\\\\\\''/g"` ;; esac case $ac_pass in 1) as_fn_append ac_configure_args0 " '$ac_arg'" ;; 2) as_fn_append ac_configure_args1 " '$ac_arg'" if test $ac_must_keep_next = true; then ac_must_keep_next=false # Got value, back to normal. else case $ac_arg in *=* | --config-cache | -C | -disable-* | --disable-* \ | -enable-* | --enable-* | -gas | --g* | -nfp | --nf* \ | -q | -quiet | --q* | -silent | --sil* | -v | -verb* \ | -with-* | --with-* | -without-* | --without-* | --x) case "$ac_configure_args0 " in "$ac_configure_args1"*" '$ac_arg' "* ) continue ;; esac ;; -* ) ac_must_keep_next=true ;; esac fi as_fn_append ac_configure_args " '$ac_arg'" ;; esac done done { ac_configure_args0=; unset ac_configure_args0;} { ac_configure_args1=; unset ac_configure_args1;} # When interrupted or exit'd, cleanup temporary files, and complete # config.log. We remove comments because anyway the quotes in there # would cause problems or look ugly. # WARNING: Use '\'' to represent an apostrophe within the trap. # WARNING: Do not start the trap code with a newline, due to a FreeBSD 4.0 bug. trap 'exit_status=$? # Sanitize IFS. IFS=" "" $as_nl" # Save into config.log some information that might help in debugging. { echo printf "%s\n" "## ---------------- ## ## Cache variables. ## ## ---------------- ##" echo # The following way of writing the cache mishandles newlines in values, ( for ac_var in `(set) 2>&1 | sed -n '\''s/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'\''`; do eval ac_val=\$$ac_var case $ac_val in #( *${as_nl}*) case $ac_var in #( *_cv_*) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 printf "%s\n" "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; esac case $ac_var in #( _ | IFS | as_nl) ;; #( BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( *) { eval $ac_var=; unset $ac_var;} ;; esac ;; esac done (set) 2>&1 | case $as_nl`(ac_space='\'' '\''; set) 2>&1` in #( *${as_nl}ac_space=\ *) sed -n \ "s/'\''/'\''\\\\'\'''\''/g; s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\''\\2'\''/p" ;; #( *) sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" ;; esac | sort ) echo printf "%s\n" "## ----------------- ## ## Output variables. ## ## ----------------- ##" echo for ac_var in $ac_subst_vars do eval ac_val=\$$ac_var case $ac_val in *\'\''*) ac_val=`printf "%s\n" "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; esac printf "%s\n" "$ac_var='\''$ac_val'\''" done | sort echo if test -n "$ac_subst_files"; then printf "%s\n" "## ------------------- ## ## File substitutions. ## ## ------------------- ##" echo for ac_var in $ac_subst_files do eval ac_val=\$$ac_var case $ac_val in *\'\''*) ac_val=`printf "%s\n" "$ac_val" | sed "s/'\''/'\''\\\\\\\\'\'''\''/g"`;; esac printf "%s\n" "$ac_var='\''$ac_val'\''" done | sort echo fi if test -s confdefs.h; then printf "%s\n" "## ----------- ## ## confdefs.h. ## ## ----------- ##" echo cat confdefs.h echo fi test "$ac_signal" != 0 && printf "%s\n" "$as_me: caught signal $ac_signal" printf "%s\n" "$as_me: exit $exit_status" } >&5 rm -f core *.core core.conftest.* && rm -f -r conftest* confdefs* conf$$* $ac_clean_files && exit $exit_status ' 0 for ac_signal in 1 2 13 15; do trap 'ac_signal='$ac_signal'; as_fn_exit 1' $ac_signal done ac_signal=0 # confdefs.h avoids OS command line length limits that DEFS can exceed. rm -f -r conftest* confdefs.h printf "%s\n" "/* confdefs.h */" > confdefs.h # Predefined preprocessor variables. printf "%s\n" "#define PACKAGE_NAME \"$PACKAGE_NAME\"" >>confdefs.h printf "%s\n" "#define PACKAGE_TARNAME \"$PACKAGE_TARNAME\"" >>confdefs.h printf "%s\n" "#define PACKAGE_VERSION \"$PACKAGE_VERSION\"" >>confdefs.h printf "%s\n" "#define PACKAGE_STRING \"$PACKAGE_STRING\"" >>confdefs.h printf "%s\n" "#define PACKAGE_BUGREPORT \"$PACKAGE_BUGREPORT\"" >>confdefs.h printf "%s\n" "#define PACKAGE_URL \"$PACKAGE_URL\"" >>confdefs.h # Let the site file select an alternate cache file if it wants to. # Prefer an explicitly selected file to automatically selected ones. if test -n "$CONFIG_SITE"; then ac_site_files="$CONFIG_SITE" elif test "x$prefix" != xNONE; then ac_site_files="$prefix/share/config.site $prefix/etc/config.site" else ac_site_files="$ac_default_prefix/share/config.site $ac_default_prefix/etc/config.site" fi for ac_site_file in $ac_site_files do case $ac_site_file in #( */*) : ;; #( *) : ac_site_file=./$ac_site_file ;; esac if test -f "$ac_site_file" && test -r "$ac_site_file"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: loading site script $ac_site_file" >&5 printf "%s\n" "$as_me: loading site script $ac_site_file" >&6;} sed 's/^/| /' "$ac_site_file" >&5 . "$ac_site_file" \ || { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "failed to load site script $ac_site_file See \`config.log' for more details" "$LINENO" 5; } fi done if test -r "$cache_file"; then # Some versions of bash will fail to source /dev/null (special files # actually), so we avoid doing that. DJGPP emulates it as a regular file. if test /dev/null != "$cache_file" && test -f "$cache_file"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: loading cache $cache_file" >&5 printf "%s\n" "$as_me: loading cache $cache_file" >&6;} case $cache_file in [\\/]* | ?:[\\/]* ) . "$cache_file";; *) . "./$cache_file";; esac fi else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: creating cache $cache_file" >&5 printf "%s\n" "$as_me: creating cache $cache_file" >&6;} >$cache_file fi # Test code for whether the C compiler supports C89 (global declarations) ac_c_conftest_c89_globals=' /* Does the compiler advertise C89 conformance? Do not test the value of __STDC__, because some compilers set it to 0 while being otherwise adequately conformant. */ #if !defined __STDC__ # error "Compiler does not advertise C89 conformance" #endif #include #include struct stat; /* Most of the following tests are stolen from RCS 5.7 src/conf.sh. */ struct buf { int x; }; struct buf * (*rcsopen) (struct buf *, struct stat *, int); static char *e (p, i) char **p; int i; { return p[i]; } static char *f (char * (*g) (char **, int), char **p, ...) { char *s; va_list v; va_start (v,p); s = g (p, va_arg (v,int)); va_end (v); return s; } /* OSF 4.0 Compaq cc is some sort of almost-ANSI by default. It has function prototypes and stuff, but not \xHH hex character constants. These do not provoke an error unfortunately, instead are silently treated as an "x". The following induces an error, until -std is added to get proper ANSI mode. Curiously \x00 != x always comes out true, for an array size at least. It is necessary to write \x00 == 0 to get something that is true only with -std. */ int osf4_cc_array ['\''\x00'\'' == 0 ? 1 : -1]; /* IBM C 6 for AIX is almost-ANSI by default, but it replaces macro parameters inside strings and character constants. */ #define FOO(x) '\''x'\'' int xlc6_cc_array[FOO(a) == '\''x'\'' ? 1 : -1]; int test (int i, double x); struct s1 {int (*f) (int a);}; struct s2 {int (*f) (double a);}; int pairnames (int, char **, int *(*)(struct buf *, struct stat *, int), int, int);' # Test code for whether the C compiler supports C89 (body of main). ac_c_conftest_c89_main=' ok |= (argc == 0 || f (e, argv, 0) != argv[0] || f (e, argv, 1) != argv[1]); ' # Test code for whether the C compiler supports C99 (global declarations) ac_c_conftest_c99_globals=' // Does the compiler advertise C99 conformance? #if !defined __STDC_VERSION__ || __STDC_VERSION__ < 199901L # error "Compiler does not advertise C99 conformance" #endif #include extern int puts (const char *); extern int printf (const char *, ...); extern int dprintf (int, const char *, ...); extern void *malloc (size_t); // Check varargs macros. These examples are taken from C99 6.10.3.5. // dprintf is used instead of fprintf to avoid needing to declare // FILE and stderr. #define debug(...) dprintf (2, __VA_ARGS__) #define showlist(...) puts (#__VA_ARGS__) #define report(test,...) ((test) ? puts (#test) : printf (__VA_ARGS__)) static void test_varargs_macros (void) { int x = 1234; int y = 5678; debug ("Flag"); debug ("X = %d\n", x); showlist (The first, second, and third items.); report (x>y, "x is %d but y is %d", x, y); } // Check long long types. #define BIG64 18446744073709551615ull #define BIG32 4294967295ul #define BIG_OK (BIG64 / BIG32 == 4294967297ull && BIG64 % BIG32 == 0) #if !BIG_OK #error "your preprocessor is broken" #endif #if BIG_OK #else #error "your preprocessor is broken" #endif static long long int bignum = -9223372036854775807LL; static unsigned long long int ubignum = BIG64; struct incomplete_array { int datasize; double data[]; }; struct named_init { int number; const wchar_t *name; double average; }; typedef const char *ccp; static inline int test_restrict (ccp restrict text) { // See if C++-style comments work. // Iterate through items via the restricted pointer. // Also check for declarations in for loops. for (unsigned int i = 0; *(text+i) != '\''\0'\''; ++i) continue; return 0; } // Check varargs and va_copy. static bool test_varargs (const char *format, ...) { va_list args; va_start (args, format); va_list args_copy; va_copy (args_copy, args); const char *str = ""; int number = 0; float fnumber = 0; while (*format) { switch (*format++) { case '\''s'\'': // string str = va_arg (args_copy, const char *); break; case '\''d'\'': // int number = va_arg (args_copy, int); break; case '\''f'\'': // float fnumber = va_arg (args_copy, double); break; default: break; } } va_end (args_copy); va_end (args); return *str && number && fnumber; } ' # Test code for whether the C compiler supports C99 (body of main). ac_c_conftest_c99_main=' // Check bool. _Bool success = false; success |= (argc != 0); // Check restrict. if (test_restrict ("String literal") == 0) success = true; char *restrict newvar = "Another string"; // Check varargs. success &= test_varargs ("s, d'\'' f .", "string", 65, 34.234); test_varargs_macros (); // Check flexible array members. struct incomplete_array *ia = malloc (sizeof (struct incomplete_array) + (sizeof (double) * 10)); ia->datasize = 10; for (int i = 0; i < ia->datasize; ++i) ia->data[i] = i * 1.234; // Check named initializers. struct named_init ni = { .number = 34, .name = L"Test wide string", .average = 543.34343, }; ni.number = 58; int dynamic_array[ni.number]; dynamic_array[0] = argv[0][0]; dynamic_array[ni.number - 1] = 543; // work around unused variable warnings ok |= (!success || bignum == 0LL || ubignum == 0uLL || newvar[0] == '\''x'\'' || dynamic_array[ni.number - 1] != 543); ' # Test code for whether the C compiler supports C11 (global declarations) ac_c_conftest_c11_globals=' // Does the compiler advertise C11 conformance? #if !defined __STDC_VERSION__ || __STDC_VERSION__ < 201112L # error "Compiler does not advertise C11 conformance" #endif // Check _Alignas. char _Alignas (double) aligned_as_double; char _Alignas (0) no_special_alignment; extern char aligned_as_int; char _Alignas (0) _Alignas (int) aligned_as_int; // Check _Alignof. enum { int_alignment = _Alignof (int), int_array_alignment = _Alignof (int[100]), char_alignment = _Alignof (char) }; _Static_assert (0 < -_Alignof (int), "_Alignof is signed"); // Check _Noreturn. int _Noreturn does_not_return (void) { for (;;) continue; } // Check _Static_assert. struct test_static_assert { int x; _Static_assert (sizeof (int) <= sizeof (long int), "_Static_assert does not work in struct"); long int y; }; // Check UTF-8 literals. #define u8 syntax error! char const utf8_literal[] = u8"happens to be ASCII" "another string"; // Check duplicate typedefs. typedef long *long_ptr; typedef long int *long_ptr; typedef long_ptr long_ptr; // Anonymous structures and unions -- taken from C11 6.7.2.1 Example 1. struct anonymous { union { struct { int i; int j; }; struct { int k; long int l; } w; }; int m; } v1; ' # Test code for whether the C compiler supports C11 (body of main). ac_c_conftest_c11_main=' _Static_assert ((offsetof (struct anonymous, i) == offsetof (struct anonymous, w.k)), "Anonymous union alignment botch"); v1.i = 2; v1.w.k = 5; ok |= v1.i != 5; ' # Test code for whether the C compiler supports C11 (complete). ac_c_conftest_c11_program="${ac_c_conftest_c89_globals} ${ac_c_conftest_c99_globals} ${ac_c_conftest_c11_globals} int main (int argc, char **argv) { int ok = 0; ${ac_c_conftest_c89_main} ${ac_c_conftest_c99_main} ${ac_c_conftest_c11_main} return ok; } " # Test code for whether the C compiler supports C99 (complete). ac_c_conftest_c99_program="${ac_c_conftest_c89_globals} ${ac_c_conftest_c99_globals} int main (int argc, char **argv) { int ok = 0; ${ac_c_conftest_c89_main} ${ac_c_conftest_c99_main} return ok; } " # Test code for whether the C compiler supports C89 (complete). ac_c_conftest_c89_program="${ac_c_conftest_c89_globals} int main (int argc, char **argv) { int ok = 0; ${ac_c_conftest_c89_main} return ok; } " as_fn_append ac_header_c_list " stdio.h stdio_h HAVE_STDIO_H" as_fn_append ac_header_c_list " stdlib.h stdlib_h HAVE_STDLIB_H" as_fn_append ac_header_c_list " string.h string_h HAVE_STRING_H" as_fn_append ac_header_c_list " inttypes.h inttypes_h HAVE_INTTYPES_H" as_fn_append ac_header_c_list " stdint.h stdint_h HAVE_STDINT_H" as_fn_append ac_header_c_list " strings.h strings_h HAVE_STRINGS_H" as_fn_append ac_header_c_list " sys/stat.h sys_stat_h HAVE_SYS_STAT_H" as_fn_append ac_header_c_list " sys/types.h sys_types_h HAVE_SYS_TYPES_H" as_fn_append ac_header_c_list " unistd.h unistd_h HAVE_UNISTD_H" # Test code for whether the C++ compiler supports C++98 (global declarations) ac_cxx_conftest_cxx98_globals=' // Does the compiler advertise C++98 conformance? #if !defined __cplusplus || __cplusplus < 199711L # error "Compiler does not advertise C++98 conformance" #endif // These inclusions are to reject old compilers that // lack the unsuffixed header files. #include #include // and are *not* freestanding headers in C++98. extern void assert (int); namespace std { extern int strcmp (const char *, const char *); } // Namespaces, exceptions, and templates were all added after "C++ 2.0". using std::exception; using std::strcmp; namespace { void test_exception_syntax() { try { throw "test"; } catch (const char *s) { // Extra parentheses suppress a warning when building autoconf itself, // due to lint rules shared with more typical C programs. assert (!(strcmp) (s, "test")); } } template struct test_template { T const val; explicit test_template(T t) : val(t) {} template T add(U u) { return static_cast(u) + val; } }; } // anonymous namespace ' # Test code for whether the C++ compiler supports C++98 (body of main) ac_cxx_conftest_cxx98_main=' assert (argc); assert (! argv[0]); { test_exception_syntax (); test_template tt (2.0); assert (tt.add (4) == 6.0); assert (true && !false); } ' # Test code for whether the C++ compiler supports C++11 (global declarations) ac_cxx_conftest_cxx11_globals=' // Does the compiler advertise C++ 2011 conformance? #if !defined __cplusplus || __cplusplus < 201103L # error "Compiler does not advertise C++11 conformance" #endif namespace cxx11test { constexpr int get_val() { return 20; } struct testinit { int i; double d; }; class delegate { public: delegate(int n) : n(n) {} delegate(): delegate(2354) {} virtual int getval() { return this->n; }; protected: int n; }; class overridden : public delegate { public: overridden(int n): delegate(n) {} virtual int getval() override final { return this->n * 2; } }; class nocopy { public: nocopy(int i): i(i) {} nocopy() = default; nocopy(const nocopy&) = delete; nocopy & operator=(const nocopy&) = delete; private: int i; }; // for testing lambda expressions template Ret eval(Fn f, Ret v) { return f(v); } // for testing variadic templates and trailing return types template auto sum(V first) -> V { return first; } template auto sum(V first, Args... rest) -> V { return first + sum(rest...); } } ' # Test code for whether the C++ compiler supports C++11 (body of main) ac_cxx_conftest_cxx11_main=' { // Test auto and decltype auto a1 = 6538; auto a2 = 48573953.4; auto a3 = "String literal"; int total = 0; for (auto i = a3; *i; ++i) { total += *i; } decltype(a2) a4 = 34895.034; } { // Test constexpr short sa[cxx11test::get_val()] = { 0 }; } { // Test initializer lists cxx11test::testinit il = { 4323, 435234.23544 }; } { // Test range-based for int array[] = {9, 7, 13, 15, 4, 18, 12, 10, 5, 3, 14, 19, 17, 8, 6, 20, 16, 2, 11, 1}; for (auto &x : array) { x += 23; } } { // Test lambda expressions using cxx11test::eval; assert (eval ([](int x) { return x*2; }, 21) == 42); double d = 2.0; assert (eval ([&](double x) { return d += x; }, 3.0) == 5.0); assert (d == 5.0); assert (eval ([=](double x) mutable { return d += x; }, 4.0) == 9.0); assert (d == 5.0); } { // Test use of variadic templates using cxx11test::sum; auto a = sum(1); auto b = sum(1, 2); auto c = sum(1.0, 2.0, 3.0); } { // Test constructor delegation cxx11test::delegate d1; cxx11test::delegate d2(); cxx11test::delegate d3(45); } { // Test override and final cxx11test::overridden o1(55464); } { // Test nullptr char *c = nullptr; } { // Test template brackets test_template<::test_template> v(test_template(12)); } { // Unicode literals char const *utf8 = u8"UTF-8 string \u2500"; char16_t const *utf16 = u"UTF-8 string \u2500"; char32_t const *utf32 = U"UTF-32 string \u2500"; } ' # Test code for whether the C compiler supports C++11 (complete). ac_cxx_conftest_cxx11_program="${ac_cxx_conftest_cxx98_globals} ${ac_cxx_conftest_cxx11_globals} int main (int argc, char **argv) { int ok = 0; ${ac_cxx_conftest_cxx98_main} ${ac_cxx_conftest_cxx11_main} return ok; } " # Test code for whether the C compiler supports C++98 (complete). ac_cxx_conftest_cxx98_program="${ac_cxx_conftest_cxx98_globals} int main (int argc, char **argv) { int ok = 0; ${ac_cxx_conftest_cxx98_main} return ok; } " gt_needs="$gt_needs " # Auxiliary files required by this configure script. ac_aux_files="config.rpath compile ltmain.sh config.guess config.sub missing install-sh" # Locations in which to look for auxiliary files. ac_aux_dir_candidates="${srcdir}${PATH_SEPARATOR}${srcdir}/..${PATH_SEPARATOR}${srcdir}/../.." # Search for a directory containing all of the required auxiliary files, # $ac_aux_files, from the $PATH-style list $ac_aux_dir_candidates. # If we don't find one directory that contains all the files we need, # we report the set of missing files from the *first* directory in # $ac_aux_dir_candidates and give up. ac_missing_aux_files="" ac_first_candidate=: printf "%s\n" "$as_me:${as_lineno-$LINENO}: looking for aux files: $ac_aux_files" >&5 as_save_IFS=$IFS; IFS=$PATH_SEPARATOR as_found=false for as_dir in $ac_aux_dir_candidates do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac as_found=: printf "%s\n" "$as_me:${as_lineno-$LINENO}: trying $as_dir" >&5 ac_aux_dir_found=yes ac_install_sh= for ac_aux in $ac_aux_files do # As a special case, if "install-sh" is required, that requirement # can be satisfied by any of "install-sh", "install.sh", or "shtool", # and $ac_install_sh is set appropriately for whichever one is found. if test x"$ac_aux" = x"install-sh" then if test -f "${as_dir}install-sh"; then printf "%s\n" "$as_me:${as_lineno-$LINENO}: ${as_dir}install-sh found" >&5 ac_install_sh="${as_dir}install-sh -c" elif test -f "${as_dir}install.sh"; then printf "%s\n" "$as_me:${as_lineno-$LINENO}: ${as_dir}install.sh found" >&5 ac_install_sh="${as_dir}install.sh -c" elif test -f "${as_dir}shtool"; then printf "%s\n" "$as_me:${as_lineno-$LINENO}: ${as_dir}shtool found" >&5 ac_install_sh="${as_dir}shtool install -c" else ac_aux_dir_found=no if $ac_first_candidate; then ac_missing_aux_files="${ac_missing_aux_files} install-sh" else break fi fi else if test -f "${as_dir}${ac_aux}"; then printf "%s\n" "$as_me:${as_lineno-$LINENO}: ${as_dir}${ac_aux} found" >&5 else ac_aux_dir_found=no if $ac_first_candidate; then ac_missing_aux_files="${ac_missing_aux_files} ${ac_aux}" else break fi fi fi done if test "$ac_aux_dir_found" = yes; then ac_aux_dir="$as_dir" break fi ac_first_candidate=false as_found=false done IFS=$as_save_IFS if $as_found then : else $as_nop as_fn_error $? "cannot find required auxiliary files:$ac_missing_aux_files" "$LINENO" 5 fi # These three variables are undocumented and unsupported, # and are intended to be withdrawn in a future Autoconf release. # They can cause serious problems if a builder's source tree is in a directory # whose full name contains unusual characters. if test -f "${ac_aux_dir}config.guess"; then ac_config_guess="$SHELL ${ac_aux_dir}config.guess" fi if test -f "${ac_aux_dir}config.sub"; then ac_config_sub="$SHELL ${ac_aux_dir}config.sub" fi if test -f "$ac_aux_dir/configure"; then ac_configure="$SHELL ${ac_aux_dir}configure" fi # Check that the precious variables saved in the cache have kept the same # value. ac_cache_corrupted=false for ac_var in $ac_precious_vars; do eval ac_old_set=\$ac_cv_env_${ac_var}_set eval ac_new_set=\$ac_env_${ac_var}_set eval ac_old_val=\$ac_cv_env_${ac_var}_value eval ac_new_val=\$ac_env_${ac_var}_value case $ac_old_set,$ac_new_set in set,) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&5 printf "%s\n" "$as_me: error: \`$ac_var' was set to \`$ac_old_val' in the previous run" >&2;} ac_cache_corrupted=: ;; ,set) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' was not set in the previous run" >&5 printf "%s\n" "$as_me: error: \`$ac_var' was not set in the previous run" >&2;} ac_cache_corrupted=: ;; ,);; *) if test "x$ac_old_val" != "x$ac_new_val"; then # differences in whitespace do not lead to failure. ac_old_val_w=`echo x $ac_old_val` ac_new_val_w=`echo x $ac_new_val` if test "$ac_old_val_w" != "$ac_new_val_w"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: \`$ac_var' has changed since the previous run:" >&5 printf "%s\n" "$as_me: error: \`$ac_var' has changed since the previous run:" >&2;} ac_cache_corrupted=: else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&5 printf "%s\n" "$as_me: warning: ignoring whitespace changes in \`$ac_var' since the previous run:" >&2;} eval $ac_var=\$ac_old_val fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: former value: \`$ac_old_val'" >&5 printf "%s\n" "$as_me: former value: \`$ac_old_val'" >&2;} { printf "%s\n" "$as_me:${as_lineno-$LINENO}: current value: \`$ac_new_val'" >&5 printf "%s\n" "$as_me: current value: \`$ac_new_val'" >&2;} fi;; esac # Pass precious variables to config.status. if test "$ac_new_set" = set; then case $ac_new_val in *\'*) ac_arg=$ac_var=`printf "%s\n" "$ac_new_val" | sed "s/'/'\\\\\\\\''/g"` ;; *) ac_arg=$ac_var=$ac_new_val ;; esac case " $ac_configure_args " in *" '$ac_arg' "*) ;; # Avoid dups. Use of quotes ensures accuracy. *) as_fn_append ac_configure_args " '$ac_arg'" ;; esac fi done if $ac_cache_corrupted; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: changes in the environment can compromise the build" >&5 printf "%s\n" "$as_me: error: changes in the environment can compromise the build" >&2;} as_fn_error $? "run \`${MAKE-make} distclean' and/or \`rm $cache_file' and start over" "$LINENO" 5 fi ## -------------------- ## ## Main body of script. ## ## -------------------- ## ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu am__api_version='1.16' # Find a good install program. We prefer a C program (faster), # so one script is as good as another. But avoid the broken or # incompatible versions: # SysV /etc/install, /usr/sbin/install # SunOS /usr/etc/install # IRIX /sbin/install # AIX /bin/install # AmigaOS /C/install, which installs bootblocks on floppy discs # AIX 4 /usr/bin/installbsd, which doesn't work without a -g flag # AFS /usr/afsws/bin/install, which mishandles nonexistent args # SVR4 /usr/ucb/install, which tries to use the nonexistent group "staff" # OS/2's system install, which has a completely different semantic # ./install, which can be erroneously created by make from ./install.sh. # Reject install programs that cannot install multiple files. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for a BSD-compatible install" >&5 printf %s "checking for a BSD-compatible install... " >&6; } if test -z "$INSTALL"; then if test ${ac_cv_path_install+y} then : printf %s "(cached) " >&6 else $as_nop as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac # Account for fact that we put trailing slashes in our PATH walk. case $as_dir in #(( ./ | /[cC]/* | \ /etc/* | /usr/sbin/* | /usr/etc/* | /sbin/* | /usr/afsws/bin/* | \ ?:[\\/]os2[\\/]install[\\/]* | ?:[\\/]OS2[\\/]INSTALL[\\/]* | \ /usr/ucb/* ) ;; *) # OSF1 and SCO ODT 3.0 have their own names for install. # Don't use installbsd from OSF since it installs stuff as root # by default. for ac_prog in ginstall scoinst install; do for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_prog$ac_exec_ext"; then if test $ac_prog = install && grep dspmsg "$as_dir$ac_prog$ac_exec_ext" >/dev/null 2>&1; then # AIX install. It has an incompatible calling convention. : elif test $ac_prog = install && grep pwplus "$as_dir$ac_prog$ac_exec_ext" >/dev/null 2>&1; then # program-specific install script used by HP pwplus--don't use. : else rm -rf conftest.one conftest.two conftest.dir echo one > conftest.one echo two > conftest.two mkdir conftest.dir if "$as_dir$ac_prog$ac_exec_ext" -c conftest.one conftest.two "`pwd`/conftest.dir/" && test -s conftest.one && test -s conftest.two && test -s conftest.dir/conftest.one && test -s conftest.dir/conftest.two then ac_cv_path_install="$as_dir$ac_prog$ac_exec_ext -c" break 3 fi fi fi done done ;; esac done IFS=$as_save_IFS rm -rf conftest.one conftest.two conftest.dir fi if test ${ac_cv_path_install+y}; then INSTALL=$ac_cv_path_install else # As a last resort, use the slow shell script. Don't cache a # value for INSTALL within a source directory, because that will # break other packages using the cache if that directory is # removed, or if the value is a relative name. INSTALL=$ac_install_sh fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $INSTALL" >&5 printf "%s\n" "$INSTALL" >&6; } # Use test -z because SunOS4 sh mishandles braces in ${var-val}. # It thinks the first close brace ends the variable substitution. test -z "$INSTALL_PROGRAM" && INSTALL_PROGRAM='${INSTALL}' test -z "$INSTALL_SCRIPT" && INSTALL_SCRIPT='${INSTALL}' test -z "$INSTALL_DATA" && INSTALL_DATA='${INSTALL} -m 644' { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether build environment is sane" >&5 printf %s "checking whether build environment is sane... " >&6; } # Reject unsafe characters in $srcdir or the absolute working directory # name. Accept space and tab only in the latter. am_lf=' ' case `pwd` in *[\\\"\#\$\&\'\`$am_lf]*) as_fn_error $? "unsafe absolute working directory name" "$LINENO" 5;; esac case $srcdir in *[\\\"\#\$\&\'\`$am_lf\ \ ]*) as_fn_error $? "unsafe srcdir value: '$srcdir'" "$LINENO" 5;; esac # Do 'set' in a subshell so we don't clobber the current shell's # arguments. Must try -L first in case configure is actually a # symlink; some systems play weird games with the mod time of symlinks # (eg FreeBSD returns the mod time of the symlink's containing # directory). if ( am_has_slept=no for am_try in 1 2; do echo "timestamp, slept: $am_has_slept" > conftest.file set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` if test "$*" = "X"; then # -L didn't work. set X `ls -t "$srcdir/configure" conftest.file` fi if test "$*" != "X $srcdir/configure conftest.file" \ && test "$*" != "X conftest.file $srcdir/configure"; then # If neither matched, then we have a broken ls. This can happen # if, for instance, CONFIG_SHELL is bash and it inherits a # broken ls alias from the environment. This has actually # happened. Such a system could not be considered "sane". as_fn_error $? "ls -t appears to fail. Make sure there is not a broken alias in your environment" "$LINENO" 5 fi if test "$2" = conftest.file || test $am_try -eq 2; then break fi # Just in case. sleep 1 am_has_slept=yes done test "$2" = conftest.file ) then # Ok. : else as_fn_error $? "newly created file is older than distributed files! Check your system clock" "$LINENO" 5 fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } # If we didn't sleep, we still need to ensure time stamps of config.status and # generated files are strictly newer. am_sleep_pid= if grep 'slept: no' conftest.file >/dev/null 2>&1; then ( sleep 1 ) & am_sleep_pid=$! fi rm -f conftest.file test "$program_prefix" != NONE && program_transform_name="s&^&$program_prefix&;$program_transform_name" # Use a double $ so make ignores it. test "$program_suffix" != NONE && program_transform_name="s&\$&$program_suffix&;$program_transform_name" # Double any \ or $. # By default was `s,x,x', remove it if useless. ac_script='s/[\\$]/&&/g;s/;s,x,x,$//' program_transform_name=`printf "%s\n" "$program_transform_name" | sed "$ac_script"` # Expand $ac_aux_dir to an absolute path. am_aux_dir=`cd "$ac_aux_dir" && pwd` if test x"${MISSING+set}" != xset; then MISSING="\${SHELL} '$am_aux_dir/missing'" fi # Use eval to expand $SHELL if eval "$MISSING --is-lightweight"; then am_missing_run="$MISSING " else am_missing_run= { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: 'missing' script is too old or missing" >&5 printf "%s\n" "$as_me: WARNING: 'missing' script is too old or missing" >&2;} fi if test x"${install_sh+set}" != xset; then case $am_aux_dir in *\ * | *\ *) install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; *) install_sh="\${SHELL} $am_aux_dir/install-sh" esac fi # Installed binaries are usually stripped using 'strip' when the user # run "make install-strip". However 'strip' might not be the right # tool to use in cross-compilation environments, therefore Automake # will honor the 'STRIP' environment variable to overrule this program. if test "$cross_compiling" != no; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. set dummy ${ac_tool_prefix}strip; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_STRIP+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$STRIP"; then ac_cv_prog_STRIP="$STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_STRIP="${ac_tool_prefix}strip" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi STRIP=$ac_cv_prog_STRIP if test -n "$STRIP"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $STRIP" >&5 printf "%s\n" "$STRIP" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_STRIP"; then ac_ct_STRIP=$STRIP # Extract the first word of "strip", so it can be a program name with args. set dummy strip; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_STRIP+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_STRIP"; then ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_STRIP="strip" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP if test -n "$ac_ct_STRIP"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_STRIP" >&5 printf "%s\n" "$ac_ct_STRIP" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_STRIP" = x; then STRIP=":" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac STRIP=$ac_ct_STRIP fi else STRIP="$ac_cv_prog_STRIP" fi fi INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for a race-free mkdir -p" >&5 printf %s "checking for a race-free mkdir -p... " >&6; } if test -z "$MKDIR_P"; then if test ${ac_cv_path_mkdir+y} then : printf %s "(cached) " >&6 else $as_nop as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/opt/sfw/bin do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_prog in mkdir gmkdir; do for ac_exec_ext in '' $ac_executable_extensions; do as_fn_executable_p "$as_dir$ac_prog$ac_exec_ext" || continue case `"$as_dir$ac_prog$ac_exec_ext" --version 2>&1` in #( 'mkdir ('*'coreutils) '* | \ 'BusyBox '* | \ 'mkdir (fileutils) '4.1*) ac_cv_path_mkdir=$as_dir$ac_prog$ac_exec_ext break 3;; esac done done done IFS=$as_save_IFS fi test -d ./--version && rmdir ./--version if test ${ac_cv_path_mkdir+y}; then MKDIR_P="$ac_cv_path_mkdir -p" else # As a last resort, use the slow shell script. Don't cache a # value for MKDIR_P within a source directory, because that will # break other packages using the cache if that directory is # removed, or if the value is a relative name. MKDIR_P="$ac_install_sh -d" fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $MKDIR_P" >&5 printf "%s\n" "$MKDIR_P" >&6; } for ac_prog in gawk mawk nawk awk do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_AWK+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$AWK"; then ac_cv_prog_AWK="$AWK" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_AWK="$ac_prog" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi AWK=$ac_cv_prog_AWK if test -n "$AWK"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $AWK" >&5 printf "%s\n" "$AWK" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -n "$AWK" && break done { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} sets \$(MAKE)" >&5 printf %s "checking whether ${MAKE-make} sets \$(MAKE)... " >&6; } set x ${MAKE-make} ac_make=`printf "%s\n" "$2" | sed 's/+/p/g; s/[^a-zA-Z0-9_]/_/g'` if eval test \${ac_cv_prog_make_${ac_make}_set+y} then : printf %s "(cached) " >&6 else $as_nop cat >conftest.make <<\_ACEOF SHELL = /bin/sh all: @echo '@@@%%%=$(MAKE)=@@@%%%' _ACEOF # GNU make sometimes prints "make[1]: Entering ...", which would confuse us. case `${MAKE-make} -f conftest.make 2>/dev/null` in *@@@%%%=?*=@@@%%%*) eval ac_cv_prog_make_${ac_make}_set=yes;; *) eval ac_cv_prog_make_${ac_make}_set=no;; esac rm -f conftest.make fi if eval test \$ac_cv_prog_make_${ac_make}_set = yes; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } SET_MAKE= else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } SET_MAKE="MAKE=${MAKE-make}" fi rm -rf .tst 2>/dev/null mkdir .tst 2>/dev/null if test -d .tst; then am__leading_dot=. else am__leading_dot=_ fi rmdir .tst 2>/dev/null # Check whether --enable-silent-rules was given. if test ${enable_silent_rules+y} then : enableval=$enable_silent_rules; fi case $enable_silent_rules in # ((( yes) AM_DEFAULT_VERBOSITY=0;; no) AM_DEFAULT_VERBOSITY=1;; *) AM_DEFAULT_VERBOSITY=1;; esac am_make=${MAKE-make} { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether $am_make supports nested variables" >&5 printf %s "checking whether $am_make supports nested variables... " >&6; } if test ${am_cv_make_support_nested_variables+y} then : printf %s "(cached) " >&6 else $as_nop if printf "%s\n" 'TRUE=$(BAR$(V)) BAR0=false BAR1=true V=1 am__doit: @$(TRUE) .PHONY: am__doit' | $am_make -f - >/dev/null 2>&1; then am_cv_make_support_nested_variables=yes else am_cv_make_support_nested_variables=no fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $am_cv_make_support_nested_variables" >&5 printf "%s\n" "$am_cv_make_support_nested_variables" >&6; } if test $am_cv_make_support_nested_variables = yes; then AM_V='$(V)' AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' else AM_V=$AM_DEFAULT_VERBOSITY AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY fi AM_BACKSLASH='\' if test "`cd $srcdir && pwd`" != "`pwd`"; then # Use -I$(srcdir) only when $(srcdir) != ., so that make's output # is not polluted with repeated "-I." am__isrc=' -I$(srcdir)' # test to see if srcdir already configured if test -f $srcdir/config.status; then as_fn_error $? "source directory already configured; run \"make distclean\" there first" "$LINENO" 5 fi fi # test whether we have cygpath if test -z "$CYGPATH_W"; then if (cygpath --version) >/dev/null 2>/dev/null; then CYGPATH_W='cygpath -w' else CYGPATH_W=echo fi fi # Define the identity of the package. PACKAGE='libcaes' VERSION='20240413' printf "%s\n" "#define PACKAGE \"$PACKAGE\"" >>confdefs.h printf "%s\n" "#define VERSION \"$VERSION\"" >>confdefs.h # Some tools Automake needs. ACLOCAL=${ACLOCAL-"${am_missing_run}aclocal-${am__api_version}"} AUTOCONF=${AUTOCONF-"${am_missing_run}autoconf"} AUTOMAKE=${AUTOMAKE-"${am_missing_run}automake-${am__api_version}"} AUTOHEADER=${AUTOHEADER-"${am_missing_run}autoheader"} MAKEINFO=${MAKEINFO-"${am_missing_run}makeinfo"} # For better backward compatibility. To be removed once Automake 1.9.x # dies out for good. For more background, see: # # mkdir_p='$(MKDIR_P)' # We need awk for the "check" target (and possibly the TAP driver). The # system "awk" is bad on some platforms. # Always define AMTAR for backward compatibility. Yes, it's still used # in the wild :-( We should find a proper way to deprecate it ... AMTAR='$${TAR-tar}' # We'll loop over all known methods to create a tar archive until one works. _am_tools='gnutar plaintar pax cpio none' # The POSIX 1988 'ustar' format is defined with fixed-size fields. # There is notably a 21 bits limit for the UID and the GID. In fact, # the 'pax' utility can hang on bigger UID/GID (see automake bug#8343 # and bug#13588). am_max_uid=2097151 # 2^21 - 1 am_max_gid=$am_max_uid # The $UID and $GID variables are not portable, so we need to resort # to the POSIX-mandated id(1) utility. Errors in the 'id' calls # below are definitely unexpected, so allow the users to see them # (that is, avoid stderr redirection). am_uid=`id -u || echo unknown` am_gid=`id -g || echo unknown` { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether UID '$am_uid' is supported by ustar format" >&5 printf %s "checking whether UID '$am_uid' is supported by ustar format... " >&6; } if test $am_uid -le $am_max_uid; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } _am_tools=none fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether GID '$am_gid' is supported by ustar format" >&5 printf %s "checking whether GID '$am_gid' is supported by ustar format... " >&6; } if test $am_gid -le $am_max_gid; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } _am_tools=none fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking how to create a ustar tar archive" >&5 printf %s "checking how to create a ustar tar archive... " >&6; } # Go ahead even if we have the value already cached. We do so because we # need to set the values for the 'am__tar' and 'am__untar' variables. _am_tools=${am_cv_prog_tar_ustar-$_am_tools} for _am_tool in $_am_tools; do case $_am_tool in gnutar) for _am_tar in tar gnutar gtar; do { echo "$as_me:$LINENO: $_am_tar --version" >&5 ($_am_tar --version) >&5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } && break done am__tar="$_am_tar --format=ustar -chf - "'"$$tardir"' am__tar_="$_am_tar --format=ustar -chf - "'"$tardir"' am__untar="$_am_tar -xf -" ;; plaintar) # Must skip GNU tar: if it does not support --format= it doesn't create # ustar tarball either. (tar --version) >/dev/null 2>&1 && continue am__tar='tar chf - "$$tardir"' am__tar_='tar chf - "$tardir"' am__untar='tar xf -' ;; pax) am__tar='pax -L -x ustar -w "$$tardir"' am__tar_='pax -L -x ustar -w "$tardir"' am__untar='pax -r' ;; cpio) am__tar='find "$$tardir" -print | cpio -o -H ustar -L' am__tar_='find "$tardir" -print | cpio -o -H ustar -L' am__untar='cpio -i -H ustar -d' ;; none) am__tar=false am__tar_=false am__untar=false ;; esac # If the value was cached, stop now. We just wanted to have am__tar # and am__untar set. test -n "${am_cv_prog_tar_ustar}" && break # tar/untar a dummy directory, and stop if the command works. rm -rf conftest.dir mkdir conftest.dir echo GrepMe > conftest.dir/file { echo "$as_me:$LINENO: tardir=conftest.dir && eval $am__tar_ >conftest.tar" >&5 (tardir=conftest.dir && eval $am__tar_ >conftest.tar) >&5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } rm -rf conftest.dir if test -s conftest.tar; then { echo "$as_me:$LINENO: $am__untar &5 ($am__untar &5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } { echo "$as_me:$LINENO: cat conftest.dir/file" >&5 (cat conftest.dir/file) >&5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } grep GrepMe conftest.dir/file >/dev/null 2>&1 && break fi done rm -rf conftest.dir if test ${am_cv_prog_tar_ustar+y} then : printf %s "(cached) " >&6 else $as_nop am_cv_prog_tar_ustar=$_am_tool fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $am_cv_prog_tar_ustar" >&5 printf "%s\n" "$am_cv_prog_tar_ustar" >&6; } # Variables for tags utilities; see am/tags.am if test -z "$CTAGS"; then CTAGS=ctags fi if test -z "$ETAGS"; then ETAGS=etags fi if test -z "$CSCOPE"; then CSCOPE=cscope fi # POSIX will say in a future version that running "rm -f" with no argument # is OK; and we want to be able to make that assumption in our Makefile # recipes. So use an aggressive probe to check that the usage we want is # actually supported "in the wild" to an acceptable degree. # See automake bug#10828. # To make any issue more visible, cause the running configure to be aborted # by default if the 'rm' program in use doesn't match our expectations; the # user can still override this though. if rm -f && rm -fr && rm -rf; then : OK; else cat >&2 <<'END' Oops! Your 'rm' program seems unable to run without file operands specified on the command line, even when the '-f' option is present. This is contrary to the behaviour of most rm programs out there, and not conforming with the upcoming POSIX standard: Please tell bug-automake@gnu.org about your system, including the value of your $PATH and any error possibly output before this message. This can help us improve future automake versions. END if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then echo 'Configuration will proceed anyway, since you have set the' >&2 echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 echo >&2 else cat >&2 <<'END' Aborting the configuration process, to ensure you take notice of the issue. You can download and install GNU coreutils to get an 'rm' implementation that behaves properly: . If you want to complete the configuration process using your problematic 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM to "yes", and re-run configure. END as_fn_error $? "Your 'rm' program is bad, sorry." "$LINENO" 5 fi fi # Make sure we can run config.sub. $SHELL "${ac_aux_dir}config.sub" sun4 >/dev/null 2>&1 || as_fn_error $? "cannot run $SHELL ${ac_aux_dir}config.sub" "$LINENO" 5 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking build system type" >&5 printf %s "checking build system type... " >&6; } if test ${ac_cv_build+y} then : printf %s "(cached) " >&6 else $as_nop ac_build_alias=$build_alias test "x$ac_build_alias" = x && ac_build_alias=`$SHELL "${ac_aux_dir}config.guess"` test "x$ac_build_alias" = x && as_fn_error $? "cannot guess build type; you must specify one" "$LINENO" 5 ac_cv_build=`$SHELL "${ac_aux_dir}config.sub" $ac_build_alias` || as_fn_error $? "$SHELL ${ac_aux_dir}config.sub $ac_build_alias failed" "$LINENO" 5 fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_build" >&5 printf "%s\n" "$ac_cv_build" >&6; } case $ac_cv_build in *-*-*) ;; *) as_fn_error $? "invalid value of canonical build" "$LINENO" 5;; esac build=$ac_cv_build ac_save_IFS=$IFS; IFS='-' set x $ac_cv_build shift build_cpu=$1 build_vendor=$2 shift; shift # Remember, the first character of IFS is used to create $*, # except with old shells: build_os=$* IFS=$ac_save_IFS case $build_os in *\ *) build_os=`echo "$build_os" | sed 's/ /-/g'`;; esac { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking host system type" >&5 printf %s "checking host system type... " >&6; } if test ${ac_cv_host+y} then : printf %s "(cached) " >&6 else $as_nop if test "x$host_alias" = x; then ac_cv_host=$ac_cv_build else ac_cv_host=`$SHELL "${ac_aux_dir}config.sub" $host_alias` || as_fn_error $? "$SHELL ${ac_aux_dir}config.sub $host_alias failed" "$LINENO" 5 fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_host" >&5 printf "%s\n" "$ac_cv_host" >&6; } case $ac_cv_host in *-*-*) ;; *) as_fn_error $? "invalid value of canonical host" "$LINENO" 5;; esac host=$ac_cv_host ac_save_IFS=$IFS; IFS='-' set x $ac_cv_host shift host_cpu=$1 host_vendor=$2 shift; shift # Remember, the first character of IFS is used to create $*, # except with old shells: host_os=$* IFS=$ac_save_IFS case $host_os in *\ *) host_os=`echo "$host_os" | sed 's/ /-/g'`;; esac case `pwd` in *\ * | *\ *) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&5 printf "%s\n" "$as_me: WARNING: Libtool does not cope well with whitespace in \`pwd\`" >&2;} ;; esac macro_version='2.4.7' macro_revision='2.4.7' ltmain=$ac_aux_dir/ltmain.sh # Backslashify metacharacters that are still active within # double-quoted strings. sed_quote_subst='s/\(["`$\\]\)/\\\1/g' # Same as above, but do not quote variable references. double_quote_subst='s/\(["`\\]\)/\\\1/g' # Sed substitution to delay expansion of an escaped shell variable in a # double_quote_subst'ed string. delay_variable_subst='s/\\\\\\\\\\\$/\\\\\\$/g' # Sed substitution to delay expansion of an escaped single quote. delay_single_quote_subst='s/'\''/'\'\\\\\\\'\''/g' # Sed substitution to avoid accidental globbing in evaled expressions no_glob_subst='s/\*/\\\*/g' ECHO='\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\\' ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO ECHO=$ECHO$ECHO$ECHO$ECHO$ECHO$ECHO { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking how to print strings" >&5 printf %s "checking how to print strings... " >&6; } # Test print first, because it will be a builtin if present. if test "X`( print -r -- -n ) 2>/dev/null`" = X-n && \ test "X`print -r -- $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='print -r --' elif test "X`printf %s $ECHO 2>/dev/null`" = "X$ECHO"; then ECHO='printf %s\n' else # Use this function as a fallback that always works. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $1 _LTECHO_EOF' } ECHO='func_fallback_echo' fi # func_echo_all arg... # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "" } case $ECHO in printf*) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: printf" >&5 printf "%s\n" "printf" >&6; } ;; print*) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: print -r" >&5 printf "%s\n" "print -r" >&6; } ;; *) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: cat" >&5 printf "%s\n" "cat" >&6; } ;; esac DEPDIR="${am__leading_dot}deps" ac_config_commands="$ac_config_commands depfiles" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} supports the include directive" >&5 printf %s "checking whether ${MAKE-make} supports the include directive... " >&6; } cat > confinc.mk << 'END' am__doit: @echo this is the am__doit target >confinc.out .PHONY: am__doit END am__include="#" am__quote= # BSD make does it like this. echo '.include "confinc.mk" # ignored' > confmf.BSD # Other make implementations (GNU, Solaris 10, AIX) do it like this. echo 'include confinc.mk # ignored' > confmf.GNU _am_result=no for s in GNU BSD; do { echo "$as_me:$LINENO: ${MAKE-make} -f confmf.$s && cat confinc.out" >&5 (${MAKE-make} -f confmf.$s && cat confinc.out) >&5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } case $?:`cat confinc.out 2>/dev/null` in #( '0:this is the am__doit target') : case $s in #( BSD) : am__include='.include' am__quote='"' ;; #( *) : am__include='include' am__quote='' ;; esac ;; #( *) : ;; esac if test "$am__include" != "#"; then _am_result="yes ($s style)" break fi done rm -f confinc.* confmf.* { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: ${_am_result}" >&5 printf "%s\n" "${_am_result}" >&6; } # Check whether --enable-dependency-tracking was given. if test ${enable_dependency_tracking+y} then : enableval=$enable_dependency_tracking; fi if test "x$enable_dependency_tracking" != xno; then am_depcomp="$ac_aux_dir/depcomp" AMDEPBACKSLASH='\' am__nodep='_no' fi if test "x$enable_dependency_tracking" != xno; then AMDEP_TRUE= AMDEP_FALSE='#' else AMDEP_TRUE='#' AMDEP_FALSE= fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. set dummy ${ac_tool_prefix}gcc; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_CC="${ac_tool_prefix}gcc" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 printf "%s\n" "$CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_CC"; then ac_ct_CC=$CC # Extract the first word of "gcc", so it can be a program name with args. set dummy gcc; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_CC"; then ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CC="gcc" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CC=$ac_cv_prog_ac_ct_CC if test -n "$ac_ct_CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 printf "%s\n" "$ac_ct_CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_CC" = x; then CC="" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CC=$ac_ct_CC fi else CC="$ac_cv_prog_CC" fi if test -z "$CC"; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. set dummy ${ac_tool_prefix}cc; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_CC="${ac_tool_prefix}cc" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 printf "%s\n" "$CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi fi if test -z "$CC"; then # Extract the first word of "cc", so it can be a program name with args. set dummy cc; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else ac_prog_rejected=no as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then if test "$as_dir$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then ac_prog_rejected=yes continue fi ac_cv_prog_CC="cc" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS if test $ac_prog_rejected = yes; then # We found a bogon in the path, so make sure we never use it. set dummy $ac_cv_prog_CC shift if test $# != 0; then # We chose a different compiler from the bogus one. # However, it has the same basename, so the bogon will be chosen # first if we set CC to just the basename; use the full file name. shift ac_cv_prog_CC="$as_dir$ac_word${1+' '}$@" fi fi fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 printf "%s\n" "$CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$CC"; then if test -n "$ac_tool_prefix"; then for ac_prog in cl.exe do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_CC="$ac_tool_prefix$ac_prog" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 printf "%s\n" "$CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -n "$CC" && break done fi if test -z "$CC"; then ac_ct_CC=$CC for ac_prog in cl.exe do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_CC"; then ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CC="$ac_prog" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CC=$ac_cv_prog_ac_ct_CC if test -n "$ac_ct_CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 printf "%s\n" "$ac_ct_CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -n "$ac_ct_CC" && break done if test "x$ac_ct_CC" = x; then CC="" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CC=$ac_ct_CC fi fi fi if test -z "$CC"; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}clang", so it can be a program name with args. set dummy ${ac_tool_prefix}clang; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_CC="${ac_tool_prefix}clang" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 printf "%s\n" "$CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_CC"; then ac_ct_CC=$CC # Extract the first word of "clang", so it can be a program name with args. set dummy clang; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_CC"; then ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CC="clang" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CC=$ac_cv_prog_ac_ct_CC if test -n "$ac_ct_CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 printf "%s\n" "$ac_ct_CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_CC" = x; then CC="" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CC=$ac_ct_CC fi else CC="$ac_cv_prog_CC" fi fi test -z "$CC" && { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "no acceptable C compiler found in \$PATH See \`config.log' for more details" "$LINENO" 5; } # Provide some information about the compiler. printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 set X $ac_compile ac_compiler=$2 for ac_option in --version -v -V -qversion -version; do { { ac_try="$ac_compiler $ac_option >&5" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_compiler $ac_option >&5") 2>conftest.err ac_status=$? if test -s conftest.err; then sed '10a\ ... rest of stderr output deleted ... 10q' conftest.err >conftest.er1 cat conftest.er1 >&5 fi rm -f conftest.er1 conftest.err printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } done cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF ac_clean_files_save=$ac_clean_files ac_clean_files="$ac_clean_files a.out a.out.dSYM a.exe b.out" # Try to create an executable without -o first, disregard a.out. # It will help us diagnose broken compilers, and finding out an intuition # of exeext. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether the C compiler works" >&5 printf %s "checking whether the C compiler works... " >&6; } ac_link_default=`printf "%s\n" "$ac_link" | sed 's/ -o *conftest[^ ]*//'` # The possible output files: ac_files="a.out conftest.exe conftest a.exe a_out.exe b.out conftest.*" ac_rmfiles= for ac_file in $ac_files do case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; * ) ac_rmfiles="$ac_rmfiles $ac_file";; esac done rm -f $ac_rmfiles if { { ac_try="$ac_link_default" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_link_default") 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } then : # Autoconf-2.13 could set the ac_cv_exeext variable to `no'. # So ignore a value of `no', otherwise this would lead to `EXEEXT = no' # in a Makefile. We should not override ac_cv_exeext if it was cached, # so that the user can short-circuit this test for compilers unknown to # Autoconf. for ac_file in $ac_files '' do test -f "$ac_file" || continue case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; [ab].out ) # We found the default executable, but exeext='' is most # certainly right. break;; *.* ) if test ${ac_cv_exeext+y} && test "$ac_cv_exeext" != no; then :; else ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` fi # We set ac_cv_exeext here because the later test for it is not # safe: cross compilers may not add the suffix if given an `-o' # argument, so we may need to know it at that point already. # Even if this section looks crufty: it has the advantage of # actually working. break;; * ) break;; esac done test "$ac_cv_exeext" = no && ac_cv_exeext= else $as_nop ac_file='' fi if test -z "$ac_file" then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } printf "%s\n" "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "C compiler cannot create executables See \`config.log' for more details" "$LINENO" 5; } else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for C compiler default output file name" >&5 printf %s "checking for C compiler default output file name... " >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_file" >&5 printf "%s\n" "$ac_file" >&6; } ac_exeext=$ac_cv_exeext rm -f -r a.out a.out.dSYM a.exe conftest$ac_cv_exeext b.out ac_clean_files=$ac_clean_files_save { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for suffix of executables" >&5 printf %s "checking for suffix of executables... " >&6; } if { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } then : # If both `conftest.exe' and `conftest' are `present' (well, observable) # catch `conftest.exe'. For instance with Cygwin, `ls conftest' will # work properly (i.e., refer to `conftest.exe'), while it won't with # `rm'. for ac_file in conftest.exe conftest conftest.*; do test -f "$ac_file" || continue case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM | *.o | *.obj ) ;; *.* ) ac_cv_exeext=`expr "$ac_file" : '[^.]*\(\..*\)'` break;; * ) break;; esac done else $as_nop { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot compute suffix of executables: cannot compile and link See \`config.log' for more details" "$LINENO" 5; } fi rm -f conftest conftest$ac_cv_exeext { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_exeext" >&5 printf "%s\n" "$ac_cv_exeext" >&6; } rm -f conftest.$ac_ext EXEEXT=$ac_cv_exeext ac_exeext=$EXEEXT cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int main (void) { FILE *f = fopen ("conftest.out", "w"); return ferror (f) || fclose (f) != 0; ; return 0; } _ACEOF ac_clean_files="$ac_clean_files conftest.out" # Check that the compiler produces executables we can run. If not, either # the compiler is broken, or we cross compile. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether we are cross compiling" >&5 printf %s "checking whether we are cross compiling... " >&6; } if test "$cross_compiling" != yes; then { { ac_try="$ac_link" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_link") 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if { ac_try='./conftest$ac_cv_exeext' { { case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_try") 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; }; then cross_compiling=no else if test "$cross_compiling" = maybe; then cross_compiling=yes else { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "cannot run C compiled programs. If you meant to cross compile, use \`--host'. See \`config.log' for more details" "$LINENO" 5; } fi fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $cross_compiling" >&5 printf "%s\n" "$cross_compiling" >&6; } rm -f conftest.$ac_ext conftest$ac_cv_exeext conftest.out ac_clean_files=$ac_clean_files_save { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for suffix of object files" >&5 printf %s "checking for suffix of object files... " >&6; } if test ${ac_cv_objext+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF rm -f conftest.o conftest.obj if { { ac_try="$ac_compile" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_compile") 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } then : for ac_file in conftest.o conftest.obj conftest.*; do test -f "$ac_file" || continue; case $ac_file in *.$ac_ext | *.xcoff | *.tds | *.d | *.pdb | *.xSYM | *.bb | *.bbg | *.map | *.inf | *.dSYM ) ;; *) ac_cv_objext=`expr "$ac_file" : '.*\.\(.*\)'` break;; esac done else $as_nop printf "%s\n" "$as_me: failed program was:" >&5 sed 's/^/| /' conftest.$ac_ext >&5 { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot compute suffix of object files: cannot compile See \`config.log' for more details" "$LINENO" 5; } fi rm -f conftest.$ac_cv_objext conftest.$ac_ext fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_objext" >&5 printf "%s\n" "$ac_cv_objext" >&6; } OBJEXT=$ac_cv_objext ac_objext=$OBJEXT { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether the compiler supports GNU C" >&5 printf %s "checking whether the compiler supports GNU C... " >&6; } if test ${ac_cv_c_compiler_gnu+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { #ifndef __GNUC__ choke me #endif ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_compiler_gnu=yes else $as_nop ac_compiler_gnu=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ac_cv_c_compiler_gnu=$ac_compiler_gnu fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_compiler_gnu" >&5 printf "%s\n" "$ac_cv_c_compiler_gnu" >&6; } ac_compiler_gnu=$ac_cv_c_compiler_gnu if test $ac_compiler_gnu = yes; then GCC=yes else GCC= fi ac_test_CFLAGS=${CFLAGS+y} ac_save_CFLAGS=$CFLAGS { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 printf %s "checking whether $CC accepts -g... " >&6; } if test ${ac_cv_prog_cc_g+y} then : printf %s "(cached) " >&6 else $as_nop ac_save_c_werror_flag=$ac_c_werror_flag ac_c_werror_flag=yes ac_cv_prog_cc_g=no CFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_cv_prog_cc_g=yes else $as_nop CFLAGS="" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : else $as_nop ac_c_werror_flag=$ac_save_c_werror_flag CFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_cv_prog_cc_g=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ac_c_werror_flag=$ac_save_c_werror_flag fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_g" >&5 printf "%s\n" "$ac_cv_prog_cc_g" >&6; } if test $ac_test_CFLAGS; then CFLAGS=$ac_save_CFLAGS elif test $ac_cv_prog_cc_g = yes; then if test "$GCC" = yes; then CFLAGS="-g -O2" else CFLAGS="-g" fi else if test "$GCC" = yes; then CFLAGS="-O2" else CFLAGS= fi fi ac_prog_cc_stdc=no if test x$ac_prog_cc_stdc = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $CC option to enable C11 features" >&5 printf %s "checking for $CC option to enable C11 features... " >&6; } if test ${ac_cv_prog_cc_c11+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_prog_cc_c11=no ac_save_CC=$CC cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $ac_c_conftest_c11_program _ACEOF for ac_arg in '' -std=gnu11 do CC="$ac_save_CC $ac_arg" if ac_fn_c_try_compile "$LINENO" then : ac_cv_prog_cc_c11=$ac_arg fi rm -f core conftest.err conftest.$ac_objext conftest.beam test "x$ac_cv_prog_cc_c11" != "xno" && break done rm -f conftest.$ac_ext CC=$ac_save_CC fi if test "x$ac_cv_prog_cc_c11" = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 printf "%s\n" "unsupported" >&6; } else $as_nop if test "x$ac_cv_prog_cc_c11" = x then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 printf "%s\n" "none needed" >&6; } else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c11" >&5 printf "%s\n" "$ac_cv_prog_cc_c11" >&6; } CC="$CC $ac_cv_prog_cc_c11" fi ac_cv_prog_cc_stdc=$ac_cv_prog_cc_c11 ac_prog_cc_stdc=c11 fi fi if test x$ac_prog_cc_stdc = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $CC option to enable C99 features" >&5 printf %s "checking for $CC option to enable C99 features... " >&6; } if test ${ac_cv_prog_cc_c99+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_prog_cc_c99=no ac_save_CC=$CC cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $ac_c_conftest_c99_program _ACEOF for ac_arg in '' -std=gnu99 -std=c99 -c99 -qlanglvl=extc1x -qlanglvl=extc99 -AC99 -D_STDC_C99= do CC="$ac_save_CC $ac_arg" if ac_fn_c_try_compile "$LINENO" then : ac_cv_prog_cc_c99=$ac_arg fi rm -f core conftest.err conftest.$ac_objext conftest.beam test "x$ac_cv_prog_cc_c99" != "xno" && break done rm -f conftest.$ac_ext CC=$ac_save_CC fi if test "x$ac_cv_prog_cc_c99" = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 printf "%s\n" "unsupported" >&6; } else $as_nop if test "x$ac_cv_prog_cc_c99" = x then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 printf "%s\n" "none needed" >&6; } else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c99" >&5 printf "%s\n" "$ac_cv_prog_cc_c99" >&6; } CC="$CC $ac_cv_prog_cc_c99" fi ac_cv_prog_cc_stdc=$ac_cv_prog_cc_c99 ac_prog_cc_stdc=c99 fi fi if test x$ac_prog_cc_stdc = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $CC option to enable C89 features" >&5 printf %s "checking for $CC option to enable C89 features... " >&6; } if test ${ac_cv_prog_cc_c89+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_prog_cc_c89=no ac_save_CC=$CC cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $ac_c_conftest_c89_program _ACEOF for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" do CC="$ac_save_CC $ac_arg" if ac_fn_c_try_compile "$LINENO" then : ac_cv_prog_cc_c89=$ac_arg fi rm -f core conftest.err conftest.$ac_objext conftest.beam test "x$ac_cv_prog_cc_c89" != "xno" && break done rm -f conftest.$ac_ext CC=$ac_save_CC fi if test "x$ac_cv_prog_cc_c89" = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 printf "%s\n" "unsupported" >&6; } else $as_nop if test "x$ac_cv_prog_cc_c89" = x then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 printf "%s\n" "none needed" >&6; } else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c89" >&5 printf "%s\n" "$ac_cv_prog_cc_c89" >&6; } CC="$CC $ac_cv_prog_cc_c89" fi ac_cv_prog_cc_stdc=$ac_cv_prog_cc_c89 ac_prog_cc_stdc=c89 fi fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether $CC understands -c and -o together" >&5 printf %s "checking whether $CC understands -c and -o together... " >&6; } if test ${am_cv_prog_cc_c_o+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF # Make sure it works both with $CC and with simple cc. # Following AC_PROG_CC_C_O, we do the test twice because some # compilers refuse to overwrite an existing .o file with -o, # though they will create one. am_cv_prog_cc_c_o=yes for am_i in 1 2; do if { echo "$as_me:$LINENO: $CC -c conftest.$ac_ext -o conftest2.$ac_objext" >&5 ($CC -c conftest.$ac_ext -o conftest2.$ac_objext) >&5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } \ && test -f conftest2.$ac_objext; then : OK else am_cv_prog_cc_c_o=no break fi done rm -f core conftest* unset am_i fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $am_cv_prog_cc_c_o" >&5 printf "%s\n" "$am_cv_prog_cc_c_o" >&6; } if test "$am_cv_prog_cc_c_o" != yes; then # Losing compiler, so override with the script. # FIXME: It is wrong to rewrite CC. # But if we don't then we get into trouble of one sort or another. # A longer-term fix would be to have automake use am__CC in this case, # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" CC="$am_aux_dir/compile $CC" fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu depcc="$CC" am_compiler_list= { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 printf %s "checking dependency style of $depcc... " >&6; } if test ${am_cv_CC_dependencies_compiler_type+y} then : printf %s "(cached) " >&6 else $as_nop if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then # We make a subdir and do the tests there. Otherwise we can end up # making bogus files that we don't know about and never remove. For # instance it was reported that on HP-UX the gcc test will end up # making a dummy file named 'D' -- because '-MD' means "put the output # in D". rm -rf conftest.dir mkdir conftest.dir # Copy depcomp to subdir because otherwise we won't find it if we're # using a relative directory. cp "$am_depcomp" conftest.dir cd conftest.dir # We will build objects and dependencies in a subdirectory because # it helps to detect inapplicable dependency modes. For instance # both Tru64's cc and ICC support -MD to output dependencies as a # side effect of compilation, but ICC will put the dependencies in # the current directory while Tru64 will put them in the object # directory. mkdir sub am_cv_CC_dependencies_compiler_type=none if test "$am_compiler_list" = ""; then am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` fi am__universal=false case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac for depmode in $am_compiler_list; do # Setup a source with many dependencies, because some compilers # like to wrap large dependency lists on column 80 (with \), and # we should not choose a depcomp mode which is confused by this. # # We need to recreate these files for each test, as the compiler may # overwrite some of them when testing with obscure command lines. # This happens at least with the AIX C compiler. : > sub/conftest.c for i in 1 2 3 4 5 6; do echo '#include "conftst'$i'.h"' >> sub/conftest.c # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with # Solaris 10 /bin/sh. echo '/* dummy */' > sub/conftst$i.h done echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf # We check with '-c' and '-o' for the sake of the "dashmstdout" # mode. It turns out that the SunPro C++ compiler does not properly # handle '-M -o', and we need to detect this. Also, some Intel # versions had trouble with output in subdirs. am__obj=sub/conftest.${OBJEXT-o} am__minus_obj="-o $am__obj" case $depmode in gcc) # This depmode causes a compiler race in universal mode. test "$am__universal" = false || continue ;; nosideeffect) # After this tag, mechanisms are not by side-effect, so they'll # only be used when explicitly requested. if test "x$enable_dependency_tracking" = xyes; then continue else break fi ;; msvc7 | msvc7msys | msvisualcpp | msvcmsys) # This compiler won't grok '-c -o', but also, the minuso test has # not run yet. These depmodes are late enough in the game, and # so weak that their functioning should not be impacted. am__obj=conftest.${OBJEXT-o} am__minus_obj= ;; none) break ;; esac if depmode=$depmode \ source=sub/conftest.c object=$am__obj \ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ >/dev/null 2>conftest.err && grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && grep $am__obj sub/conftest.Po > /dev/null 2>&1 && ${MAKE-make} -s -f confmf > /dev/null 2>&1; then # icc doesn't choke on unknown options, it will just issue warnings # or remarks (even with -Werror). So we grep stderr for any message # that says an option was ignored or not supported. # When given -MP, icc 7.0 and 7.1 complain thusly: # icc: Command line warning: ignoring option '-M'; no argument required # The diagnosis changed in icc 8.0: # icc: Command line remark: option '-MP' not supported if (grep 'ignoring option' conftest.err || grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else am_cv_CC_dependencies_compiler_type=$depmode break fi fi done cd .. rm -rf conftest.dir else am_cv_CC_dependencies_compiler_type=none fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $am_cv_CC_dependencies_compiler_type" >&5 printf "%s\n" "$am_cv_CC_dependencies_compiler_type" >&6; } CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type if test "x$enable_dependency_tracking" != xno \ && test "$am_cv_CC_dependencies_compiler_type" = gcc3; then am__fastdepCC_TRUE= am__fastdepCC_FALSE='#' else am__fastdepCC_TRUE='#' am__fastdepCC_FALSE= fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for a sed that does not truncate output" >&5 printf %s "checking for a sed that does not truncate output... " >&6; } if test ${ac_cv_path_SED+y} then : printf %s "(cached) " >&6 else $as_nop ac_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ for ac_i in 1 2 3 4 5 6 7; do ac_script="$ac_script$as_nl$ac_script" done echo "$ac_script" 2>/dev/null | sed 99q >conftest.sed { ac_script=; unset ac_script;} if test -z "$SED"; then ac_path_SED_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_prog in sed gsed do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_SED="$as_dir$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_SED" || continue # Check for GNU ac_path_SED and select it if it is found. # Check for GNU $ac_path_SED case `"$ac_path_SED" --version 2>&1` in *GNU*) ac_cv_path_SED="$ac_path_SED" ac_path_SED_found=:;; *) ac_count=0 printf %s 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" printf "%s\n" '' >> "conftest.nl" "$ac_path_SED" -f conftest.sed < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_SED_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_SED="$ac_path_SED" ac_path_SED_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_SED_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_SED"; then as_fn_error $? "no acceptable sed could be found in \$PATH" "$LINENO" 5 fi else ac_cv_path_SED=$SED fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_SED" >&5 printf "%s\n" "$ac_cv_path_SED" >&6; } SED="$ac_cv_path_SED" rm -f conftest.sed test -z "$SED" && SED=sed Xsed="$SED -e 1s/^X//" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for grep that handles long lines and -e" >&5 printf %s "checking for grep that handles long lines and -e... " >&6; } if test ${ac_cv_path_GREP+y} then : printf %s "(cached) " >&6 else $as_nop if test -z "$GREP"; then ac_path_GREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_prog in grep ggrep do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_GREP="$as_dir$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_GREP" || continue # Check for GNU ac_path_GREP and select it if it is found. # Check for GNU $ac_path_GREP case `"$ac_path_GREP" --version 2>&1` in *GNU*) ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_found=:;; *) ac_count=0 printf %s 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" printf "%s\n" 'GREP' >> "conftest.nl" "$ac_path_GREP" -e 'GREP$' -e '-(cannot match)-' < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_GREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_GREP="$ac_path_GREP" ac_path_GREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_GREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_GREP"; then as_fn_error $? "no acceptable grep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_GREP=$GREP fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_GREP" >&5 printf "%s\n" "$ac_cv_path_GREP" >&6; } GREP="$ac_cv_path_GREP" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for egrep" >&5 printf %s "checking for egrep... " >&6; } if test ${ac_cv_path_EGREP+y} then : printf %s "(cached) " >&6 else $as_nop if echo a | $GREP -E '(a|b)' >/dev/null 2>&1 then ac_cv_path_EGREP="$GREP -E" else if test -z "$EGREP"; then ac_path_EGREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_prog in egrep do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_EGREP="$as_dir$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_EGREP" || continue # Check for GNU ac_path_EGREP and select it if it is found. # Check for GNU $ac_path_EGREP case `"$ac_path_EGREP" --version 2>&1` in *GNU*) ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_found=:;; *) ac_count=0 printf %s 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" printf "%s\n" 'EGREP' >> "conftest.nl" "$ac_path_EGREP" 'EGREP$' < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_EGREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_EGREP="$ac_path_EGREP" ac_path_EGREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_EGREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_EGREP"; then as_fn_error $? "no acceptable egrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_EGREP=$EGREP fi fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_EGREP" >&5 printf "%s\n" "$ac_cv_path_EGREP" >&6; } EGREP="$ac_cv_path_EGREP" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for fgrep" >&5 printf %s "checking for fgrep... " >&6; } if test ${ac_cv_path_FGREP+y} then : printf %s "(cached) " >&6 else $as_nop if echo 'ab*c' | $GREP -F 'ab*c' >/dev/null 2>&1 then ac_cv_path_FGREP="$GREP -F" else if test -z "$FGREP"; then ac_path_FGREP_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH$PATH_SEPARATOR/usr/xpg4/bin do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_prog in fgrep do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_FGREP="$as_dir$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_FGREP" || continue # Check for GNU ac_path_FGREP and select it if it is found. # Check for GNU $ac_path_FGREP case `"$ac_path_FGREP" --version 2>&1` in *GNU*) ac_cv_path_FGREP="$ac_path_FGREP" ac_path_FGREP_found=:;; *) ac_count=0 printf %s 0123456789 >"conftest.in" while : do cat "conftest.in" "conftest.in" >"conftest.tmp" mv "conftest.tmp" "conftest.in" cp "conftest.in" "conftest.nl" printf "%s\n" 'FGREP' >> "conftest.nl" "$ac_path_FGREP" FGREP < "conftest.nl" >"conftest.out" 2>/dev/null || break diff "conftest.out" "conftest.nl" >/dev/null 2>&1 || break as_fn_arith $ac_count + 1 && ac_count=$as_val if test $ac_count -gt ${ac_path_FGREP_max-0}; then # Best one so far, save it but keep looking for a better one ac_cv_path_FGREP="$ac_path_FGREP" ac_path_FGREP_max=$ac_count fi # 10*(2^10) chars as input seems more than enough test $ac_count -gt 10 && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out;; esac $ac_path_FGREP_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_FGREP"; then as_fn_error $? "no acceptable fgrep could be found in $PATH$PATH_SEPARATOR/usr/xpg4/bin" "$LINENO" 5 fi else ac_cv_path_FGREP=$FGREP fi fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_FGREP" >&5 printf "%s\n" "$ac_cv_path_FGREP" >&6; } FGREP="$ac_cv_path_FGREP" test -z "$GREP" && GREP=grep # Check whether --with-gnu-ld was given. if test ${with_gnu_ld+y} then : withval=$with_gnu_ld; test no = "$withval" || with_gnu_ld=yes else $as_nop with_gnu_ld=no fi ac_prog=ld if test yes = "$GCC"; then # Check if gcc -print-prog-name=ld gives a path. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for ld used by $CC" >&5 printf %s "checking for ld used by $CC... " >&6; } case $host in *-*-mingw*) # gcc leaves a trailing carriage return, which upsets mingw ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; *) ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; esac case $ac_prog in # Accept absolute paths. [\\/]* | ?:[\\/]*) re_direlt='/[^/][^/]*/\.\./' # Canonicalize the pathname of ld ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` done test -z "$LD" && LD=$ac_prog ;; "") # If it fails, then pretend we aren't using GCC. ac_prog=ld ;; *) # If it is relative, then search for the first ld in PATH. with_gnu_ld=unknown ;; esac elif test yes = "$with_gnu_ld"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for GNU ld" >&5 printf %s "checking for GNU ld... " >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for non-GNU ld" >&5 printf %s "checking for non-GNU ld... " >&6; } fi if test ${lt_cv_path_LD+y} then : printf %s "(cached) " >&6 else $as_nop if test -z "$LD"; then lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then lt_cv_path_LD=$ac_dir/$ac_prog # Check to see if the program is GNU ld. I'd rather use --version, # but apparently some variants of GNU ld only accept -v. # Break only if it was the GNU/non-GNU ld that we prefer. case `"$lt_cv_path_LD" -v 2>&1 &5 printf "%s\n" "$LD" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -z "$LD" && as_fn_error $? "no acceptable ld found in \$PATH" "$LINENO" 5 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if the linker ($LD) is GNU ld" >&5 printf %s "checking if the linker ($LD) is GNU ld... " >&6; } if test ${lt_cv_prog_gnu_ld+y} then : printf %s "(cached) " >&6 else $as_nop # I'd rather use --version here, but apparently some GNU lds only accept -v. case `$LD -v 2>&1 &5 printf "%s\n" "$lt_cv_prog_gnu_ld" >&6; } with_gnu_ld=$lt_cv_prog_gnu_ld { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for BSD- or MS-compatible name lister (nm)" >&5 printf %s "checking for BSD- or MS-compatible name lister (nm)... " >&6; } if test ${lt_cv_path_NM+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$NM"; then # Let the user override the test. lt_cv_path_NM=$NM else lt_nm_to_check=${ac_tool_prefix}nm if test -n "$ac_tool_prefix" && test "$build" = "$host"; then lt_nm_to_check="$lt_nm_to_check nm" fi for lt_tmp_nm in $lt_nm_to_check; do lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH /usr/ccs/bin/elf /usr/ccs/bin /usr/ucb /bin; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. tmp_nm=$ac_dir/$lt_tmp_nm if test -f "$tmp_nm" || test -f "$tmp_nm$ac_exeext"; then # Check to see if the nm accepts a BSD-compat flag. # Adding the 'sed 1q' prevents false positives on HP-UX, which says: # nm: unknown option "B" ignored # Tru64's nm complains that /dev/null is an invalid object file # MSYS converts /dev/null to NUL, MinGW nm treats NUL as empty case $build_os in mingw*) lt_bad_file=conftest.nm/nofile ;; *) lt_bad_file=/dev/null ;; esac case `"$tmp_nm" -B $lt_bad_file 2>&1 | $SED '1q'` in *$lt_bad_file* | *'Invalid file or object type'*) lt_cv_path_NM="$tmp_nm -B" break 2 ;; *) case `"$tmp_nm" -p /dev/null 2>&1 | $SED '1q'` in */dev/null*) lt_cv_path_NM="$tmp_nm -p" break 2 ;; *) lt_cv_path_NM=${lt_cv_path_NM="$tmp_nm"} # keep the first match, but continue # so that we can try to find one that supports BSD flags ;; esac ;; esac fi done IFS=$lt_save_ifs done : ${lt_cv_path_NM=no} fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_NM" >&5 printf "%s\n" "$lt_cv_path_NM" >&6; } if test no != "$lt_cv_path_NM"; then NM=$lt_cv_path_NM else # Didn't find any BSD compatible name lister, look for dumpbin. if test -n "$DUMPBIN"; then : # Let the user override the test. else if test -n "$ac_tool_prefix"; then for ac_prog in dumpbin "link -dump" do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_DUMPBIN+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$DUMPBIN"; then ac_cv_prog_DUMPBIN="$DUMPBIN" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_DUMPBIN="$ac_tool_prefix$ac_prog" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DUMPBIN=$ac_cv_prog_DUMPBIN if test -n "$DUMPBIN"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $DUMPBIN" >&5 printf "%s\n" "$DUMPBIN" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -n "$DUMPBIN" && break done fi if test -z "$DUMPBIN"; then ac_ct_DUMPBIN=$DUMPBIN for ac_prog in dumpbin "link -dump" do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_DUMPBIN+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_DUMPBIN"; then ac_cv_prog_ac_ct_DUMPBIN="$ac_ct_DUMPBIN" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DUMPBIN="$ac_prog" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DUMPBIN=$ac_cv_prog_ac_ct_DUMPBIN if test -n "$ac_ct_DUMPBIN"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DUMPBIN" >&5 printf "%s\n" "$ac_ct_DUMPBIN" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -n "$ac_ct_DUMPBIN" && break done if test "x$ac_ct_DUMPBIN" = x; then DUMPBIN=":" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DUMPBIN=$ac_ct_DUMPBIN fi fi case `$DUMPBIN -symbols -headers /dev/null 2>&1 | $SED '1q'` in *COFF*) DUMPBIN="$DUMPBIN -symbols -headers" ;; *) DUMPBIN=: ;; esac fi if test : != "$DUMPBIN"; then NM=$DUMPBIN fi fi test -z "$NM" && NM=nm { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking the name lister ($NM) interface" >&5 printf %s "checking the name lister ($NM) interface... " >&6; } if test ${lt_cv_nm_interface+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_nm_interface="BSD nm" echo "int some_variable = 0;" > conftest.$ac_ext (eval echo "\"\$as_me:$LINENO: $ac_compile\"" >&5) (eval "$ac_compile" 2>conftest.err) cat conftest.err >&5 (eval echo "\"\$as_me:$LINENO: $NM \\\"conftest.$ac_objext\\\"\"" >&5) (eval "$NM \"conftest.$ac_objext\"" 2>conftest.err > conftest.out) cat conftest.err >&5 (eval echo "\"\$as_me:$LINENO: output\"" >&5) cat conftest.out >&5 if $GREP 'External.*some_variable' conftest.out > /dev/null; then lt_cv_nm_interface="MS dumpbin" fi rm -f conftest* fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_nm_interface" >&5 printf "%s\n" "$lt_cv_nm_interface" >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether ln -s works" >&5 printf %s "checking whether ln -s works... " >&6; } LN_S=$as_ln_s if test "$LN_S" = "ln -s"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no, using $LN_S" >&5 printf "%s\n" "no, using $LN_S" >&6; } fi # find the maximum length of command line arguments { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking the maximum length of command line arguments" >&5 printf %s "checking the maximum length of command line arguments... " >&6; } if test ${lt_cv_sys_max_cmd_len+y} then : printf %s "(cached) " >&6 else $as_nop i=0 teststring=ABCD case $build_os in msdosdjgpp*) # On DJGPP, this test can blow up pretty badly due to problems in libc # (any single argument exceeding 2000 bytes causes a buffer overrun # during glob expansion). Even if it were fixed, the result of this # check would be larger than it should be. lt_cv_sys_max_cmd_len=12288; # 12K is about right ;; gnu*) # Under GNU Hurd, this test is not required because there is # no limit to the length of command line arguments. # Libtool will interpret -1 as no limit whatsoever lt_cv_sys_max_cmd_len=-1; ;; cygwin* | mingw* | cegcc*) # On Win9x/ME, this test blows up -- it succeeds, but takes # about 5 minutes as the teststring grows exponentially. # Worse, since 9x/ME are not pre-emptively multitasking, # you end up with a "frozen" computer, even though with patience # the test eventually succeeds (with a max line length of 256k). # Instead, let's just punt: use the minimum linelength reported by # all of the supported platforms: 8192 (on NT/2K/XP). lt_cv_sys_max_cmd_len=8192; ;; mint*) # On MiNT this can take a long time and run out of memory. lt_cv_sys_max_cmd_len=8192; ;; amigaos*) # On AmigaOS with pdksh, this test takes hours, literally. # So we just punt and use a minimum line length of 8192. lt_cv_sys_max_cmd_len=8192; ;; bitrig* | darwin* | dragonfly* | freebsd* | midnightbsd* | netbsd* | openbsd*) # This has been around since 386BSD, at least. Likely further. if test -x /sbin/sysctl; then lt_cv_sys_max_cmd_len=`/sbin/sysctl -n kern.argmax` elif test -x /usr/sbin/sysctl; then lt_cv_sys_max_cmd_len=`/usr/sbin/sysctl -n kern.argmax` else lt_cv_sys_max_cmd_len=65536 # usable default for all BSDs fi # And add a safety zone lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` ;; interix*) # We know the value 262144 and hardcode it with a safety zone (like BSD) lt_cv_sys_max_cmd_len=196608 ;; os2*) # The test takes a long time on OS/2. lt_cv_sys_max_cmd_len=8192 ;; osf*) # Dr. Hans Ekkehard Plesser reports seeing a kernel panic running configure # due to this test when exec_disable_arg_limit is 1 on Tru64. It is not # nice to cause kernel panics so lets avoid the loop below. # First set a reasonable default. lt_cv_sys_max_cmd_len=16384 # if test -x /sbin/sysconfig; then case `/sbin/sysconfig -q proc exec_disable_arg_limit` in *1*) lt_cv_sys_max_cmd_len=-1 ;; esac fi ;; sco3.2v5*) lt_cv_sys_max_cmd_len=102400 ;; sysv5* | sco5v6* | sysv4.2uw2*) kargmax=`grep ARG_MAX /etc/conf/cf.d/stune 2>/dev/null` if test -n "$kargmax"; then lt_cv_sys_max_cmd_len=`echo $kargmax | $SED 's/.*[ ]//'` else lt_cv_sys_max_cmd_len=32768 fi ;; *) lt_cv_sys_max_cmd_len=`(getconf ARG_MAX) 2> /dev/null` if test -n "$lt_cv_sys_max_cmd_len" && \ test undefined != "$lt_cv_sys_max_cmd_len"; then lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 4` lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \* 3` else # Make teststring a little bigger before we do anything with it. # a 1K string should be a reasonable start. for i in 1 2 3 4 5 6 7 8; do teststring=$teststring$teststring done SHELL=${SHELL-${CONFIG_SHELL-/bin/sh}} # If test is not a shell built-in, we'll probably end up computing a # maximum length that is only half of the actual maximum length, but # we can't tell. while { test X`env echo "$teststring$teststring" 2>/dev/null` \ = "X$teststring$teststring"; } >/dev/null 2>&1 && test 17 != "$i" # 1/2 MB should be enough do i=`expr $i + 1` teststring=$teststring$teststring done # Only check the string length outside the loop. lt_cv_sys_max_cmd_len=`expr "X$teststring" : ".*" 2>&1` teststring= # Add a significant safety factor because C++ compilers can tack on # massive amounts of additional arguments before passing them to the # linker. It appears as though 1/2 is a usable value. lt_cv_sys_max_cmd_len=`expr $lt_cv_sys_max_cmd_len \/ 2` fi ;; esac fi if test -n "$lt_cv_sys_max_cmd_len"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_sys_max_cmd_len" >&5 printf "%s\n" "$lt_cv_sys_max_cmd_len" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: none" >&5 printf "%s\n" "none" >&6; } fi max_cmd_len=$lt_cv_sys_max_cmd_len : ${CP="cp -f"} : ${MV="mv -f"} : ${RM="rm -f"} if ( (MAIL=60; unset MAIL) || exit) >/dev/null 2>&1; then lt_unset=unset else lt_unset=false fi # test EBCDIC or ASCII case `echo X|tr X '\101'` in A) # ASCII based system # \n is not interpreted correctly by Solaris 8 /usr/ucb/tr lt_SP2NL='tr \040 \012' lt_NL2SP='tr \015\012 \040\040' ;; *) # EBCDIC based system lt_SP2NL='tr \100 \n' lt_NL2SP='tr \r\n \100\100' ;; esac { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking how to convert $build file names to $host format" >&5 printf %s "checking how to convert $build file names to $host format... " >&6; } if test ${lt_cv_to_host_file_cmd+y} then : printf %s "(cached) " >&6 else $as_nop case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_w32 ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_cygwin_to_w32 ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_w32 ;; esac ;; *-*-cygwin* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_host_file_cmd=func_convert_file_msys_to_cygwin ;; *-*-cygwin* ) lt_cv_to_host_file_cmd=func_convert_file_noop ;; * ) # otherwise, assume *nix lt_cv_to_host_file_cmd=func_convert_file_nix_to_cygwin ;; esac ;; * ) # unhandled hosts (and "normal" native builds) lt_cv_to_host_file_cmd=func_convert_file_noop ;; esac fi to_host_file_cmd=$lt_cv_to_host_file_cmd { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_to_host_file_cmd" >&5 printf "%s\n" "$lt_cv_to_host_file_cmd" >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking how to convert $build file names to toolchain format" >&5 printf %s "checking how to convert $build file names to toolchain format... " >&6; } if test ${lt_cv_to_tool_file_cmd+y} then : printf %s "(cached) " >&6 else $as_nop #assume ordinary cross tools, or native build. lt_cv_to_tool_file_cmd=func_convert_file_noop case $host in *-*-mingw* ) case $build in *-*-mingw* ) # actually msys lt_cv_to_tool_file_cmd=func_convert_file_msys_to_w32 ;; esac ;; esac fi to_tool_file_cmd=$lt_cv_to_tool_file_cmd { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_to_tool_file_cmd" >&5 printf "%s\n" "$lt_cv_to_tool_file_cmd" >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $LD option to reload object files" >&5 printf %s "checking for $LD option to reload object files... " >&6; } if test ${lt_cv_ld_reload_flag+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_ld_reload_flag='-r' fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_reload_flag" >&5 printf "%s\n" "$lt_cv_ld_reload_flag" >&6; } reload_flag=$lt_cv_ld_reload_flag case $reload_flag in "" | " "*) ;; *) reload_flag=" $reload_flag" ;; esac reload_cmds='$LD$reload_flag -o $output$reload_objs' case $host_os in cygwin* | mingw* | pw32* | cegcc*) if test yes != "$GCC"; then reload_cmds=false fi ;; darwin*) if test yes = "$GCC"; then reload_cmds='$LTCC $LTCFLAGS -nostdlib $wl-r -o $output$reload_objs' else reload_cmds='$LD$reload_flag -o $output$reload_objs' fi ;; esac if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}file", so it can be a program name with args. set dummy ${ac_tool_prefix}file; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_FILECMD+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$FILECMD"; then ac_cv_prog_FILECMD="$FILECMD" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_FILECMD="${ac_tool_prefix}file" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi FILECMD=$ac_cv_prog_FILECMD if test -n "$FILECMD"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $FILECMD" >&5 printf "%s\n" "$FILECMD" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_FILECMD"; then ac_ct_FILECMD=$FILECMD # Extract the first word of "file", so it can be a program name with args. set dummy file; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_FILECMD+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_FILECMD"; then ac_cv_prog_ac_ct_FILECMD="$ac_ct_FILECMD" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_FILECMD="file" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_FILECMD=$ac_cv_prog_ac_ct_FILECMD if test -n "$ac_ct_FILECMD"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_FILECMD" >&5 printf "%s\n" "$ac_ct_FILECMD" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_FILECMD" = x; then FILECMD=":" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac FILECMD=$ac_ct_FILECMD fi else FILECMD="$ac_cv_prog_FILECMD" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}objdump", so it can be a program name with args. set dummy ${ac_tool_prefix}objdump; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_OBJDUMP+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$OBJDUMP"; then ac_cv_prog_OBJDUMP="$OBJDUMP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_OBJDUMP="${ac_tool_prefix}objdump" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OBJDUMP=$ac_cv_prog_OBJDUMP if test -n "$OBJDUMP"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $OBJDUMP" >&5 printf "%s\n" "$OBJDUMP" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_OBJDUMP"; then ac_ct_OBJDUMP=$OBJDUMP # Extract the first word of "objdump", so it can be a program name with args. set dummy objdump; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_OBJDUMP+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_OBJDUMP"; then ac_cv_prog_ac_ct_OBJDUMP="$ac_ct_OBJDUMP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OBJDUMP="objdump" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OBJDUMP=$ac_cv_prog_ac_ct_OBJDUMP if test -n "$ac_ct_OBJDUMP"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OBJDUMP" >&5 printf "%s\n" "$ac_ct_OBJDUMP" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_OBJDUMP" = x; then OBJDUMP="false" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OBJDUMP=$ac_ct_OBJDUMP fi else OBJDUMP="$ac_cv_prog_OBJDUMP" fi test -z "$OBJDUMP" && OBJDUMP=objdump { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking how to recognize dependent libraries" >&5 printf %s "checking how to recognize dependent libraries... " >&6; } if test ${lt_cv_deplibs_check_method+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_file_magic_cmd='$MAGIC_CMD' lt_cv_file_magic_test_file= lt_cv_deplibs_check_method='unknown' # Need to set the preceding variable on all platforms that support # interlibrary dependencies. # 'none' -- dependencies not supported. # 'unknown' -- same as none, but documents that we really don't know. # 'pass_all' -- all dependencies passed with no checks. # 'test_compile' -- check by making test program. # 'file_magic [[regex]]' -- check by looking for files in library path # that responds to the $file_magic_cmd with a given extended regex. # If you have 'file' or equivalent on your system and you're not sure # whether 'pass_all' will *always* work, you probably want this one. case $host_os in aix[4-9]*) lt_cv_deplibs_check_method=pass_all ;; beos*) lt_cv_deplibs_check_method=pass_all ;; bsdi[45]*) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib)' lt_cv_file_magic_cmd='$FILECMD -L' lt_cv_file_magic_test_file=/shlib/libc.so ;; cygwin*) # func_win32_libid is a shell function defined in ltmain.sh lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' ;; mingw* | pw32*) # Base MSYS/MinGW do not provide the 'file' command needed by # func_win32_libid shell function, so use a weaker test based on 'objdump', # unless we find 'file', for example because we are cross-compiling. if ( file / ) >/dev/null 2>&1; then lt_cv_deplibs_check_method='file_magic ^x86 archive import|^x86 DLL' lt_cv_file_magic_cmd='func_win32_libid' else # Keep this pattern in sync with the one in func_win32_libid. lt_cv_deplibs_check_method='file_magic file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' lt_cv_file_magic_cmd='$OBJDUMP -f' fi ;; cegcc*) # use the weaker test based on 'objdump'. See mingw*. lt_cv_deplibs_check_method='file_magic file format pe-arm-.*little(.*architecture: arm)?' lt_cv_file_magic_cmd='$OBJDUMP -f' ;; darwin* | rhapsody*) lt_cv_deplibs_check_method=pass_all ;; freebsd* | dragonfly* | midnightbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then case $host_cpu in i*86 ) # Not sure whether the presence of OpenBSD here was a mistake. # Let's accept both of them until this is cleared up. lt_cv_deplibs_check_method='file_magic (FreeBSD|OpenBSD|DragonFly)/i[3-9]86 (compact )?demand paged shared library' lt_cv_file_magic_cmd=$FILECMD lt_cv_file_magic_test_file=`echo /usr/lib/libc.so.*` ;; esac else lt_cv_deplibs_check_method=pass_all fi ;; haiku*) lt_cv_deplibs_check_method=pass_all ;; hpux10.20* | hpux11*) lt_cv_file_magic_cmd=$FILECMD case $host_cpu in ia64*) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF-[0-9][0-9]) shared object file - IA64' lt_cv_file_magic_test_file=/usr/lib/hpux32/libc.so ;; hppa*64*) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|ELF[ -][0-9][0-9])(-bit)?( [LM]SB)? shared object( file)?[, -]* PA-RISC [0-9]\.[0-9]' lt_cv_file_magic_test_file=/usr/lib/pa20_64/libc.sl ;; *) lt_cv_deplibs_check_method='file_magic (s[0-9][0-9][0-9]|PA-RISC[0-9]\.[0-9]) shared library' lt_cv_file_magic_test_file=/usr/lib/libc.sl ;; esac ;; interix[3-9]*) # PIC code is broken on Interix 3.x, that's why |\.a not |_pic\.a here lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|\.a)$' ;; irix5* | irix6* | nonstopux*) case $LD in *-32|*"-32 ") libmagic=32-bit;; *-n32|*"-n32 ") libmagic=N32;; *-64|*"-64 ") libmagic=64-bit;; *) libmagic=never-match;; esac lt_cv_deplibs_check_method=pass_all ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) lt_cv_deplibs_check_method=pass_all ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ > /dev/null; then lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so|_pic\.a)$' fi ;; newos6*) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (executable|dynamic lib)' lt_cv_file_magic_cmd=$FILECMD lt_cv_file_magic_test_file=/usr/lib/libnls.so ;; *nto* | *qnx*) lt_cv_deplibs_check_method=pass_all ;; openbsd* | bitrig*) if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|\.so|_pic\.a)$' else lt_cv_deplibs_check_method='match_pattern /lib[^/]+(\.so\.[0-9]+\.[0-9]+|_pic\.a)$' fi ;; osf3* | osf4* | osf5*) lt_cv_deplibs_check_method=pass_all ;; rdos*) lt_cv_deplibs_check_method=pass_all ;; solaris*) lt_cv_deplibs_check_method=pass_all ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) lt_cv_deplibs_check_method=pass_all ;; sysv4 | sysv4.3*) case $host_vendor in motorola) lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [ML]SB (shared object|dynamic lib) M[0-9][0-9]* Version [0-9]' lt_cv_file_magic_test_file=`echo /usr/lib/libc.so*` ;; ncr) lt_cv_deplibs_check_method=pass_all ;; sequent) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method='file_magic ELF [0-9][0-9]*-bit [LM]SB (shared object|dynamic lib )' ;; sni) lt_cv_file_magic_cmd='/bin/file' lt_cv_deplibs_check_method="file_magic ELF [0-9][0-9]*-bit [LM]SB dynamic lib" lt_cv_file_magic_test_file=/lib/libc.so ;; siemens) lt_cv_deplibs_check_method=pass_all ;; pc) lt_cv_deplibs_check_method=pass_all ;; esac ;; tpf*) lt_cv_deplibs_check_method=pass_all ;; os2*) lt_cv_deplibs_check_method=pass_all ;; esac fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_deplibs_check_method" >&5 printf "%s\n" "$lt_cv_deplibs_check_method" >&6; } file_magic_glob= want_nocaseglob=no if test "$build" = "$host"; then case $host_os in mingw* | pw32*) if ( shopt | grep nocaseglob ) >/dev/null 2>&1; then want_nocaseglob=yes else file_magic_glob=`echo aAbBcCdDeEfFgGhHiIjJkKlLmMnNoOpPqQrRsStTuUvVwWxXyYzZ | $SED -e "s/\(..\)/s\/[\1]\/[\1]\/g;/g"` fi ;; esac fi file_magic_cmd=$lt_cv_file_magic_cmd deplibs_check_method=$lt_cv_deplibs_check_method test -z "$deplibs_check_method" && deplibs_check_method=unknown if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}dlltool", so it can be a program name with args. set dummy ${ac_tool_prefix}dlltool; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_DLLTOOL+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$DLLTOOL"; then ac_cv_prog_DLLTOOL="$DLLTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_DLLTOOL="${ac_tool_prefix}dlltool" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DLLTOOL=$ac_cv_prog_DLLTOOL if test -n "$DLLTOOL"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $DLLTOOL" >&5 printf "%s\n" "$DLLTOOL" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_DLLTOOL"; then ac_ct_DLLTOOL=$DLLTOOL # Extract the first word of "dlltool", so it can be a program name with args. set dummy dlltool; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_DLLTOOL+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_DLLTOOL"; then ac_cv_prog_ac_ct_DLLTOOL="$ac_ct_DLLTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DLLTOOL="dlltool" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DLLTOOL=$ac_cv_prog_ac_ct_DLLTOOL if test -n "$ac_ct_DLLTOOL"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DLLTOOL" >&5 printf "%s\n" "$ac_ct_DLLTOOL" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_DLLTOOL" = x; then DLLTOOL="false" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DLLTOOL=$ac_ct_DLLTOOL fi else DLLTOOL="$ac_cv_prog_DLLTOOL" fi test -z "$DLLTOOL" && DLLTOOL=dlltool { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking how to associate runtime and link libraries" >&5 printf %s "checking how to associate runtime and link libraries... " >&6; } if test ${lt_cv_sharedlib_from_linklib_cmd+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_sharedlib_from_linklib_cmd='unknown' case $host_os in cygwin* | mingw* | pw32* | cegcc*) # two different shell functions defined in ltmain.sh; # decide which one to use based on capabilities of $DLLTOOL case `$DLLTOOL --help 2>&1` in *--identify-strict*) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib ;; *) lt_cv_sharedlib_from_linklib_cmd=func_cygming_dll_for_implib_fallback ;; esac ;; *) # fallback: assume linklib IS sharedlib lt_cv_sharedlib_from_linklib_cmd=$ECHO ;; esac fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_sharedlib_from_linklib_cmd" >&5 printf "%s\n" "$lt_cv_sharedlib_from_linklib_cmd" >&6; } sharedlib_from_linklib_cmd=$lt_cv_sharedlib_from_linklib_cmd test -z "$sharedlib_from_linklib_cmd" && sharedlib_from_linklib_cmd=$ECHO if test -n "$ac_tool_prefix"; then for ac_prog in ar do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_AR+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$AR"; then ac_cv_prog_AR="$AR" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_AR="$ac_tool_prefix$ac_prog" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi AR=$ac_cv_prog_AR if test -n "$AR"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $AR" >&5 printf "%s\n" "$AR" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -n "$AR" && break done fi if test -z "$AR"; then ac_ct_AR=$AR for ac_prog in ar do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_AR+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_AR"; then ac_cv_prog_ac_ct_AR="$ac_ct_AR" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_AR="$ac_prog" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_AR=$ac_cv_prog_ac_ct_AR if test -n "$ac_ct_AR"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_AR" >&5 printf "%s\n" "$ac_ct_AR" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -n "$ac_ct_AR" && break done if test "x$ac_ct_AR" = x; then AR="false" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac AR=$ac_ct_AR fi fi : ${AR=ar} # Use ARFLAGS variable as AR's operation code to sync the variable naming with # Automake. If both AR_FLAGS and ARFLAGS are specified, AR_FLAGS should have # higher priority because thats what people were doing historically (setting # ARFLAGS for automake and AR_FLAGS for libtool). FIXME: Make the AR_FLAGS # variable obsoleted/removed. test ${AR_FLAGS+y} || AR_FLAGS=${ARFLAGS-cr} lt_ar_flags=$AR_FLAGS # Make AR_FLAGS overridable by 'make ARFLAGS='. Don't try to run-time override # by AR_FLAGS because that was never working and AR_FLAGS is about to die. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for archiver @FILE support" >&5 printf %s "checking for archiver @FILE support... " >&6; } if test ${lt_cv_ar_at_file+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_ar_at_file=no cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : echo conftest.$ac_objext > conftest.lst lt_ar_try='$AR $AR_FLAGS libconftest.a @conftest.lst >&5' { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$lt_ar_try\""; } >&5 (eval $lt_ar_try) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if test 0 -eq "$ac_status"; then # Ensure the archiver fails upon bogus file names. rm -f conftest.$ac_objext libconftest.a { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$lt_ar_try\""; } >&5 (eval $lt_ar_try) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } if test 0 -ne "$ac_status"; then lt_cv_ar_at_file=@ fi fi rm -f conftest.* libconftest.a fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ar_at_file" >&5 printf "%s\n" "$lt_cv_ar_at_file" >&6; } if test no = "$lt_cv_ar_at_file"; then archiver_list_spec= else archiver_list_spec=$lt_cv_ar_at_file fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}strip", so it can be a program name with args. set dummy ${ac_tool_prefix}strip; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_STRIP+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$STRIP"; then ac_cv_prog_STRIP="$STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_STRIP="${ac_tool_prefix}strip" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi STRIP=$ac_cv_prog_STRIP if test -n "$STRIP"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $STRIP" >&5 printf "%s\n" "$STRIP" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_STRIP"; then ac_ct_STRIP=$STRIP # Extract the first word of "strip", so it can be a program name with args. set dummy strip; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_STRIP+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_STRIP"; then ac_cv_prog_ac_ct_STRIP="$ac_ct_STRIP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_STRIP="strip" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_STRIP=$ac_cv_prog_ac_ct_STRIP if test -n "$ac_ct_STRIP"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_STRIP" >&5 printf "%s\n" "$ac_ct_STRIP" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_STRIP" = x; then STRIP=":" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac STRIP=$ac_ct_STRIP fi else STRIP="$ac_cv_prog_STRIP" fi test -z "$STRIP" && STRIP=: if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}ranlib", so it can be a program name with args. set dummy ${ac_tool_prefix}ranlib; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_RANLIB+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$RANLIB"; then ac_cv_prog_RANLIB="$RANLIB" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_RANLIB="${ac_tool_prefix}ranlib" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi RANLIB=$ac_cv_prog_RANLIB if test -n "$RANLIB"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $RANLIB" >&5 printf "%s\n" "$RANLIB" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_RANLIB"; then ac_ct_RANLIB=$RANLIB # Extract the first word of "ranlib", so it can be a program name with args. set dummy ranlib; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_RANLIB+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_RANLIB"; then ac_cv_prog_ac_ct_RANLIB="$ac_ct_RANLIB" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_RANLIB="ranlib" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_RANLIB=$ac_cv_prog_ac_ct_RANLIB if test -n "$ac_ct_RANLIB"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_RANLIB" >&5 printf "%s\n" "$ac_ct_RANLIB" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_RANLIB" = x; then RANLIB=":" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac RANLIB=$ac_ct_RANLIB fi else RANLIB="$ac_cv_prog_RANLIB" fi test -z "$RANLIB" && RANLIB=: # Determine commands to create old-style static archives. old_archive_cmds='$AR $AR_FLAGS $oldlib$oldobjs' old_postinstall_cmds='chmod 644 $oldlib' old_postuninstall_cmds= if test -n "$RANLIB"; then case $host_os in bitrig* | openbsd*) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB -t \$tool_oldlib" ;; *) old_postinstall_cmds="$old_postinstall_cmds~\$RANLIB \$tool_oldlib" ;; esac old_archive_cmds="$old_archive_cmds~\$RANLIB \$tool_oldlib" fi case $host_os in darwin*) lock_old_archive_extraction=yes ;; *) lock_old_archive_extraction=no ;; esac # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC # Check for command to grab the raw symbol name followed by C symbol from nm. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking command to parse $NM output from $compiler object" >&5 printf %s "checking command to parse $NM output from $compiler object... " >&6; } if test ${lt_cv_sys_global_symbol_pipe+y} then : printf %s "(cached) " >&6 else $as_nop # These are sane defaults that work on at least a few old systems. # [They come from Ultrix. What could be older than Ultrix?!! ;)] # Character class describing NM global symbol codes. symcode='[BCDEGRST]' # Regexp to match symbols that can be accessed directly from C. sympat='\([_A-Za-z][_A-Za-z0-9]*\)' # Define system-specific variables. case $host_os in aix*) symcode='[BCDT]' ;; cygwin* | mingw* | pw32* | cegcc*) symcode='[ABCDGISTW]' ;; hpux*) if test ia64 = "$host_cpu"; then symcode='[ABCDEGRST]' fi ;; irix* | nonstopux*) symcode='[BCDEGRST]' ;; osf*) symcode='[BCDEGQRST]' ;; solaris*) symcode='[BDRT]' ;; sco3.2v5*) symcode='[DT]' ;; sysv4.2uw2*) symcode='[DT]' ;; sysv5* | sco5v6* | unixware* | OpenUNIX*) symcode='[ABDT]' ;; sysv4) symcode='[DFNSTU]' ;; esac # If we're using GNU nm, then use its standard symbol codes. case `$NM -V 2>&1` in *GNU* | *'with BFD'*) symcode='[ABCDGIRSTW]' ;; esac if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Gets list of data symbols to import. lt_cv_sys_global_symbol_to_import="$SED -n -e 's/^I .* \(.*\)$/\1/p'" # Adjust the below global symbol transforms to fixup imported variables. lt_cdecl_hook=" -e 's/^I .* \(.*\)$/extern __declspec(dllimport) char \1;/p'" lt_c_name_hook=" -e 's/^I .* \(.*\)$/ {\"\1\", (void *) 0},/p'" lt_c_name_lib_hook="\ -e 's/^I .* \(lib.*\)$/ {\"\1\", (void *) 0},/p'\ -e 's/^I .* \(.*\)$/ {\"lib\1\", (void *) 0},/p'" else # Disable hooks by default. lt_cv_sys_global_symbol_to_import= lt_cdecl_hook= lt_c_name_hook= lt_c_name_lib_hook= fi # Transform an extracted symbol line into a proper C declaration. # Some systems (esp. on ia64) link data and code symbols differently, # so use this general approach. lt_cv_sys_global_symbol_to_cdecl="$SED -n"\ $lt_cdecl_hook\ " -e 's/^T .* \(.*\)$/extern int \1();/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/extern char \1;/p'" # Transform an extracted symbol line into symbol name and symbol address lt_cv_sys_global_symbol_to_c_name_address="$SED -n"\ $lt_c_name_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/p'" # Transform an extracted symbol line into symbol name with lib prefix and # symbol address. lt_cv_sys_global_symbol_to_c_name_address_lib_prefix="$SED -n"\ $lt_c_name_lib_hook\ " -e 's/^: \(.*\) .*$/ {\"\1\", (void *) 0},/p'"\ " -e 's/^$symcode$symcode* .* \(lib.*\)$/ {\"\1\", (void *) \&\1},/p'"\ " -e 's/^$symcode$symcode* .* \(.*\)$/ {\"lib\1\", (void *) \&\1},/p'" # Handle CRLF in mingw tool chain opt_cr= case $build_os in mingw*) opt_cr=`$ECHO 'x\{0,1\}' | tr x '\015'` # option cr in regexp ;; esac # Try without a prefix underscore, then with it. for ac_symprfx in "" "_"; do # Transform symcode, sympat, and symprfx into a raw symbol and a C symbol. symxfrm="\\1 $ac_symprfx\\2 \\2" # Write the raw and C identifiers. if test "$lt_cv_nm_interface" = "MS dumpbin"; then # Fake it for dumpbin and say T for any non-static function, # D for any global variable and I for any imported variable. # Also find C++ and __fastcall symbols from MSVC++ or ICC, # which start with @ or ?. lt_cv_sys_global_symbol_pipe="$AWK '"\ " {last_section=section; section=\$ 3};"\ " /^COFF SYMBOL TABLE/{for(i in hide) delete hide[i]};"\ " /Section length .*#relocs.*(pick any)/{hide[last_section]=1};"\ " /^ *Symbol name *: /{split(\$ 0,sn,\":\"); si=substr(sn[2],2)};"\ " /^ *Type *: code/{print \"T\",si,substr(si,length(prfx))};"\ " /^ *Type *: data/{print \"I\",si,substr(si,length(prfx))};"\ " \$ 0!~/External *\|/{next};"\ " / 0+ UNDEF /{next}; / UNDEF \([^|]\)*()/{next};"\ " {if(hide[section]) next};"\ " {f=\"D\"}; \$ 0~/\(\).*\|/{f=\"T\"};"\ " {split(\$ 0,a,/\||\r/); split(a[2],s)};"\ " s[1]~/^[@?]/{print f,s[1],s[1]; next};"\ " s[1]~prfx {split(s[1],t,\"@\"); print f,t[1],substr(t[1],length(prfx))}"\ " ' prfx=^$ac_symprfx" else lt_cv_sys_global_symbol_pipe="$SED -n -e 's/^.*[ ]\($symcode$symcode*\)[ ][ ]*$ac_symprfx$sympat$opt_cr$/$symxfrm/p'" fi lt_cv_sys_global_symbol_pipe="$lt_cv_sys_global_symbol_pipe | $SED '/ __gnu_lto/d'" # Check to see that the pipe works correctly. pipe_works=no rm -f conftest* cat > conftest.$ac_ext <<_LT_EOF #ifdef __cplusplus extern "C" { #endif char nm_test_var; void nm_test_func(void); void nm_test_func(void){} #ifdef __cplusplus } #endif int main(){nm_test_var='a';nm_test_func();return(0);} _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then # Now try to grab the symbols. nlist=conftest.nm if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist\""; } >&5 (eval $NM conftest.$ac_objext \| "$lt_cv_sys_global_symbol_pipe" \> $nlist) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s "$nlist"; then # Try sorting and uniquifying the output. if sort "$nlist" | uniq > "$nlist"T; then mv -f "$nlist"T "$nlist" else rm -f "$nlist"T fi # Make sure that we snagged all the symbols we need. if $GREP ' nm_test_var$' "$nlist" >/dev/null; then if $GREP ' nm_test_func$' "$nlist" >/dev/null; then cat <<_LT_EOF > conftest.$ac_ext /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE /* DATA imports from DLLs on WIN32 can't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT_DLSYM_CONST #elif defined __osf__ /* This system does not cope well with relocations in const data. */ # define LT_DLSYM_CONST #else # define LT_DLSYM_CONST const #endif #ifdef __cplusplus extern "C" { #endif _LT_EOF # Now generate the symbol file. eval "$lt_cv_sys_global_symbol_to_cdecl"' < "$nlist" | $GREP -v main >> conftest.$ac_ext' cat <<_LT_EOF >> conftest.$ac_ext /* The mapping between symbol names and symbols. */ LT_DLSYM_CONST struct { const char *name; void *address; } lt__PROGRAM__LTX_preloaded_symbols[] = { { "@PROGRAM@", (void *) 0 }, _LT_EOF $SED "s/^$symcode$symcode* .* \(.*\)$/ {\"\1\", (void *) \&\1},/" < "$nlist" | $GREP -v main >> conftest.$ac_ext cat <<\_LT_EOF >> conftest.$ac_ext {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt__PROGRAM__LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif _LT_EOF # Now try linking the two files. mv conftest.$ac_objext conftstm.$ac_objext lt_globsym_save_LIBS=$LIBS lt_globsym_save_CFLAGS=$CFLAGS LIBS=conftstm.$ac_objext CFLAGS="$CFLAGS$lt_prog_compiler_no_builtin_flag" if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s conftest$ac_exeext; then pipe_works=yes fi LIBS=$lt_globsym_save_LIBS CFLAGS=$lt_globsym_save_CFLAGS else echo "cannot find nm_test_func in $nlist" >&5 fi else echo "cannot find nm_test_var in $nlist" >&5 fi else echo "cannot run $lt_cv_sys_global_symbol_pipe" >&5 fi else echo "$progname: failed program was:" >&5 cat conftest.$ac_ext >&5 fi rm -rf conftest* conftst* # Do not use the global_symbol_pipe unless it works. if test yes = "$pipe_works"; then break else lt_cv_sys_global_symbol_pipe= fi done fi if test -z "$lt_cv_sys_global_symbol_pipe"; then lt_cv_sys_global_symbol_to_cdecl= fi if test -z "$lt_cv_sys_global_symbol_pipe$lt_cv_sys_global_symbol_to_cdecl"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: failed" >&5 printf "%s\n" "failed" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: ok" >&5 printf "%s\n" "ok" >&6; } fi # Response file support. if test "$lt_cv_nm_interface" = "MS dumpbin"; then nm_file_list_spec='@' elif $NM --help 2>/dev/null | grep '[@]FILE' >/dev/null; then nm_file_list_spec='@' fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for sysroot" >&5 printf %s "checking for sysroot... " >&6; } # Check whether --with-sysroot was given. if test ${with_sysroot+y} then : withval=$with_sysroot; else $as_nop with_sysroot=no fi lt_sysroot= case $with_sysroot in #( yes) if test yes = "$GCC"; then lt_sysroot=`$CC --print-sysroot 2>/dev/null` fi ;; #( /*) lt_sysroot=`echo "$with_sysroot" | $SED -e "$sed_quote_subst"` ;; #( no|'') ;; #( *) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $with_sysroot" >&5 printf "%s\n" "$with_sysroot" >&6; } as_fn_error $? "The sysroot must be an absolute path." "$LINENO" 5 ;; esac { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: ${lt_sysroot:-no}" >&5 printf "%s\n" "${lt_sysroot:-no}" >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for a working dd" >&5 printf %s "checking for a working dd... " >&6; } if test ${ac_cv_path_lt_DD+y} then : printf %s "(cached) " >&6 else $as_nop printf 0123456789abcdef0123456789abcdef >conftest.i cat conftest.i conftest.i >conftest2.i : ${lt_DD:=$DD} if test -z "$lt_DD"; then ac_path_lt_DD_found=false # Loop through the user's path and test for each of PROGNAME-LIST as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_prog in dd do for ac_exec_ext in '' $ac_executable_extensions; do ac_path_lt_DD="$as_dir$ac_prog$ac_exec_ext" as_fn_executable_p "$ac_path_lt_DD" || continue if "$ac_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && ac_cv_path_lt_DD="$ac_path_lt_DD" ac_path_lt_DD_found=: fi $ac_path_lt_DD_found && break 3 done done done IFS=$as_save_IFS if test -z "$ac_cv_path_lt_DD"; then : fi else ac_cv_path_lt_DD=$lt_DD fi rm -f conftest.i conftest2.i conftest.out fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_path_lt_DD" >&5 printf "%s\n" "$ac_cv_path_lt_DD" >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking how to truncate binary pipes" >&5 printf %s "checking how to truncate binary pipes... " >&6; } if test ${lt_cv_truncate_bin+y} then : printf %s "(cached) " >&6 else $as_nop printf 0123456789abcdef0123456789abcdef >conftest.i cat conftest.i conftest.i >conftest2.i lt_cv_truncate_bin= if "$ac_cv_path_lt_DD" bs=32 count=1 conftest.out 2>/dev/null; then cmp -s conftest.i conftest.out \ && lt_cv_truncate_bin="$ac_cv_path_lt_DD bs=4096 count=1" fi rm -f conftest.i conftest2.i conftest.out test -z "$lt_cv_truncate_bin" && lt_cv_truncate_bin="$SED -e 4q" fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_truncate_bin" >&5 printf "%s\n" "$lt_cv_truncate_bin" >&6; } # Calculate cc_basename. Skip known compiler wrappers and cross-prefix. func_cc_basename () { for cc_temp in $*""; do case $cc_temp in compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; \-*) ;; *) break;; esac done func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` } # Check whether --enable-libtool-lock was given. if test ${enable_libtool_lock+y} then : enableval=$enable_libtool_lock; fi test no = "$enable_libtool_lock" || enable_libtool_lock=yes # Some flags need to be propagated to the compiler or linker for good # libtool support. case $host in ia64-*-hpux*) # Find out what ABI is being produced by ac_compile, and set mode # options accordingly. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `$FILECMD conftest.$ac_objext` in *ELF-32*) HPUX_IA64_MODE=32 ;; *ELF-64*) HPUX_IA64_MODE=64 ;; esac fi rm -rf conftest* ;; *-*-irix6*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '#line '$LINENO' "configure"' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then if test yes = "$lt_cv_prog_gnu_ld"; then case `$FILECMD conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -melf32bsmip" ;; *N32*) LD="${LD-ld} -melf32bmipn32" ;; *64-bit*) LD="${LD-ld} -melf64bmip" ;; esac else case `$FILECMD conftest.$ac_objext` in *32-bit*) LD="${LD-ld} -32" ;; *N32*) LD="${LD-ld} -n32" ;; *64-bit*) LD="${LD-ld} -64" ;; esac fi fi rm -rf conftest* ;; mips64*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo '#line '$LINENO' "configure"' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then emul=elf case `$FILECMD conftest.$ac_objext` in *32-bit*) emul="${emul}32" ;; *64-bit*) emul="${emul}64" ;; esac case `$FILECMD conftest.$ac_objext` in *MSB*) emul="${emul}btsmip" ;; *LSB*) emul="${emul}ltsmip" ;; esac case `$FILECMD conftest.$ac_objext` in *N32*) emul="${emul}n32" ;; esac LD="${LD-ld} -m $emul" fi rm -rf conftest* ;; x86_64-*kfreebsd*-gnu|x86_64-*linux*|powerpc*-*linux*| \ s390*-*linux*|s390*-*tpf*|sparc*-*linux*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. Note that the listed cases only cover the # situations where additional linker options are needed (such as when # doing 32-bit compilation for a host where ld defaults to 64-bit, or # vice versa); the common cases where no linker options are needed do # not appear in the list. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `$FILECMD conftest.o` in *32-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_i386_fbsd" ;; x86_64-*linux*) case `$FILECMD conftest.o` in *x86-64*) LD="${LD-ld} -m elf32_x86_64" ;; *) LD="${LD-ld} -m elf_i386" ;; esac ;; powerpc64le-*linux*) LD="${LD-ld} -m elf32lppclinux" ;; powerpc64-*linux*) LD="${LD-ld} -m elf32ppclinux" ;; s390x-*linux*) LD="${LD-ld} -m elf_s390" ;; sparc64-*linux*) LD="${LD-ld} -m elf32_sparc" ;; esac ;; *64-bit*) case $host in x86_64-*kfreebsd*-gnu) LD="${LD-ld} -m elf_x86_64_fbsd" ;; x86_64-*linux*) LD="${LD-ld} -m elf_x86_64" ;; powerpcle-*linux*) LD="${LD-ld} -m elf64lppc" ;; powerpc-*linux*) LD="${LD-ld} -m elf64ppc" ;; s390*-*linux*|s390*-*tpf*) LD="${LD-ld} -m elf64_s390" ;; sparc*-*linux*) LD="${LD-ld} -m elf64_sparc" ;; esac ;; esac fi rm -rf conftest* ;; *-*-sco3.2v5*) # On SCO OpenServer 5, we need -belf to get full-featured binaries. SAVE_CFLAGS=$CFLAGS CFLAGS="$CFLAGS -belf" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether the C compiler needs -belf" >&5 printf %s "checking whether the C compiler needs -belf... " >&6; } if test ${lt_cv_cc_needs_belf+y} then : printf %s "(cached) " >&6 else $as_nop ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : lt_cv_cc_needs_belf=yes else $as_nop lt_cv_cc_needs_belf=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_cc_needs_belf" >&5 printf "%s\n" "$lt_cv_cc_needs_belf" >&6; } if test yes != "$lt_cv_cc_needs_belf"; then # this is probably gcc 2.8.0, egcs 1.0 or newer; no need for -belf CFLAGS=$SAVE_CFLAGS fi ;; *-*solaris*) # Find out what ABI is being produced by ac_compile, and set linker # options accordingly. echo 'int i;' > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then case `$FILECMD conftest.o` in *64-bit*) case $lt_cv_prog_gnu_ld in yes*) case $host in i?86-*-solaris*|x86_64-*-solaris*) LD="${LD-ld} -m elf_x86_64" ;; sparc*-*-solaris*) LD="${LD-ld} -m elf64_sparc" ;; esac # GNU ld 2.21 introduced _sol2 emulations. Use them if available. if ${LD-ld} -V | grep _sol2 >/dev/null 2>&1; then LD=${LD-ld}_sol2 fi ;; *) if ${LD-ld} -64 -r -o conftest2.o conftest.o >/dev/null 2>&1; then LD="${LD-ld} -64" fi ;; esac ;; esac fi rm -rf conftest* ;; esac need_locks=$enable_libtool_lock if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}mt", so it can be a program name with args. set dummy ${ac_tool_prefix}mt; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_MANIFEST_TOOL+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$MANIFEST_TOOL"; then ac_cv_prog_MANIFEST_TOOL="$MANIFEST_TOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_MANIFEST_TOOL="${ac_tool_prefix}mt" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi MANIFEST_TOOL=$ac_cv_prog_MANIFEST_TOOL if test -n "$MANIFEST_TOOL"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $MANIFEST_TOOL" >&5 printf "%s\n" "$MANIFEST_TOOL" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_MANIFEST_TOOL"; then ac_ct_MANIFEST_TOOL=$MANIFEST_TOOL # Extract the first word of "mt", so it can be a program name with args. set dummy mt; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_MANIFEST_TOOL+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_MANIFEST_TOOL"; then ac_cv_prog_ac_ct_MANIFEST_TOOL="$ac_ct_MANIFEST_TOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_MANIFEST_TOOL="mt" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_MANIFEST_TOOL=$ac_cv_prog_ac_ct_MANIFEST_TOOL if test -n "$ac_ct_MANIFEST_TOOL"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_MANIFEST_TOOL" >&5 printf "%s\n" "$ac_ct_MANIFEST_TOOL" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_MANIFEST_TOOL" = x; then MANIFEST_TOOL=":" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac MANIFEST_TOOL=$ac_ct_MANIFEST_TOOL fi else MANIFEST_TOOL="$ac_cv_prog_MANIFEST_TOOL" fi test -z "$MANIFEST_TOOL" && MANIFEST_TOOL=mt { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if $MANIFEST_TOOL is a manifest tool" >&5 printf %s "checking if $MANIFEST_TOOL is a manifest tool... " >&6; } if test ${lt_cv_path_mainfest_tool+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_path_mainfest_tool=no echo "$as_me:$LINENO: $MANIFEST_TOOL '-?'" >&5 $MANIFEST_TOOL '-?' 2>conftest.err > conftest.out cat conftest.err >&5 if $GREP 'Manifest Tool' conftest.out > /dev/null; then lt_cv_path_mainfest_tool=yes fi rm -f conftest* fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_path_mainfest_tool" >&5 printf "%s\n" "$lt_cv_path_mainfest_tool" >&6; } if test yes != "$lt_cv_path_mainfest_tool"; then MANIFEST_TOOL=: fi case $host_os in rhapsody* | darwin*) if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}dsymutil", so it can be a program name with args. set dummy ${ac_tool_prefix}dsymutil; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_DSYMUTIL+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$DSYMUTIL"; then ac_cv_prog_DSYMUTIL="$DSYMUTIL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_DSYMUTIL="${ac_tool_prefix}dsymutil" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DSYMUTIL=$ac_cv_prog_DSYMUTIL if test -n "$DSYMUTIL"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $DSYMUTIL" >&5 printf "%s\n" "$DSYMUTIL" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_DSYMUTIL"; then ac_ct_DSYMUTIL=$DSYMUTIL # Extract the first word of "dsymutil", so it can be a program name with args. set dummy dsymutil; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_DSYMUTIL+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_DSYMUTIL"; then ac_cv_prog_ac_ct_DSYMUTIL="$ac_ct_DSYMUTIL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DSYMUTIL="dsymutil" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DSYMUTIL=$ac_cv_prog_ac_ct_DSYMUTIL if test -n "$ac_ct_DSYMUTIL"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DSYMUTIL" >&5 printf "%s\n" "$ac_ct_DSYMUTIL" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_DSYMUTIL" = x; then DSYMUTIL=":" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DSYMUTIL=$ac_ct_DSYMUTIL fi else DSYMUTIL="$ac_cv_prog_DSYMUTIL" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}nmedit", so it can be a program name with args. set dummy ${ac_tool_prefix}nmedit; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_NMEDIT+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$NMEDIT"; then ac_cv_prog_NMEDIT="$NMEDIT" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_NMEDIT="${ac_tool_prefix}nmedit" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi NMEDIT=$ac_cv_prog_NMEDIT if test -n "$NMEDIT"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $NMEDIT" >&5 printf "%s\n" "$NMEDIT" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_NMEDIT"; then ac_ct_NMEDIT=$NMEDIT # Extract the first word of "nmedit", so it can be a program name with args. set dummy nmedit; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_NMEDIT+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_NMEDIT"; then ac_cv_prog_ac_ct_NMEDIT="$ac_ct_NMEDIT" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_NMEDIT="nmedit" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_NMEDIT=$ac_cv_prog_ac_ct_NMEDIT if test -n "$ac_ct_NMEDIT"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_NMEDIT" >&5 printf "%s\n" "$ac_ct_NMEDIT" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_NMEDIT" = x; then NMEDIT=":" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac NMEDIT=$ac_ct_NMEDIT fi else NMEDIT="$ac_cv_prog_NMEDIT" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}lipo", so it can be a program name with args. set dummy ${ac_tool_prefix}lipo; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_LIPO+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$LIPO"; then ac_cv_prog_LIPO="$LIPO" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_LIPO="${ac_tool_prefix}lipo" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi LIPO=$ac_cv_prog_LIPO if test -n "$LIPO"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $LIPO" >&5 printf "%s\n" "$LIPO" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_LIPO"; then ac_ct_LIPO=$LIPO # Extract the first word of "lipo", so it can be a program name with args. set dummy lipo; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_LIPO+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_LIPO"; then ac_cv_prog_ac_ct_LIPO="$ac_ct_LIPO" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_LIPO="lipo" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_LIPO=$ac_cv_prog_ac_ct_LIPO if test -n "$ac_ct_LIPO"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_LIPO" >&5 printf "%s\n" "$ac_ct_LIPO" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_LIPO" = x; then LIPO=":" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac LIPO=$ac_ct_LIPO fi else LIPO="$ac_cv_prog_LIPO" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}otool", so it can be a program name with args. set dummy ${ac_tool_prefix}otool; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_OTOOL+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$OTOOL"; then ac_cv_prog_OTOOL="$OTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_OTOOL="${ac_tool_prefix}otool" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OTOOL=$ac_cv_prog_OTOOL if test -n "$OTOOL"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $OTOOL" >&5 printf "%s\n" "$OTOOL" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_OTOOL"; then ac_ct_OTOOL=$OTOOL # Extract the first word of "otool", so it can be a program name with args. set dummy otool; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_OTOOL+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_OTOOL"; then ac_cv_prog_ac_ct_OTOOL="$ac_ct_OTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OTOOL="otool" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OTOOL=$ac_cv_prog_ac_ct_OTOOL if test -n "$ac_ct_OTOOL"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OTOOL" >&5 printf "%s\n" "$ac_ct_OTOOL" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_OTOOL" = x; then OTOOL=":" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OTOOL=$ac_ct_OTOOL fi else OTOOL="$ac_cv_prog_OTOOL" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}otool64", so it can be a program name with args. set dummy ${ac_tool_prefix}otool64; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_OTOOL64+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$OTOOL64"; then ac_cv_prog_OTOOL64="$OTOOL64" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_OTOOL64="${ac_tool_prefix}otool64" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OTOOL64=$ac_cv_prog_OTOOL64 if test -n "$OTOOL64"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $OTOOL64" >&5 printf "%s\n" "$OTOOL64" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_OTOOL64"; then ac_ct_OTOOL64=$OTOOL64 # Extract the first word of "otool64", so it can be a program name with args. set dummy otool64; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_OTOOL64+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_OTOOL64"; then ac_cv_prog_ac_ct_OTOOL64="$ac_ct_OTOOL64" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OTOOL64="otool64" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OTOOL64=$ac_cv_prog_ac_ct_OTOOL64 if test -n "$ac_ct_OTOOL64"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OTOOL64" >&5 printf "%s\n" "$ac_ct_OTOOL64" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_OTOOL64" = x; then OTOOL64=":" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OTOOL64=$ac_ct_OTOOL64 fi else OTOOL64="$ac_cv_prog_OTOOL64" fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for -single_module linker flag" >&5 printf %s "checking for -single_module linker flag... " >&6; } if test ${lt_cv_apple_cc_single_mod+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_apple_cc_single_mod=no if test -z "$LT_MULTI_MODULE"; then # By default we will add the -single_module flag. You can override # by either setting the environment variable LT_MULTI_MODULE # non-empty at configure time, or by adding -multi_module to the # link flags. rm -rf libconftest.dylib* echo "int foo(void){return 1;}" > conftest.c echo "$LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c" >&5 $LTCC $LTCFLAGS $LDFLAGS -o libconftest.dylib \ -dynamiclib -Wl,-single_module conftest.c 2>conftest.err _lt_result=$? # If there is a non-empty error log, and "single_module" # appears in it, assume the flag caused a linker warning if test -s conftest.err && $GREP single_module conftest.err; then cat conftest.err >&5 # Otherwise, if the output was created with a 0 exit code from # the compiler, it worked. elif test -f libconftest.dylib && test 0 = "$_lt_result"; then lt_cv_apple_cc_single_mod=yes else cat conftest.err >&5 fi rm -rf libconftest.dylib* rm -f conftest.* fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_apple_cc_single_mod" >&5 printf "%s\n" "$lt_cv_apple_cc_single_mod" >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for -exported_symbols_list linker flag" >&5 printf %s "checking for -exported_symbols_list linker flag... " >&6; } if test ${lt_cv_ld_exported_symbols_list+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_ld_exported_symbols_list=no save_LDFLAGS=$LDFLAGS echo "_main" > conftest.sym LDFLAGS="$LDFLAGS -Wl,-exported_symbols_list,conftest.sym" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : lt_cv_ld_exported_symbols_list=yes else $as_nop lt_cv_ld_exported_symbols_list=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_exported_symbols_list" >&5 printf "%s\n" "$lt_cv_ld_exported_symbols_list" >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for -force_load linker flag" >&5 printf %s "checking for -force_load linker flag... " >&6; } if test ${lt_cv_ld_force_load+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_ld_force_load=no cat > conftest.c << _LT_EOF int forced_loaded() { return 2;} _LT_EOF echo "$LTCC $LTCFLAGS -c -o conftest.o conftest.c" >&5 $LTCC $LTCFLAGS -c -o conftest.o conftest.c 2>&5 echo "$AR $AR_FLAGS libconftest.a conftest.o" >&5 $AR $AR_FLAGS libconftest.a conftest.o 2>&5 echo "$RANLIB libconftest.a" >&5 $RANLIB libconftest.a 2>&5 cat > conftest.c << _LT_EOF int main() { return 0;} _LT_EOF echo "$LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a" >&5 $LTCC $LTCFLAGS $LDFLAGS -o conftest conftest.c -Wl,-force_load,./libconftest.a 2>conftest.err _lt_result=$? if test -s conftest.err && $GREP force_load conftest.err; then cat conftest.err >&5 elif test -f conftest && test 0 = "$_lt_result" && $GREP forced_load conftest >/dev/null 2>&1; then lt_cv_ld_force_load=yes else cat conftest.err >&5 fi rm -f conftest.err libconftest.a conftest conftest.c rm -rf conftest.dSYM fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_ld_force_load" >&5 printf "%s\n" "$lt_cv_ld_force_load" >&6; } case $host_os in rhapsody* | darwin1.[012]) _lt_dar_allow_undefined='$wl-undefined ${wl}suppress' ;; darwin1.*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; darwin*) case $MACOSX_DEPLOYMENT_TARGET,$host in 10.[012],*|,*powerpc*-darwin[5-8]*) _lt_dar_allow_undefined='$wl-flat_namespace $wl-undefined ${wl}suppress' ;; *) _lt_dar_allow_undefined='$wl-undefined ${wl}dynamic_lookup' ;; esac ;; esac if test yes = "$lt_cv_apple_cc_single_mod"; then _lt_dar_single_mod='$single_module' fi if test yes = "$lt_cv_ld_exported_symbols_list"; then _lt_dar_export_syms=' $wl-exported_symbols_list,$output_objdir/$libname-symbols.expsym' else _lt_dar_export_syms='~$NMEDIT -s $output_objdir/$libname-symbols.expsym $lib' fi if test : != "$DSYMUTIL" && test no = "$lt_cv_ld_force_load"; then _lt_dsymutil='~$DSYMUTIL $lib || :' else _lt_dsymutil= fi ;; esac # func_munge_path_list VARIABLE PATH # ----------------------------------- # VARIABLE is name of variable containing _space_ separated list of # directories to be munged by the contents of PATH, which is string # having a format: # "DIR[:DIR]:" # string "DIR[ DIR]" will be prepended to VARIABLE # ":DIR[:DIR]" # string "DIR[ DIR]" will be appended to VARIABLE # "DIRP[:DIRP]::[DIRA:]DIRA" # string "DIRP[ DIRP]" will be prepended to VARIABLE and string # "DIRA[ DIRA]" will be appended to VARIABLE # "DIR[:DIR]" # VARIABLE will be replaced by "DIR[ DIR]" func_munge_path_list () { case x$2 in x) ;; *:) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'` \$$1\" ;; x:*) eval $1=\"\$$1 `$ECHO $2 | $SED 's/:/ /g'`\" ;; *::*) eval $1=\"\$$1\ `$ECHO $2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" eval $1=\"`$ECHO $2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \$$1\" ;; *) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'`\" ;; esac } ac_header= ac_cache= for ac_item in $ac_header_c_list do if test $ac_cache; then ac_fn_c_check_header_compile "$LINENO" $ac_header ac_cv_header_$ac_cache "$ac_includes_default" if eval test \"x\$ac_cv_header_$ac_cache\" = xyes; then printf "%s\n" "#define $ac_item 1" >> confdefs.h fi ac_header= ac_cache= elif test $ac_header; then ac_cache=$ac_item else ac_header=$ac_item fi done if test $ac_cv_header_stdlib_h = yes && test $ac_cv_header_string_h = yes then : printf "%s\n" "#define STDC_HEADERS 1" >>confdefs.h fi ac_fn_c_check_header_compile "$LINENO" "dlfcn.h" "ac_cv_header_dlfcn_h" "$ac_includes_default " if test "x$ac_cv_header_dlfcn_h" = xyes then : printf "%s\n" "#define HAVE_DLFCN_H 1" >>confdefs.h fi # Set options enable_win32_dll=yes case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-cegcc*) if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}as", so it can be a program name with args. set dummy ${ac_tool_prefix}as; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_AS+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$AS"; then ac_cv_prog_AS="$AS" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_AS="${ac_tool_prefix}as" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi AS=$ac_cv_prog_AS if test -n "$AS"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $AS" >&5 printf "%s\n" "$AS" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_AS"; then ac_ct_AS=$AS # Extract the first word of "as", so it can be a program name with args. set dummy as; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_AS+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_AS"; then ac_cv_prog_ac_ct_AS="$ac_ct_AS" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_AS="as" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_AS=$ac_cv_prog_ac_ct_AS if test -n "$ac_ct_AS"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_AS" >&5 printf "%s\n" "$ac_ct_AS" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_AS" = x; then AS="false" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac AS=$ac_ct_AS fi else AS="$ac_cv_prog_AS" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}dlltool", so it can be a program name with args. set dummy ${ac_tool_prefix}dlltool; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_DLLTOOL+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$DLLTOOL"; then ac_cv_prog_DLLTOOL="$DLLTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_DLLTOOL="${ac_tool_prefix}dlltool" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi DLLTOOL=$ac_cv_prog_DLLTOOL if test -n "$DLLTOOL"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $DLLTOOL" >&5 printf "%s\n" "$DLLTOOL" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_DLLTOOL"; then ac_ct_DLLTOOL=$DLLTOOL # Extract the first word of "dlltool", so it can be a program name with args. set dummy dlltool; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_DLLTOOL+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_DLLTOOL"; then ac_cv_prog_ac_ct_DLLTOOL="$ac_ct_DLLTOOL" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_DLLTOOL="dlltool" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_DLLTOOL=$ac_cv_prog_ac_ct_DLLTOOL if test -n "$ac_ct_DLLTOOL"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_DLLTOOL" >&5 printf "%s\n" "$ac_ct_DLLTOOL" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_DLLTOOL" = x; then DLLTOOL="false" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac DLLTOOL=$ac_ct_DLLTOOL fi else DLLTOOL="$ac_cv_prog_DLLTOOL" fi if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}objdump", so it can be a program name with args. set dummy ${ac_tool_prefix}objdump; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_OBJDUMP+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$OBJDUMP"; then ac_cv_prog_OBJDUMP="$OBJDUMP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_OBJDUMP="${ac_tool_prefix}objdump" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi OBJDUMP=$ac_cv_prog_OBJDUMP if test -n "$OBJDUMP"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $OBJDUMP" >&5 printf "%s\n" "$OBJDUMP" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_OBJDUMP"; then ac_ct_OBJDUMP=$OBJDUMP # Extract the first word of "objdump", so it can be a program name with args. set dummy objdump; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_OBJDUMP+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_OBJDUMP"; then ac_cv_prog_ac_ct_OBJDUMP="$ac_ct_OBJDUMP" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_OBJDUMP="objdump" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_OBJDUMP=$ac_cv_prog_ac_ct_OBJDUMP if test -n "$ac_ct_OBJDUMP"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_OBJDUMP" >&5 printf "%s\n" "$ac_ct_OBJDUMP" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_OBJDUMP" = x; then OBJDUMP="false" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac OBJDUMP=$ac_ct_OBJDUMP fi else OBJDUMP="$ac_cv_prog_OBJDUMP" fi ;; esac test -z "$AS" && AS=as test -z "$DLLTOOL" && DLLTOOL=dlltool test -z "$OBJDUMP" && OBJDUMP=objdump enable_dlopen=no # Check whether --enable-shared was given. if test ${enable_shared+y} then : enableval=$enable_shared; p=${PACKAGE-default} case $enableval in yes) enable_shared=yes ;; no) enable_shared=no ;; *) enable_shared=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_shared=yes fi done IFS=$lt_save_ifs ;; esac else $as_nop enable_shared=yes fi # Check whether --enable-static was given. if test ${enable_static+y} then : enableval=$enable_static; p=${PACKAGE-default} case $enableval in yes) enable_static=yes ;; no) enable_static=no ;; *) enable_static=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_static=yes fi done IFS=$lt_save_ifs ;; esac else $as_nop enable_static=yes fi # Check whether --with-pic was given. if test ${with_pic+y} then : withval=$with_pic; lt_p=${PACKAGE-default} case $withval in yes|no) pic_mode=$withval ;; *) pic_mode=default # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for lt_pkg in $withval; do IFS=$lt_save_ifs if test "X$lt_pkg" = "X$lt_p"; then pic_mode=yes fi done IFS=$lt_save_ifs ;; esac else $as_nop pic_mode=default fi # Check whether --enable-fast-install was given. if test ${enable_fast_install+y} then : enableval=$enable_fast_install; p=${PACKAGE-default} case $enableval in yes) enable_fast_install=yes ;; no) enable_fast_install=no ;; *) enable_fast_install=no # Look at the argument we got. We use all the common list separators. lt_save_ifs=$IFS; IFS=$IFS$PATH_SEPARATOR, for pkg in $enableval; do IFS=$lt_save_ifs if test "X$pkg" = "X$p"; then enable_fast_install=yes fi done IFS=$lt_save_ifs ;; esac else $as_nop enable_fast_install=yes fi shared_archive_member_spec= case $host,$enable_shared in power*-*-aix[5-9]*,yes) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking which variant of shared library versioning to provide" >&5 printf %s "checking which variant of shared library versioning to provide... " >&6; } # Check whether --with-aix-soname was given. if test ${with_aix_soname+y} then : withval=$with_aix_soname; case $withval in aix|svr4|both) ;; *) as_fn_error $? "Unknown argument to --with-aix-soname" "$LINENO" 5 ;; esac lt_cv_with_aix_soname=$with_aix_soname else $as_nop if test ${lt_cv_with_aix_soname+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_with_aix_soname=aix fi with_aix_soname=$lt_cv_with_aix_soname fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $with_aix_soname" >&5 printf "%s\n" "$with_aix_soname" >&6; } if test aix != "$with_aix_soname"; then # For the AIX way of multilib, we name the shared archive member # based on the bitwidth used, traditionally 'shr.o' or 'shr_64.o', # and 'shr.imp' or 'shr_64.imp', respectively, for the Import File. # Even when GNU compilers ignore OBJECT_MODE but need '-maix64' flag, # the AIX toolchain works better with OBJECT_MODE set (default 32). if test 64 = "${OBJECT_MODE-32}"; then shared_archive_member_spec=shr_64 else shared_archive_member_spec=shr fi fi ;; *) with_aix_soname=aix ;; esac # This can be used to rebuild libtool when needed LIBTOOL_DEPS=$ltmain # Always use our own libtool. LIBTOOL='$(SHELL) $(top_builddir)/libtool' test -z "$LN_S" && LN_S="ln -s" if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for objdir" >&5 printf %s "checking for objdir... " >&6; } if test ${lt_cv_objdir+y} then : printf %s "(cached) " >&6 else $as_nop rm -f .libs 2>/dev/null mkdir .libs 2>/dev/null if test -d .libs; then lt_cv_objdir=.libs else # MS-DOS does not allow filenames that begin with a dot. lt_cv_objdir=_libs fi rmdir .libs 2>/dev/null fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_objdir" >&5 printf "%s\n" "$lt_cv_objdir" >&6; } objdir=$lt_cv_objdir printf "%s\n" "#define LT_OBJDIR \"$lt_cv_objdir/\"" >>confdefs.h case $host_os in aix3*) # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi ;; esac # Global variables: ofile=libtool can_build_shared=yes # All known linkers require a '.a' archive for static linking (except MSVC and # ICC, which need '.lib'). libext=a with_gnu_ld=$lt_cv_prog_gnu_ld old_CC=$CC old_CFLAGS=$CFLAGS # Set sane defaults for various variables test -z "$CC" && CC=cc test -z "$LTCC" && LTCC=$CC test -z "$LTCFLAGS" && LTCFLAGS=$CFLAGS test -z "$LD" && LD=ld test -z "$ac_objext" && ac_objext=o func_cc_basename $compiler cc_basename=$func_cc_basename_result # Only perform the check for file, if the check method requires it test -z "$MAGIC_CMD" && MAGIC_CMD=file case $deplibs_check_method in file_magic*) if test "$file_magic_cmd" = '$MAGIC_CMD'; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for ${ac_tool_prefix}file" >&5 printf %s "checking for ${ac_tool_prefix}file... " >&6; } if test ${lt_cv_path_MAGIC_CMD+y} then : printf %s "(cached) " >&6 else $as_nop case $MAGIC_CMD in [\\/*] | ?:[\\/]*) lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD=$MAGIC_CMD lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" for ac_dir in $ac_dummy; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/${ac_tool_prefix}file"; then lt_cv_path_MAGIC_CMD=$ac_dir/"${ac_tool_prefix}file" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD=$lt_cv_path_MAGIC_CMD if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS=$lt_save_ifs MAGIC_CMD=$lt_save_MAGIC_CMD ;; esac fi MAGIC_CMD=$lt_cv_path_MAGIC_CMD if test -n "$MAGIC_CMD"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5 printf "%s\n" "$MAGIC_CMD" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test -z "$lt_cv_path_MAGIC_CMD"; then if test -n "$ac_tool_prefix"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for file" >&5 printf %s "checking for file... " >&6; } if test ${lt_cv_path_MAGIC_CMD+y} then : printf %s "(cached) " >&6 else $as_nop case $MAGIC_CMD in [\\/*] | ?:[\\/]*) lt_cv_path_MAGIC_CMD=$MAGIC_CMD # Let the user override the test with a path. ;; *) lt_save_MAGIC_CMD=$MAGIC_CMD lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR ac_dummy="/usr/bin$PATH_SEPARATOR$PATH" for ac_dir in $ac_dummy; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/file"; then lt_cv_path_MAGIC_CMD=$ac_dir/"file" if test -n "$file_magic_test_file"; then case $deplibs_check_method in "file_magic "*) file_magic_regex=`expr "$deplibs_check_method" : "file_magic \(.*\)"` MAGIC_CMD=$lt_cv_path_MAGIC_CMD if eval $file_magic_cmd \$file_magic_test_file 2> /dev/null | $EGREP "$file_magic_regex" > /dev/null; then : else cat <<_LT_EOF 1>&2 *** Warning: the command libtool uses to detect shared libraries, *** $file_magic_cmd, produces output that libtool cannot recognize. *** The result is that libtool may fail to recognize shared libraries *** as such. This will affect the creation of libtool libraries that *** depend on shared libraries, but programs linked with such libtool *** libraries will work regardless of this problem. Nevertheless, you *** may want to report the problem to your system manager and/or to *** bug-libtool@gnu.org _LT_EOF fi ;; esac fi break fi done IFS=$lt_save_ifs MAGIC_CMD=$lt_save_MAGIC_CMD ;; esac fi MAGIC_CMD=$lt_cv_path_MAGIC_CMD if test -n "$MAGIC_CMD"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $MAGIC_CMD" >&5 printf "%s\n" "$MAGIC_CMD" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi else MAGIC_CMD=: fi fi fi ;; esac # Use C for the default configuration in the libtool script lt_save_CC=$CC ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu # Source file extension for C test sources. ac_ext=c # Object file extension for compiled C test sources. objext=o objext=$objext # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(){return(0);}' # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC # Save the default compiler, since it gets overwritten when the other # tags are being tested, and _LT_TAGVAR(compiler, []) is a NOP. compiler_DEFAULT=$CC # save warnings/boilerplate of simple test code ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" >conftest.$ac_ext eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_compiler_boilerplate=`cat conftest.err` $RM conftest* ac_outfile=conftest.$ac_objext echo "$lt_simple_link_test_code" >conftest.$ac_ext eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_linker_boilerplate=`cat conftest.err` $RM -r conftest* ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... if test -n "$compiler"; then lt_prog_compiler_no_builtin_flag= if test yes = "$GCC"; then case $cc_basename in nvcc*) lt_prog_compiler_no_builtin_flag=' -Xcompiler -fno-builtin' ;; *) lt_prog_compiler_no_builtin_flag=' -fno-builtin' ;; esac { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -fno-rtti -fno-exceptions" >&5 printf %s "checking if $compiler supports -fno-rtti -fno-exceptions... " >&6; } if test ${lt_cv_prog_compiler_rtti_exceptions+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_prog_compiler_rtti_exceptions=no ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-fno-rtti -fno-exceptions" ## exclude from sc_useless_quotes_in_assignment # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_rtti_exceptions=yes fi fi $RM conftest* fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_rtti_exceptions" >&5 printf "%s\n" "$lt_cv_prog_compiler_rtti_exceptions" >&6; } if test yes = "$lt_cv_prog_compiler_rtti_exceptions"; then lt_prog_compiler_no_builtin_flag="$lt_prog_compiler_no_builtin_flag -fno-rtti -fno-exceptions" else : fi fi lt_prog_compiler_wl= lt_prog_compiler_pic= lt_prog_compiler_static= if test yes = "$GCC"; then lt_prog_compiler_wl='-Wl,' lt_prog_compiler_static='-static' case $host_os in aix*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor lt_prog_compiler_static='-Bstatic' fi lt_prog_compiler_pic='-fPIC' ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support lt_prog_compiler_pic='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the '-m68020' flag to GCC prevents building anything better, # like '-m68040'. lt_prog_compiler_pic='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries lt_prog_compiler_pic='-DDLL_EXPORT' case $host_os in os2*) lt_prog_compiler_static='$wl-static' ;; esac ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files lt_prog_compiler_pic='-fno-common' ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. lt_prog_compiler_static= ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) # +Z the default ;; *) lt_prog_compiler_pic='-fPIC' ;; esac ;; interix[3-9]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; msdosdjgpp*) # Just because we use GCC doesn't mean we suddenly get shared libraries # on systems that don't support them. lt_prog_compiler_can_build_shared=no enable_shared=no ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic='-fPIC -shared' ;; sysv4*MP*) if test -d /usr/nec; then lt_prog_compiler_pic=-Kconform_pic fi ;; *) lt_prog_compiler_pic='-fPIC' ;; esac case $cc_basename in nvcc*) # Cuda Compiler Driver 2.2 lt_prog_compiler_wl='-Xlinker ' if test -n "$lt_prog_compiler_pic"; then lt_prog_compiler_pic="-Xcompiler $lt_prog_compiler_pic" fi ;; esac else # PORTME Check for flag to pass linker flags through the system compiler. case $host_os in aix*) lt_prog_compiler_wl='-Wl,' if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor lt_prog_compiler_static='-Bstatic' else lt_prog_compiler_static='-bnso -bI:/lib/syscalls.exp' fi ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files lt_prog_compiler_pic='-fno-common' case $cc_basename in nagfor*) # NAG Fortran compiler lt_prog_compiler_wl='-Wl,-Wl,,' lt_prog_compiler_pic='-PIC' lt_prog_compiler_static='-Bstatic' ;; esac ;; mingw* | cygwin* | pw32* | os2* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). lt_prog_compiler_pic='-DDLL_EXPORT' case $host_os in os2*) lt_prog_compiler_static='$wl-static' ;; esac ;; hpux9* | hpux10* | hpux11*) lt_prog_compiler_wl='-Wl,' # PIC is the default for IA64 HP-UX and 64-bit HP-UX, but # not for PA HP-UX. case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) lt_prog_compiler_pic='+Z' ;; esac # Is there a better lt_prog_compiler_static that works with the bundled CC? lt_prog_compiler_static='$wl-a ${wl}archive' ;; irix5* | irix6* | nonstopux*) lt_prog_compiler_wl='-Wl,' # PIC (with -KPIC) is the default. lt_prog_compiler_static='-non_shared' ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in # old Intel for x86_64, which still supported -KPIC. ecc*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-static' ;; # icc used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. icc* | ifort*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fPIC' lt_prog_compiler_static='-static' ;; # Lahey Fortran 8.1. lf95*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='--shared' lt_prog_compiler_static='--static' ;; nagfor*) # NAG Fortran compiler lt_prog_compiler_wl='-Wl,-Wl,,' lt_prog_compiler_pic='-PIC' lt_prog_compiler_static='-Bstatic' ;; tcc*) # Fabrice Bellard et al's Tiny C Compiler lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fPIC' lt_prog_compiler_static='-static' ;; pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group compilers (*not* the Pentium gcc compiler, # which looks to be a dead project) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fpic' lt_prog_compiler_static='-Bstatic' ;; ccc*) lt_prog_compiler_wl='-Wl,' # All Alpha code is PIC. lt_prog_compiler_static='-non_shared' ;; xl* | bgxl* | bgf* | mpixl*) # IBM XL C 8.0/Fortran 10.1, 11.1 on PPC and BlueGene lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-qpic' lt_prog_compiler_static='-qstaticlink' ;; *) case `$CC -V 2>&1 | $SED 5q` in *Sun\ Ceres\ Fortran* | *Sun*Fortran*\ [1-7].* | *Sun*Fortran*\ 8.[0-3]*) # Sun Fortran 8.3 passes all unrecognized flags to the linker lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='' ;; *Sun\ F* | *Sun*Fortran*) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='-Qoption ld ' ;; *Sun\ C*) # Sun C 5.9 lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' lt_prog_compiler_wl='-Wl,' ;; *Intel*\ [CF]*Compiler*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fPIC' lt_prog_compiler_static='-static' ;; *Portland\ Group*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-fpic' lt_prog_compiler_static='-Bstatic' ;; esac ;; esac ;; newsos6) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; *nto* | *qnx*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic='-fPIC -shared' ;; osf3* | osf4* | osf5*) lt_prog_compiler_wl='-Wl,' # All OSF/1 code is PIC. lt_prog_compiler_static='-non_shared' ;; rdos*) lt_prog_compiler_static='-non_shared' ;; solaris*) lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' case $cc_basename in f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) lt_prog_compiler_wl='-Qoption ld ';; *) lt_prog_compiler_wl='-Wl,';; esac ;; sunos4*) lt_prog_compiler_wl='-Qoption ld ' lt_prog_compiler_pic='-PIC' lt_prog_compiler_static='-Bstatic' ;; sysv4 | sysv4.2uw2* | sysv4.3*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; sysv4*MP*) if test -d /usr/nec; then lt_prog_compiler_pic='-Kconform_pic' lt_prog_compiler_static='-Bstatic' fi ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_pic='-KPIC' lt_prog_compiler_static='-Bstatic' ;; unicos*) lt_prog_compiler_wl='-Wl,' lt_prog_compiler_can_build_shared=no ;; uts4*) lt_prog_compiler_pic='-pic' lt_prog_compiler_static='-Bstatic' ;; *) lt_prog_compiler_can_build_shared=no ;; esac fi case $host_os in # For platforms that do not support PIC, -DPIC is meaningless: *djgpp*) lt_prog_compiler_pic= ;; *) lt_prog_compiler_pic="$lt_prog_compiler_pic -DPIC" ;; esac { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $compiler option to produce PIC" >&5 printf %s "checking for $compiler option to produce PIC... " >&6; } if test ${lt_cv_prog_compiler_pic+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_prog_compiler_pic=$lt_prog_compiler_pic fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic" >&5 printf "%s\n" "$lt_cv_prog_compiler_pic" >&6; } lt_prog_compiler_pic=$lt_cv_prog_compiler_pic # # Check to make sure the PIC flag actually works. # if test -n "$lt_prog_compiler_pic"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if $compiler PIC flag $lt_prog_compiler_pic works" >&5 printf %s "checking if $compiler PIC flag $lt_prog_compiler_pic works... " >&6; } if test ${lt_cv_prog_compiler_pic_works+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_prog_compiler_pic_works=no ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="$lt_prog_compiler_pic -DPIC" ## exclude from sc_useless_quotes_in_assignment # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_pic_works=yes fi fi $RM conftest* fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_works" >&5 printf "%s\n" "$lt_cv_prog_compiler_pic_works" >&6; } if test yes = "$lt_cv_prog_compiler_pic_works"; then case $lt_prog_compiler_pic in "" | " "*) ;; *) lt_prog_compiler_pic=" $lt_prog_compiler_pic" ;; esac else lt_prog_compiler_pic= lt_prog_compiler_can_build_shared=no fi fi # # Check to make sure the static flag actually works. # wl=$lt_prog_compiler_wl eval lt_tmp_static_flag=\"$lt_prog_compiler_static\" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if $compiler static flag $lt_tmp_static_flag works" >&5 printf %s "checking if $compiler static flag $lt_tmp_static_flag works... " >&6; } if test ${lt_cv_prog_compiler_static_works+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_prog_compiler_static_works=no save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS $lt_tmp_static_flag" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&5 $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_static_works=yes fi else lt_cv_prog_compiler_static_works=yes fi fi $RM -r conftest* LDFLAGS=$save_LDFLAGS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_static_works" >&5 printf "%s\n" "$lt_cv_prog_compiler_static_works" >&6; } if test yes = "$lt_cv_prog_compiler_static_works"; then : else lt_prog_compiler_static= fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 printf %s "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if test ${lt_cv_prog_compiler_c_o+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_prog_compiler_c_o=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o" >&5 printf "%s\n" "$lt_cv_prog_compiler_c_o" >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 printf %s "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if test ${lt_cv_prog_compiler_c_o+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_prog_compiler_c_o=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o" >&5 printf "%s\n" "$lt_cv_prog_compiler_c_o" >&6; } hard_links=nottested if test no = "$lt_cv_prog_compiler_c_o" && test no != "$need_locks"; then # do not overwrite the value of need_locks provided by the user { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if we can lock with hard links" >&5 printf %s "checking if we can lock with hard links... " >&6; } hard_links=yes $RM conftest* ln conftest.a conftest.b 2>/dev/null && hard_links=no touch conftest.a ln conftest.a conftest.b 2>&5 || hard_links=no ln conftest.a conftest.b 2>/dev/null && hard_links=no { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $hard_links" >&5 printf "%s\n" "$hard_links" >&6; } if test no = "$hard_links"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&5 printf "%s\n" "$as_me: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&2;} need_locks=warn fi else need_locks=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether the $compiler linker ($LD) supports shared libraries" >&5 printf %s "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } runpath_var= allow_undefined_flag= always_export_symbols=no archive_cmds= archive_expsym_cmds= compiler_needs_object=no enable_shared_with_static_runtimes=no export_dynamic_flag_spec= export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' hardcode_automatic=no hardcode_direct=no hardcode_direct_absolute=no hardcode_libdir_flag_spec= hardcode_libdir_separator= hardcode_minus_L=no hardcode_shlibpath_var=unsupported inherit_rpath=no link_all_deplibs=unknown module_cmds= module_expsym_cmds= old_archive_from_new_cmds= old_archive_from_expsyms_cmds= thread_safe_flag_spec= whole_archive_flag_spec= # include_expsyms should be a list of space-separated symbols to be *always* # included in the symbol list include_expsyms= # exclude_expsyms can be an extended regexp of symbols to exclude # it will be wrapped by ' (' and ')$', so one must not match beginning or # end of line. Example: 'a|bc|.*d.*' will exclude the symbols 'a' and 'bc', # as well as any symbol that contains 'd'. exclude_expsyms='_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*' # Although _GLOBAL_OFFSET_TABLE_ is a valid symbol C name, most a.out # platforms (ab)use it in PIC code, but their linkers get confused if # the symbol is explicitly referenced. Since portable code cannot # rely on this symbol name, it's probably fine to never include it in # preloaded symbol tables. # Exclude shared library initialization/finalization symbols. extract_expsyms_cmds= case $host_os in cygwin* | mingw* | pw32* | cegcc*) # FIXME: the MSVC++ and ICC port hasn't been tested in a loooong time # When not using gcc, we currently assume that we are using # Microsoft Visual C++ or Intel C++ Compiler. if test yes != "$GCC"; then with_gnu_ld=no fi ;; interix*) # we just hope/assume this is gcc and not c89 (= MSVC++ or ICC) with_gnu_ld=yes ;; openbsd* | bitrig*) with_gnu_ld=no ;; esac ld_shlibs=yes # On some targets, GNU ld is compatible enough with the native linker # that we're better off using the native interface for both. lt_use_gnu_ld_interface=no if test yes = "$with_gnu_ld"; then case $host_os in aix*) # The AIX port of GNU ld has always aspired to compatibility # with the native linker. However, as the warning in the GNU ld # block says, versions before 2.19.5* couldn't really create working # shared libraries, regardless of the interface used. case `$LD -v 2>&1` in *\ \(GNU\ Binutils\)\ 2.19.5*) ;; *\ \(GNU\ Binutils\)\ 2.[2-9]*) ;; *\ \(GNU\ Binutils\)\ [3-9]*) ;; *) lt_use_gnu_ld_interface=yes ;; esac ;; *) lt_use_gnu_ld_interface=yes ;; esac fi if test yes = "$lt_use_gnu_ld_interface"; then # If archive_cmds runs LD, not CC, wlarc should be empty wlarc='$wl' # Set some defaults for GNU ld with shared library support. These # are reset later if shared libraries are not supported. Putting them # here allows them to be overridden if necessary. runpath_var=LD_RUN_PATH hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' export_dynamic_flag_spec='$wl--export-dynamic' # ancient GNU ld didn't support --whole-archive et. al. if $LD --help 2>&1 | $GREP 'no-whole-archive' > /dev/null; then whole_archive_flag_spec=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' else whole_archive_flag_spec= fi supports_anon_versioning=no case `$LD -v | $SED -e 's/([^)]\+)\s\+//' 2>&1` in *GNU\ gold*) supports_anon_versioning=yes ;; *\ [01].* | *\ 2.[0-9].* | *\ 2.10.*) ;; # catch versions < 2.11 *\ 2.11.93.0.2\ *) supports_anon_versioning=yes ;; # RH7.3 ... *\ 2.11.92.0.12\ *) supports_anon_versioning=yes ;; # Mandrake 8.2 ... *\ 2.11.*) ;; # other 2.11 versions *) supports_anon_versioning=yes ;; esac # See if GNU ld supports shared libraries. case $host_os in aix[3-9]*) # On AIX/PPC, the GNU linker is very broken if test ia64 != "$host_cpu"; then ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: the GNU linker, at least up to release 2.19, is reported *** to be unable to reliably create shared libraries on AIX. *** Therefore, libtool is disabling shared libraries support. If you *** really care for shared libraries, you may want to install binutils *** 2.20 or above, or modify your PATH so that a non-GNU linker is found. *** You will then need to restart the configuration process. _LT_EOF fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='' ;; m68k) archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then allow_undefined_flag=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME archive_cmds='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' else ld_shlibs=no fi ;; cygwin* | mingw* | pw32* | cegcc*) # _LT_TAGVAR(hardcode_libdir_flag_spec, ) is actually meaningless, # as there is no search path for DLLs. hardcode_libdir_flag_spec='-L$libdir' export_dynamic_flag_spec='$wl--export-all-symbols' allow_undefined_flag=unsupported always_export_symbols=no enable_shared_with_static_runtimes=yes export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1 DATA/;s/^.*[ ]__nm__\([^ ]*\)[ ][^ ]*/\1 DATA/;/^I[ ]/d;/^[AITW][ ]/s/.* //'\'' | sort | uniq > $export_symbols' exclude_expsyms='[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname' if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file, use it as # is; otherwise, prepend EXPORTS... archive_expsym_cmds='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared $output_objdir/$soname.def $libobjs $deplibs $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else ld_shlibs=no fi ;; haiku*) archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' link_all_deplibs=yes ;; os2*) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes allow_undefined_flag=unsupported shrext_cmds=.dll archive_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' archive_expsym_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' old_archive_From_new_cmds='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' enable_shared_with_static_runtimes=yes file_list_spec='@' ;; interix[3-9]*) hardcode_direct=no hardcode_shlibpath_var=no hardcode_libdir_flag_spec='$wl-rpath,$libdir' export_dynamic_flag_spec='$wl-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' archive_expsym_cmds='$SED "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) tmp_diet=no if test linux-dietlibc = "$host_os"; then case $cc_basename in diet\ *) tmp_diet=yes;; # linux-dietlibc with static linking (!diet-dyn) esac fi if $LD --help 2>&1 | $EGREP ': supported targets:.* elf' > /dev/null \ && test no = "$tmp_diet" then tmp_addflag=' $pic_flag' tmp_sharedflag='-shared' case $cc_basename,$host_cpu in pgcc*) # Portland Group C compiler whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag' ;; pgf77* | pgf90* | pgf95* | pgfortran*) # Portland Group f77 and f90 compilers whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' tmp_addflag=' $pic_flag -Mnomain' ;; ecc*,ia64* | icc*,ia64*) # Intel C compiler on ia64 tmp_addflag=' -i_dynamic' ;; efc*,ia64* | ifort*,ia64*) # Intel Fortran compiler on ia64 tmp_addflag=' -i_dynamic -nofor_main' ;; ifc* | ifort*) # Intel Fortran compiler tmp_addflag=' -nofor_main' ;; lf95*) # Lahey Fortran 8.1 whole_archive_flag_spec= tmp_sharedflag='--shared' ;; nagfor*) # NAGFOR 5.3 tmp_sharedflag='-Wl,-shared' ;; xl[cC]* | bgxl[cC]* | mpixl[cC]*) # IBM XL C 8.0 on PPC (deal with xlf below) tmp_sharedflag='-qmkshrobj' tmp_addflag= ;; nvcc*) # Cuda Compiler Driver 2.2 whole_archive_flag_spec='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' compiler_needs_object=yes ;; esac case `$CC -V 2>&1 | $SED 5q` in *Sun\ C*) # Sun C 5.9 whole_archive_flag_spec='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' compiler_needs_object=yes tmp_sharedflag='-G' ;; *Sun\ F*) # Sun Fortran 8.3 tmp_sharedflag='-G' ;; esac archive_cmds='$CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' if test yes = "$supports_anon_versioning"; then archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC '"$tmp_sharedflag""$tmp_addflag"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' fi case $cc_basename in tcc*) export_dynamic_flag_spec='-rdynamic' ;; xlf* | bgf* | bgxlf* | mpixlf*) # IBM XL Fortran 10.1 on PPC cannot create shared libs itself whole_archive_flag_spec='--whole-archive$convenience --no-whole-archive' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' archive_cmds='$LD -shared $libobjs $deplibs $linker_flags -soname $soname -o $lib' if test yes = "$supports_anon_versioning"; then archive_expsym_cmds='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $LD -shared $libobjs $deplibs $linker_flags -soname $soname -version-script $output_objdir/$libname.ver -o $lib' fi ;; esac else ld_shlibs=no fi ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then archive_cmds='$LD -Bshareable $libobjs $deplibs $linker_flags -o $lib' wlarc= else archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' fi ;; solaris*) if $LD -v 2>&1 | $GREP 'BFD 2\.8' > /dev/null; then ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: The releases 2.8.* of the GNU linker cannot reliably *** create shared libraries on Solaris systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.9.1 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF elif $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) case `$LD -v 2>&1` in *\ [01].* | *\ 2.[0-9].* | *\ 2.1[0-5].*) ld_shlibs=no cat <<_LT_EOF 1>&2 *** Warning: Releases of the GNU linker prior to 2.16.91.0.3 cannot *** reliably create shared libraries on SCO systems. Therefore, libtool *** is disabling shared libraries support. We urge you to upgrade GNU *** binutils to release 2.16.91.0.3 or newer. Another option is to modify *** your PATH or compiler configuration so that the native linker is *** used, and then restart. _LT_EOF ;; *) # For security reasons, it is highly recommended that you always # use absolute paths for naming shared libraries, and exclude the # DT_RUNPATH tag from executables and libraries. But doing so # requires that you compile everything twice, which is a pain. if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; esac ;; sunos4*) archive_cmds='$LD -assert pure-text -Bshareable -o $lib $libobjs $deplibs $linker_flags' wlarc= hardcode_direct=yes hardcode_shlibpath_var=no ;; *) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' else ld_shlibs=no fi ;; esac if test no = "$ld_shlibs"; then runpath_var= hardcode_libdir_flag_spec= export_dynamic_flag_spec= whole_archive_flag_spec= fi else # PORTME fill in a description of your system's linker (not GNU ld) case $host_os in aix3*) allow_undefined_flag=unsupported always_export_symbols=yes archive_expsym_cmds='$LD -o $output_objdir/$soname $libobjs $deplibs $linker_flags -bE:$export_symbols -T512 -H512 -bM:SRE~$AR $AR_FLAGS $lib $output_objdir/$soname' # Note: this linker hardcodes the directories in LIBPATH if there # are no directories specified by -L. hardcode_minus_L=yes if test yes = "$GCC" && test -z "$lt_prog_compiler_static"; then # Neither direct hardcoding nor static linking is supported with a # broken collect2. hardcode_direct=unsupported fi ;; aix[4-9]*) if test ia64 = "$host_cpu"; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag= else # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to GNU nm, but means don't demangle to AIX nm. # Without the "-l" option, or with the "-B" option, AIX nm treats # weak defined symbols like other global defined symbols, whereas # GNU nm marks them as "W". # While the 'weak' keyword is ignored in the Export File, we need # it in the Import File for the 'aix-soname' feature, so we have # to replace the "-B" option with "-P" for AIX nm. if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then export_symbols_cmds='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' else export_symbols_cmds='`func_echo_all $NM | $SED -e '\''s/B\([^B]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "L") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && (substr(\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' fi aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # have runtime linking enabled, and use it for executables. # For shared libraries, we enable/disable runtime linking # depending on the kind of the shared library created - # when "with_aix_soname,aix_use_runtimelinking" is: # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables # "aix,yes" lib.so shared, rtl:yes, for executables # lib.a static archive # "both,no" lib.so.V(shr.o) shared, rtl:yes # lib.a(lib.so.V) shared, rtl:no, for executables # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a(lib.so.V) shared, rtl:no # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a static archive case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) for ld_flag in $LDFLAGS; do if (test x-brtl = "x$ld_flag" || test x-Wl,-brtl = "x$ld_flag"); then aix_use_runtimelinking=yes break fi done if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then # With aix-soname=svr4, we create the lib.so.V shared archives only, # so we don't have lib.a shared libs to link our executables. # We have to force runtime linking in this case. aix_use_runtimelinking=yes LDFLAGS="$LDFLAGS -Wl,-brtl" fi ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. archive_cmds='' hardcode_direct=yes hardcode_direct_absolute=yes hardcode_libdir_separator=':' link_all_deplibs=yes file_list_spec='$wl-f,' case $with_aix_soname,$aix_use_runtimelinking in aix,*) ;; # traditional, no import file svr4,* | *,yes) # use import file # The Import File defines what to hardcode. hardcode_direct=no hardcode_direct_absolute=no ;; esac if test yes = "$GCC"; then case $host_os in aix4.[012]|aix4.[012].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`$CC -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 hardcode_direct=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking hardcode_minus_L=yes hardcode_libdir_flag_spec='-L$libdir' hardcode_libdir_separator= fi ;; esac shared_flag='-shared' if test yes = "$aix_use_runtimelinking"; then shared_flag="$shared_flag "'$wl-G' fi # Need to ensure runtime linking is disabled for the traditional # shared library, or the linker may eventually find shared libraries # /with/ Import File - we do not want to mix them. shared_flag_aix='-shared' shared_flag_svr4='-shared $wl-G' else # not using gcc if test ia64 = "$host_cpu"; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test yes = "$aix_use_runtimelinking"; then shared_flag='$wl-G' else shared_flag='$wl-bM:SRE' fi shared_flag_aix='$wl-bM:SRE' shared_flag_svr4='$wl-G' fi fi export_dynamic_flag_spec='$wl-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to export. always_export_symbols=yes if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. allow_undefined_flag='-berok' # Determine the default libpath from the value encoded in an # empty executable. if test set = "${lt_cv_aix_libpath+set}"; then aix_libpath=$lt_cv_aix_libpath else if test ${lt_cv_aix_libpath_+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath_=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=/usr/lib:/lib fi fi aix_libpath=$lt_cv_aix_libpath_ fi hardcode_libdir_flag_spec='$wl-blibpath:$libdir:'"$aix_libpath" archive_expsym_cmds='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag else if test ia64 = "$host_cpu"; then hardcode_libdir_flag_spec='$wl-R $libdir:/usr/lib:/lib' allow_undefined_flag="-z nodefs" archive_expsym_cmds="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. if test set = "${lt_cv_aix_libpath+set}"; then aix_libpath=$lt_cv_aix_libpath else if test ${lt_cv_aix_libpath_+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath_=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath_"; then lt_cv_aix_libpath_=/usr/lib:/lib fi fi aix_libpath=$lt_cv_aix_libpath_ fi hardcode_libdir_flag_spec='$wl-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. no_undefined_flag=' $wl-bernotok' allow_undefined_flag=' $wl-berok' if test yes = "$with_gnu_ld"; then # We only use this code for GNU lds that support --whole-archive. whole_archive_flag_spec='$wl--whole-archive$convenience $wl--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives whole_archive_flag_spec='$convenience' fi archive_cmds_need_lc=yes archive_expsym_cmds='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' # -brtl affects multiple linker settings, -berok does not and is overridden later compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([, ]\\)%-berok\\1%g"`' if test svr4 != "$with_aix_soname"; then # This is similar to how AIX traditionally builds its shared libraries. archive_expsym_cmds="$archive_expsym_cmds"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' fi if test aix != "$with_aix_soname"; then archive_expsym_cmds="$archive_expsym_cmds"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' else # used by -dlpreopen to get the symbols archive_expsym_cmds="$archive_expsym_cmds"'~$MV $output_objdir/$realname.d/$soname $output_objdir' fi archive_expsym_cmds="$archive_expsym_cmds"'~$RM -r $output_objdir/$realname.d' fi fi ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds='' ;; m68k) archive_cmds='$RM $output_objdir/a2ixlibrary.data~$ECHO "#define NAME $libname" > $output_objdir/a2ixlibrary.data~$ECHO "#define LIBRARY_ID 1" >> $output_objdir/a2ixlibrary.data~$ECHO "#define VERSION $major" >> $output_objdir/a2ixlibrary.data~$ECHO "#define REVISION $revision" >> $output_objdir/a2ixlibrary.data~$AR $AR_FLAGS $lib $libobjs~$RANLIB $lib~(cd $output_objdir && a2ixlibrary -32)' hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; bsdi[45]*) export_dynamic_flag_spec=-rdynamic ;; cygwin* | mingw* | pw32* | cegcc*) # When not using gcc, we currently assume that we are using # Microsoft Visual C++ or Intel C++ Compiler. # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. case $cc_basename in cl* | icl*) # Native MSVC or ICC hardcode_libdir_flag_spec=' ' allow_undefined_flag=unsupported always_export_symbols=yes file_list_spec='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. archive_cmds='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' archive_expsym_cmds='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then cp "$export_symbols" "$output_objdir/$soname.def"; echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; else $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, )='true' enable_shared_with_static_runtimes=yes exclude_expsyms='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' export_symbols_cmds='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1,DATA/'\'' | $SED -e '\''/^[AITW][ ]/s/.*[ ]//'\'' | sort | uniq > $export_symbols' # Don't use ranlib old_postinstall_cmds='chmod 644 $oldlib' postlink_cmds='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile=$lt_outputfile.exe lt_tool_outputfile=$lt_tool_outputfile.exe ;; esac~ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # Assume MSVC and ICC wrapper hardcode_libdir_flag_spec=' ' allow_undefined_flag=unsupported # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. archive_cmds='$CC -o $lib $libobjs $compiler_flags `func_echo_all "$deplibs" | $SED '\''s/ -lc$//'\''` -link -dll~linknames=' # The linker will automatically build a .lib file if we build a DLL. old_archive_from_new_cmds='true' # FIXME: Should let the user specify the lib program. old_archive_cmds='lib -OUT:$oldlib$oldobjs$old_deplibs' enable_shared_with_static_runtimes=yes ;; esac ;; darwin* | rhapsody*) archive_cmds_need_lc=no hardcode_direct=no hardcode_automatic=yes hardcode_shlibpath_var=unsupported if test yes = "$lt_cv_ld_force_load"; then whole_archive_flag_spec='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' else whole_archive_flag_spec='' fi link_all_deplibs=yes allow_undefined_flag=$_lt_dar_allow_undefined case $cc_basename in ifort*|nagfor*) _lt_dar_can_shared=yes ;; *) _lt_dar_can_shared=$GCC ;; esac if test yes = "$_lt_dar_can_shared"; then output_verbose_link_cmd=func_echo_all archive_cmds="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil" module_cmds="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil" archive_expsym_cmds="$SED 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil" module_expsym_cmds="$SED -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil" else ld_shlibs=no fi ;; dgux*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_libdir_flag_spec='-L$libdir' hardcode_shlibpath_var=no ;; # FreeBSD 2.2.[012] allows us to include c++rt0.o to get C++ constructor # support. Future versions do this automatically, but an explicit c++rt0.o # does not break anything, and helps significantly (at the cost of a little # extra space). freebsd2.2*) archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags /usr/lib/c++rt0.o' hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; # Unfortunately, older versions of FreeBSD 2 do not have this feature. freebsd2.*) archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes hardcode_minus_L=yes hardcode_shlibpath_var=no ;; # FreeBSD 3 and greater uses gcc -shared to do shared libraries. freebsd* | dragonfly* | midnightbsd*) archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; hpux9*) if test yes = "$GCC"; then archive_cmds='$RM $output_objdir/$soname~$CC -shared $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $libobjs $deplibs $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' else archive_cmds='$RM $output_objdir/$soname~$LD -b +b $install_libdir -o $output_objdir/$soname $libobjs $deplibs $linker_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' fi hardcode_libdir_flag_spec='$wl+b $wl$libdir' hardcode_libdir_separator=: hardcode_direct=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes export_dynamic_flag_spec='$wl-E' ;; hpux10*) if test yes,no = "$GCC,$with_gnu_ld"; then archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi if test no = "$with_gnu_ld"; then hardcode_libdir_flag_spec='$wl+b $wl$libdir' hardcode_libdir_separator=: hardcode_direct=yes hardcode_direct_absolute=yes export_dynamic_flag_spec='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes fi ;; hpux11*) if test yes,no = "$GCC,$with_gnu_ld"; then case $host_cpu in hppa*64*) archive_cmds='$CC -shared $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) archive_cmds='$CC -shared $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' ;; esac else case $host_cpu in hppa*64*) archive_cmds='$CC -b $wl+h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' ;; ia64*) archive_cmds='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $libobjs $deplibs $compiler_flags' ;; *) # Older versions of the 11.00 compiler do not understand -b yet # (HP92453-01 A.11.01.20 doesn't, HP92453-01 B.11.X.35175-35176.GP does) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if $CC understands -b" >&5 printf %s "checking if $CC understands -b... " >&6; } if test ${lt_cv_prog_compiler__b+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_prog_compiler__b=no save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS -b" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&5 $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler__b=yes fi else lt_cv_prog_compiler__b=yes fi fi $RM -r conftest* LDFLAGS=$save_LDFLAGS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler__b" >&5 printf "%s\n" "$lt_cv_prog_compiler__b" >&6; } if test yes = "$lt_cv_prog_compiler__b"; then archive_cmds='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -b +h $soname +b $install_libdir -o $lib $libobjs $deplibs $linker_flags' fi ;; esac fi if test no = "$with_gnu_ld"; then hardcode_libdir_flag_spec='$wl+b $wl$libdir' hardcode_libdir_separator=: case $host_cpu in hppa*64*|ia64*) hardcode_direct=no hardcode_shlibpath_var=no ;; *) hardcode_direct=yes hardcode_direct_absolute=yes export_dynamic_flag_spec='$wl-E' # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes ;; esac fi ;; irix5* | irix6* | nonstopux*) if test yes = "$GCC"; then archive_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' # Try to use the -exported_symbol ld option, if it does not # work, assume that -exports_file does not work either and # implicitly export all symbols. # This should be the same for all languages, so no per-tag cache variable. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether the $host_os linker accepts -exported_symbol" >&5 printf %s "checking whether the $host_os linker accepts -exported_symbol... " >&6; } if test ${lt_cv_irix_exported_symbol+y} then : printf %s "(cached) " >&6 else $as_nop save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS -shared $wl-exported_symbol ${wl}foo $wl-update_registry $wl/dev/null" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int foo (void) { return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : lt_cv_irix_exported_symbol=yes else $as_nop lt_cv_irix_exported_symbol=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_irix_exported_symbol" >&5 printf "%s\n" "$lt_cv_irix_exported_symbol" >&6; } if test yes = "$lt_cv_irix_exported_symbol"; then archive_expsym_cmds='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations $wl-exports_file $wl$export_symbols -o $lib' fi else archive_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' archive_expsym_cmds='$CC -shared $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -exports_file $export_symbols -o $lib' fi archive_cmds_need_lc='no' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' hardcode_libdir_separator=: inherit_rpath=yes link_all_deplibs=yes ;; linux*) case $cc_basename in tcc*) # Fabrice Bellard et al's Tiny C Compiler ld_shlibs=yes archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then archive_cmds='$LD -Bshareable -o $lib $libobjs $deplibs $linker_flags' # a.out else archive_cmds='$LD -shared -o $lib $libobjs $deplibs $linker_flags' # ELF fi hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes hardcode_shlibpath_var=no ;; newsos6) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' hardcode_libdir_separator=: hardcode_shlibpath_var=no ;; *nto* | *qnx*) ;; openbsd* | bitrig*) if test -f /usr/libexec/ld.so; then hardcode_direct=yes hardcode_shlibpath_var=no hardcode_direct_absolute=yes if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags $wl-retain-symbols-file,$export_symbols' hardcode_libdir_flag_spec='$wl-rpath,$libdir' export_dynamic_flag_spec='$wl-E' else archive_cmds='$CC -shared $pic_flag -o $lib $libobjs $deplibs $compiler_flags' hardcode_libdir_flag_spec='$wl-rpath,$libdir' fi else ld_shlibs=no fi ;; os2*) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes allow_undefined_flag=unsupported shrext_cmds=.dll archive_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' archive_expsym_cmds='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' old_archive_From_new_cmds='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' enable_shared_with_static_runtimes=yes file_list_spec='@' ;; osf3*) if test yes = "$GCC"; then allow_undefined_flag=' $wl-expect_unresolved $wl\*' archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' else allow_undefined_flag=' -expect_unresolved \*' archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' fi archive_cmds_need_lc='no' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' hardcode_libdir_separator=: ;; osf4* | osf5*) # as osf3* with the addition of -msym flag if test yes = "$GCC"; then allow_undefined_flag=' $wl-expect_unresolved $wl\*' archive_cmds='$CC -shared$allow_undefined_flag $pic_flag $libobjs $deplibs $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' hardcode_libdir_flag_spec='$wl-rpath $wl$libdir' else allow_undefined_flag=' -expect_unresolved \*' archive_cmds='$CC -shared$allow_undefined_flag $libobjs $deplibs $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' archive_expsym_cmds='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done; printf "%s\\n" "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $wl-input $wl$lib.exp $compiler_flags $libobjs $deplibs -soname $soname `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~$RM $lib.exp' # Both c and cxx compiler support -rpath directly hardcode_libdir_flag_spec='-rpath $libdir' fi archive_cmds_need_lc='no' hardcode_libdir_separator=: ;; solaris*) no_undefined_flag=' -z defs' if test yes = "$GCC"; then wlarc='$wl' archive_cmds='$CC -shared $pic_flag $wl-z ${wl}text $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag $wl-z ${wl}text $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' else case `$CC -V 2>&1` in *"Compilers 5.0"*) wlarc='' archive_cmds='$LD -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $linker_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $LD -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $linker_flags~$RM $lib.exp' ;; *) wlarc='$wl' archive_cmds='$CC -G$allow_undefined_flag -h $soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G$allow_undefined_flag -M $lib.exp -h $soname -o $lib $libobjs $deplibs $compiler_flags~$RM $lib.exp' ;; esac fi hardcode_libdir_flag_spec='-R$libdir' hardcode_shlibpath_var=no case $host_os in solaris2.[0-5] | solaris2.[0-5].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands '-z linker_flag'. GCC discards it without '$wl', # but is careful enough not to reorder. # Supported since Solaris 2.6 (maybe 2.5.1?) if test yes = "$GCC"; then whole_archive_flag_spec='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' else whole_archive_flag_spec='-z allextract$convenience -z defaultextract' fi ;; esac link_all_deplibs=yes ;; sunos4*) if test sequent = "$host_vendor"; then # Use $CC to link under sequent, because it throws in some extra .o # files that make .init and .fini sections work. archive_cmds='$CC -G $wl-h $soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$LD -assert pure-text -Bstatic -o $lib $libobjs $deplibs $linker_flags' fi hardcode_libdir_flag_spec='-L$libdir' hardcode_direct=yes hardcode_minus_L=yes hardcode_shlibpath_var=no ;; sysv4) case $host_vendor in sni) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=yes # is this really true??? ;; siemens) ## LD is ld it makes a PLAMLIB ## CC just makes a GrossModule. archive_cmds='$LD -G -o $lib $libobjs $deplibs $linker_flags' reload_cmds='$CC -r -o $output$reload_objs' hardcode_direct=no ;; motorola) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_direct=no #Motorola manual says yes, but my tests say they lie ;; esac runpath_var='LD_RUN_PATH' hardcode_shlibpath_var=no ;; sysv4.3*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_shlibpath_var=no export_dynamic_flag_spec='-Bexport' ;; sysv4*MP*) if test -d /usr/nec; then archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_shlibpath_var=no runpath_var=LD_RUN_PATH hardcode_runpath_var=yes ld_shlibs=yes fi ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) no_undefined_flag='$wl-z,text' archive_cmds_need_lc=no hardcode_shlibpath_var=no runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then archive_cmds='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We CANNOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. no_undefined_flag='$wl-z,text' allow_undefined_flag='$wl-z,nodefs' archive_cmds_need_lc=no hardcode_shlibpath_var=no hardcode_libdir_flag_spec='$wl-R,$libdir' hardcode_libdir_separator=':' link_all_deplibs=yes export_dynamic_flag_spec='$wl-Bexport' runpath_var='LD_RUN_PATH' if test yes = "$GCC"; then archive_cmds='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' else archive_cmds='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' fi ;; uts4*) archive_cmds='$LD -G -h $soname -o $lib $libobjs $deplibs $linker_flags' hardcode_libdir_flag_spec='-L$libdir' hardcode_shlibpath_var=no ;; *) ld_shlibs=no ;; esac if test sni = "$host_vendor"; then case $host in sysv4 | sysv4.2uw2* | sysv4.3* | sysv5*) export_dynamic_flag_spec='$wl-Blargedynsym' ;; esac fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs" >&5 printf "%s\n" "$ld_shlibs" >&6; } test no = "$ld_shlibs" && can_build_shared=no with_gnu_ld=$with_gnu_ld # # Do we need to explicitly link libc? # case "x$archive_cmds_need_lc" in x|xyes) # Assume -lc should be added archive_cmds_need_lc=yes if test yes,yes = "$GCC,$enable_shared"; then case $archive_cmds in *'~'*) # FIXME: we may have to deal with multi-command sequences. ;; '$CC '*) # Test whether the compiler implicitly links with -lc since on some # systems, -lgcc has to come before -lc. If gcc already passes -lc # to ld, don't add -lc before -lgcc. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether -lc should be explicitly linked in" >&5 printf %s "checking whether -lc should be explicitly linked in... " >&6; } if test ${lt_cv_archive_cmds_need_lc+y} then : printf %s "(cached) " >&6 else $as_nop $RM conftest* echo "$lt_simple_compile_test_code" > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } 2>conftest.err; then soname=conftest lib=conftest libobjs=conftest.$ac_objext deplibs= wl=$lt_prog_compiler_wl pic_flag=$lt_prog_compiler_pic compiler_flags=-v linker_flags=-v verstring= output_objdir=. libname=conftest lt_save_allow_undefined_flag=$allow_undefined_flag allow_undefined_flag= if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1\""; } >&5 (eval $archive_cmds 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } then lt_cv_archive_cmds_need_lc=no else lt_cv_archive_cmds_need_lc=yes fi allow_undefined_flag=$lt_save_allow_undefined_flag else cat conftest.err 1>&5 fi $RM conftest* fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_archive_cmds_need_lc" >&5 printf "%s\n" "$lt_cv_archive_cmds_need_lc" >&6; } archive_cmds_need_lc=$lt_cv_archive_cmds_need_lc ;; esac fi ;; esac { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking dynamic linker characteristics" >&5 printf %s "checking dynamic linker characteristics... " >&6; } if test yes = "$GCC"; then case $host_os in darwin*) lt_awk_arg='/^libraries:/,/LR/' ;; *) lt_awk_arg='/^libraries:/' ;; esac case $host_os in mingw* | cegcc*) lt_sed_strip_eq='s|=\([A-Za-z]:\)|\1|g' ;; *) lt_sed_strip_eq='s|=/|/|g' ;; esac lt_search_path_spec=`$CC -print-search-dirs | awk $lt_awk_arg | $SED -e "s/^libraries://" -e $lt_sed_strip_eq` case $lt_search_path_spec in *\;*) # if the path contains ";" then we assume it to be the separator # otherwise default to the standard path separator (i.e. ":") - it is # assumed that no part of a normal pathname contains ";" but that should # okay in the real world where ";" in dirpaths is itself problematic. lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED 's/;/ /g'` ;; *) lt_search_path_spec=`$ECHO "$lt_search_path_spec" | $SED "s/$PATH_SEPARATOR/ /g"` ;; esac # Ok, now we have the path, separated by spaces, we can step through it # and add multilib dir if necessary... lt_tmp_lt_search_path_spec= lt_multi_os_dir=/`$CC $CPPFLAGS $CFLAGS $LDFLAGS -print-multi-os-directory 2>/dev/null` # ...but if some path component already ends with the multilib dir we assume # that all is fine and trust -print-search-dirs as is (GCC 4.2? or newer). case "$lt_multi_os_dir; $lt_search_path_spec " in "/; "* | "/.; "* | "/./; "* | *"$lt_multi_os_dir "* | *"$lt_multi_os_dir/ "*) lt_multi_os_dir= ;; esac for lt_sys_path in $lt_search_path_spec; do if test -d "$lt_sys_path$lt_multi_os_dir"; then lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path$lt_multi_os_dir" elif test -n "$lt_multi_os_dir"; then test -d "$lt_sys_path" && \ lt_tmp_lt_search_path_spec="$lt_tmp_lt_search_path_spec $lt_sys_path" fi done lt_search_path_spec=`$ECHO "$lt_tmp_lt_search_path_spec" | awk ' BEGIN {RS = " "; FS = "/|\n";} { lt_foo = ""; lt_count = 0; for (lt_i = NF; lt_i > 0; lt_i--) { if ($lt_i != "" && $lt_i != ".") { if ($lt_i == "..") { lt_count++; } else { if (lt_count == 0) { lt_foo = "/" $lt_i lt_foo; } else { lt_count--; } } } } if (lt_foo != "") { lt_freq[lt_foo]++; } if (lt_freq[lt_foo] == 1) { print lt_foo; } }'` # AWK program above erroneously prepends '/' to C:/dos/paths # for these hosts. case $host_os in mingw* | cegcc*) lt_search_path_spec=`$ECHO "$lt_search_path_spec" |\ $SED 's|/\([A-Za-z]:\)|\1|g'` ;; esac sys_lib_search_path_spec=`$ECHO "$lt_search_path_spec" | $lt_NL2SP` else sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" fi library_names_spec= libname_spec='lib$name' soname_spec= shrext_cmds=.so postinstall_cmds= postuninstall_cmds= finish_cmds= finish_eval= shlibpath_var= shlibpath_overrides_runpath=unknown version_type=none dynamic_linker="$host_os ld.so" sys_lib_dlsearch_path_spec="/lib /usr/lib" need_lib_prefix=unknown hardcode_into_libs=no # when you set need_version to no, make sure it does not cause -set_version # flags to be left without arguments need_version=unknown case $host_os in aix3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname.a' shlibpath_var=LIBPATH # AIX 3 has no versioning support, so we append a major version to the name. soname_spec='$libname$release$shared_ext$major' ;; aix[4-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no hardcode_into_libs=yes if test ia64 = "$host_cpu"; then # AIX 5 supports IA64 library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH else # With GCC up to 2.95.x, collect2 would create an import file # for dependence libraries. The import file would start with # the line '#! .'. This would cause the generated library to # depend on '.', always an invalid library. This was fixed in # development snapshots of GCC prior to 3.0. case $host_os in aix4 | aix4.[01] | aix4.[01].*) if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' echo ' yes ' echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then : else can_build_shared=no fi ;; esac # Using Import Files as archive members, it is possible to support # filename-based versioning of shared library archives on AIX. While # this would work for both with and without runtime linking, it will # prevent static linking of such archives. So we do filename-based # shared library versioning with .so extension only, which is used # when both runtime linking and shared linking is enabled. # Unfortunately, runtime linking may impact performance, so we do # not want this to be the default eventually. Also, we use the # versioned .so libs for executables only if there is the -brtl # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only. # To allow for filename-based versioning support, we need to create # libNAME.so.V as an archive file, containing: # *) an Import File, referring to the versioned filename of the # archive as well as the shared archive member, telling the # bitwidth (32 or 64) of that shared object, and providing the # list of exported symbols of that shared object, eventually # decorated with the 'weak' keyword # *) the shared object with the F_LOADONLY flag set, to really avoid # it being seen by the linker. # At run time we better use the real file rather than another symlink, # but for link time we create the symlink libNAME.so -> libNAME.so.V case $with_aix_soname,$aix_use_runtimelinking in # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct # soname into executable. Probably we can add versioning support to # collect2, so additional links can be useful in future. aix,yes) # traditional libtool dynamic_linker='AIX unversionable lib.so' # If using run time linking (on AIX 4.2 or later) use lib.so # instead of lib.a to let people know that these are not # typical AIX shared libraries. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; aix,no) # traditional AIX only dynamic_linker='AIX lib.a(lib.so.V)' # We preserve .a as extension for shared libraries through AIX4.2 # and later when we are not doing run time linking. library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' ;; svr4,*) # full svr4 only dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o)" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,yes) # both, prefer svr4 dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o), lib.a(lib.so.V)" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # unpreferred sharedlib libNAME.a needs extra handling postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"' postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,no) # both, prefer aix dynamic_linker="AIX lib.a(lib.so.V), lib.so.V($shared_archive_member_spec.o)" library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)' postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"' ;; esac shlibpath_var=LIBPATH fi ;; amigaos*) case $host_cpu in powerpc) # Since July 2007 AmigaOS4 officially supports .so libraries. # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; m68k) library_names_spec='$libname.ixlibrary $libname.a' # Create ${libname}_ixlibrary.a entries in /sys/libs. finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' ;; esac ;; beos*) library_names_spec='$libname$shared_ext' dynamic_linker="$host_os ld.so" shlibpath_var=LIBRARY_PATH ;; bsdi[45]*) version_type=linux # correct to gnu/linux during the next big refactor need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" # the default ld.so.conf also contains /usr/contrib/lib and # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow # libtool to hard-code these into programs ;; cygwin* | mingw* | pw32* | cegcc*) version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no case $GCC,$cc_basename in yes,*) # gcc library_names_spec='$libname.dll.a' # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes case $host_os in cygwin*) # Cygwin DLLs use 'cyg' prefix rather than 'lib' soname_spec='`echo $libname | $SED -e 's/^lib/cyg/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/lib/w32api" ;; mingw* | cegcc*) # MinGW DLLs use traditional 'lib' prefix soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' ;; pw32*) # pw32 DLLs use 'pw' prefix rather than 'lib' library_names_spec='`echo $libname | $SED -e 's/^lib/pw/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' ;; esac dynamic_linker='Win32 ld.exe' ;; *,cl* | *,icl*) # Native MSVC or ICC libname_spec='$name' soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' library_names_spec='$libname.dll.lib' case $build_os in mingw*) sys_lib_search_path_spec= lt_save_ifs=$IFS IFS=';' for lt_path in $LIB do IFS=$lt_save_ifs # Let DOS variable expansion print the short 8.3 style file name. lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" done IFS=$lt_save_ifs # Convert to MSYS style. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's|\\\\|/|g' -e 's| \\([a-zA-Z]\\):| /\\1|g' -e 's|^ ||'` ;; cygwin*) # Convert to unix form, then to dos form, then back to unix form # but this time dos style (no spaces!) so that the unix form looks # like /cygdrive/c/PROGRA~1:/cygdr... sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` ;; *) sys_lib_search_path_spec=$LIB if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then # It is most probably a Windows format PATH. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` else sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` fi # FIXME: find the short name or the path components, as spaces are # common. (e.g. "Program Files" -> "PROGRA~1") ;; esac # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes dynamic_linker='Win32 link.exe' ;; *) # Assume MSVC and ICC wrapper library_names_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext $libname.lib' dynamic_linker='Win32 ld.exe' ;; esac # FIXME: first we should search . and the directory the executable is in shlibpath_var=PATH ;; darwin* | rhapsody*) dynamic_linker="$host_os dyld" version_type=darwin need_lib_prefix=no need_version=no library_names_spec='$libname$release$major$shared_ext $libname$shared_ext' soname_spec='$libname$release$major$shared_ext' shlibpath_overrides_runpath=yes shlibpath_var=DYLD_LIBRARY_PATH shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' sys_lib_search_path_spec="$sys_lib_search_path_spec /usr/local/lib" sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' ;; dgux*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; freebsd* | dragonfly* | midnightbsd*) # DragonFly does not have aout. When/if they implement a new # versioning mechanism, adjust this. if test -x /usr/bin/objformat; then objformat=`/usr/bin/objformat` else case $host_os in freebsd[23].*) objformat=aout ;; *) objformat=elf ;; esac fi version_type=freebsd-$objformat case $version_type in freebsd-elf*) library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' need_version=no need_lib_prefix=no ;; freebsd-*) library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' need_version=yes ;; esac shlibpath_var=LD_LIBRARY_PATH case $host_os in freebsd2.*) shlibpath_overrides_runpath=yes ;; freebsd3.[01]* | freebsdelf3.[01]*) shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; freebsd3.[2-9]* | freebsdelf3.[2-9]* | \ freebsd4.[0-5] | freebsdelf4.[0-5] | freebsd4.1.1 | freebsdelf4.1.1) shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; *) # from 4.6 on, and DragonFly shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; esac ;; haiku*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no dynamic_linker="$host_os runtime_loader" library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LIBRARY_PATH shlibpath_overrides_runpath=no sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' hardcode_into_libs=yes ;; hpux9* | hpux10* | hpux11*) # Give a soname corresponding to the major version so that dld.sl refuses to # link against other versions. version_type=sunos need_lib_prefix=no need_version=no case $host_cpu in ia64*) shrext_cmds='.so' hardcode_into_libs=yes dynamic_linker="$host_os dld.so" shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' if test 32 = "$HPUX_IA64_MODE"; then sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" sys_lib_dlsearch_path_spec=/usr/lib/hpux32 else sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" sys_lib_dlsearch_path_spec=/usr/lib/hpux64 fi ;; hppa*64*) shrext_cmds='.sl' hardcode_into_libs=yes dynamic_linker="$host_os dld.sl" shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; *) shrext_cmds='.sl' dynamic_linker="$host_os dld.sl" shlibpath_var=SHLIB_PATH shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' ;; esac # HP-UX runs *really* slowly unless shared libraries are mode 555, ... postinstall_cmds='chmod 555 $lib' # or fails outright, so override atomically: install_override_mode=555 ;; interix[3-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; irix5* | irix6* | nonstopux*) case $host_os in nonstopux*) version_type=nonstopux ;; *) if test yes = "$lt_cv_prog_gnu_ld"; then version_type=linux # correct to gnu/linux during the next big refactor else version_type=irix fi ;; esac need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext' case $host_os in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in # libtool.m4 will add one of these switches to LD *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= libmagic=32-bit;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 libmagic=N32;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 libmagic=64-bit;; *) libsuff= shlibsuff= libmagic=never-match;; esac ;; esac shlibpath_var=LD_LIBRARY${shlibsuff}_PATH shlibpath_overrides_runpath=no sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff" sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff" hardcode_into_libs=yes ;; # No shared lib support for Linux oldld, aout, or coff. linux*oldld* | linux*aout* | linux*coff*) dynamic_linker=no ;; linux*android*) version_type=none # Android doesn't support versioned libraries. need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext' soname_spec='$libname$release$shared_ext' finish_cmds= shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes dynamic_linker='Android linker' # Don't embed -rpath directories since the linker doesn't support them. hardcode_libdir_flag_spec='-L$libdir' ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no # Some binutils ld are patched to set DT_RUNPATH if test ${lt_cv_shlibpath_overrides_runpath+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_shlibpath_overrides_runpath=no save_LDFLAGS=$LDFLAGS save_libdir=$libdir eval "libdir=/foo; wl=\"$lt_prog_compiler_wl\"; \ LDFLAGS=\"\$LDFLAGS $hardcode_libdir_flag_spec\"" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : if ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null then : lt_cv_shlibpath_overrides_runpath=yes fi fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS libdir=$save_libdir fi shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes # Add ABI-specific directories to the system library path. sys_lib_dlsearch_path_spec="/lib64 /usr/lib64 /lib /usr/lib" # Ideally, we could use ldconfig to report *all* directores which are # searched for libraries, however this is still not possible. Aside from not # being certain /sbin/ldconfig is available, command # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64, # even though it is searched at run-time. Try to do the best guess by # appending ld.so.conf contents (and includes) to the search path. if test -f /etc/ld.so.conf; then lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` sys_lib_dlsearch_path_spec="$sys_lib_dlsearch_path_spec $lt_ld_extra" fi # We used to test for /lib/ld.so.1 and disable shared libraries on # powerpc, because MkLinux only supported shared libraries with the # GNU dynamic linker. Since this was broken with cross compilers, # most powerpc-linux boxes support dynamic linking these days and # people can always --disable-shared, the test was removed, and we # assume the GNU/Linux dynamic linker is in use. dynamic_linker='GNU/Linux ld.so' ;; netbsd*) version_type=sunos need_lib_prefix=no need_version=no if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' dynamic_linker='NetBSD (a.out) ld.so' else library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='NetBSD ld.elf_so' fi shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; newsos6) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; *nto* | *qnx*) version_type=qnx need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='ldqnx.so' ;; openbsd* | bitrig*) version_type=sunos sys_lib_dlsearch_path_spec=/usr/lib need_lib_prefix=no if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then need_version=no else need_version=yes fi library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; os2*) libname_spec='$name' version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no # OS/2 can only load a DLL with a base name of 8 characters or less. soname_spec='`test -n "$os2dllname" && libname="$os2dllname"; v=$($ECHO $release$versuffix | tr -d .-); n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _); $ECHO $n$v`$shared_ext' library_names_spec='${libname}_dll.$libext' dynamic_linker='OS/2 ld.exe' shlibpath_var=BEGINLIBPATH sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' ;; osf3* | osf4* | osf5*) version_type=osf need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; rdos*) dynamic_linker=no ;; solaris*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes # ldd complains unless libraries are executable postinstall_cmds='chmod +x $lib' ;; sunos4*) version_type=sunos library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes if test yes = "$with_gnu_ld"; then need_lib_prefix=no fi need_version=yes ;; sysv4 | sysv4.3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH case $host_vendor in sni) shlibpath_overrides_runpath=no need_lib_prefix=no runpath_var=LD_RUN_PATH ;; siemens) need_lib_prefix=no ;; motorola) need_lib_prefix=no need_version=no shlibpath_overrides_runpath=no sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' ;; esac ;; sysv4*MP*) if test -d /usr/nec; then version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext' soname_spec='$libname$shared_ext.$major' shlibpath_var=LD_LIBRARY_PATH fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) version_type=sco need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes if test yes = "$with_gnu_ld"; then sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' else sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' case $host_os in sco3.2v5*) sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" ;; esac fi sys_lib_dlsearch_path_spec='/usr/lib' ;; tpf*) # TPF is a cross-target only. Preferred cross-host = GNU/Linux. version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; uts4*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; *) dynamic_linker=no ;; esac { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $dynamic_linker" >&5 printf "%s\n" "$dynamic_linker" >&6; } test no = "$dynamic_linker" && can_build_shared=no variables_saved_for_relink="PATH $shlibpath_var $runpath_var" if test yes = "$GCC"; then variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" fi if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec fi if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec fi # remember unaugmented sys_lib_dlsearch_path content for libtool script decls... configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec # ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH" # to be used as default LT_SYS_LIBRARY_PATH value in generated libtool configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking how to hardcode library paths into programs" >&5 printf %s "checking how to hardcode library paths into programs... " >&6; } hardcode_action= if test -n "$hardcode_libdir_flag_spec" || test -n "$runpath_var" || test yes = "$hardcode_automatic"; then # We can hardcode non-existent directories. if test no != "$hardcode_direct" && # If the only mechanism to avoid hardcoding is shlibpath_var, we # have to relink, otherwise we might link with an installed library # when we should be linking with a yet-to-be-installed one ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, )" && test no != "$hardcode_minus_L"; then # Linking always hardcodes the temporary library directory. hardcode_action=relink else # We can link without hardcoding, and we can hardcode nonexisting dirs. hardcode_action=immediate fi else # We cannot hardcode anything, or else we can only hardcode existing # directories. hardcode_action=unsupported fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $hardcode_action" >&5 printf "%s\n" "$hardcode_action" >&6; } if test relink = "$hardcode_action" || test yes = "$inherit_rpath"; then # Fast installation is not supported enable_fast_install=no elif test yes = "$shlibpath_overrides_runpath" || test no = "$enable_shared"; then # Fast installation is not necessary enable_fast_install=needless fi if test yes != "$enable_dlopen"; then enable_dlopen=unknown enable_dlopen_self=unknown enable_dlopen_self_static=unknown else lt_cv_dlopen=no lt_cv_dlopen_libs= case $host_os in beos*) lt_cv_dlopen=load_add_on lt_cv_dlopen_libs= lt_cv_dlopen_self=yes ;; mingw* | pw32* | cegcc*) lt_cv_dlopen=LoadLibrary lt_cv_dlopen_libs= ;; cygwin*) lt_cv_dlopen=dlopen lt_cv_dlopen_libs= ;; darwin*) # if libdl is installed we need to link against it { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 printf %s "checking for dlopen in -ldl... " >&6; } if test ${ac_cv_lib_dl_dlopen+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-ldl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char dlopen (); int main (void) { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_dl_dlopen=yes else $as_nop ac_cv_lib_dl_dlopen=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 printf "%s\n" "$ac_cv_lib_dl_dlopen" >&6; } if test "x$ac_cv_lib_dl_dlopen" = xyes then : lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl else $as_nop lt_cv_dlopen=dyld lt_cv_dlopen_libs= lt_cv_dlopen_self=yes fi ;; tpf*) # Don't try to run any link tests for TPF. We know it's impossible # because TPF is a cross-compiler, and we know how we open DSOs. lt_cv_dlopen=dlopen lt_cv_dlopen_libs= lt_cv_dlopen_self=no ;; *) ac_fn_c_check_func "$LINENO" "shl_load" "ac_cv_func_shl_load" if test "x$ac_cv_func_shl_load" = xyes then : lt_cv_dlopen=shl_load else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for shl_load in -ldld" >&5 printf %s "checking for shl_load in -ldld... " >&6; } if test ${ac_cv_lib_dld_shl_load+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-ldld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char shl_load (); int main (void) { return shl_load (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_dld_shl_load=yes else $as_nop ac_cv_lib_dld_shl_load=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_shl_load" >&5 printf "%s\n" "$ac_cv_lib_dld_shl_load" >&6; } if test "x$ac_cv_lib_dld_shl_load" = xyes then : lt_cv_dlopen=shl_load lt_cv_dlopen_libs=-ldld else $as_nop ac_fn_c_check_func "$LINENO" "dlopen" "ac_cv_func_dlopen" if test "x$ac_cv_func_dlopen" = xyes then : lt_cv_dlopen=dlopen else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 printf %s "checking for dlopen in -ldl... " >&6; } if test ${ac_cv_lib_dl_dlopen+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-ldl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char dlopen (); int main (void) { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_dl_dlopen=yes else $as_nop ac_cv_lib_dl_dlopen=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 printf "%s\n" "$ac_cv_lib_dl_dlopen" >&6; } if test "x$ac_cv_lib_dl_dlopen" = xyes then : lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-ldl else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for dlopen in -lsvld" >&5 printf %s "checking for dlopen in -lsvld... " >&6; } if test ${ac_cv_lib_svld_dlopen+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lsvld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char dlopen (); int main (void) { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_svld_dlopen=yes else $as_nop ac_cv_lib_svld_dlopen=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_svld_dlopen" >&5 printf "%s\n" "$ac_cv_lib_svld_dlopen" >&6; } if test "x$ac_cv_lib_svld_dlopen" = xyes then : lt_cv_dlopen=dlopen lt_cv_dlopen_libs=-lsvld else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for dld_link in -ldld" >&5 printf %s "checking for dld_link in -ldld... " >&6; } if test ${ac_cv_lib_dld_dld_link+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-ldld $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char dld_link (); int main (void) { return dld_link (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_dld_dld_link=yes else $as_nop ac_cv_lib_dld_dld_link=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dld_dld_link" >&5 printf "%s\n" "$ac_cv_lib_dld_dld_link" >&6; } if test "x$ac_cv_lib_dld_dld_link" = xyes then : lt_cv_dlopen=dld_link lt_cv_dlopen_libs=-ldld fi fi fi fi fi fi ;; esac if test no = "$lt_cv_dlopen"; then enable_dlopen=no else enable_dlopen=yes fi case $lt_cv_dlopen in dlopen) save_CPPFLAGS=$CPPFLAGS test yes = "$ac_cv_header_dlfcn_h" && CPPFLAGS="$CPPFLAGS -DHAVE_DLFCN_H" save_LDFLAGS=$LDFLAGS wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $export_dynamic_flag_spec\" save_LIBS=$LIBS LIBS="$lt_cv_dlopen_libs $LIBS" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether a program can dlopen itself" >&5 printf %s "checking whether a program can dlopen itself... " >&6; } if test ${lt_cv_dlopen_self+y} then : printf %s "(cached) " >&6 else $as_nop if test yes = "$cross_compiling"; then : lt_cv_dlopen_self=cross else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF #line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisibility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; } _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s "conftest$ac_exeext" 2>/dev/null; then (./conftest; exit; ) >&5 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) lt_cv_dlopen_self=yes ;; x$lt_dlneed_uscore) lt_cv_dlopen_self=yes ;; x$lt_dlunknown|x*) lt_cv_dlopen_self=no ;; esac else : # compilation failed lt_cv_dlopen_self=no fi fi rm -fr conftest* fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_dlopen_self" >&5 printf "%s\n" "$lt_cv_dlopen_self" >&6; } if test yes = "$lt_cv_dlopen_self"; then wl=$lt_prog_compiler_wl eval LDFLAGS=\"\$LDFLAGS $lt_prog_compiler_static\" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether a statically linked program can dlopen itself" >&5 printf %s "checking whether a statically linked program can dlopen itself... " >&6; } if test ${lt_cv_dlopen_self_static+y} then : printf %s "(cached) " >&6 else $as_nop if test yes = "$cross_compiling"; then : lt_cv_dlopen_self_static=cross else lt_dlunknown=0; lt_dlno_uscore=1; lt_dlneed_uscore=2 lt_status=$lt_dlunknown cat > conftest.$ac_ext <<_LT_EOF #line $LINENO "configure" #include "confdefs.h" #if HAVE_DLFCN_H #include #endif #include #ifdef RTLD_GLOBAL # define LT_DLGLOBAL RTLD_GLOBAL #else # ifdef DL_GLOBAL # define LT_DLGLOBAL DL_GLOBAL # else # define LT_DLGLOBAL 0 # endif #endif /* We may have to define LT_DLLAZY_OR_NOW in the command line if we find out it does not work in some platform. */ #ifndef LT_DLLAZY_OR_NOW # ifdef RTLD_LAZY # define LT_DLLAZY_OR_NOW RTLD_LAZY # else # ifdef DL_LAZY # define LT_DLLAZY_OR_NOW DL_LAZY # else # ifdef RTLD_NOW # define LT_DLLAZY_OR_NOW RTLD_NOW # else # ifdef DL_NOW # define LT_DLLAZY_OR_NOW DL_NOW # else # define LT_DLLAZY_OR_NOW 0 # endif # endif # endif # endif #endif /* When -fvisibility=hidden is used, assume the code has been annotated correspondingly for the symbols needed. */ #if defined __GNUC__ && (((__GNUC__ == 3) && (__GNUC_MINOR__ >= 3)) || (__GNUC__ > 3)) int fnord () __attribute__((visibility("default"))); #endif int fnord () { return 42; } int main () { void *self = dlopen (0, LT_DLGLOBAL|LT_DLLAZY_OR_NOW); int status = $lt_dlunknown; if (self) { if (dlsym (self,"fnord")) status = $lt_dlno_uscore; else { if (dlsym( self,"_fnord")) status = $lt_dlneed_uscore; else puts (dlerror ()); } /* dlclose (self); */ } else puts (dlerror ()); return status; } _LT_EOF if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_link\""; } >&5 (eval $ac_link) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } && test -s "conftest$ac_exeext" 2>/dev/null; then (./conftest; exit; ) >&5 2>/dev/null lt_status=$? case x$lt_status in x$lt_dlno_uscore) lt_cv_dlopen_self_static=yes ;; x$lt_dlneed_uscore) lt_cv_dlopen_self_static=yes ;; x$lt_dlunknown|x*) lt_cv_dlopen_self_static=no ;; esac else : # compilation failed lt_cv_dlopen_self_static=no fi fi rm -fr conftest* fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_dlopen_self_static" >&5 printf "%s\n" "$lt_cv_dlopen_self_static" >&6; } fi CPPFLAGS=$save_CPPFLAGS LDFLAGS=$save_LDFLAGS LIBS=$save_LIBS ;; esac case $lt_cv_dlopen_self in yes|no) enable_dlopen_self=$lt_cv_dlopen_self ;; *) enable_dlopen_self=unknown ;; esac case $lt_cv_dlopen_self_static in yes|no) enable_dlopen_self_static=$lt_cv_dlopen_self_static ;; *) enable_dlopen_self_static=unknown ;; esac fi striplib= old_striplib= { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether stripping libraries is possible" >&5 printf %s "checking whether stripping libraries is possible... " >&6; } if test -z "$STRIP"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } else if $STRIP -V 2>&1 | $GREP "GNU strip" >/dev/null; then old_striplib="$STRIP --strip-debug" striplib="$STRIP --strip-unneeded" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } else case $host_os in darwin*) # FIXME - insert some real tests, host_os isn't really good enough striplib="$STRIP -x" old_striplib="$STRIP -S" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } ;; freebsd*) if $STRIP -V 2>&1 | $GREP "elftoolchain" >/dev/null; then old_striplib="$STRIP --strip-debug" striplib="$STRIP --strip-unneeded" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi ;; *) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } ;; esac fi fi # Report what library types will actually be built { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if libtool supports shared libraries" >&5 printf %s "checking if libtool supports shared libraries... " >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $can_build_shared" >&5 printf "%s\n" "$can_build_shared" >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether to build shared libraries" >&5 printf %s "checking whether to build shared libraries... " >&6; } test no = "$can_build_shared" && enable_shared=no # On AIX, shared libraries and static libraries use the same namespace, and # are all built from PIC. case $host_os in aix3*) test yes = "$enable_shared" && enable_static=no if test -n "$RANLIB"; then archive_cmds="$archive_cmds~\$RANLIB \$lib" postinstall_cmds='$RANLIB $lib' fi ;; aix[4-9]*) if test ia64 != "$host_cpu"; then case $enable_shared,$with_aix_soname,$aix_use_runtimelinking in yes,aix,yes) ;; # shared object as lib.so file only yes,svr4,*) ;; # shared object as lib.so archive member only yes,*) enable_static=no ;; # shared object in lib.a archive as well esac fi ;; esac { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $enable_shared" >&5 printf "%s\n" "$enable_shared" >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether to build static libraries" >&5 printf %s "checking whether to build static libraries... " >&6; } # Make sure either enable_shared or enable_static is yes. test yes = "$enable_shared" || enable_static=yes { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $enable_static" >&5 printf "%s\n" "$enable_static" >&6; } fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu CC=$lt_save_CC ac_config_commands="$ac_config_commands libtool" # Only expand once: ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}gcc", so it can be a program name with args. set dummy ${ac_tool_prefix}gcc; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_CC="${ac_tool_prefix}gcc" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 printf "%s\n" "$CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_CC"; then ac_ct_CC=$CC # Extract the first word of "gcc", so it can be a program name with args. set dummy gcc; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_CC"; then ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CC="gcc" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CC=$ac_cv_prog_ac_ct_CC if test -n "$ac_ct_CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 printf "%s\n" "$ac_ct_CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_CC" = x; then CC="" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CC=$ac_ct_CC fi else CC="$ac_cv_prog_CC" fi if test -z "$CC"; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}cc", so it can be a program name with args. set dummy ${ac_tool_prefix}cc; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_CC="${ac_tool_prefix}cc" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 printf "%s\n" "$CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi fi if test -z "$CC"; then # Extract the first word of "cc", so it can be a program name with args. set dummy cc; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else ac_prog_rejected=no as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then if test "$as_dir$ac_word$ac_exec_ext" = "/usr/ucb/cc"; then ac_prog_rejected=yes continue fi ac_cv_prog_CC="cc" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS if test $ac_prog_rejected = yes; then # We found a bogon in the path, so make sure we never use it. set dummy $ac_cv_prog_CC shift if test $# != 0; then # We chose a different compiler from the bogus one. # However, it has the same basename, so the bogon will be chosen # first if we set CC to just the basename; use the full file name. shift ac_cv_prog_CC="$as_dir$ac_word${1+' '}$@" fi fi fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 printf "%s\n" "$CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$CC"; then if test -n "$ac_tool_prefix"; then for ac_prog in cl.exe do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_CC="$ac_tool_prefix$ac_prog" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 printf "%s\n" "$CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -n "$CC" && break done fi if test -z "$CC"; then ac_ct_CC=$CC for ac_prog in cl.exe do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_CC"; then ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CC="$ac_prog" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CC=$ac_cv_prog_ac_ct_CC if test -n "$ac_ct_CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 printf "%s\n" "$ac_ct_CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -n "$ac_ct_CC" && break done if test "x$ac_ct_CC" = x; then CC="" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CC=$ac_ct_CC fi fi fi if test -z "$CC"; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}clang", so it can be a program name with args. set dummy ${ac_tool_prefix}clang; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$CC"; then ac_cv_prog_CC="$CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_CC="${ac_tool_prefix}clang" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CC=$ac_cv_prog_CC if test -n "$CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CC" >&5 printf "%s\n" "$CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_prog_CC"; then ac_ct_CC=$CC # Extract the first word of "clang", so it can be a program name with args. set dummy clang; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_CC+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_CC"; then ac_cv_prog_ac_ct_CC="$ac_ct_CC" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CC="clang" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CC=$ac_cv_prog_ac_ct_CC if test -n "$ac_ct_CC"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CC" >&5 printf "%s\n" "$ac_ct_CC" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_ct_CC" = x; then CC="" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CC=$ac_ct_CC fi else CC="$ac_cv_prog_CC" fi fi test -z "$CC" && { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "no acceptable C compiler found in \$PATH See \`config.log' for more details" "$LINENO" 5; } # Provide some information about the compiler. printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for C compiler version" >&5 set X $ac_compile ac_compiler=$2 for ac_option in --version -v -V -qversion -version; do { { ac_try="$ac_compiler $ac_option >&5" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_compiler $ac_option >&5") 2>conftest.err ac_status=$? if test -s conftest.err; then sed '10a\ ... rest of stderr output deleted ... 10q' conftest.err >conftest.er1 cat conftest.er1 >&5 fi rm -f conftest.er1 conftest.err printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } done { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether the compiler supports GNU C" >&5 printf %s "checking whether the compiler supports GNU C... " >&6; } if test ${ac_cv_c_compiler_gnu+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { #ifndef __GNUC__ choke me #endif ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_compiler_gnu=yes else $as_nop ac_compiler_gnu=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ac_cv_c_compiler_gnu=$ac_compiler_gnu fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_compiler_gnu" >&5 printf "%s\n" "$ac_cv_c_compiler_gnu" >&6; } ac_compiler_gnu=$ac_cv_c_compiler_gnu if test $ac_compiler_gnu = yes; then GCC=yes else GCC= fi ac_test_CFLAGS=${CFLAGS+y} ac_save_CFLAGS=$CFLAGS { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether $CC accepts -g" >&5 printf %s "checking whether $CC accepts -g... " >&6; } if test ${ac_cv_prog_cc_g+y} then : printf %s "(cached) " >&6 else $as_nop ac_save_c_werror_flag=$ac_c_werror_flag ac_c_werror_flag=yes ac_cv_prog_cc_g=no CFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_cv_prog_cc_g=yes else $as_nop CFLAGS="" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : else $as_nop ac_c_werror_flag=$ac_save_c_werror_flag CFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_cv_prog_cc_g=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ac_c_werror_flag=$ac_save_c_werror_flag fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_g" >&5 printf "%s\n" "$ac_cv_prog_cc_g" >&6; } if test $ac_test_CFLAGS; then CFLAGS=$ac_save_CFLAGS elif test $ac_cv_prog_cc_g = yes; then if test "$GCC" = yes; then CFLAGS="-g -O2" else CFLAGS="-g" fi else if test "$GCC" = yes; then CFLAGS="-O2" else CFLAGS= fi fi ac_prog_cc_stdc=no if test x$ac_prog_cc_stdc = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $CC option to enable C11 features" >&5 printf %s "checking for $CC option to enable C11 features... " >&6; } if test ${ac_cv_prog_cc_c11+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_prog_cc_c11=no ac_save_CC=$CC cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $ac_c_conftest_c11_program _ACEOF for ac_arg in '' -std=gnu11 do CC="$ac_save_CC $ac_arg" if ac_fn_c_try_compile "$LINENO" then : ac_cv_prog_cc_c11=$ac_arg fi rm -f core conftest.err conftest.$ac_objext conftest.beam test "x$ac_cv_prog_cc_c11" != "xno" && break done rm -f conftest.$ac_ext CC=$ac_save_CC fi if test "x$ac_cv_prog_cc_c11" = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 printf "%s\n" "unsupported" >&6; } else $as_nop if test "x$ac_cv_prog_cc_c11" = x then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 printf "%s\n" "none needed" >&6; } else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c11" >&5 printf "%s\n" "$ac_cv_prog_cc_c11" >&6; } CC="$CC $ac_cv_prog_cc_c11" fi ac_cv_prog_cc_stdc=$ac_cv_prog_cc_c11 ac_prog_cc_stdc=c11 fi fi if test x$ac_prog_cc_stdc = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $CC option to enable C99 features" >&5 printf %s "checking for $CC option to enable C99 features... " >&6; } if test ${ac_cv_prog_cc_c99+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_prog_cc_c99=no ac_save_CC=$CC cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $ac_c_conftest_c99_program _ACEOF for ac_arg in '' -std=gnu99 -std=c99 -c99 -qlanglvl=extc1x -qlanglvl=extc99 -AC99 -D_STDC_C99= do CC="$ac_save_CC $ac_arg" if ac_fn_c_try_compile "$LINENO" then : ac_cv_prog_cc_c99=$ac_arg fi rm -f core conftest.err conftest.$ac_objext conftest.beam test "x$ac_cv_prog_cc_c99" != "xno" && break done rm -f conftest.$ac_ext CC=$ac_save_CC fi if test "x$ac_cv_prog_cc_c99" = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 printf "%s\n" "unsupported" >&6; } else $as_nop if test "x$ac_cv_prog_cc_c99" = x then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 printf "%s\n" "none needed" >&6; } else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c99" >&5 printf "%s\n" "$ac_cv_prog_cc_c99" >&6; } CC="$CC $ac_cv_prog_cc_c99" fi ac_cv_prog_cc_stdc=$ac_cv_prog_cc_c99 ac_prog_cc_stdc=c99 fi fi if test x$ac_prog_cc_stdc = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $CC option to enable C89 features" >&5 printf %s "checking for $CC option to enable C89 features... " >&6; } if test ${ac_cv_prog_cc_c89+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_prog_cc_c89=no ac_save_CC=$CC cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $ac_c_conftest_c89_program _ACEOF for ac_arg in '' -qlanglvl=extc89 -qlanglvl=ansi -std -Ae "-Aa -D_HPUX_SOURCE" "-Xc -D__EXTENSIONS__" do CC="$ac_save_CC $ac_arg" if ac_fn_c_try_compile "$LINENO" then : ac_cv_prog_cc_c89=$ac_arg fi rm -f core conftest.err conftest.$ac_objext conftest.beam test "x$ac_cv_prog_cc_c89" != "xno" && break done rm -f conftest.$ac_ext CC=$ac_save_CC fi if test "x$ac_cv_prog_cc_c89" = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 printf "%s\n" "unsupported" >&6; } else $as_nop if test "x$ac_cv_prog_cc_c89" = x then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 printf "%s\n" "none needed" >&6; } else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cc_c89" >&5 printf "%s\n" "$ac_cv_prog_cc_c89" >&6; } CC="$CC $ac_cv_prog_cc_c89" fi ac_cv_prog_cc_stdc=$ac_cv_prog_cc_c89 ac_prog_cc_stdc=c89 fi fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether $CC understands -c and -o together" >&5 printf %s "checking whether $CC understands -c and -o together... " >&6; } if test ${am_cv_prog_cc_c_o+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF # Make sure it works both with $CC and with simple cc. # Following AC_PROG_CC_C_O, we do the test twice because some # compilers refuse to overwrite an existing .o file with -o, # though they will create one. am_cv_prog_cc_c_o=yes for am_i in 1 2; do if { echo "$as_me:$LINENO: $CC -c conftest.$ac_ext -o conftest2.$ac_objext" >&5 ($CC -c conftest.$ac_ext -o conftest2.$ac_objext) >&5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } \ && test -f conftest2.$ac_objext; then : OK else am_cv_prog_cc_c_o=no break fi done rm -f core conftest* unset am_i fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $am_cv_prog_cc_c_o" >&5 printf "%s\n" "$am_cv_prog_cc_c_o" >&6; } if test "$am_cv_prog_cc_c_o" != yes; then # Losing compiler, so override with the script. # FIXME: It is wrong to rewrite CC. # But if we don't then we get into trouble of one sort or another. # A longer-term fix would be to have automake use am__CC in this case, # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" CC="$am_aux_dir/compile $CC" fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu depcc="$CC" am_compiler_list= { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 printf %s "checking dependency style of $depcc... " >&6; } if test ${am_cv_CC_dependencies_compiler_type+y} then : printf %s "(cached) " >&6 else $as_nop if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then # We make a subdir and do the tests there. Otherwise we can end up # making bogus files that we don't know about and never remove. For # instance it was reported that on HP-UX the gcc test will end up # making a dummy file named 'D' -- because '-MD' means "put the output # in D". rm -rf conftest.dir mkdir conftest.dir # Copy depcomp to subdir because otherwise we won't find it if we're # using a relative directory. cp "$am_depcomp" conftest.dir cd conftest.dir # We will build objects and dependencies in a subdirectory because # it helps to detect inapplicable dependency modes. For instance # both Tru64's cc and ICC support -MD to output dependencies as a # side effect of compilation, but ICC will put the dependencies in # the current directory while Tru64 will put them in the object # directory. mkdir sub am_cv_CC_dependencies_compiler_type=none if test "$am_compiler_list" = ""; then am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` fi am__universal=false case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac for depmode in $am_compiler_list; do # Setup a source with many dependencies, because some compilers # like to wrap large dependency lists on column 80 (with \), and # we should not choose a depcomp mode which is confused by this. # # We need to recreate these files for each test, as the compiler may # overwrite some of them when testing with obscure command lines. # This happens at least with the AIX C compiler. : > sub/conftest.c for i in 1 2 3 4 5 6; do echo '#include "conftst'$i'.h"' >> sub/conftest.c # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with # Solaris 10 /bin/sh. echo '/* dummy */' > sub/conftst$i.h done echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf # We check with '-c' and '-o' for the sake of the "dashmstdout" # mode. It turns out that the SunPro C++ compiler does not properly # handle '-M -o', and we need to detect this. Also, some Intel # versions had trouble with output in subdirs. am__obj=sub/conftest.${OBJEXT-o} am__minus_obj="-o $am__obj" case $depmode in gcc) # This depmode causes a compiler race in universal mode. test "$am__universal" = false || continue ;; nosideeffect) # After this tag, mechanisms are not by side-effect, so they'll # only be used when explicitly requested. if test "x$enable_dependency_tracking" = xyes; then continue else break fi ;; msvc7 | msvc7msys | msvisualcpp | msvcmsys) # This compiler won't grok '-c -o', but also, the minuso test has # not run yet. These depmodes are late enough in the game, and # so weak that their functioning should not be impacted. am__obj=conftest.${OBJEXT-o} am__minus_obj= ;; none) break ;; esac if depmode=$depmode \ source=sub/conftest.c object=$am__obj \ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ >/dev/null 2>conftest.err && grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && grep $am__obj sub/conftest.Po > /dev/null 2>&1 && ${MAKE-make} -s -f confmf > /dev/null 2>&1; then # icc doesn't choke on unknown options, it will just issue warnings # or remarks (even with -Werror). So we grep stderr for any message # that says an option was ignored or not supported. # When given -MP, icc 7.0 and 7.1 complain thusly: # icc: Command line warning: ignoring option '-M'; no argument required # The diagnosis changed in icc 8.0: # icc: Command line remark: option '-MP' not supported if (grep 'ignoring option' conftest.err || grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else am_cv_CC_dependencies_compiler_type=$depmode break fi fi done cd .. rm -rf conftest.dir else am_cv_CC_dependencies_compiler_type=none fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $am_cv_CC_dependencies_compiler_type" >&5 printf "%s\n" "$am_cv_CC_dependencies_compiler_type" >&6; } CCDEPMODE=depmode=$am_cv_CC_dependencies_compiler_type if test "x$enable_dependency_tracking" != xno \ && test "$am_cv_CC_dependencies_compiler_type" = gcc3; then am__fastdepCC_TRUE= am__fastdepCC_FALSE='#' else am__fastdepCC_TRUE='#' am__fastdepCC_FALSE= fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking how to run the C preprocessor" >&5 printf %s "checking how to run the C preprocessor... " >&6; } # On Suns, sometimes $CPP names a directory. if test -n "$CPP" && test -d "$CPP"; then CPP= fi if test -z "$CPP"; then if test ${ac_cv_prog_CPP+y} then : printf %s "(cached) " >&6 else $as_nop # Double quotes because $CC needs to be expanded for CPP in "$CC -E" "$CC -E -traditional-cpp" cpp /lib/cpp do ac_preproc_ok=false for ac_c_preproc_warn_flag in '' yes do # Use a header file that comes with gcc, so configuring glibc # with a fresh cross-compiler works. # On the NeXT, cc -E runs the code through the compiler's parser, # not just through cpp. "Syntax error" is here to catch this case. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include Syntax error _ACEOF if ac_fn_c_try_cpp "$LINENO" then : else $as_nop # Broken: fails on valid input. continue fi rm -f conftest.err conftest.i conftest.$ac_ext # OK, works on sane cases. Now check whether nonexistent headers # can be detected and how. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_c_try_cpp "$LINENO" then : # Broken: success on invalid input. continue else $as_nop # Passes both tests. ac_preproc_ok=: break fi rm -f conftest.err conftest.i conftest.$ac_ext done # Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. rm -f conftest.i conftest.err conftest.$ac_ext if $ac_preproc_ok then : break fi done ac_cv_prog_CPP=$CPP fi CPP=$ac_cv_prog_CPP else ac_cv_prog_CPP=$CPP fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CPP" >&5 printf "%s\n" "$CPP" >&6; } ac_preproc_ok=false for ac_c_preproc_warn_flag in '' yes do # Use a header file that comes with gcc, so configuring glibc # with a fresh cross-compiler works. # On the NeXT, cc -E runs the code through the compiler's parser, # not just through cpp. "Syntax error" is here to catch this case. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include Syntax error _ACEOF if ac_fn_c_try_cpp "$LINENO" then : else $as_nop # Broken: fails on valid input. continue fi rm -f conftest.err conftest.i conftest.$ac_ext # OK, works on sane cases. Now check whether nonexistent headers # can be detected and how. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_c_try_cpp "$LINENO" then : # Broken: success on invalid input. continue else $as_nop # Passes both tests. ac_preproc_ok=: break fi rm -f conftest.err conftest.i conftest.$ac_ext done # Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. rm -f conftest.i conftest.err conftest.$ac_ext if $ac_preproc_ok then : else $as_nop { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "C preprocessor \"$CPP\" fails sanity check See \`config.log' for more details" "$LINENO" 5; } fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu if test $ac_cv_c_compiler_gnu = yes; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether $CC needs -traditional" >&5 printf %s "checking whether $CC needs -traditional... " >&6; } if test ${ac_cv_prog_gcc_traditional+y} then : printf %s "(cached) " >&6 else $as_nop ac_pattern="Autoconf.*'x'" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include Autoconf TIOCGETP _ACEOF if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | $EGREP "$ac_pattern" >/dev/null 2>&1 then : ac_cv_prog_gcc_traditional=yes else $as_nop ac_cv_prog_gcc_traditional=no fi rm -rf conftest* if test $ac_cv_prog_gcc_traditional = no; then cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include Autoconf TCGETA _ACEOF if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | $EGREP "$ac_pattern" >/dev/null 2>&1 then : ac_cv_prog_gcc_traditional=yes fi rm -rf conftest* fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_gcc_traditional" >&5 printf "%s\n" "$ac_cv_prog_gcc_traditional" >&6; } if test $ac_cv_prog_gcc_traditional = yes; then CC="$CC -traditional" fi fi ac_ext=cpp ac_cpp='$CXXCPP $CPPFLAGS' ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_cxx_compiler_gnu if test -z "$CXX"; then if test -n "$CCC"; then CXX=$CCC else if test -n "$ac_tool_prefix"; then for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC clang++ do # Extract the first word of "$ac_tool_prefix$ac_prog", so it can be a program name with args. set dummy $ac_tool_prefix$ac_prog; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_CXX+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$CXX"; then ac_cv_prog_CXX="$CXX" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_CXX="$ac_tool_prefix$ac_prog" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi CXX=$ac_cv_prog_CXX if test -n "$CXX"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CXX" >&5 printf "%s\n" "$CXX" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -n "$CXX" && break done fi if test -z "$CXX"; then ac_ct_CXX=$CXX for ac_prog in g++ c++ gpp aCC CC cxx cc++ cl.exe FCC KCC RCC xlC_r xlC clang++ do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_ac_ct_CXX+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$ac_ct_CXX"; then ac_cv_prog_ac_ct_CXX="$ac_ct_CXX" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_ac_ct_CXX="$ac_prog" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi ac_ct_CXX=$ac_cv_prog_ac_ct_CXX if test -n "$ac_ct_CXX"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_ct_CXX" >&5 printf "%s\n" "$ac_ct_CXX" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -n "$ac_ct_CXX" && break done if test "x$ac_ct_CXX" = x; then CXX="g++" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac CXX=$ac_ct_CXX fi fi fi fi # Provide some information about the compiler. printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for C++ compiler version" >&5 set X $ac_compile ac_compiler=$2 for ac_option in --version -v -V -qversion; do { { ac_try="$ac_compiler $ac_option >&5" case "(($ac_try" in *\"* | *\`* | *\\*) ac_try_echo=\$ac_try;; *) ac_try_echo=$ac_try;; esac eval ac_try_echo="\"\$as_me:${as_lineno-$LINENO}: $ac_try_echo\"" printf "%s\n" "$ac_try_echo"; } >&5 (eval "$ac_compiler $ac_option >&5") 2>conftest.err ac_status=$? if test -s conftest.err; then sed '10a\ ... rest of stderr output deleted ... 10q' conftest.err >conftest.er1 cat conftest.er1 >&5 fi rm -f conftest.er1 conftest.err printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } done { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether the compiler supports GNU C++" >&5 printf %s "checking whether the compiler supports GNU C++... " >&6; } if test ${ac_cv_cxx_compiler_gnu+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { #ifndef __GNUC__ choke me #endif ; return 0; } _ACEOF if ac_fn_cxx_try_compile "$LINENO" then : ac_compiler_gnu=yes else $as_nop ac_compiler_gnu=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ac_cv_cxx_compiler_gnu=$ac_compiler_gnu fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_cxx_compiler_gnu" >&5 printf "%s\n" "$ac_cv_cxx_compiler_gnu" >&6; } ac_compiler_gnu=$ac_cv_cxx_compiler_gnu if test $ac_compiler_gnu = yes; then GXX=yes else GXX= fi ac_test_CXXFLAGS=${CXXFLAGS+y} ac_save_CXXFLAGS=$CXXFLAGS { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether $CXX accepts -g" >&5 printf %s "checking whether $CXX accepts -g... " >&6; } if test ${ac_cv_prog_cxx_g+y} then : printf %s "(cached) " >&6 else $as_nop ac_save_cxx_werror_flag=$ac_cxx_werror_flag ac_cxx_werror_flag=yes ac_cv_prog_cxx_g=no CXXFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_cxx_try_compile "$LINENO" then : ac_cv_prog_cxx_g=yes else $as_nop CXXFLAGS="" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_cxx_try_compile "$LINENO" then : else $as_nop ac_cxx_werror_flag=$ac_save_cxx_werror_flag CXXFLAGS="-g" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_cxx_try_compile "$LINENO" then : ac_cv_prog_cxx_g=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ac_cxx_werror_flag=$ac_save_cxx_werror_flag fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cxx_g" >&5 printf "%s\n" "$ac_cv_prog_cxx_g" >&6; } if test $ac_test_CXXFLAGS; then CXXFLAGS=$ac_save_CXXFLAGS elif test $ac_cv_prog_cxx_g = yes; then if test "$GXX" = yes; then CXXFLAGS="-g -O2" else CXXFLAGS="-g" fi else if test "$GXX" = yes; then CXXFLAGS="-O2" else CXXFLAGS= fi fi ac_prog_cxx_stdcxx=no if test x$ac_prog_cxx_stdcxx = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $CXX option to enable C++11 features" >&5 printf %s "checking for $CXX option to enable C++11 features... " >&6; } if test ${ac_cv_prog_cxx_cxx11+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_prog_cxx_cxx11=no ac_save_CXX=$CXX cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $ac_cxx_conftest_cxx11_program _ACEOF for ac_arg in '' -std=gnu++11 -std=gnu++0x -std=c++11 -std=c++0x -qlanglvl=extended0x -AA do CXX="$ac_save_CXX $ac_arg" if ac_fn_cxx_try_compile "$LINENO" then : ac_cv_prog_cxx_cxx11=$ac_arg fi rm -f core conftest.err conftest.$ac_objext conftest.beam test "x$ac_cv_prog_cxx_cxx11" != "xno" && break done rm -f conftest.$ac_ext CXX=$ac_save_CXX fi if test "x$ac_cv_prog_cxx_cxx11" = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 printf "%s\n" "unsupported" >&6; } else $as_nop if test "x$ac_cv_prog_cxx_cxx11" = x then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 printf "%s\n" "none needed" >&6; } else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cxx_cxx11" >&5 printf "%s\n" "$ac_cv_prog_cxx_cxx11" >&6; } CXX="$CXX $ac_cv_prog_cxx_cxx11" fi ac_cv_prog_cxx_stdcxx=$ac_cv_prog_cxx_cxx11 ac_prog_cxx_stdcxx=cxx11 fi fi if test x$ac_prog_cxx_stdcxx = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $CXX option to enable C++98 features" >&5 printf %s "checking for $CXX option to enable C++98 features... " >&6; } if test ${ac_cv_prog_cxx_cxx98+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_prog_cxx_cxx98=no ac_save_CXX=$CXX cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ $ac_cxx_conftest_cxx98_program _ACEOF for ac_arg in '' -std=gnu++98 -std=c++98 -qlanglvl=extended -AA do CXX="$ac_save_CXX $ac_arg" if ac_fn_cxx_try_compile "$LINENO" then : ac_cv_prog_cxx_cxx98=$ac_arg fi rm -f core conftest.err conftest.$ac_objext conftest.beam test "x$ac_cv_prog_cxx_cxx98" != "xno" && break done rm -f conftest.$ac_ext CXX=$ac_save_CXX fi if test "x$ac_cv_prog_cxx_cxx98" = xno then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: unsupported" >&5 printf "%s\n" "unsupported" >&6; } else $as_nop if test "x$ac_cv_prog_cxx_cxx98" = x then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: none needed" >&5 printf "%s\n" "none needed" >&6; } else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_prog_cxx_cxx98" >&5 printf "%s\n" "$ac_cv_prog_cxx_cxx98" >&6; } CXX="$CXX $ac_cv_prog_cxx_cxx98" fi ac_cv_prog_cxx_stdcxx=$ac_cv_prog_cxx_cxx98 ac_prog_cxx_stdcxx=cxx98 fi fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu depcc="$CXX" am_compiler_list= { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking dependency style of $depcc" >&5 printf %s "checking dependency style of $depcc... " >&6; } if test ${am_cv_CXX_dependencies_compiler_type+y} then : printf %s "(cached) " >&6 else $as_nop if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then # We make a subdir and do the tests there. Otherwise we can end up # making bogus files that we don't know about and never remove. For # instance it was reported that on HP-UX the gcc test will end up # making a dummy file named 'D' -- because '-MD' means "put the output # in D". rm -rf conftest.dir mkdir conftest.dir # Copy depcomp to subdir because otherwise we won't find it if we're # using a relative directory. cp "$am_depcomp" conftest.dir cd conftest.dir # We will build objects and dependencies in a subdirectory because # it helps to detect inapplicable dependency modes. For instance # both Tru64's cc and ICC support -MD to output dependencies as a # side effect of compilation, but ICC will put the dependencies in # the current directory while Tru64 will put them in the object # directory. mkdir sub am_cv_CXX_dependencies_compiler_type=none if test "$am_compiler_list" = ""; then am_compiler_list=`sed -n 's/^#*\([a-zA-Z0-9]*\))$/\1/p' < ./depcomp` fi am__universal=false case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac for depmode in $am_compiler_list; do # Setup a source with many dependencies, because some compilers # like to wrap large dependency lists on column 80 (with \), and # we should not choose a depcomp mode which is confused by this. # # We need to recreate these files for each test, as the compiler may # overwrite some of them when testing with obscure command lines. # This happens at least with the AIX C compiler. : > sub/conftest.c for i in 1 2 3 4 5 6; do echo '#include "conftst'$i'.h"' >> sub/conftest.c # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with # Solaris 10 /bin/sh. echo '/* dummy */' > sub/conftst$i.h done echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf # We check with '-c' and '-o' for the sake of the "dashmstdout" # mode. It turns out that the SunPro C++ compiler does not properly # handle '-M -o', and we need to detect this. Also, some Intel # versions had trouble with output in subdirs. am__obj=sub/conftest.${OBJEXT-o} am__minus_obj="-o $am__obj" case $depmode in gcc) # This depmode causes a compiler race in universal mode. test "$am__universal" = false || continue ;; nosideeffect) # After this tag, mechanisms are not by side-effect, so they'll # only be used when explicitly requested. if test "x$enable_dependency_tracking" = xyes; then continue else break fi ;; msvc7 | msvc7msys | msvisualcpp | msvcmsys) # This compiler won't grok '-c -o', but also, the minuso test has # not run yet. These depmodes are late enough in the game, and # so weak that their functioning should not be impacted. am__obj=conftest.${OBJEXT-o} am__minus_obj= ;; none) break ;; esac if depmode=$depmode \ source=sub/conftest.c object=$am__obj \ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ >/dev/null 2>conftest.err && grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && grep $am__obj sub/conftest.Po > /dev/null 2>&1 && ${MAKE-make} -s -f confmf > /dev/null 2>&1; then # icc doesn't choke on unknown options, it will just issue warnings # or remarks (even with -Werror). So we grep stderr for any message # that says an option was ignored or not supported. # When given -MP, icc 7.0 and 7.1 complain thusly: # icc: Command line warning: ignoring option '-M'; no argument required # The diagnosis changed in icc 8.0: # icc: Command line remark: option '-MP' not supported if (grep 'ignoring option' conftest.err || grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else am_cv_CXX_dependencies_compiler_type=$depmode break fi fi done cd .. rm -rf conftest.dir else am_cv_CXX_dependencies_compiler_type=none fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $am_cv_CXX_dependencies_compiler_type" >&5 printf "%s\n" "$am_cv_CXX_dependencies_compiler_type" >&6; } CXXDEPMODE=depmode=$am_cv_CXX_dependencies_compiler_type if test "x$enable_dependency_tracking" != xno \ && test "$am_cv_CXX_dependencies_compiler_type" = gcc3; then am__fastdepCXX_TRUE= am__fastdepCXX_FALSE='#' else am__fastdepCXX_TRUE='#' am__fastdepCXX_FALSE= fi func_stripname_cnf () { case $2 in .*) func_stripname_result=`$ECHO "$3" | $SED "s%^$1%%; s%\\\\$2\$%%"`;; *) func_stripname_result=`$ECHO "$3" | $SED "s%^$1%%; s%$2\$%%"`;; esac } # func_stripname_cnf if test -n "$CXX" && ( test no != "$CXX" && ( (test g++ = "$CXX" && `g++ -v >/dev/null 2>&1` ) || (test g++ != "$CXX"))); then ac_ext=cpp ac_cpp='$CXXCPP $CPPFLAGS' ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_cxx_compiler_gnu { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking how to run the C++ preprocessor" >&5 printf %s "checking how to run the C++ preprocessor... " >&6; } if test -z "$CXXCPP"; then if test ${ac_cv_prog_CXXCPP+y} then : printf %s "(cached) " >&6 else $as_nop # Double quotes because $CXX needs to be expanded for CXXCPP in "$CXX -E" cpp /lib/cpp do ac_preproc_ok=false for ac_cxx_preproc_warn_flag in '' yes do # Use a header file that comes with gcc, so configuring glibc # with a fresh cross-compiler works. # On the NeXT, cc -E runs the code through the compiler's parser, # not just through cpp. "Syntax error" is here to catch this case. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include Syntax error _ACEOF if ac_fn_cxx_try_cpp "$LINENO" then : else $as_nop # Broken: fails on valid input. continue fi rm -f conftest.err conftest.i conftest.$ac_ext # OK, works on sane cases. Now check whether nonexistent headers # can be detected and how. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_cxx_try_cpp "$LINENO" then : # Broken: success on invalid input. continue else $as_nop # Passes both tests. ac_preproc_ok=: break fi rm -f conftest.err conftest.i conftest.$ac_ext done # Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. rm -f conftest.i conftest.err conftest.$ac_ext if $ac_preproc_ok then : break fi done ac_cv_prog_CXXCPP=$CXXCPP fi CXXCPP=$ac_cv_prog_CXXCPP else ac_cv_prog_CXXCPP=$CXXCPP fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $CXXCPP" >&5 printf "%s\n" "$CXXCPP" >&6; } ac_preproc_ok=false for ac_cxx_preproc_warn_flag in '' yes do # Use a header file that comes with gcc, so configuring glibc # with a fresh cross-compiler works. # On the NeXT, cc -E runs the code through the compiler's parser, # not just through cpp. "Syntax error" is here to catch this case. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include Syntax error _ACEOF if ac_fn_cxx_try_cpp "$LINENO" then : else $as_nop # Broken: fails on valid input. continue fi rm -f conftest.err conftest.i conftest.$ac_ext # OK, works on sane cases. Now check whether nonexistent headers # can be detected and how. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include _ACEOF if ac_fn_cxx_try_cpp "$LINENO" then : # Broken: success on invalid input. continue else $as_nop # Passes both tests. ac_preproc_ok=: break fi rm -f conftest.err conftest.i conftest.$ac_ext done # Because of `break', _AC_PREPROC_IFELSE's cleaning code was skipped. rm -f conftest.i conftest.err conftest.$ac_ext if $ac_preproc_ok then : else $as_nop { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "C++ preprocessor \"$CXXCPP\" fails sanity check See \`config.log' for more details" "$LINENO" 5; } fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu else _lt_caught_CXX_error=yes fi ac_ext=cpp ac_cpp='$CXXCPP $CPPFLAGS' ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_cxx_compiler_gnu archive_cmds_need_lc_CXX=no allow_undefined_flag_CXX= always_export_symbols_CXX=no archive_expsym_cmds_CXX= compiler_needs_object_CXX=no export_dynamic_flag_spec_CXX= hardcode_direct_CXX=no hardcode_direct_absolute_CXX=no hardcode_libdir_flag_spec_CXX= hardcode_libdir_separator_CXX= hardcode_minus_L_CXX=no hardcode_shlibpath_var_CXX=unsupported hardcode_automatic_CXX=no inherit_rpath_CXX=no module_cmds_CXX= module_expsym_cmds_CXX= link_all_deplibs_CXX=unknown old_archive_cmds_CXX=$old_archive_cmds reload_flag_CXX=$reload_flag reload_cmds_CXX=$reload_cmds no_undefined_flag_CXX= whole_archive_flag_spec_CXX= enable_shared_with_static_runtimes_CXX=no # Source file extension for C++ test sources. ac_ext=cpp # Object file extension for compiled C++ test sources. objext=o objext_CXX=$objext # No sense in running all these tests if we already determined that # the CXX compiler isn't working. Some variables (like enable_shared) # are currently assumed to apply to all compilers on this platform, # and will be corrupted by setting them based on a non-working compiler. if test yes != "$_lt_caught_CXX_error"; then # Code to be used in simple compile tests lt_simple_compile_test_code="int some_variable = 0;" # Code to be used in simple link tests lt_simple_link_test_code='int main(int, char *[]) { return(0); }' # ltmain only uses $CC for tagged configurations so make sure $CC is set. # If no C compiler was specified, use CC. LTCC=${LTCC-"$CC"} # If no C compiler flags were specified, use CFLAGS. LTCFLAGS=${LTCFLAGS-"$CFLAGS"} # Allow CC to be a program name with arguments. compiler=$CC # save warnings/boilerplate of simple test code ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" >conftest.$ac_ext eval "$ac_compile" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_compiler_boilerplate=`cat conftest.err` $RM conftest* ac_outfile=conftest.$ac_objext echo "$lt_simple_link_test_code" >conftest.$ac_ext eval "$ac_link" 2>&1 >/dev/null | $SED '/^$/d; /^ *+/d' >conftest.err _lt_linker_boilerplate=`cat conftest.err` $RM -r conftest* # Allow CC to be a program name with arguments. lt_save_CC=$CC lt_save_CFLAGS=$CFLAGS lt_save_LD=$LD lt_save_GCC=$GCC GCC=$GXX lt_save_with_gnu_ld=$with_gnu_ld lt_save_path_LD=$lt_cv_path_LD if test -n "${lt_cv_prog_gnu_ldcxx+set}"; then lt_cv_prog_gnu_ld=$lt_cv_prog_gnu_ldcxx else $as_unset lt_cv_prog_gnu_ld fi if test -n "${lt_cv_path_LDCXX+set}"; then lt_cv_path_LD=$lt_cv_path_LDCXX else $as_unset lt_cv_path_LD fi test -z "${LDCXX+set}" || LD=$LDCXX CC=${CXX-"c++"} CFLAGS=$CXXFLAGS compiler=$CC compiler_CXX=$CC func_cc_basename $compiler cc_basename=$func_cc_basename_result if test -n "$compiler"; then # We don't want -fno-exception when compiling C++ code, so set the # no_builtin_flag separately if test yes = "$GXX"; then lt_prog_compiler_no_builtin_flag_CXX=' -fno-builtin' else lt_prog_compiler_no_builtin_flag_CXX= fi if test yes = "$GXX"; then # Set up default GNU C++ configuration # Check whether --with-gnu-ld was given. if test ${with_gnu_ld+y} then : withval=$with_gnu_ld; test no = "$withval" || with_gnu_ld=yes else $as_nop with_gnu_ld=no fi ac_prog=ld if test yes = "$GCC"; then # Check if gcc -print-prog-name=ld gives a path. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for ld used by $CC" >&5 printf %s "checking for ld used by $CC... " >&6; } case $host in *-*-mingw*) # gcc leaves a trailing carriage return, which upsets mingw ac_prog=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; *) ac_prog=`($CC -print-prog-name=ld) 2>&5` ;; esac case $ac_prog in # Accept absolute paths. [\\/]* | ?:[\\/]*) re_direlt='/[^/][^/]*/\.\./' # Canonicalize the pathname of ld ac_prog=`$ECHO "$ac_prog"| $SED 's%\\\\%/%g'` while $ECHO "$ac_prog" | $GREP "$re_direlt" > /dev/null 2>&1; do ac_prog=`$ECHO $ac_prog| $SED "s%$re_direlt%/%"` done test -z "$LD" && LD=$ac_prog ;; "") # If it fails, then pretend we aren't using GCC. ac_prog=ld ;; *) # If it is relative, then search for the first ld in PATH. with_gnu_ld=unknown ;; esac elif test yes = "$with_gnu_ld"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for GNU ld" >&5 printf %s "checking for GNU ld... " >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for non-GNU ld" >&5 printf %s "checking for non-GNU ld... " >&6; } fi if test ${lt_cv_path_LD+y} then : printf %s "(cached) " >&6 else $as_nop if test -z "$LD"; then lt_save_ifs=$IFS; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS=$lt_save_ifs test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then lt_cv_path_LD=$ac_dir/$ac_prog # Check to see if the program is GNU ld. I'd rather use --version, # but apparently some variants of GNU ld only accept -v. # Break only if it was the GNU/non-GNU ld that we prefer. case `"$lt_cv_path_LD" -v 2>&1 &5 printf "%s\n" "$LD" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -z "$LD" && as_fn_error $? "no acceptable ld found in \$PATH" "$LINENO" 5 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if the linker ($LD) is GNU ld" >&5 printf %s "checking if the linker ($LD) is GNU ld... " >&6; } if test ${lt_cv_prog_gnu_ld+y} then : printf %s "(cached) " >&6 else $as_nop # I'd rather use --version here, but apparently some GNU lds only accept -v. case `$LD -v 2>&1 &5 printf "%s\n" "$lt_cv_prog_gnu_ld" >&6; } with_gnu_ld=$lt_cv_prog_gnu_ld # Check if GNU C++ uses GNU ld as the underlying linker, since the # archiving commands below assume that GNU ld is being used. if test yes = "$with_gnu_ld"; then archive_cmds_CXX='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds_CXX='$CC $pic_flag -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir' export_dynamic_flag_spec_CXX='$wl--export-dynamic' # If archive_cmds runs LD, not CC, wlarc should be empty # XXX I think wlarc can be eliminated in ltcf-cxx, but I need to # investigate it a little bit more. (MM) wlarc='$wl' # ancient GNU ld didn't support --whole-archive et. al. if eval "`$CC -print-prog-name=ld` --help 2>&1" | $GREP 'no-whole-archive' > /dev/null; then whole_archive_flag_spec_CXX=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' else whole_archive_flag_spec_CXX= fi else with_gnu_ld=no wlarc= # A generic and very simple default shared library creation # command for GNU C++ for the case where it uses the native # linker, instead of GNU ld. If possible, this setting should # overridden to take advantage of the native linker features on # the platform it is being used on. archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' fi # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else GXX=no with_gnu_ld=no wlarc= fi # PORTME: fill in a description of your system's C++ link characteristics { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether the $compiler linker ($LD) supports shared libraries" >&5 printf %s "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } ld_shlibs_CXX=yes case $host_os in aix3*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; aix[4-9]*) if test ia64 = "$host_cpu"; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no exp_sym_flag='-Bexport' no_entry_flag= else aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # have runtime linking enabled, and use it for executables. # For shared libraries, we enable/disable runtime linking # depending on the kind of the shared library created - # when "with_aix_soname,aix_use_runtimelinking" is: # "aix,no" lib.a(lib.so.V) shared, rtl:no, for executables # "aix,yes" lib.so shared, rtl:yes, for executables # lib.a static archive # "both,no" lib.so.V(shr.o) shared, rtl:yes # lib.a(lib.so.V) shared, rtl:no, for executables # "both,yes" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a(lib.so.V) shared, rtl:no # "svr4,*" lib.so.V(shr.o) shared, rtl:yes, for executables # lib.a static archive case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) for ld_flag in $LDFLAGS; do case $ld_flag in *-brtl*) aix_use_runtimelinking=yes break ;; esac done if test svr4,no = "$with_aix_soname,$aix_use_runtimelinking"; then # With aix-soname=svr4, we create the lib.so.V shared archives only, # so we don't have lib.a shared libs to link our executables. # We have to force runtime linking in this case. aix_use_runtimelinking=yes LDFLAGS="$LDFLAGS -Wl,-brtl" fi ;; esac exp_sym_flag='-bexport' no_entry_flag='-bnoentry' fi # When large executables or shared objects are built, AIX ld can # have problems creating the table of contents. If linking a library # or program results in "error TOC overflow" add -mminimal-toc to # CXXFLAGS/CFLAGS for g++/gcc. In the cases where that is not # enough to fix the problem, add -Wl,-bbigtoc to LDFLAGS. archive_cmds_CXX='' hardcode_direct_CXX=yes hardcode_direct_absolute_CXX=yes hardcode_libdir_separator_CXX=':' link_all_deplibs_CXX=yes file_list_spec_CXX='$wl-f,' case $with_aix_soname,$aix_use_runtimelinking in aix,*) ;; # no import file svr4,* | *,yes) # use import file # The Import File defines what to hardcode. hardcode_direct_CXX=no hardcode_direct_absolute_CXX=no ;; esac if test yes = "$GXX"; then case $host_os in aix4.[012]|aix4.[012].*) # We only want to do this on AIX 4.2 and lower, the check # below for broken collect2 doesn't work under 4.3+ collect2name=`$CC -print-prog-name=collect2` if test -f "$collect2name" && strings "$collect2name" | $GREP resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 hardcode_direct_CXX=unsupported # It fails to find uninstalled libraries when the uninstalled # path is not listed in the libpath. Setting hardcode_minus_L # to unsupported forces relinking hardcode_minus_L_CXX=yes hardcode_libdir_flag_spec_CXX='-L$libdir' hardcode_libdir_separator_CXX= fi esac shared_flag='-shared' if test yes = "$aix_use_runtimelinking"; then shared_flag=$shared_flag' $wl-G' fi # Need to ensure runtime linking is disabled for the traditional # shared library, or the linker may eventually find shared libraries # /with/ Import File - we do not want to mix them. shared_flag_aix='-shared' shared_flag_svr4='-shared $wl-G' else # not using gcc if test ia64 = "$host_cpu"; then # VisualAge C++, Version 5.5 for AIX 5L for IA-64, Beta 3 Release # chokes on -Wl,-G. The following line is correct: shared_flag='-G' else if test yes = "$aix_use_runtimelinking"; then shared_flag='$wl-G' else shared_flag='$wl-bM:SRE' fi shared_flag_aix='$wl-bM:SRE' shared_flag_svr4='$wl-G' fi fi export_dynamic_flag_spec_CXX='$wl-bexpall' # It seems that -bexpall does not export symbols beginning with # underscore (_), so it is better to generate a list of symbols to # export. always_export_symbols_CXX=yes if test aix,yes = "$with_aix_soname,$aix_use_runtimelinking"; then # Warning - without using the other runtime loading flags (-brtl), # -berok will link without error, but may produce a broken library. # The "-G" linker flag allows undefined symbols. no_undefined_flag_CXX='-bernotok' # Determine the default libpath from the value encoded in an empty # executable. if test set = "${lt_cv_aix_libpath+set}"; then aix_libpath=$lt_cv_aix_libpath else if test ${lt_cv_aix_libpath__CXX+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO" then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath__CXX=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath__CXX"; then lt_cv_aix_libpath__CXX=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath__CXX"; then lt_cv_aix_libpath__CXX=/usr/lib:/lib fi fi aix_libpath=$lt_cv_aix_libpath__CXX fi hardcode_libdir_flag_spec_CXX='$wl-blibpath:$libdir:'"$aix_libpath" archive_expsym_cmds_CXX='$CC -o $output_objdir/$soname $libobjs $deplibs $wl'$no_entry_flag' $compiler_flags `if test -n "$allow_undefined_flag"; then func_echo_all "$wl$allow_undefined_flag"; else :; fi` $wl'$exp_sym_flag:\$export_symbols' '$shared_flag else if test ia64 = "$host_cpu"; then hardcode_libdir_flag_spec_CXX='$wl-R $libdir:/usr/lib:/lib' allow_undefined_flag_CXX="-z nodefs" archive_expsym_cmds_CXX="\$CC $shared_flag"' -o $output_objdir/$soname $libobjs $deplibs '"\$wl$no_entry_flag"' $compiler_flags $wl$allow_undefined_flag '"\$wl$exp_sym_flag:\$export_symbols" else # Determine the default libpath from the value encoded in an # empty executable. if test set = "${lt_cv_aix_libpath+set}"; then aix_libpath=$lt_cv_aix_libpath else if test ${lt_cv_aix_libpath__CXX+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO" then : lt_aix_libpath_sed=' /Import File Strings/,/^$/ { /^0/ { s/^0 *\([^ ]*\) *$/\1/ p } }' lt_cv_aix_libpath__CXX=`dump -H conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` # Check for a 64-bit object if we didn't find anything. if test -z "$lt_cv_aix_libpath__CXX"; then lt_cv_aix_libpath__CXX=`dump -HX64 conftest$ac_exeext 2>/dev/null | $SED -n -e "$lt_aix_libpath_sed"` fi fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext if test -z "$lt_cv_aix_libpath__CXX"; then lt_cv_aix_libpath__CXX=/usr/lib:/lib fi fi aix_libpath=$lt_cv_aix_libpath__CXX fi hardcode_libdir_flag_spec_CXX='$wl-blibpath:$libdir:'"$aix_libpath" # Warning - without using the other run time loading flags, # -berok will link without error, but may produce a broken library. no_undefined_flag_CXX=' $wl-bernotok' allow_undefined_flag_CXX=' $wl-berok' if test yes = "$with_gnu_ld"; then # We only use this code for GNU lds that support --whole-archive. whole_archive_flag_spec_CXX='$wl--whole-archive$convenience $wl--no-whole-archive' else # Exported symbols can be pulled into shared objects from archives whole_archive_flag_spec_CXX='$convenience' fi archive_cmds_need_lc_CXX=yes archive_expsym_cmds_CXX='$RM -r $output_objdir/$realname.d~$MKDIR $output_objdir/$realname.d' # -brtl affects multiple linker settings, -berok does not and is overridden later compiler_flags_filtered='`func_echo_all "$compiler_flags " | $SED -e "s%-brtl\\([, ]\\)%-berok\\1%g"`' if test svr4 != "$with_aix_soname"; then # This is similar to how AIX traditionally builds its shared # libraries. Need -bnortl late, we may have -brtl in LDFLAGS. archive_expsym_cmds_CXX="$archive_expsym_cmds_CXX"'~$CC '$shared_flag_aix' -o $output_objdir/$realname.d/$soname $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$AR $AR_FLAGS $output_objdir/$libname$release.a $output_objdir/$realname.d/$soname' fi if test aix != "$with_aix_soname"; then archive_expsym_cmds_CXX="$archive_expsym_cmds_CXX"'~$CC '$shared_flag_svr4' -o $output_objdir/$realname.d/$shared_archive_member_spec.o $libobjs $deplibs $wl-bnoentry '$compiler_flags_filtered'$wl-bE:$export_symbols$allow_undefined_flag~$STRIP -e $output_objdir/$realname.d/$shared_archive_member_spec.o~( func_echo_all "#! $soname($shared_archive_member_spec.o)"; if test shr_64 = "$shared_archive_member_spec"; then func_echo_all "# 64"; else func_echo_all "# 32"; fi; cat $export_symbols ) > $output_objdir/$realname.d/$shared_archive_member_spec.imp~$AR $AR_FLAGS $output_objdir/$soname $output_objdir/$realname.d/$shared_archive_member_spec.o $output_objdir/$realname.d/$shared_archive_member_spec.imp' else # used by -dlpreopen to get the symbols archive_expsym_cmds_CXX="$archive_expsym_cmds_CXX"'~$MV $output_objdir/$realname.d/$soname $output_objdir' fi archive_expsym_cmds_CXX="$archive_expsym_cmds_CXX"'~$RM -r $output_objdir/$realname.d' fi fi ;; beos*) if $LD --help 2>&1 | $GREP ': supported targets:.* elf' > /dev/null; then allow_undefined_flag_CXX=unsupported # Joseph Beckenbach says some releases of gcc # support --undefined. This deserves some investigation. FIXME archive_cmds_CXX='$CC -nostart $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' else ld_shlibs_CXX=no fi ;; chorus*) case $cc_basename in *) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; esac ;; cygwin* | mingw* | pw32* | cegcc*) case $GXX,$cc_basename in ,cl* | no,cl* | ,icl* | no,icl*) # Native MSVC or ICC # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. hardcode_libdir_flag_spec_CXX=' ' allow_undefined_flag_CXX=unsupported always_export_symbols_CXX=yes file_list_spec_CXX='@' # Tell ltmain to make .lib files, not .a files. libext=lib # Tell ltmain to make .dll files, not .so files. shrext_cmds=.dll # FIXME: Setting linknames here is a bad hack. archive_cmds_CXX='$CC -o $output_objdir/$soname $libobjs $compiler_flags $deplibs -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~linknames=' archive_expsym_cmds_CXX='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then cp "$export_symbols" "$output_objdir/$soname.def"; echo "$tool_output_objdir$soname.def" > "$output_objdir/$soname.exp"; else $SED -e '\''s/^/-link -EXPORT:/'\'' < $export_symbols > $output_objdir/$soname.exp; fi~ $CC -o $tool_output_objdir$soname $libobjs $compiler_flags $deplibs "@$tool_output_objdir$soname.exp" -Wl,-DLL,-IMPLIB:"$tool_output_objdir$libname.dll.lib"~ linknames=' # The linker will not automatically build a static lib if we build a DLL. # _LT_TAGVAR(old_archive_from_new_cmds, CXX)='true' enable_shared_with_static_runtimes_CXX=yes # Don't use ranlib old_postinstall_cmds_CXX='chmod 644 $oldlib' postlink_cmds_CXX='lt_outputfile="@OUTPUT@"~ lt_tool_outputfile="@TOOL_OUTPUT@"~ case $lt_outputfile in *.exe|*.EXE) ;; *) lt_outputfile=$lt_outputfile.exe lt_tool_outputfile=$lt_tool_outputfile.exe ;; esac~ func_to_tool_file "$lt_outputfile"~ if test : != "$MANIFEST_TOOL" && test -f "$lt_outputfile.manifest"; then $MANIFEST_TOOL -manifest "$lt_tool_outputfile.manifest" -outputresource:"$lt_tool_outputfile" || exit 1; $RM "$lt_outputfile.manifest"; fi' ;; *) # g++ # _LT_TAGVAR(hardcode_libdir_flag_spec, CXX) is actually meaningless, # as there is no search path for DLLs. hardcode_libdir_flag_spec_CXX='-L$libdir' export_dynamic_flag_spec_CXX='$wl--export-all-symbols' allow_undefined_flag_CXX=unsupported always_export_symbols_CXX=no enable_shared_with_static_runtimes_CXX=yes if $LD --help 2>&1 | $GREP 'auto-import' > /dev/null; then archive_cmds_CXX='$CC -shared -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' # If the export-symbols file already is a .def file, use it as # is; otherwise, prepend EXPORTS... archive_expsym_cmds_CXX='if test DEF = "`$SED -n -e '\''s/^[ ]*//'\'' -e '\''/^\(;.*\)*$/d'\'' -e '\''s/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p'\'' -e q $export_symbols`" ; then cp $export_symbols $output_objdir/$soname.def; else echo EXPORTS > $output_objdir/$soname.def; cat $export_symbols >> $output_objdir/$soname.def; fi~ $CC -shared -nostdlib $output_objdir/$soname.def $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $output_objdir/$soname $wl--enable-auto-image-base -Xlinker --out-implib -Xlinker $lib' else ld_shlibs_CXX=no fi ;; esac ;; darwin* | rhapsody*) archive_cmds_need_lc_CXX=no hardcode_direct_CXX=no hardcode_automatic_CXX=yes hardcode_shlibpath_var_CXX=unsupported if test yes = "$lt_cv_ld_force_load"; then whole_archive_flag_spec_CXX='`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience $wl-force_load,$conv\"; done; func_echo_all \"$new_convenience\"`' else whole_archive_flag_spec_CXX='' fi link_all_deplibs_CXX=yes allow_undefined_flag_CXX=$_lt_dar_allow_undefined case $cc_basename in ifort*|nagfor*) _lt_dar_can_shared=yes ;; *) _lt_dar_can_shared=$GCC ;; esac if test yes = "$_lt_dar_can_shared"; then output_verbose_link_cmd=func_echo_all archive_cmds_CXX="\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dsymutil" module_cmds_CXX="\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dsymutil" archive_expsym_cmds_CXX="$SED 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$libobjs \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring $_lt_dar_single_mod$_lt_dar_export_syms$_lt_dsymutil" module_expsym_cmds_CXX="$SED -e 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC \$allow_undefined_flag -o \$lib -bundle \$libobjs \$deplibs \$compiler_flags$_lt_dar_export_syms$_lt_dsymutil" if test yes != "$lt_cv_apple_cc_single_mod"; then archive_cmds_CXX="\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dsymutil" archive_expsym_cmds_CXX="$SED 's|^|_|' < \$export_symbols > \$output_objdir/\$libname-symbols.expsym~\$CC -r -keep_private_externs -nostdlib -o \$lib-master.o \$libobjs~\$CC -dynamiclib \$allow_undefined_flag -o \$lib \$lib-master.o \$deplibs \$compiler_flags -install_name \$rpath/\$soname \$verstring$_lt_dar_export_syms$_lt_dsymutil" fi else ld_shlibs_CXX=no fi ;; os2*) hardcode_libdir_flag_spec_CXX='-L$libdir' hardcode_minus_L_CXX=yes allow_undefined_flag_CXX=unsupported shrext_cmds=.dll archive_cmds_CXX='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ emxexp $libobjs | $SED /"_DLL_InitTerm"/d >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' archive_expsym_cmds_CXX='$ECHO "LIBRARY ${soname%$shared_ext} INITINSTANCE TERMINSTANCE" > $output_objdir/$libname.def~ $ECHO "DESCRIPTION \"$libname\"" >> $output_objdir/$libname.def~ $ECHO "DATA MULTIPLE NONSHARED" >> $output_objdir/$libname.def~ $ECHO EXPORTS >> $output_objdir/$libname.def~ prefix_cmds="$SED"~ if test EXPORTS = "`$SED 1q $export_symbols`"; then prefix_cmds="$prefix_cmds -e 1d"; fi~ prefix_cmds="$prefix_cmds -e \"s/^\(.*\)$/_\1/g\""~ cat $export_symbols | $prefix_cmds >> $output_objdir/$libname.def~ $CC -Zdll -Zcrtdll -o $output_objdir/$soname $libobjs $deplibs $compiler_flags $output_objdir/$libname.def~ emximp -o $lib $output_objdir/$libname.def' old_archive_From_new_cmds_CXX='emximp -o $output_objdir/${libname}_dll.a $output_objdir/$libname.def' enable_shared_with_static_runtimes_CXX=yes file_list_spec_CXX='@' ;; dgux*) case $cc_basename in ec++*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; ghcx*) # Green Hills C++ Compiler # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; *) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; esac ;; freebsd2.*) # C++ shared libraries reported to be fairly broken before # switch to ELF ld_shlibs_CXX=no ;; freebsd-elf*) archive_cmds_need_lc_CXX=no ;; freebsd* | dragonfly* | midnightbsd*) # FreeBSD 3 and later use GNU C++ and GNU ld with standard ELF # conventions ld_shlibs_CXX=yes ;; haiku*) archive_cmds_CXX='$CC -shared $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' link_all_deplibs_CXX=yes ;; hpux9*) hardcode_libdir_flag_spec_CXX='$wl+b $wl$libdir' hardcode_libdir_separator_CXX=: export_dynamic_flag_spec_CXX='$wl-E' hardcode_direct_CXX=yes hardcode_minus_L_CXX=yes # Not in the search PATH, # but as the default # location of the library. case $cc_basename in CC*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; aCC*) archive_cmds_CXX='$RM $output_objdir/$soname~$CC -b $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $EGREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes = "$GXX"; then archive_cmds_CXX='$RM $output_objdir/$soname~$CC -shared -nostdlib $pic_flag $wl+b $wl$install_libdir -o $output_objdir/$soname $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~test "x$output_objdir/$soname" = "x$lib" || mv $output_objdir/$soname $lib' else # FIXME: insert proper C++ library support ld_shlibs_CXX=no fi ;; esac ;; hpux10*|hpux11*) if test no = "$with_gnu_ld"; then hardcode_libdir_flag_spec_CXX='$wl+b $wl$libdir' hardcode_libdir_separator_CXX=: case $host_cpu in hppa*64*|ia64*) ;; *) export_dynamic_flag_spec_CXX='$wl-E' ;; esac fi case $host_cpu in hppa*64*|ia64*) hardcode_direct_CXX=no hardcode_shlibpath_var_CXX=no ;; *) hardcode_direct_CXX=yes hardcode_direct_absolute_CXX=yes hardcode_minus_L_CXX=yes # Not in the search PATH, # but as the default # location of the library. ;; esac case $cc_basename in CC*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; aCC*) case $host_cpu in hppa*64*) archive_cmds_CXX='$CC -b $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; ia64*) archive_cmds_CXX='$CC -b $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; *) archive_cmds_CXX='$CC -b $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; esac # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`($CC -b $CFLAGS -v conftest.$objext 2>&1) | $GREP "\-L"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes = "$GXX"; then if test no = "$with_gnu_ld"; then case $host_cpu in hppa*64*) archive_cmds_CXX='$CC -shared -nostdlib -fPIC $wl+h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; ia64*) archive_cmds_CXX='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+nodefaultrpath -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; *) archive_cmds_CXX='$CC -shared -nostdlib $pic_flag $wl+h $wl$soname $wl+b $wl$install_libdir -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' ;; esac fi else # FIXME: insert proper C++ library support ld_shlibs_CXX=no fi ;; esac ;; interix[3-9]*) hardcode_direct_CXX=no hardcode_shlibpath_var_CXX=no hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir' export_dynamic_flag_spec_CXX='$wl-E' # Hack: On Interix 3.x, we cannot compile PIC because of a broken gcc. # Instead, shared libraries are loaded at an image base (0x10000000 by # default) and relocated if they conflict, which is a slow very memory # consuming and fragmenting process. To avoid this, we pick a random, # 256 KiB-aligned image base between 0x50000000 and 0x6FFC0000 at link # time. Moving up from 0x10000000 also allows more sbrk(2) space. archive_cmds_CXX='$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' archive_expsym_cmds_CXX='$SED "s|^|_|" $export_symbols >$output_objdir/$soname.expsym~$CC -shared $pic_flag $libobjs $deplibs $compiler_flags $wl-h,$soname $wl--retain-symbols-file,$output_objdir/$soname.expsym $wl--image-base,`expr ${RANDOM-$$} % 4096 / 2 \* 262144 + 1342177280` -o $lib' ;; irix5* | irix6*) case $cc_basename in CC*) # SGI C++ archive_cmds_CXX='$CC -shared -all -multigot $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' # Archives containing C++ object files must be created using # "CC -ar", where "CC" is the IRIX C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. old_archive_cmds_CXX='$CC -ar -WR,-u -o $oldlib $oldobjs' ;; *) if test yes = "$GXX"; then if test no = "$with_gnu_ld"; then archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' else archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` -o $lib' fi fi link_all_deplibs_CXX=yes ;; esac hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir' hardcode_libdir_separator_CXX=: inherit_rpath_CXX=yes ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in KCC*) # Kuck and Associates, Inc. (KAI) C++ Compiler # KCC will only create a shared library if the output file # ends with ".so" (or ".sl" for HP-UX), so rename the library # to its proper name (with version) after linking. archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' archive_expsym_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo $lib | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib $wl-retain-symbols-file,$export_symbols; mv \$templib $lib' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 | $GREP "ld"`; rm -f libconftest$shared_ext; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir' export_dynamic_flag_spec_CXX='$wl--export-dynamic' # Archives containing C++ object files must be created using # "CC -Bstatic", where "CC" is the KAI C++ compiler. old_archive_cmds_CXX='$CC -Bstatic -o $oldlib $oldobjs' ;; icpc* | ecpc* ) # Intel C++ with_gnu_ld=yes # version 8.0 and above of icpc choke on multiply defined symbols # if we add $predep_objects and $postdep_objects, however 7.1 and # earlier do not add the objects themselves. case `$CC -V 2>&1` in *"Version 7."*) archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; *) # Version 8.0 or newer tmp_idyn= case $host_cpu in ia64*) tmp_idyn=' -i_dynamic';; esac archive_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds_CXX='$CC -shared'"$tmp_idyn"' $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; esac archive_cmds_need_lc_CXX=no hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir' export_dynamic_flag_spec_CXX='$wl--export-dynamic' whole_archive_flag_spec_CXX='$wl--whole-archive$convenience $wl--no-whole-archive' ;; pgCC* | pgcpp*) # Portland Group C++ compiler case `$CC -V` in *pgCC\ [1-5].* | *pgcpp\ [1-5].*) prelink_cmds_CXX='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $objs $libobjs $compile_deplibs~ compile_command="$compile_command `find $tpldir -name \*.o | sort | $NL2SP`"' old_archive_cmds_CXX='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $oldobjs$old_deplibs~ $AR $AR_FLAGS $oldlib$oldobjs$old_deplibs `find $tpldir -name \*.o | sort | $NL2SP`~ $RANLIB $oldlib' archive_cmds_CXX='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds_CXX='tpldir=Template.dir~ rm -rf $tpldir~ $CC --prelink_objects --instantiation_dir $tpldir $predep_objects $libobjs $deplibs $convenience $postdep_objects~ $CC -shared $pic_flag $predep_objects $libobjs $deplibs `find $tpldir -name \*.o | sort | $NL2SP` $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; *) # Version 6 and above use weak symbols archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname $wl-retain-symbols-file $wl$export_symbols -o $lib' ;; esac hardcode_libdir_flag_spec_CXX='$wl--rpath $wl$libdir' export_dynamic_flag_spec_CXX='$wl--export-dynamic' whole_archive_flag_spec_CXX='$wl--whole-archive`for conv in $convenience\"\"; do test -n \"$conv\" && new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' ;; cxx*) # Compaq C++ archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib' archive_expsym_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname -o $lib $wl-retain-symbols-file $wl$export_symbols' runpath_var=LD_RUN_PATH hardcode_libdir_flag_spec_CXX='-rpath $libdir' hardcode_libdir_separator_CXX=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld .*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "X$list" | $Xsed' ;; xl* | mpixl* | bgxl*) # IBM XL 8.0 on PPC, with GNU ld hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir' export_dynamic_flag_spec_CXX='$wl--export-dynamic' archive_cmds_CXX='$CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname -o $lib' if test yes = "$supports_anon_versioning"; then archive_expsym_cmds_CXX='echo "{ global:" > $output_objdir/$libname.ver~ cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $output_objdir/$libname.ver~ echo "local: *; };" >> $output_objdir/$libname.ver~ $CC -qmkshrobj $libobjs $deplibs $compiler_flags $wl-soname $wl$soname $wl-version-script $wl$output_objdir/$libname.ver -o $lib' fi ;; *) case `$CC -V 2>&1 | $SED 5q` in *Sun\ C*) # Sun C++ 5.9 no_undefined_flag_CXX=' -zdefs' archive_cmds_CXX='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' archive_expsym_cmds_CXX='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file $wl$export_symbols' hardcode_libdir_flag_spec_CXX='-R$libdir' whole_archive_flag_spec_CXX='$wl--whole-archive`new_convenience=; for conv in $convenience\"\"; do test -z \"$conv\" || new_convenience=\"$new_convenience,$conv\"; done; func_echo_all \"$new_convenience\"` $wl--no-whole-archive' compiler_needs_object_CXX=yes # Not sure whether something based on # $CC $CFLAGS -v conftest.$objext -o libconftest$shared_ext 2>&1 # would be better. output_verbose_link_cmd='func_echo_all' # Archives containing C++ object files must be created using # "CC -xar", where "CC" is the Sun C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. old_archive_cmds_CXX='$CC -xar -o $oldlib $oldobjs' ;; esac ;; esac ;; lynxos*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; m88k*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; mvs*) case $cc_basename in cxx*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; *) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; esac ;; netbsd*) if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then archive_cmds_CXX='$LD -Bshareable -o $lib $predep_objects $libobjs $deplibs $postdep_objects $linker_flags' wlarc= hardcode_libdir_flag_spec_CXX='-R$libdir' hardcode_direct_CXX=yes hardcode_shlibpath_var_CXX=no fi # Workaround some broken pre-1.5 toolchains output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP conftest.$objext | $SED -e "s:-lgcc -lc -lgcc::"' ;; *nto* | *qnx*) ld_shlibs_CXX=yes ;; openbsd* | bitrig*) if test -f /usr/libexec/ld.so; then hardcode_direct_CXX=yes hardcode_shlibpath_var_CXX=no hardcode_direct_absolute_CXX=yes archive_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -o $lib' hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir' if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`"; then archive_expsym_cmds_CXX='$CC -shared $pic_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-retain-symbols-file,$export_symbols -o $lib' export_dynamic_flag_spec_CXX='$wl-E' whole_archive_flag_spec_CXX=$wlarc'--whole-archive$convenience '$wlarc'--no-whole-archive' fi output_verbose_link_cmd=func_echo_all else ld_shlibs_CXX=no fi ;; osf3* | osf4* | osf5*) case $cc_basename in KCC*) # Kuck and Associates, Inc. (KAI) C++ Compiler # KCC will only create a shared library if the output file # ends with ".so" (or ".sl" for HP-UX), so rename the library # to its proper name (with version) after linking. archive_cmds_CXX='tempext=`echo $shared_ext | $SED -e '\''s/\([^()0-9A-Za-z{}]\)/\\\\\1/g'\''`; templib=`echo "$lib" | $SED -e "s/\$tempext\..*/.so/"`; $CC $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags --soname $soname -o \$templib; mv \$templib $lib' hardcode_libdir_flag_spec_CXX='$wl-rpath,$libdir' hardcode_libdir_separator_CXX=: # Archives containing C++ object files must be created using # the KAI C++ compiler. case $host in osf3*) old_archive_cmds_CXX='$CC -Bstatic -o $oldlib $oldobjs' ;; *) old_archive_cmds_CXX='$CC -o $oldlib $oldobjs' ;; esac ;; RCC*) # Rational C++ 2.4.1 # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; cxx*) case $host in osf3*) allow_undefined_flag_CXX=' $wl-expect_unresolved $wl\*' archive_cmds_CXX='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $soname `test -n "$verstring" && func_echo_all "$wl-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir' ;; *) allow_undefined_flag_CXX=' -expect_unresolved \*' archive_cmds_CXX='$CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname `test -n "$verstring" && func_echo_all "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib' archive_expsym_cmds_CXX='for i in `cat $export_symbols`; do printf "%s %s\\n" -exported_symbol "\$i" >> $lib.exp; done~ echo "-hidden">> $lib.exp~ $CC -shared$allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags -msym -soname $soname $wl-input $wl$lib.exp `test -n "$verstring" && $ECHO "-set_version $verstring"` -update_registry $output_objdir/so_locations -o $lib~ $RM $lib.exp' hardcode_libdir_flag_spec_CXX='-rpath $libdir' ;; esac hardcode_libdir_separator_CXX=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. # # There doesn't appear to be a way to prevent this compiler from # explicitly linking system object files so we need to strip them # from the output so that they don't get included in the library # dependencies. output_verbose_link_cmd='templist=`$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP "ld" | $GREP -v "ld:"`; templist=`func_echo_all "$templist" | $SED "s/\(^.*ld.*\)\( .*ld.*$\)/\1/"`; list= ; for z in $templist; do case $z in conftest.$objext) list="$list $z";; *.$objext);; *) list="$list $z";;esac; done; func_echo_all "$list"' ;; *) if test yes,no = "$GXX,$with_gnu_ld"; then allow_undefined_flag_CXX=' $wl-expect_unresolved $wl\*' case $host in osf3*) archive_cmds_CXX='$CC -shared -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' ;; *) archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $allow_undefined_flag $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-msym $wl-soname $wl$soname `test -n "$verstring" && func_echo_all "$wl-set_version $wl$verstring"` $wl-update_registry $wl$output_objdir/so_locations -o $lib' ;; esac hardcode_libdir_flag_spec_CXX='$wl-rpath $wl$libdir' hardcode_libdir_separator_CXX=: # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else # FIXME: insert proper C++ library support ld_shlibs_CXX=no fi ;; esac ;; psos*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; sunos4*) case $cc_basename in CC*) # Sun C++ 4.x # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; lcc*) # Lucid # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; *) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; esac ;; solaris*) case $cc_basename in CC* | sunCC*) # Sun C++ 4.2, 5.x and Centerline C++ archive_cmds_need_lc_CXX=yes no_undefined_flag_CXX=' -zdefs' archive_cmds_CXX='$CC -G$allow_undefined_flag -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags' archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G$allow_undefined_flag $wl-M $wl$lib.exp -h$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' hardcode_libdir_flag_spec_CXX='-R$libdir' hardcode_shlibpath_var_CXX=no case $host_os in solaris2.[0-5] | solaris2.[0-5].*) ;; *) # The compiler driver will combine and reorder linker options, # but understands '-z linker_flag'. # Supported since Solaris 2.6 (maybe 2.5.1?) whole_archive_flag_spec_CXX='-z allextract$convenience -z defaultextract' ;; esac link_all_deplibs_CXX=yes output_verbose_link_cmd='func_echo_all' # Archives containing C++ object files must be created using # "CC -xar", where "CC" is the Sun C++ compiler. This is # necessary to make sure instantiated templates are included # in the archive. old_archive_cmds_CXX='$CC -xar -o $oldlib $oldobjs' ;; gcx*) # Green Hills C++ Compiler archive_cmds_CXX='$CC -shared $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' # The C++ compiler must be used to create the archive. old_archive_cmds_CXX='$CC $LDFLAGS -archive -o $oldlib $oldobjs' ;; *) # GNU C++ compiler with Solaris linker if test yes,no = "$GXX,$with_gnu_ld"; then no_undefined_flag_CXX=' $wl-z ${wl}defs' if $CC --version | $GREP -v '^2\.7' > /dev/null; then archive_cmds_CXX='$CC -shared $pic_flag -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -shared $pic_flag -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -shared $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' else # g++ 2.7 appears to require '-G' NOT '-shared' on this # platform. archive_cmds_CXX='$CC -G -nostdlib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags $wl-h $wl$soname -o $lib' archive_expsym_cmds_CXX='echo "{ global:" > $lib.exp~cat $export_symbols | $SED -e "s/\(.*\)/\1;/" >> $lib.exp~echo "local: *; };" >> $lib.exp~ $CC -G -nostdlib $wl-M $wl$lib.exp $wl-h $wl$soname -o $lib $predep_objects $libobjs $deplibs $postdep_objects $compiler_flags~$RM $lib.exp' # Commands to make compiler produce verbose output that lists # what "hidden" libraries, object files and flags are used when # linking a shared library. output_verbose_link_cmd='$CC -G $CFLAGS -v conftest.$objext 2>&1 | $GREP -v "^Configured with:" | $GREP "\-L"' fi hardcode_libdir_flag_spec_CXX='$wl-R $wl$libdir' case $host_os in solaris2.[0-5] | solaris2.[0-5].*) ;; *) whole_archive_flag_spec_CXX='$wl-z ${wl}allextract$convenience $wl-z ${wl}defaultextract' ;; esac fi ;; esac ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) no_undefined_flag_CXX='$wl-z,text' archive_cmds_need_lc_CXX=no hardcode_shlibpath_var_CXX=no runpath_var='LD_RUN_PATH' case $cc_basename in CC*) archive_cmds_CXX='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_CXX='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; *) archive_cmds_CXX='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_CXX='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; sysv5* | sco3.2v5* | sco5v6*) # Note: We CANNOT use -z defs as we might desire, because we do not # link with -lc, and that would cause any symbols used from libc to # always be unresolved, which means just about no library would # ever link correctly. If we're not using GNU ld we use -z text # though, which does catch some bad symbols but isn't as heavy-handed # as -z defs. no_undefined_flag_CXX='$wl-z,text' allow_undefined_flag_CXX='$wl-z,nodefs' archive_cmds_need_lc_CXX=no hardcode_shlibpath_var_CXX=no hardcode_libdir_flag_spec_CXX='$wl-R,$libdir' hardcode_libdir_separator_CXX=':' link_all_deplibs_CXX=yes export_dynamic_flag_spec_CXX='$wl-Bexport' runpath_var='LD_RUN_PATH' case $cc_basename in CC*) archive_cmds_CXX='$CC -G $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_CXX='$CC -G $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' old_archive_cmds_CXX='$CC -Tprelink_objects $oldobjs~ '"$old_archive_cmds_CXX" reload_cmds_CXX='$CC -Tprelink_objects $reload_objs~ '"$reload_cmds_CXX" ;; *) archive_cmds_CXX='$CC -shared $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' archive_expsym_cmds_CXX='$CC -shared $wl-Bexport:$export_symbols $wl-h,$soname -o $lib $libobjs $deplibs $compiler_flags' ;; esac ;; tandem*) case $cc_basename in NCC*) # NonStop-UX NCC 3.20 # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; *) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; esac ;; vxworks*) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; *) # FIXME: insert proper C++ library support ld_shlibs_CXX=no ;; esac { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs_CXX" >&5 printf "%s\n" "$ld_shlibs_CXX" >&6; } test no = "$ld_shlibs_CXX" && can_build_shared=no GCC_CXX=$GXX LD_CXX=$LD ## CAVEAT EMPTOR: ## There is no encapsulation within the following macros, do not change ## the running order or otherwise move them around unless you know exactly ## what you are doing... # Dependencies to place before and after the object being linked: predep_objects_CXX= postdep_objects_CXX= predeps_CXX= postdeps_CXX= compiler_lib_search_path_CXX= cat > conftest.$ac_ext <<_LT_EOF class Foo { public: Foo (void) { a = 0; } private: int a; }; _LT_EOF _lt_libdeps_save_CFLAGS=$CFLAGS case "$CC $CFLAGS " in #( *\ -flto*\ *) CFLAGS="$CFLAGS -fno-lto" ;; *\ -fwhopr*\ *) CFLAGS="$CFLAGS -fno-whopr" ;; *\ -fuse-linker-plugin*\ *) CFLAGS="$CFLAGS -fno-use-linker-plugin" ;; esac if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then # Parse the compiler output and extract the necessary # objects, libraries and library flags. # Sentinel used to keep track of whether or not we are before # the conftest object file. pre_test_object_deps_done=no for p in `eval "$output_verbose_link_cmd"`; do case $prev$p in -L* | -R* | -l*) # Some compilers place space between "-{L,R}" and the path. # Remove the space. if test x-L = "$p" || test x-R = "$p"; then prev=$p continue fi # Expand the sysroot to ease extracting the directories later. if test -z "$prev"; then case $p in -L*) func_stripname_cnf '-L' '' "$p"; prev=-L; p=$func_stripname_result ;; -R*) func_stripname_cnf '-R' '' "$p"; prev=-R; p=$func_stripname_result ;; -l*) func_stripname_cnf '-l' '' "$p"; prev=-l; p=$func_stripname_result ;; esac fi case $p in =*) func_stripname_cnf '=' '' "$p"; p=$lt_sysroot$func_stripname_result ;; esac if test no = "$pre_test_object_deps_done"; then case $prev in -L | -R) # Internal compiler library paths should come after those # provided the user. The postdeps already come after the # user supplied libs so there is no need to process them. if test -z "$compiler_lib_search_path_CXX"; then compiler_lib_search_path_CXX=$prev$p else compiler_lib_search_path_CXX="${compiler_lib_search_path_CXX} $prev$p" fi ;; # The "-l" case would never come before the object being # linked, so don't bother handling this case. esac else if test -z "$postdeps_CXX"; then postdeps_CXX=$prev$p else postdeps_CXX="${postdeps_CXX} $prev$p" fi fi prev= ;; *.lto.$objext) ;; # Ignore GCC LTO objects *.$objext) # This assumes that the test object file only shows up # once in the compiler output. if test "$p" = "conftest.$objext"; then pre_test_object_deps_done=yes continue fi if test no = "$pre_test_object_deps_done"; then if test -z "$predep_objects_CXX"; then predep_objects_CXX=$p else predep_objects_CXX="$predep_objects_CXX $p" fi else if test -z "$postdep_objects_CXX"; then postdep_objects_CXX=$p else postdep_objects_CXX="$postdep_objects_CXX $p" fi fi ;; *) ;; # Ignore the rest. esac done # Clean up. rm -f a.out a.exe else echo "libtool.m4: error: problem compiling CXX test program" fi $RM -f confest.$objext CFLAGS=$_lt_libdeps_save_CFLAGS # PORTME: override above test on systems where it is broken case $host_os in interix[3-9]*) # Interix 3.5 installs completely hosed .la files for C++, so rather than # hack all around it, let's just trust "g++" to DTRT. predep_objects_CXX= postdep_objects_CXX= postdeps_CXX= ;; esac case " $postdeps_CXX " in *" -lc "*) archive_cmds_need_lc_CXX=no ;; esac compiler_lib_search_dirs_CXX= if test -n "${compiler_lib_search_path_CXX}"; then compiler_lib_search_dirs_CXX=`echo " ${compiler_lib_search_path_CXX}" | $SED -e 's! -L! !g' -e 's!^ !!'` fi lt_prog_compiler_wl_CXX= lt_prog_compiler_pic_CXX= lt_prog_compiler_static_CXX= # C++ specific cases for pic, static, wl, etc. if test yes = "$GXX"; then lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_static_CXX='-static' case $host_os in aix*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor lt_prog_compiler_static_CXX='-Bstatic' fi lt_prog_compiler_pic_CXX='-fPIC' ;; amigaos*) case $host_cpu in powerpc) # see comment about AmigaOS4 .so support lt_prog_compiler_pic_CXX='-fPIC' ;; m68k) # FIXME: we need at least 68020 code to build shared libraries, but # adding the '-m68020' flag to GCC prevents building anything better, # like '-m68040'. lt_prog_compiler_pic_CXX='-m68020 -resident32 -malways-restore-a4' ;; esac ;; beos* | irix5* | irix6* | nonstopux* | osf3* | osf4* | osf5*) # PIC is the default for these OSes. ;; mingw* | cygwin* | os2* | pw32* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). # Although the cygwin gcc ignores -fPIC, still need this for old-style # (--disable-auto-import) libraries lt_prog_compiler_pic_CXX='-DDLL_EXPORT' case $host_os in os2*) lt_prog_compiler_static_CXX='$wl-static' ;; esac ;; darwin* | rhapsody*) # PIC is the default on this platform # Common symbols not allowed in MH_DYLIB files lt_prog_compiler_pic_CXX='-fno-common' ;; *djgpp*) # DJGPP does not support shared libraries at all lt_prog_compiler_pic_CXX= ;; haiku*) # PIC is the default for Haiku. # The "-static" flag exists, but is broken. lt_prog_compiler_static_CXX= ;; interix[3-9]*) # Interix 3.x gcc -fpic/-fPIC options generate broken code. # Instead, we relocate shared libraries at runtime. ;; sysv4*MP*) if test -d /usr/nec; then lt_prog_compiler_pic_CXX=-Kconform_pic fi ;; hpux*) # PIC is the default for 64-bit PA HP-UX, but not for 32-bit # PA HP-UX. On IA64 HP-UX, PIC is the default but the pic flag # sets the default TLS model and affects inlining. case $host_cpu in hppa*64*) ;; *) lt_prog_compiler_pic_CXX='-fPIC' ;; esac ;; *qnx* | *nto*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic_CXX='-fPIC -shared' ;; *) lt_prog_compiler_pic_CXX='-fPIC' ;; esac else case $host_os in aix[4-9]*) # All AIX code is PIC. if test ia64 = "$host_cpu"; then # AIX 5 now supports IA64 processor lt_prog_compiler_static_CXX='-Bstatic' else lt_prog_compiler_static_CXX='-bnso -bI:/lib/syscalls.exp' fi ;; chorus*) case $cc_basename in cxch68*) # Green Hills C++ Compiler # _LT_TAGVAR(lt_prog_compiler_static, CXX)="--no_auto_instantiation -u __main -u __premain -u _abort -r $COOL_DIR/lib/libOrb.a $MVME_DIR/lib/CC/libC.a $MVME_DIR/lib/classix/libcx.s.a" ;; esac ;; mingw* | cygwin* | os2* | pw32* | cegcc*) # This hack is so that the source file can tell whether it is being # built for inclusion in a dll (and should export symbols for example). lt_prog_compiler_pic_CXX='-DDLL_EXPORT' ;; dgux*) case $cc_basename in ec++*) lt_prog_compiler_pic_CXX='-KPIC' ;; ghcx*) # Green Hills C++ Compiler lt_prog_compiler_pic_CXX='-pic' ;; *) ;; esac ;; freebsd* | dragonfly* | midnightbsd*) # FreeBSD uses GNU C++ ;; hpux9* | hpux10* | hpux11*) case $cc_basename in CC*) lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_static_CXX='$wl-a ${wl}archive' if test ia64 != "$host_cpu"; then lt_prog_compiler_pic_CXX='+Z' fi ;; aCC*) lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_static_CXX='$wl-a ${wl}archive' case $host_cpu in hppa*64*|ia64*) # +Z the default ;; *) lt_prog_compiler_pic_CXX='+Z' ;; esac ;; *) ;; esac ;; interix*) # This is c89, which is MS Visual C++ (no shared libs) # Anyone wants to do a port? ;; irix5* | irix6* | nonstopux*) case $cc_basename in CC*) lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_static_CXX='-non_shared' # CC pic flag -KPIC is the default. ;; *) ;; esac ;; linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) case $cc_basename in KCC*) # KAI C++ Compiler lt_prog_compiler_wl_CXX='--backend -Wl,' lt_prog_compiler_pic_CXX='-fPIC' ;; ecpc* ) # old Intel C++ for x86_64, which still supported -KPIC. lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_pic_CXX='-KPIC' lt_prog_compiler_static_CXX='-static' ;; icpc* ) # Intel C++, used to be incompatible with GCC. # ICC 10 doesn't accept -KPIC any more. lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_pic_CXX='-fPIC' lt_prog_compiler_static_CXX='-static' ;; pgCC* | pgcpp*) # Portland Group C++ compiler lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_pic_CXX='-fpic' lt_prog_compiler_static_CXX='-Bstatic' ;; cxx*) # Compaq C++ # Make sure the PIC flag is empty. It appears that all Alpha # Linux and Compaq Tru64 Unix objects are PIC. lt_prog_compiler_pic_CXX= lt_prog_compiler_static_CXX='-non_shared' ;; xlc* | xlC* | bgxl[cC]* | mpixl[cC]*) # IBM XL 8.0, 9.0 on PPC and BlueGene lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_pic_CXX='-qpic' lt_prog_compiler_static_CXX='-qstaticlink' ;; *) case `$CC -V 2>&1 | $SED 5q` in *Sun\ C*) # Sun C++ 5.9 lt_prog_compiler_pic_CXX='-KPIC' lt_prog_compiler_static_CXX='-Bstatic' lt_prog_compiler_wl_CXX='-Qoption ld ' ;; esac ;; esac ;; lynxos*) ;; m88k*) ;; mvs*) case $cc_basename in cxx*) lt_prog_compiler_pic_CXX='-W c,exportall' ;; *) ;; esac ;; netbsd*) ;; *qnx* | *nto*) # QNX uses GNU C++, but need to define -shared option too, otherwise # it will coredump. lt_prog_compiler_pic_CXX='-fPIC -shared' ;; osf3* | osf4* | osf5*) case $cc_basename in KCC*) lt_prog_compiler_wl_CXX='--backend -Wl,' ;; RCC*) # Rational C++ 2.4.1 lt_prog_compiler_pic_CXX='-pic' ;; cxx*) # Digital/Compaq C++ lt_prog_compiler_wl_CXX='-Wl,' # Make sure the PIC flag is empty. It appears that all Alpha # Linux and Compaq Tru64 Unix objects are PIC. lt_prog_compiler_pic_CXX= lt_prog_compiler_static_CXX='-non_shared' ;; *) ;; esac ;; psos*) ;; solaris*) case $cc_basename in CC* | sunCC*) # Sun C++ 4.2, 5.x and Centerline C++ lt_prog_compiler_pic_CXX='-KPIC' lt_prog_compiler_static_CXX='-Bstatic' lt_prog_compiler_wl_CXX='-Qoption ld ' ;; gcx*) # Green Hills C++ Compiler lt_prog_compiler_pic_CXX='-PIC' ;; *) ;; esac ;; sunos4*) case $cc_basename in CC*) # Sun C++ 4.x lt_prog_compiler_pic_CXX='-pic' lt_prog_compiler_static_CXX='-Bstatic' ;; lcc*) # Lucid lt_prog_compiler_pic_CXX='-pic' ;; *) ;; esac ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) case $cc_basename in CC*) lt_prog_compiler_wl_CXX='-Wl,' lt_prog_compiler_pic_CXX='-KPIC' lt_prog_compiler_static_CXX='-Bstatic' ;; esac ;; tandem*) case $cc_basename in NCC*) # NonStop-UX NCC 3.20 lt_prog_compiler_pic_CXX='-KPIC' ;; *) ;; esac ;; vxworks*) ;; *) lt_prog_compiler_can_build_shared_CXX=no ;; esac fi case $host_os in # For platforms that do not support PIC, -DPIC is meaningless: *djgpp*) lt_prog_compiler_pic_CXX= ;; *) lt_prog_compiler_pic_CXX="$lt_prog_compiler_pic_CXX -DPIC" ;; esac { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $compiler option to produce PIC" >&5 printf %s "checking for $compiler option to produce PIC... " >&6; } if test ${lt_cv_prog_compiler_pic_CXX+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_prog_compiler_pic_CXX=$lt_prog_compiler_pic_CXX fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_CXX" >&5 printf "%s\n" "$lt_cv_prog_compiler_pic_CXX" >&6; } lt_prog_compiler_pic_CXX=$lt_cv_prog_compiler_pic_CXX # # Check to make sure the PIC flag actually works. # if test -n "$lt_prog_compiler_pic_CXX"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if $compiler PIC flag $lt_prog_compiler_pic_CXX works" >&5 printf %s "checking if $compiler PIC flag $lt_prog_compiler_pic_CXX works... " >&6; } if test ${lt_cv_prog_compiler_pic_works_CXX+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_prog_compiler_pic_works_CXX=no ac_outfile=conftest.$ac_objext echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="$lt_prog_compiler_pic_CXX -DPIC" ## exclude from sc_useless_quotes_in_assignment # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. # The option is referenced via a variable to avoid confusing sed. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>conftest.err) ac_status=$? cat conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s "$ac_outfile"; then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings other than the usual output. $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' >conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if test ! -s conftest.er2 || diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_pic_works_CXX=yes fi fi $RM conftest* fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_pic_works_CXX" >&5 printf "%s\n" "$lt_cv_prog_compiler_pic_works_CXX" >&6; } if test yes = "$lt_cv_prog_compiler_pic_works_CXX"; then case $lt_prog_compiler_pic_CXX in "" | " "*) ;; *) lt_prog_compiler_pic_CXX=" $lt_prog_compiler_pic_CXX" ;; esac else lt_prog_compiler_pic_CXX= lt_prog_compiler_can_build_shared_CXX=no fi fi # # Check to make sure the static flag actually works. # wl=$lt_prog_compiler_wl_CXX eval lt_tmp_static_flag=\"$lt_prog_compiler_static_CXX\" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if $compiler static flag $lt_tmp_static_flag works" >&5 printf %s "checking if $compiler static flag $lt_tmp_static_flag works... " >&6; } if test ${lt_cv_prog_compiler_static_works_CXX+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_prog_compiler_static_works_CXX=no save_LDFLAGS=$LDFLAGS LDFLAGS="$LDFLAGS $lt_tmp_static_flag" echo "$lt_simple_link_test_code" > conftest.$ac_ext if (eval $ac_link 2>conftest.err) && test -s conftest$ac_exeext; then # The linker can only warn and ignore the option if not recognized # So say no if there are warnings if test -s conftest.err; then # Append any errors to the config.log. cat conftest.err 1>&5 $ECHO "$_lt_linker_boilerplate" | $SED '/^$/d' > conftest.exp $SED '/^$/d; /^ *+/d' conftest.err >conftest.er2 if diff conftest.exp conftest.er2 >/dev/null; then lt_cv_prog_compiler_static_works_CXX=yes fi else lt_cv_prog_compiler_static_works_CXX=yes fi fi $RM -r conftest* LDFLAGS=$save_LDFLAGS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_static_works_CXX" >&5 printf "%s\n" "$lt_cv_prog_compiler_static_works_CXX" >&6; } if test yes = "$lt_cv_prog_compiler_static_works_CXX"; then : else lt_prog_compiler_static_CXX= fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 printf %s "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if test ${lt_cv_prog_compiler_c_o_CXX+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_prog_compiler_c_o_CXX=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o_CXX=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o_CXX" >&5 printf "%s\n" "$lt_cv_prog_compiler_c_o_CXX" >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if $compiler supports -c -o file.$ac_objext" >&5 printf %s "checking if $compiler supports -c -o file.$ac_objext... " >&6; } if test ${lt_cv_prog_compiler_c_o_CXX+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_prog_compiler_c_o_CXX=no $RM -r conftest 2>/dev/null mkdir conftest cd conftest mkdir out echo "$lt_simple_compile_test_code" > conftest.$ac_ext lt_compiler_flag="-o out/conftest2.$ac_objext" # Insert the option either (1) after the last *FLAGS variable, or # (2) before a word containing "conftest.", or (3) at the end. # Note that $ac_compile itself does not contain backslashes and begins # with a dollar sign (not a hyphen), so the echo should work correctly. lt_compile=`echo "$ac_compile" | $SED \ -e 's:.*FLAGS}\{0,1\} :&$lt_compiler_flag :; t' \ -e 's: [^ ]*conftest\.: $lt_compiler_flag&:; t' \ -e 's:$: $lt_compiler_flag:'` (eval echo "\"\$as_me:$LINENO: $lt_compile\"" >&5) (eval "$lt_compile" 2>out/conftest.err) ac_status=$? cat out/conftest.err >&5 echo "$as_me:$LINENO: \$? = $ac_status" >&5 if (exit $ac_status) && test -s out/conftest2.$ac_objext then # The compiler can only warn and ignore the option if not recognized # So say no if there are warnings $ECHO "$_lt_compiler_boilerplate" | $SED '/^$/d' > out/conftest.exp $SED '/^$/d; /^ *+/d' out/conftest.err >out/conftest.er2 if test ! -s out/conftest.er2 || diff out/conftest.exp out/conftest.er2 >/dev/null; then lt_cv_prog_compiler_c_o_CXX=yes fi fi chmod u+w . 2>&5 $RM conftest* # SGI C++ compiler will create directory out/ii_files/ for # template instantiation test -d out/ii_files && $RM out/ii_files/* && rmdir out/ii_files $RM out/* && rmdir out cd .. $RM -r conftest $RM conftest* fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_prog_compiler_c_o_CXX" >&5 printf "%s\n" "$lt_cv_prog_compiler_c_o_CXX" >&6; } hard_links=nottested if test no = "$lt_cv_prog_compiler_c_o_CXX" && test no != "$need_locks"; then # do not overwrite the value of need_locks provided by the user { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if we can lock with hard links" >&5 printf %s "checking if we can lock with hard links... " >&6; } hard_links=yes $RM conftest* ln conftest.a conftest.b 2>/dev/null && hard_links=no touch conftest.a ln conftest.a conftest.b 2>&5 || hard_links=no ln conftest.a conftest.b 2>/dev/null && hard_links=no { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $hard_links" >&5 printf "%s\n" "$hard_links" >&6; } if test no = "$hard_links"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&5 printf "%s\n" "$as_me: WARNING: '$CC' does not support '-c -o', so 'make -j' may be unsafe" >&2;} need_locks=warn fi else need_locks=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether the $compiler linker ($LD) supports shared libraries" >&5 printf %s "checking whether the $compiler linker ($LD) supports shared libraries... " >&6; } export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' exclude_expsyms_CXX='_GLOBAL_OFFSET_TABLE_|_GLOBAL__F[ID]_.*' case $host_os in aix[4-9]*) # If we're using GNU nm, then we don't want the "-C" option. # -C means demangle to GNU nm, but means don't demangle to AIX nm. # Without the "-l" option, or with the "-B" option, AIX nm treats # weak defined symbols like other global defined symbols, whereas # GNU nm marks them as "W". # While the 'weak' keyword is ignored in the Export File, we need # it in the Import File for the 'aix-soname' feature, so we have # to replace the "-B" option with "-P" for AIX nm. if $NM -V 2>&1 | $GREP 'GNU' > /dev/null; then export_symbols_cmds_CXX='$NM -Bpg $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "W")) && (substr(\$ 3,1,1) != ".")) { if (\$ 2 == "W") { print \$ 3 " weak" } else { print \$ 3 } } }'\'' | sort -u > $export_symbols' else export_symbols_cmds_CXX='`func_echo_all $NM | $SED -e '\''s/B\([^B]*\)$/P\1/'\''` -PCpgl $libobjs $convenience | awk '\''{ if (((\$ 2 == "T") || (\$ 2 == "D") || (\$ 2 == "B") || (\$ 2 == "L") || (\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) && (substr(\$ 1,1,1) != ".")) { if ((\$ 2 == "W") || (\$ 2 == "V") || (\$ 2 == "Z")) { print \$ 1 " weak" } else { print \$ 1 } } }'\'' | sort -u > $export_symbols' fi ;; pw32*) export_symbols_cmds_CXX=$ltdll_cmds ;; cygwin* | mingw* | cegcc*) case $cc_basename in cl* | icl*) exclude_expsyms_CXX='_NULL_IMPORT_DESCRIPTOR|_IMPORT_DESCRIPTOR_.*' ;; *) export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED -e '\''/^[BCDGRS][ ]/s/.*[ ]\([^ ]*\)/\1 DATA/;s/^.*[ ]__nm__\([^ ]*\)[ ][^ ]*/\1 DATA/;/^I[ ]/d;/^[AITW][ ]/s/.* //'\'' | sort | uniq > $export_symbols' exclude_expsyms_CXX='[_]+GLOBAL_OFFSET_TABLE_|[_]+GLOBAL__[FID]_.*|[_]+head_[A-Za-z0-9_]+_dll|[A-Za-z0-9_]+_dll_iname' ;; esac ;; *) export_symbols_cmds_CXX='$NM $libobjs $convenience | $global_symbol_pipe | $SED '\''s/.* //'\'' | sort | uniq > $export_symbols' ;; esac { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ld_shlibs_CXX" >&5 printf "%s\n" "$ld_shlibs_CXX" >&6; } test no = "$ld_shlibs_CXX" && can_build_shared=no with_gnu_ld_CXX=$with_gnu_ld # # Do we need to explicitly link libc? # case "x$archive_cmds_need_lc_CXX" in x|xyes) # Assume -lc should be added archive_cmds_need_lc_CXX=yes if test yes,yes = "$GCC,$enable_shared"; then case $archive_cmds_CXX in *'~'*) # FIXME: we may have to deal with multi-command sequences. ;; '$CC '*) # Test whether the compiler implicitly links with -lc since on some # systems, -lgcc has to come before -lc. If gcc already passes -lc # to ld, don't add -lc before -lgcc. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether -lc should be explicitly linked in" >&5 printf %s "checking whether -lc should be explicitly linked in... " >&6; } if test ${lt_cv_archive_cmds_need_lc_CXX+y} then : printf %s "(cached) " >&6 else $as_nop $RM conftest* echo "$lt_simple_compile_test_code" > conftest.$ac_ext if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$ac_compile\""; } >&5 (eval $ac_compile) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } 2>conftest.err; then soname=conftest lib=conftest libobjs=conftest.$ac_objext deplibs= wl=$lt_prog_compiler_wl_CXX pic_flag=$lt_prog_compiler_pic_CXX compiler_flags=-v linker_flags=-v verstring= output_objdir=. libname=conftest lt_save_allow_undefined_flag=$allow_undefined_flag_CXX allow_undefined_flag_CXX= if { { eval echo "\"\$as_me\":${as_lineno-$LINENO}: \"$archive_cmds_CXX 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1\""; } >&5 (eval $archive_cmds_CXX 2\>\&1 \| $GREP \" -lc \" \>/dev/null 2\>\&1) 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; } then lt_cv_archive_cmds_need_lc_CXX=no else lt_cv_archive_cmds_need_lc_CXX=yes fi allow_undefined_flag_CXX=$lt_save_allow_undefined_flag else cat conftest.err 1>&5 fi $RM conftest* fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $lt_cv_archive_cmds_need_lc_CXX" >&5 printf "%s\n" "$lt_cv_archive_cmds_need_lc_CXX" >&6; } archive_cmds_need_lc_CXX=$lt_cv_archive_cmds_need_lc_CXX ;; esac fi ;; esac { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking dynamic linker characteristics" >&5 printf %s "checking dynamic linker characteristics... " >&6; } library_names_spec= libname_spec='lib$name' soname_spec= shrext_cmds=.so postinstall_cmds= postuninstall_cmds= finish_cmds= finish_eval= shlibpath_var= shlibpath_overrides_runpath=unknown version_type=none dynamic_linker="$host_os ld.so" sys_lib_dlsearch_path_spec="/lib /usr/lib" need_lib_prefix=unknown hardcode_into_libs=no # when you set need_version to no, make sure it does not cause -set_version # flags to be left without arguments need_version=unknown case $host_os in aix3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname.a' shlibpath_var=LIBPATH # AIX 3 has no versioning support, so we append a major version to the name. soname_spec='$libname$release$shared_ext$major' ;; aix[4-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no hardcode_into_libs=yes if test ia64 = "$host_cpu"; then # AIX 5 supports IA64 library_names_spec='$libname$release$shared_ext$major $libname$release$shared_ext$versuffix $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH else # With GCC up to 2.95.x, collect2 would create an import file # for dependence libraries. The import file would start with # the line '#! .'. This would cause the generated library to # depend on '.', always an invalid library. This was fixed in # development snapshots of GCC prior to 3.0. case $host_os in aix4 | aix4.[01] | aix4.[01].*) if { echo '#if __GNUC__ > 2 || (__GNUC__ == 2 && __GNUC_MINOR__ >= 97)' echo ' yes ' echo '#endif'; } | $CC -E - | $GREP yes > /dev/null; then : else can_build_shared=no fi ;; esac # Using Import Files as archive members, it is possible to support # filename-based versioning of shared library archives on AIX. While # this would work for both with and without runtime linking, it will # prevent static linking of such archives. So we do filename-based # shared library versioning with .so extension only, which is used # when both runtime linking and shared linking is enabled. # Unfortunately, runtime linking may impact performance, so we do # not want this to be the default eventually. Also, we use the # versioned .so libs for executables only if there is the -brtl # linker flag in LDFLAGS as well, or --with-aix-soname=svr4 only. # To allow for filename-based versioning support, we need to create # libNAME.so.V as an archive file, containing: # *) an Import File, referring to the versioned filename of the # archive as well as the shared archive member, telling the # bitwidth (32 or 64) of that shared object, and providing the # list of exported symbols of that shared object, eventually # decorated with the 'weak' keyword # *) the shared object with the F_LOADONLY flag set, to really avoid # it being seen by the linker. # At run time we better use the real file rather than another symlink, # but for link time we create the symlink libNAME.so -> libNAME.so.V case $with_aix_soname,$aix_use_runtimelinking in # AIX (on Power*) has no versioning support, so currently we cannot hardcode correct # soname into executable. Probably we can add versioning support to # collect2, so additional links can be useful in future. aix,yes) # traditional libtool dynamic_linker='AIX unversionable lib.so' # If using run time linking (on AIX 4.2 or later) use lib.so # instead of lib.a to let people know that these are not # typical AIX shared libraries. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; aix,no) # traditional AIX only dynamic_linker='AIX lib.a(lib.so.V)' # We preserve .a as extension for shared libraries through AIX4.2 # and later when we are not doing run time linking. library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' ;; svr4,*) # full svr4 only dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o)" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,yes) # both, prefer svr4 dynamic_linker="AIX lib.so.V($shared_archive_member_spec.o), lib.a(lib.so.V)" library_names_spec='$libname$release$shared_ext$major $libname$shared_ext' # unpreferred sharedlib libNAME.a needs extra handling postinstall_cmds='test -n "$linkname" || linkname="$realname"~func_stripname "" ".so" "$linkname"~$install_shared_prog "$dir/$func_stripname_result.$libext" "$destdir/$func_stripname_result.$libext"~test -z "$tstripme" || test -z "$striplib" || $striplib "$destdir/$func_stripname_result.$libext"' postuninstall_cmds='for n in $library_names $old_library; do :; done~func_stripname "" ".so" "$n"~test "$func_stripname_result" = "$n" || func_append rmfiles " $odir/$func_stripname_result.$libext"' # We do not specify a path in Import Files, so LIBPATH fires. shlibpath_overrides_runpath=yes ;; *,no) # both, prefer aix dynamic_linker="AIX lib.a(lib.so.V), lib.so.V($shared_archive_member_spec.o)" library_names_spec='$libname$release.a $libname.a' soname_spec='$libname$release$shared_ext$major' # unpreferred sharedlib libNAME.so.V and symlink libNAME.so need extra handling postinstall_cmds='test -z "$dlname" || $install_shared_prog $dir/$dlname $destdir/$dlname~test -z "$tstripme" || test -z "$striplib" || $striplib $destdir/$dlname~test -n "$linkname" || linkname=$realname~func_stripname "" ".a" "$linkname"~(cd "$destdir" && $LN_S -f $dlname $func_stripname_result.so)' postuninstall_cmds='test -z "$dlname" || func_append rmfiles " $odir/$dlname"~for n in $old_library $library_names; do :; done~func_stripname "" ".a" "$n"~func_append rmfiles " $odir/$func_stripname_result.so"' ;; esac shlibpath_var=LIBPATH fi ;; amigaos*) case $host_cpu in powerpc) # Since July 2007 AmigaOS4 officially supports .so libraries. # When compiling the executable, add -use-dynld -Lsobjs: to the compileline. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' ;; m68k) library_names_spec='$libname.ixlibrary $libname.a' # Create ${libname}_ixlibrary.a entries in /sys/libs. finish_eval='for lib in `ls $libdir/*.ixlibrary 2>/dev/null`; do libname=`func_echo_all "$lib" | $SED '\''s%^.*/\([^/]*\)\.ixlibrary$%\1%'\''`; $RM /sys/libs/${libname}_ixlibrary.a; $show "cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a"; cd /sys/libs && $LN_S $lib ${libname}_ixlibrary.a || exit 1; done' ;; esac ;; beos*) library_names_spec='$libname$shared_ext' dynamic_linker="$host_os ld.so" shlibpath_var=LIBRARY_PATH ;; bsdi[45]*) version_type=linux # correct to gnu/linux during the next big refactor need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/shlib /usr/lib /usr/X11/lib /usr/contrib/lib /lib /usr/local/lib" sys_lib_dlsearch_path_spec="/shlib /usr/lib /usr/local/lib" # the default ld.so.conf also contains /usr/contrib/lib and # /usr/X11R6/lib (/usr/X11 is a link to /usr/X11R6), but let us allow # libtool to hard-code these into programs ;; cygwin* | mingw* | pw32* | cegcc*) version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no case $GCC,$cc_basename in yes,*) # gcc library_names_spec='$libname.dll.a' # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes case $host_os in cygwin*) # Cygwin DLLs use 'cyg' prefix rather than 'lib' soname_spec='`echo $libname | $SED -e 's/^lib/cyg/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' ;; mingw* | cegcc*) # MinGW DLLs use traditional 'lib' prefix soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' ;; pw32*) # pw32 DLLs use 'pw' prefix rather than 'lib' library_names_spec='`echo $libname | $SED -e 's/^lib/pw/'``echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' ;; esac dynamic_linker='Win32 ld.exe' ;; *,cl* | *,icl*) # Native MSVC or ICC libname_spec='$name' soname_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext' library_names_spec='$libname.dll.lib' case $build_os in mingw*) sys_lib_search_path_spec= lt_save_ifs=$IFS IFS=';' for lt_path in $LIB do IFS=$lt_save_ifs # Let DOS variable expansion print the short 8.3 style file name. lt_path=`cd "$lt_path" 2>/dev/null && cmd //C "for %i in (".") do @echo %~si"` sys_lib_search_path_spec="$sys_lib_search_path_spec $lt_path" done IFS=$lt_save_ifs # Convert to MSYS style. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's|\\\\|/|g' -e 's| \\([a-zA-Z]\\):| /\\1|g' -e 's|^ ||'` ;; cygwin*) # Convert to unix form, then to dos form, then back to unix form # but this time dos style (no spaces!) so that the unix form looks # like /cygdrive/c/PROGRA~1:/cygdr... sys_lib_search_path_spec=`cygpath --path --unix "$LIB"` sys_lib_search_path_spec=`cygpath --path --dos "$sys_lib_search_path_spec" 2>/dev/null` sys_lib_search_path_spec=`cygpath --path --unix "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` ;; *) sys_lib_search_path_spec=$LIB if $ECHO "$sys_lib_search_path_spec" | $GREP ';[c-zC-Z]:/' >/dev/null; then # It is most probably a Windows format PATH. sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e 's/;/ /g'` else sys_lib_search_path_spec=`$ECHO "$sys_lib_search_path_spec" | $SED -e "s/$PATH_SEPARATOR/ /g"` fi # FIXME: find the short name or the path components, as spaces are # common. (e.g. "Program Files" -> "PROGRA~1") ;; esac # DLL is installed to $(libdir)/../bin by postinstall_cmds postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; echo \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; echo \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' shlibpath_overrides_runpath=yes dynamic_linker='Win32 link.exe' ;; *) # Assume MSVC and ICC wrapper library_names_spec='$libname`echo $release | $SED -e 's/[.]/-/g'`$versuffix$shared_ext $libname.lib' dynamic_linker='Win32 ld.exe' ;; esac # FIXME: first we should search . and the directory the executable is in shlibpath_var=PATH ;; darwin* | rhapsody*) dynamic_linker="$host_os dyld" version_type=darwin need_lib_prefix=no need_version=no library_names_spec='$libname$release$major$shared_ext $libname$shared_ext' soname_spec='$libname$release$major$shared_ext' shlibpath_overrides_runpath=yes shlibpath_var=DYLD_LIBRARY_PATH shrext_cmds='`test .$module = .yes && echo .so || echo .dylib`' sys_lib_dlsearch_path_spec='/usr/local/lib /lib /usr/lib' ;; dgux*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; freebsd* | dragonfly* | midnightbsd*) # DragonFly does not have aout. When/if they implement a new # versioning mechanism, adjust this. if test -x /usr/bin/objformat; then objformat=`/usr/bin/objformat` else case $host_os in freebsd[23].*) objformat=aout ;; *) objformat=elf ;; esac fi version_type=freebsd-$objformat case $version_type in freebsd-elf*) library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' need_version=no need_lib_prefix=no ;; freebsd-*) library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' need_version=yes ;; esac shlibpath_var=LD_LIBRARY_PATH case $host_os in freebsd2.*) shlibpath_overrides_runpath=yes ;; freebsd3.[01]* | freebsdelf3.[01]*) shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; freebsd3.[2-9]* | freebsdelf3.[2-9]* | \ freebsd4.[0-5] | freebsdelf4.[0-5] | freebsd4.1.1 | freebsdelf4.1.1) shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; *) # from 4.6 on, and DragonFly shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; esac ;; haiku*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no dynamic_linker="$host_os runtime_loader" library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LIBRARY_PATH shlibpath_overrides_runpath=no sys_lib_dlsearch_path_spec='/boot/home/config/lib /boot/common/lib /boot/system/lib' hardcode_into_libs=yes ;; hpux9* | hpux10* | hpux11*) # Give a soname corresponding to the major version so that dld.sl refuses to # link against other versions. version_type=sunos need_lib_prefix=no need_version=no case $host_cpu in ia64*) shrext_cmds='.so' hardcode_into_libs=yes dynamic_linker="$host_os dld.so" shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' if test 32 = "$HPUX_IA64_MODE"; then sys_lib_search_path_spec="/usr/lib/hpux32 /usr/local/lib/hpux32 /usr/local/lib" sys_lib_dlsearch_path_spec=/usr/lib/hpux32 else sys_lib_search_path_spec="/usr/lib/hpux64 /usr/local/lib/hpux64" sys_lib_dlsearch_path_spec=/usr/lib/hpux64 fi ;; hppa*64*) shrext_cmds='.sl' hardcode_into_libs=yes dynamic_linker="$host_os dld.sl" shlibpath_var=LD_LIBRARY_PATH # How should we handle SHLIB_PATH shlibpath_overrides_runpath=yes # Unless +noenvvar is specified. library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' sys_lib_search_path_spec="/usr/lib/pa20_64 /usr/ccs/lib/pa20_64" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; *) shrext_cmds='.sl' dynamic_linker="$host_os dld.sl" shlibpath_var=SHLIB_PATH shlibpath_overrides_runpath=no # +s is required to enable SHLIB_PATH library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' ;; esac # HP-UX runs *really* slowly unless shared libraries are mode 555, ... postinstall_cmds='chmod 555 $lib' # or fails outright, so override atomically: install_override_mode=555 ;; interix[3-9]*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='Interix 3.x ld.so.1 (PE, like ELF)' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; irix5* | irix6* | nonstopux*) case $host_os in nonstopux*) version_type=nonstopux ;; *) if test yes = "$lt_cv_prog_gnu_ld"; then version_type=linux # correct to gnu/linux during the next big refactor else version_type=irix fi ;; esac need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$release$shared_ext $libname$shared_ext' case $host_os in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in # libtool.m4 will add one of these switches to LD *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= libmagic=32-bit;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 libmagic=N32;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 libmagic=64-bit;; *) libsuff= shlibsuff= libmagic=never-match;; esac ;; esac shlibpath_var=LD_LIBRARY${shlibsuff}_PATH shlibpath_overrides_runpath=no sys_lib_search_path_spec="/usr/lib$libsuff /lib$libsuff /usr/local/lib$libsuff" sys_lib_dlsearch_path_spec="/usr/lib$libsuff /lib$libsuff" hardcode_into_libs=yes ;; # No shared lib support for Linux oldld, aout, or coff. linux*oldld* | linux*aout* | linux*coff*) dynamic_linker=no ;; linux*android*) version_type=none # Android doesn't support versioned libraries. need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext' soname_spec='$libname$release$shared_ext' finish_cmds= shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes dynamic_linker='Android linker' # Don't embed -rpath directories since the linker doesn't support them. hardcode_libdir_flag_spec_CXX='-L$libdir' ;; # This must be glibc/ELF. linux* | k*bsd*-gnu | kopensolaris*-gnu | gnu*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' finish_cmds='PATH="\$PATH:/sbin" ldconfig -n $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no # Some binutils ld are patched to set DT_RUNPATH if test ${lt_cv_shlibpath_overrides_runpath+y} then : printf %s "(cached) " >&6 else $as_nop lt_cv_shlibpath_overrides_runpath=no save_LDFLAGS=$LDFLAGS save_libdir=$libdir eval "libdir=/foo; wl=\"$lt_prog_compiler_wl_CXX\"; \ LDFLAGS=\"\$LDFLAGS $hardcode_libdir_flag_spec_CXX\"" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { ; return 0; } _ACEOF if ac_fn_cxx_try_link "$LINENO" then : if ($OBJDUMP -p conftest$ac_exeext) 2>/dev/null | grep "RUNPATH.*$libdir" >/dev/null then : lt_cv_shlibpath_overrides_runpath=yes fi fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LDFLAGS=$save_LDFLAGS libdir=$save_libdir fi shlibpath_overrides_runpath=$lt_cv_shlibpath_overrides_runpath # This implies no fast_install, which is unacceptable. # Some rework will be needed to allow for fast_install # before this can be enabled. hardcode_into_libs=yes # Add ABI-specific directories to the system library path. sys_lib_dlsearch_path_spec="/lib64 /usr/lib64 /lib /usr/lib" # Ideally, we could use ldconfig to report *all* directores which are # searched for libraries, however this is still not possible. Aside from not # being certain /sbin/ldconfig is available, command # 'ldconfig -N -X -v | grep ^/' on 64bit Fedora does not report /usr/lib64, # even though it is searched at run-time. Try to do the best guess by # appending ld.so.conf contents (and includes) to the search path. if test -f /etc/ld.so.conf; then lt_ld_extra=`awk '/^include / { system(sprintf("cd /etc; cat %s 2>/dev/null", \$2)); skip = 1; } { if (!skip) print \$0; skip = 0; }' < /etc/ld.so.conf | $SED -e 's/#.*//;/^[ ]*hwcap[ ]/d;s/[:, ]/ /g;s/=[^=]*$//;s/=[^= ]* / /g;s/"//g;/^$/d' | tr '\n' ' '` sys_lib_dlsearch_path_spec="$sys_lib_dlsearch_path_spec $lt_ld_extra" fi # We used to test for /lib/ld.so.1 and disable shared libraries on # powerpc, because MkLinux only supported shared libraries with the # GNU dynamic linker. Since this was broken with cross compilers, # most powerpc-linux boxes support dynamic linking these days and # people can always --disable-shared, the test was removed, and we # assume the GNU/Linux dynamic linker is in use. dynamic_linker='GNU/Linux ld.so' ;; netbsd*) version_type=sunos need_lib_prefix=no need_version=no if echo __ELF__ | $CC -E - | $GREP __ELF__ >/dev/null; then library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' dynamic_linker='NetBSD (a.out) ld.so' else library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' dynamic_linker='NetBSD ld.elf_so' fi shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes ;; newsos6) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; *nto* | *qnx*) version_type=qnx need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes dynamic_linker='ldqnx.so' ;; openbsd* | bitrig*) version_type=sunos sys_lib_dlsearch_path_spec=/usr/lib need_lib_prefix=no if test -z "`echo __ELF__ | $CC -E - | $GREP __ELF__`"; then need_version=no else need_version=yes fi library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/sbin" ldconfig -m $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes ;; os2*) libname_spec='$name' version_type=windows shrext_cmds=.dll need_version=no need_lib_prefix=no # OS/2 can only load a DLL with a base name of 8 characters or less. soname_spec='`test -n "$os2dllname" && libname="$os2dllname"; v=$($ECHO $release$versuffix | tr -d .-); n=$($ECHO $libname | cut -b -$((8 - ${#v})) | tr . _); $ECHO $n$v`$shared_ext' library_names_spec='${libname}_dll.$libext' dynamic_linker='OS/2 ld.exe' shlibpath_var=BEGINLIBPATH sys_lib_search_path_spec="/lib /usr/lib /usr/local/lib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec postinstall_cmds='base_file=`basename \$file`~ dlpath=`$SHELL 2>&1 -c '\''. $dir/'\''\$base_file'\''i; $ECHO \$dlname'\''`~ dldir=$destdir/`dirname \$dlpath`~ test -d \$dldir || mkdir -p \$dldir~ $install_prog $dir/$dlname \$dldir/$dlname~ chmod a+x \$dldir/$dlname~ if test -n '\''$stripme'\'' && test -n '\''$striplib'\''; then eval '\''$striplib \$dldir/$dlname'\'' || exit \$?; fi' postuninstall_cmds='dldll=`$SHELL 2>&1 -c '\''. $file; $ECHO \$dlname'\''`~ dlpath=$dir/\$dldll~ $RM \$dlpath' ;; osf3* | osf4* | osf5*) version_type=osf need_lib_prefix=no need_version=no soname_spec='$libname$release$shared_ext$major' library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH sys_lib_search_path_spec="/usr/shlib /usr/ccs/lib /usr/lib/cmplrs/cc /usr/lib /usr/local/lib /var/shlib" sys_lib_dlsearch_path_spec=$sys_lib_search_path_spec ;; rdos*) dynamic_linker=no ;; solaris*) version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes # ldd complains unless libraries are executable postinstall_cmds='chmod +x $lib' ;; sunos4*) version_type=sunos library_names_spec='$libname$release$shared_ext$versuffix $libname$shared_ext$versuffix' finish_cmds='PATH="\$PATH:/usr/etc" ldconfig $libdir' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes if test yes = "$with_gnu_ld"; then need_lib_prefix=no fi need_version=yes ;; sysv4 | sysv4.3*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH case $host_vendor in sni) shlibpath_overrides_runpath=no need_lib_prefix=no runpath_var=LD_RUN_PATH ;; siemens) need_lib_prefix=no ;; motorola) need_lib_prefix=no need_version=no shlibpath_overrides_runpath=no sys_lib_search_path_spec='/lib /usr/lib /usr/ccs/lib' ;; esac ;; sysv4*MP*) if test -d /usr/nec; then version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$shared_ext.$versuffix $libname$shared_ext.$major $libname$shared_ext' soname_spec='$libname$shared_ext.$major' shlibpath_var=LD_LIBRARY_PATH fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) version_type=sco need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=yes hardcode_into_libs=yes if test yes = "$with_gnu_ld"; then sys_lib_search_path_spec='/usr/local/lib /usr/gnu/lib /usr/ccs/lib /usr/lib /lib' else sys_lib_search_path_spec='/usr/ccs/lib /usr/lib' case $host_os in sco3.2v5*) sys_lib_search_path_spec="$sys_lib_search_path_spec /lib" ;; esac fi sys_lib_dlsearch_path_spec='/usr/lib' ;; tpf*) # TPF is a cross-target only. Preferred cross-host = GNU/Linux. version_type=linux # correct to gnu/linux during the next big refactor need_lib_prefix=no need_version=no library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' shlibpath_var=LD_LIBRARY_PATH shlibpath_overrides_runpath=no hardcode_into_libs=yes ;; uts4*) version_type=linux # correct to gnu/linux during the next big refactor library_names_spec='$libname$release$shared_ext$versuffix $libname$release$shared_ext$major $libname$shared_ext' soname_spec='$libname$release$shared_ext$major' shlibpath_var=LD_LIBRARY_PATH ;; *) dynamic_linker=no ;; esac { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $dynamic_linker" >&5 printf "%s\n" "$dynamic_linker" >&6; } test no = "$dynamic_linker" && can_build_shared=no variables_saved_for_relink="PATH $shlibpath_var $runpath_var" if test yes = "$GCC"; then variables_saved_for_relink="$variables_saved_for_relink GCC_EXEC_PREFIX COMPILER_PATH LIBRARY_PATH" fi if test set = "${lt_cv_sys_lib_search_path_spec+set}"; then sys_lib_search_path_spec=$lt_cv_sys_lib_search_path_spec fi if test set = "${lt_cv_sys_lib_dlsearch_path_spec+set}"; then sys_lib_dlsearch_path_spec=$lt_cv_sys_lib_dlsearch_path_spec fi # remember unaugmented sys_lib_dlsearch_path content for libtool script decls... configure_time_dlsearch_path=$sys_lib_dlsearch_path_spec # ... but it needs LT_SYS_LIBRARY_PATH munging for other configure-time code func_munge_path_list sys_lib_dlsearch_path_spec "$LT_SYS_LIBRARY_PATH" # to be used as default LT_SYS_LIBRARY_PATH value in generated libtool configure_time_lt_sys_library_path=$LT_SYS_LIBRARY_PATH { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking how to hardcode library paths into programs" >&5 printf %s "checking how to hardcode library paths into programs... " >&6; } hardcode_action_CXX= if test -n "$hardcode_libdir_flag_spec_CXX" || test -n "$runpath_var_CXX" || test yes = "$hardcode_automatic_CXX"; then # We can hardcode non-existent directories. if test no != "$hardcode_direct_CXX" && # If the only mechanism to avoid hardcoding is shlibpath_var, we # have to relink, otherwise we might link with an installed library # when we should be linking with a yet-to-be-installed one ## test no != "$_LT_TAGVAR(hardcode_shlibpath_var, CXX)" && test no != "$hardcode_minus_L_CXX"; then # Linking always hardcodes the temporary library directory. hardcode_action_CXX=relink else # We can link without hardcoding, and we can hardcode nonexisting dirs. hardcode_action_CXX=immediate fi else # We cannot hardcode anything, or else we can only hardcode existing # directories. hardcode_action_CXX=unsupported fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $hardcode_action_CXX" >&5 printf "%s\n" "$hardcode_action_CXX" >&6; } if test relink = "$hardcode_action_CXX" || test yes = "$inherit_rpath_CXX"; then # Fast installation is not supported enable_fast_install=no elif test yes = "$shlibpath_overrides_runpath" || test no = "$enable_shared"; then # Fast installation is not necessary enable_fast_install=needless fi fi # test -n "$compiler" CC=$lt_save_CC CFLAGS=$lt_save_CFLAGS LDCXX=$LD LD=$lt_save_LD GCC=$lt_save_GCC with_gnu_ld=$lt_save_with_gnu_ld lt_cv_path_LDCXX=$lt_cv_path_LD lt_cv_path_LD=$lt_save_path_LD lt_cv_prog_gnu_ldcxx=$lt_cv_prog_gnu_ld lt_cv_prog_gnu_ld=$lt_save_with_gnu_ld fi # test yes != "$_lt_caught_CXX_error" ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether ${MAKE-make} sets \$(MAKE)" >&5 printf %s "checking whether ${MAKE-make} sets \$(MAKE)... " >&6; } set x ${MAKE-make} ac_make=`printf "%s\n" "$2" | sed 's/+/p/g; s/[^a-zA-Z0-9_]/_/g'` if eval test \${ac_cv_prog_make_${ac_make}_set+y} then : printf %s "(cached) " >&6 else $as_nop cat >conftest.make <<\_ACEOF SHELL = /bin/sh all: @echo '@@@%%%=$(MAKE)=@@@%%%' _ACEOF # GNU make sometimes prints "make[1]: Entering ...", which would confuse us. case `${MAKE-make} -f conftest.make 2>/dev/null` in *@@@%%%=?*=@@@%%%*) eval ac_cv_prog_make_${ac_make}_set=yes;; *) eval ac_cv_prog_make_${ac_make}_set=no;; esac rm -f conftest.make fi if eval test \$ac_cv_prog_make_${ac_make}_set = yes; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } SET_MAKE= else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } SET_MAKE="MAKE=${MAKE-make}" fi # Extract the first word of "pkg-config", so it can be a program name with args. set dummy pkg-config; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_path_PKGCONFIG+y} then : printf %s "(cached) " >&6 else $as_nop case $PKGCONFIG in [\\/]* | ?:[\\/]*) ac_cv_path_PKGCONFIG="$PKGCONFIG" # Let the user override the test with a path. ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_path_PKGCONFIG="$as_dir$ac_word$ac_exec_ext" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS ;; esac fi PKGCONFIG=$ac_cv_path_PKGCONFIG if test -n "$PKGCONFIG"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $PKGCONFIG" >&5 printf "%s\n" "$PKGCONFIG" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether NLS is requested" >&5 printf %s "checking whether NLS is requested... " >&6; } # Check whether --enable-nls was given. if test ${enable_nls+y} then : enableval=$enable_nls; USE_NLS=$enableval else $as_nop USE_NLS=yes fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $USE_NLS" >&5 printf "%s\n" "$USE_NLS" >&6; } GETTEXT_MACRO_VERSION=0.20 # Prepare PATH_SEPARATOR. # The user is always right. if test "${PATH_SEPARATOR+set}" != set; then # Determine PATH_SEPARATOR by trying to find /bin/sh in a PATH which # contains only /bin. Note that ksh looks also at the FPATH variable, # so we have to set that as well for the test. PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \ && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \ || PATH_SEPARATOR=';' } fi # Find out how to test for executable files. Don't use a zero-byte file, # as systems may use methods other than mode bits to determine executability. cat >conf$$.file <<_ASEOF #! /bin/sh exit 0 _ASEOF chmod +x conf$$.file if test -x conf$$.file >/dev/null 2>&1; then ac_executable_p="test -x" else ac_executable_p="test -f" fi rm -f conf$$.file # Extract the first word of "msgfmt", so it can be a program name with args. set dummy msgfmt; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_path_MSGFMT+y} then : printf %s "(cached) " >&6 else $as_nop case "$MSGFMT" in [\\/]* | ?:[\\/]*) ac_cv_path_MSGFMT="$MSGFMT" # Let the user override the test with a path. ;; *) ac_save_IFS="$IFS"; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS="$ac_save_IFS" test -z "$ac_dir" && ac_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if $ac_executable_p "$ac_dir/$ac_word$ac_exec_ext"; then echo "$as_me: trying $ac_dir/$ac_word..." >&5 if $ac_dir/$ac_word --statistics /dev/null >&5 2>&1 && (if $ac_dir/$ac_word --statistics /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi); then ac_cv_path_MSGFMT="$ac_dir/$ac_word$ac_exec_ext" break 2 fi fi done done IFS="$ac_save_IFS" test -z "$ac_cv_path_MSGFMT" && ac_cv_path_MSGFMT=":" ;; esac fi MSGFMT="$ac_cv_path_MSGFMT" if test "$MSGFMT" != ":"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $MSGFMT" >&5 printf "%s\n" "$MSGFMT" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi # Extract the first word of "gmsgfmt", so it can be a program name with args. set dummy gmsgfmt; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_path_GMSGFMT+y} then : printf %s "(cached) " >&6 else $as_nop case $GMSGFMT in [\\/]* | ?:[\\/]*) ac_cv_path_GMSGFMT="$GMSGFMT" # Let the user override the test with a path. ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_path_GMSGFMT="$as_dir$ac_word$ac_exec_ext" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS test -z "$ac_cv_path_GMSGFMT" && ac_cv_path_GMSGFMT="$MSGFMT" ;; esac fi GMSGFMT=$ac_cv_path_GMSGFMT if test -n "$GMSGFMT"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $GMSGFMT" >&5 printf "%s\n" "$GMSGFMT" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi case `$GMSGFMT --version | sed 1q | sed -e 's,^[^0-9]*,,'` in '' | 0.[0-9] | 0.[0-9].* | 0.1[0-4] | 0.1[0-4].*) GMSGFMT_015=: ;; *) GMSGFMT_015=$GMSGFMT ;; esac # Prepare PATH_SEPARATOR. # The user is always right. if test "${PATH_SEPARATOR+set}" != set; then # Determine PATH_SEPARATOR by trying to find /bin/sh in a PATH which # contains only /bin. Note that ksh looks also at the FPATH variable, # so we have to set that as well for the test. PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \ && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \ || PATH_SEPARATOR=';' } fi # Find out how to test for executable files. Don't use a zero-byte file, # as systems may use methods other than mode bits to determine executability. cat >conf$$.file <<_ASEOF #! /bin/sh exit 0 _ASEOF chmod +x conf$$.file if test -x conf$$.file >/dev/null 2>&1; then ac_executable_p="test -x" else ac_executable_p="test -f" fi rm -f conf$$.file # Extract the first word of "xgettext", so it can be a program name with args. set dummy xgettext; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_path_XGETTEXT+y} then : printf %s "(cached) " >&6 else $as_nop case "$XGETTEXT" in [\\/]* | ?:[\\/]*) ac_cv_path_XGETTEXT="$XGETTEXT" # Let the user override the test with a path. ;; *) ac_save_IFS="$IFS"; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS="$ac_save_IFS" test -z "$ac_dir" && ac_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if $ac_executable_p "$ac_dir/$ac_word$ac_exec_ext"; then echo "$as_me: trying $ac_dir/$ac_word..." >&5 if $ac_dir/$ac_word --omit-header --copyright-holder= --msgid-bugs-address= /dev/null >&5 2>&1 && (if $ac_dir/$ac_word --omit-header --copyright-holder= --msgid-bugs-address= /dev/null 2>&1 >/dev/null | grep usage >/dev/null; then exit 1; else exit 0; fi); then ac_cv_path_XGETTEXT="$ac_dir/$ac_word$ac_exec_ext" break 2 fi fi done done IFS="$ac_save_IFS" test -z "$ac_cv_path_XGETTEXT" && ac_cv_path_XGETTEXT=":" ;; esac fi XGETTEXT="$ac_cv_path_XGETTEXT" if test "$XGETTEXT" != ":"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $XGETTEXT" >&5 printf "%s\n" "$XGETTEXT" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi rm -f messages.po case `$XGETTEXT --version | sed 1q | sed -e 's,^[^0-9]*,,'` in '' | 0.[0-9] | 0.[0-9].* | 0.1[0-4] | 0.1[0-4].*) XGETTEXT_015=: ;; *) XGETTEXT_015=$XGETTEXT ;; esac # Prepare PATH_SEPARATOR. # The user is always right. if test "${PATH_SEPARATOR+set}" != set; then # Determine PATH_SEPARATOR by trying to find /bin/sh in a PATH which # contains only /bin. Note that ksh looks also at the FPATH variable, # so we have to set that as well for the test. PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \ && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \ || PATH_SEPARATOR=';' } fi # Find out how to test for executable files. Don't use a zero-byte file, # as systems may use methods other than mode bits to determine executability. cat >conf$$.file <<_ASEOF #! /bin/sh exit 0 _ASEOF chmod +x conf$$.file if test -x conf$$.file >/dev/null 2>&1; then ac_executable_p="test -x" else ac_executable_p="test -f" fi rm -f conf$$.file # Extract the first word of "msgmerge", so it can be a program name with args. set dummy msgmerge; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_path_MSGMERGE+y} then : printf %s "(cached) " >&6 else $as_nop case "$MSGMERGE" in [\\/]* | ?:[\\/]*) ac_cv_path_MSGMERGE="$MSGMERGE" # Let the user override the test with a path. ;; *) ac_save_IFS="$IFS"; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS="$ac_save_IFS" test -z "$ac_dir" && ac_dir=. for ac_exec_ext in '' $ac_executable_extensions; do if $ac_executable_p "$ac_dir/$ac_word$ac_exec_ext"; then echo "$as_me: trying $ac_dir/$ac_word..." >&5 if $ac_dir/$ac_word --update -q /dev/null /dev/null >&5 2>&1; then ac_cv_path_MSGMERGE="$ac_dir/$ac_word$ac_exec_ext" break 2 fi fi done done IFS="$ac_save_IFS" test -z "$ac_cv_path_MSGMERGE" && ac_cv_path_MSGMERGE=":" ;; esac fi MSGMERGE="$ac_cv_path_MSGMERGE" if test "$MSGMERGE" != ":"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $MSGMERGE" >&5 printf "%s\n" "$MSGMERGE" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if LC_ALL=C $MSGMERGE --help | grep ' --for-msgfmt ' >/dev/null; then MSGMERGE_FOR_MSGFMT_OPTION='--for-msgfmt' else if LC_ALL=C $MSGMERGE --help | grep ' --no-fuzzy-matching ' >/dev/null; then MSGMERGE_FOR_MSGFMT_OPTION='--no-fuzzy-matching --no-location --quiet' else MSGMERGE_FOR_MSGFMT_OPTION='--no-location --quiet' fi fi test -n "${XGETTEXT_EXTRA_OPTIONS+set}" || XGETTEXT_EXTRA_OPTIONS= ac_config_commands="$ac_config_commands po-directories" if test "X$prefix" = "XNONE"; then acl_final_prefix="$ac_default_prefix" else acl_final_prefix="$prefix" fi if test "X$exec_prefix" = "XNONE"; then acl_final_exec_prefix='${prefix}' else acl_final_exec_prefix="$exec_prefix" fi acl_save_prefix="$prefix" prefix="$acl_final_prefix" eval acl_final_exec_prefix=\"$acl_final_exec_prefix\" prefix="$acl_save_prefix" # Check whether --with-gnu-ld was given. if test ${with_gnu_ld+y} then : withval=$with_gnu_ld; test "$withval" = no || with_gnu_ld=yes else $as_nop with_gnu_ld=no fi # Prepare PATH_SEPARATOR. # The user is always right. if test "${PATH_SEPARATOR+set}" != set; then # Determine PATH_SEPARATOR by trying to find /bin/sh in a PATH which # contains only /bin. Note that ksh looks also at the FPATH variable, # so we have to set that as well for the test. PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \ && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 \ || PATH_SEPARATOR=';' } fi if test -n "$LD"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for ld" >&5 printf %s "checking for ld... " >&6; } elif test "$GCC" = yes; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for ld used by $CC" >&5 printf %s "checking for ld used by $CC... " >&6; } elif test "$with_gnu_ld" = yes; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for GNU ld" >&5 printf %s "checking for GNU ld... " >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for non-GNU ld" >&5 printf %s "checking for non-GNU ld... " >&6; } fi if test -n "$LD"; then # Let the user override the test with a path. : else if test ${acl_cv_path_LD+y} then : printf %s "(cached) " >&6 else $as_nop acl_cv_path_LD= # Final result of this test ac_prog=ld # Program to search in $PATH if test "$GCC" = yes; then # Check if gcc -print-prog-name=ld gives a path. case $host in *-*-mingw*) # gcc leaves a trailing carriage return which upsets mingw acl_output=`($CC -print-prog-name=ld) 2>&5 | tr -d '\015'` ;; *) acl_output=`($CC -print-prog-name=ld) 2>&5` ;; esac case $acl_output in # Accept absolute paths. [\\/]* | ?:[\\/]*) re_direlt='/[^/][^/]*/\.\./' # Canonicalize the pathname of ld acl_output=`echo "$acl_output" | sed 's%\\\\%/%g'` while echo "$acl_output" | grep "$re_direlt" > /dev/null 2>&1; do acl_output=`echo $acl_output | sed "s%$re_direlt%/%"` done # Got the pathname. No search in PATH is needed. acl_cv_path_LD="$acl_output" ac_prog= ;; "") # If it fails, then pretend we aren't using GCC. ;; *) # If it is relative, then search for the first ld in PATH. with_gnu_ld=unknown ;; esac fi if test -n "$ac_prog"; then # Search for $ac_prog in $PATH. acl_save_ifs="$IFS"; IFS=$PATH_SEPARATOR for ac_dir in $PATH; do IFS="$acl_save_ifs" test -z "$ac_dir" && ac_dir=. if test -f "$ac_dir/$ac_prog" || test -f "$ac_dir/$ac_prog$ac_exeext"; then acl_cv_path_LD="$ac_dir/$ac_prog" # Check to see if the program is GNU ld. I'd rather use --version, # but apparently some variants of GNU ld only accept -v. # Break only if it was the GNU/non-GNU ld that we prefer. case `"$acl_cv_path_LD" -v 2>&1 conftest.$ac_ext /* end confdefs.h. */ #if defined __powerpc64__ || defined _ARCH_PPC64 int ok; #else error fail #endif _ACEOF if ac_fn_c_try_compile "$LINENO" then : # The compiler produces 64-bit code. Add option '-b64' so that the # linker groks 64-bit object files. case "$acl_cv_path_LD " in *" -b64 "*) ;; *) acl_cv_path_LD="$acl_cv_path_LD -b64" ;; esac fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ;; sparc64-*-netbsd*) cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #if defined __sparcv9 || defined __arch64__ int ok; #else error fail #endif _ACEOF if ac_fn_c_try_compile "$LINENO" then : else $as_nop # The compiler produces 32-bit code. Add option '-m elf32_sparc' # so that the linker groks 32-bit object files. case "$acl_cv_path_LD " in *" -m elf32_sparc "*) ;; *) acl_cv_path_LD="$acl_cv_path_LD -m elf32_sparc" ;; esac fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ;; esac fi LD="$acl_cv_path_LD" fi if test -n "$LD"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $LD" >&5 printf "%s\n" "$LD" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } as_fn_error $? "no acceptable ld found in \$PATH" "$LINENO" 5 fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if the linker ($LD) is GNU ld" >&5 printf %s "checking if the linker ($LD) is GNU ld... " >&6; } if test ${acl_cv_prog_gnu_ld+y} then : printf %s "(cached) " >&6 else $as_nop # I'd rather use --version here, but apparently some GNU lds only accept -v. case `$LD -v 2>&1 &5 printf "%s\n" "$acl_cv_prog_gnu_ld" >&6; } with_gnu_ld=$acl_cv_prog_gnu_ld { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for shared library run path origin" >&5 printf %s "checking for shared library run path origin... " >&6; } if test ${acl_cv_rpath+y} then : printf %s "(cached) " >&6 else $as_nop CC="$CC" GCC="$GCC" LDFLAGS="$LDFLAGS" LD="$LD" with_gnu_ld="$with_gnu_ld" \ ${CONFIG_SHELL-/bin/sh} "$ac_aux_dir/config.rpath" "$host" > conftest.sh . ./conftest.sh rm -f ./conftest.sh acl_cv_rpath=done fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $acl_cv_rpath" >&5 printf "%s\n" "$acl_cv_rpath" >&6; } wl="$acl_cv_wl" acl_libext="$acl_cv_libext" acl_shlibext="$acl_cv_shlibext" acl_libname_spec="$acl_cv_libname_spec" acl_library_names_spec="$acl_cv_library_names_spec" acl_hardcode_libdir_flag_spec="$acl_cv_hardcode_libdir_flag_spec" acl_hardcode_libdir_separator="$acl_cv_hardcode_libdir_separator" acl_hardcode_direct="$acl_cv_hardcode_direct" acl_hardcode_minus_L="$acl_cv_hardcode_minus_L" # Check whether --enable-rpath was given. if test ${enable_rpath+y} then : enableval=$enable_rpath; : else $as_nop enable_rpath=yes fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking 32-bit host C ABI" >&5 printf %s "checking 32-bit host C ABI... " >&6; } if test ${gl_cv_host_cpu_c_abi_32bit+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$gl_cv_host_cpu_c_abi"; then case "$gl_cv_host_cpu_c_abi" in i386 | x86_64-x32 | arm | armhf | arm64-ilp32 | hppa | ia64-ilp32 | mips | mipsn32 | powerpc | riscv*-ilp32* | s390 | sparc) gl_cv_host_cpu_c_abi_32bit=yes ;; x86_64 | alpha | arm64 | hppa64 | ia64 | mips64 | powerpc64 | powerpc64-elfv2 | riscv*-lp64* | s390x | sparc64 ) gl_cv_host_cpu_c_abi_32bit=no ;; *) gl_cv_host_cpu_c_abi_32bit=unknown ;; esac else case "$host_cpu" in # CPUs that only support a 32-bit ABI. arc \ | bfin \ | cris* \ | csky \ | epiphany \ | ft32 \ | h8300 \ | m68k \ | microblaze | microblazeel \ | nds32 | nds32le | nds32be \ | nios2 | nios2eb | nios2el \ | or1k* \ | or32 \ | sh | sh1234 | sh1234elb \ | tic6x \ | xtensa* ) gl_cv_host_cpu_c_abi_32bit=yes ;; # CPUs that only support a 64-bit ABI. alpha | alphaev[4-8] | alphaev56 | alphapca5[67] | alphaev6[78] \ | mmix ) gl_cv_host_cpu_c_abi_32bit=no ;; i[34567]86 ) gl_cv_host_cpu_c_abi_32bit=yes ;; x86_64 ) # On x86_64 systems, the C compiler may be generating code in one of # these ABIs: # - 64-bit instruction set, 64-bit pointers, 64-bit 'long': x86_64. # - 64-bit instruction set, 64-bit pointers, 32-bit 'long': x86_64 # with native Windows (mingw, MSVC). # - 64-bit instruction set, 32-bit pointers, 32-bit 'long': x86_64-x32. # - 32-bit instruction set, 32-bit pointers, 32-bit 'long': i386. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #if (defined __x86_64__ || defined __amd64__ \ || defined _M_X64 || defined _M_AMD64) \ && !(defined __ILP32__ || defined _ILP32) int ok; #else error fail #endif _ACEOF if ac_fn_c_try_compile "$LINENO" then : gl_cv_host_cpu_c_abi_32bit=no else $as_nop gl_cv_host_cpu_c_abi_32bit=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ;; arm* | aarch64 ) # Assume arm with EABI. # On arm64 systems, the C compiler may be generating code in one of # these ABIs: # - aarch64 instruction set, 64-bit pointers, 64-bit 'long': arm64. # - aarch64 instruction set, 32-bit pointers, 32-bit 'long': arm64-ilp32. # - 32-bit instruction set, 32-bit pointers, 32-bit 'long': arm or armhf. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #if defined __aarch64__ && !(defined __ILP32__ || defined _ILP32) int ok; #else error fail #endif _ACEOF if ac_fn_c_try_compile "$LINENO" then : gl_cv_host_cpu_c_abi_32bit=no else $as_nop gl_cv_host_cpu_c_abi_32bit=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ;; hppa1.0 | hppa1.1 | hppa2.0* | hppa64 ) # On hppa, the C compiler may be generating 32-bit code or 64-bit # code. In the latter case, it defines _LP64 and __LP64__. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef __LP64__ int ok; #else error fail #endif _ACEOF if ac_fn_c_try_compile "$LINENO" then : gl_cv_host_cpu_c_abi_32bit=no else $as_nop gl_cv_host_cpu_c_abi_32bit=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ;; ia64* ) # On ia64 on HP-UX, the C compiler may be generating 64-bit code or # 32-bit code. In the latter case, it defines _ILP32. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef _ILP32 int ok; #else error fail #endif _ACEOF if ac_fn_c_try_compile "$LINENO" then : gl_cv_host_cpu_c_abi_32bit=yes else $as_nop gl_cv_host_cpu_c_abi_32bit=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ;; mips* ) # We should also check for (_MIPS_SZPTR == 64), but gcc keeps this # at 32. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #if defined _MIPS_SZLONG && (_MIPS_SZLONG == 64) int ok; #else error fail #endif _ACEOF if ac_fn_c_try_compile "$LINENO" then : gl_cv_host_cpu_c_abi_32bit=no else $as_nop gl_cv_host_cpu_c_abi_32bit=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ;; powerpc* ) # Different ABIs are in use on AIX vs. Mac OS X vs. Linux,*BSD. # No need to distinguish them here; the caller may distinguish # them based on the OS. # On powerpc64 systems, the C compiler may still be generating # 32-bit code. And on powerpc-ibm-aix systems, the C compiler may # be generating 64-bit code. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #if defined __powerpc64__ || defined _ARCH_PPC64 int ok; #else error fail #endif _ACEOF if ac_fn_c_try_compile "$LINENO" then : gl_cv_host_cpu_c_abi_32bit=no else $as_nop gl_cv_host_cpu_c_abi_32bit=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ;; rs6000 ) gl_cv_host_cpu_c_abi_32bit=yes ;; riscv32 | riscv64 ) # There are 6 ABIs: ilp32, ilp32f, ilp32d, lp64, lp64f, lp64d. # Size of 'long' and 'void *': cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #if defined __LP64__ int ok; #else error fail #endif _ACEOF if ac_fn_c_try_compile "$LINENO" then : gl_cv_host_cpu_c_abi_32bit=no else $as_nop gl_cv_host_cpu_c_abi_32bit=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ;; s390* ) # On s390x, the C compiler may be generating 64-bit (= s390x) code # or 31-bit (= s390) code. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #if defined __LP64__ || defined __s390x__ int ok; #else error fail #endif _ACEOF if ac_fn_c_try_compile "$LINENO" then : gl_cv_host_cpu_c_abi_32bit=no else $as_nop gl_cv_host_cpu_c_abi_32bit=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ;; sparc | sparc64 ) # UltraSPARCs running Linux have `uname -m` = "sparc64", but the # C compiler still generates 32-bit code. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #if defined __sparcv9 || defined __arch64__ int ok; #else error fail #endif _ACEOF if ac_fn_c_try_compile "$LINENO" then : gl_cv_host_cpu_c_abi_32bit=no else $as_nop gl_cv_host_cpu_c_abi_32bit=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ;; *) gl_cv_host_cpu_c_abi_32bit=unknown ;; esac fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $gl_cv_host_cpu_c_abi_32bit" >&5 printf "%s\n" "$gl_cv_host_cpu_c_abi_32bit" >&6; } HOST_CPU_C_ABI_32BIT="$gl_cv_host_cpu_c_abi_32bit" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for ELF binary format" >&5 printf %s "checking for ELF binary format... " >&6; } if test ${gl_cv_elf+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #ifdef __ELF__ Extensible Linking Format #endif _ACEOF if (eval "$ac_cpp conftest.$ac_ext") 2>&5 | $EGREP "Extensible Linking Format" >/dev/null 2>&1 then : gl_cv_elf=yes else $as_nop gl_cv_elf=no fi rm -rf conftest* fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $gl_cv_elf" >&5 printf "%s\n" "$gl_cv_elf" >&6; } if test $gl_cv_elf; then # Extract the ELF class of a file (5th byte) in decimal. # Cf. https://en.wikipedia.org/wiki/Executable_and_Linkable_Format#File_header if od -A x < /dev/null >/dev/null 2>/dev/null; then # Use POSIX od. func_elfclass () { od -A n -t d1 -j 4 -N 1 } else # Use BSD hexdump. func_elfclass () { dd bs=1 count=1 skip=4 2>/dev/null | hexdump -e '1/1 "%3d "' echo } fi case $HOST_CPU_C_ABI_32BIT in yes) # 32-bit ABI. acl_is_expected_elfclass () { test "`func_elfclass | sed -e 's/[ ]//g'`" = 1 } ;; no) # 64-bit ABI. acl_is_expected_elfclass () { test "`func_elfclass | sed -e 's/[ ]//g'`" = 2 } ;; *) # Unknown. acl_is_expected_elfclass () { : } ;; esac else acl_is_expected_elfclass () { : } fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for the common suffixes of directories in the library search path" >&5 printf %s "checking for the common suffixes of directories in the library search path... " >&6; } if test ${acl_cv_libdirstems+y} then : printf %s "(cached) " >&6 else $as_nop acl_libdirstem=lib acl_libdirstem2= acl_libdirstem3= case "$host_os" in solaris*) if test $HOST_CPU_C_ABI_32BIT = no; then acl_libdirstem2=lib/64 case "$host_cpu" in sparc*) acl_libdirstem3=lib/sparcv9 ;; i*86 | x86_64) acl_libdirstem3=lib/amd64 ;; esac fi ;; *) searchpath=`(LC_ALL=C $CC $CPPFLAGS $CFLAGS -print-search-dirs) 2>/dev/null \ | sed -n -e 's,^libraries: ,,p' | sed -e 's,^=,,'` if test $HOST_CPU_C_ABI_32BIT != no; then # 32-bit or unknown ABI. if test -d /usr/lib32; then acl_libdirstem2=lib32 fi fi if test $HOST_CPU_C_ABI_32BIT != yes; then # 64-bit or unknown ABI. if test -d /usr/lib64; then acl_libdirstem3=lib64 fi fi if test -n "$searchpath"; then acl_save_IFS="${IFS= }"; IFS=":" for searchdir in $searchpath; do if test -d "$searchdir"; then case "$searchdir" in */lib32/ | */lib32 ) acl_libdirstem2=lib32 ;; */lib64/ | */lib64 ) acl_libdirstem3=lib64 ;; */../ | */.. ) # Better ignore directories of this form. They are misleading. ;; *) searchdir=`cd "$searchdir" && pwd` case "$searchdir" in */lib32 ) acl_libdirstem2=lib32 ;; */lib64 ) acl_libdirstem3=lib64 ;; esac ;; esac fi done IFS="$acl_save_IFS" if test $HOST_CPU_C_ABI_32BIT = yes; then # 32-bit ABI. acl_libdirstem3= fi if test $HOST_CPU_C_ABI_32BIT = no; then # 64-bit ABI. acl_libdirstem2= fi fi ;; esac test -n "$acl_libdirstem2" || acl_libdirstem2="$acl_libdirstem" test -n "$acl_libdirstem3" || acl_libdirstem3="$acl_libdirstem" acl_cv_libdirstems="$acl_libdirstem,$acl_libdirstem2,$acl_libdirstem3" fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $acl_cv_libdirstems" >&5 printf "%s\n" "$acl_cv_libdirstems" >&6; } acl_libdirstem=`echo "$acl_cv_libdirstems" | sed -e 's/,.*//'` acl_libdirstem2=`echo "$acl_cv_libdirstems" | sed -e 's/^[^,]*,//' -e 's/,.*//'` acl_libdirstem3=`echo "$acl_cv_libdirstems" | sed -e 's/^[^,]*,[^,]*,//' -e 's/,.*//'` use_additional=yes acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval additional_includedir=\"$includedir\" eval additional_libdir=\"$libdir\" eval additional_libdir2=\"$exec_prefix/$acl_libdirstem2\" eval additional_libdir3=\"$exec_prefix/$acl_libdirstem3\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" # Check whether --with-libiconv-prefix was given. if test ${with_libiconv_prefix+y} then : withval=$with_libiconv_prefix; if test "X$withval" = "Xno"; then use_additional=no else if test "X$withval" = "X"; then acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval additional_includedir=\"$includedir\" eval additional_libdir=\"$libdir\" eval additional_libdir2=\"$exec_prefix/$acl_libdirstem2\" eval additional_libdir3=\"$exec_prefix/$acl_libdirstem3\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" else additional_includedir="$withval/include" additional_libdir="$withval/$acl_libdirstem" additional_libdir2="$withval/$acl_libdirstem2" additional_libdir3="$withval/$acl_libdirstem3" fi fi fi if test "X$additional_libdir2" = "X$additional_libdir"; then additional_libdir2= fi if test "X$additional_libdir3" = "X$additional_libdir"; then additional_libdir3= fi LIBICONV= LTLIBICONV= INCICONV= LIBICONV_PREFIX= HAVE_LIBICONV= rpathdirs= ltrpathdirs= names_already_handled= names_next_round='iconv ' while test -n "$names_next_round"; do names_this_round="$names_next_round" names_next_round= for name in $names_this_round; do already_handled= for n in $names_already_handled; do if test "$n" = "$name"; then already_handled=yes break fi done if test -z "$already_handled"; then names_already_handled="$names_already_handled $name" uppername=`echo "$name" | sed -e 'y|abcdefghijklmnopqrstuvwxyz./+-|ABCDEFGHIJKLMNOPQRSTUVWXYZ____|'` eval value=\"\$HAVE_LIB$uppername\" if test -n "$value"; then if test "$value" = yes; then eval value=\"\$LIB$uppername\" test -z "$value" || LIBICONV="${LIBICONV}${LIBICONV:+ }$value" eval value=\"\$LTLIB$uppername\" test -z "$value" || LTLIBICONV="${LTLIBICONV}${LTLIBICONV:+ }$value" else : fi else found_dir= found_la= found_so= found_a= eval libname=\"$acl_libname_spec\" # typically: libname=lib$name if test -n "$acl_shlibext"; then shrext=".$acl_shlibext" # typically: shrext=.so else shrext= fi if test $use_additional = yes; then for additional_libdir_variable in additional_libdir additional_libdir2 additional_libdir3; do if test "X$found_dir" = "X"; then eval dir=\$$additional_libdir_variable if test -n "$dir"; then if test -n "$acl_shlibext"; then if test -f "$dir/$libname$shrext" && acl_is_expected_elfclass < "$dir/$libname$shrext"; then found_dir="$dir" found_so="$dir/$libname$shrext" else if test "$acl_library_names_spec" = '$libname$shrext$versuffix'; then ver=`(cd "$dir" && \ for f in "$libname$shrext".*; do echo "$f"; done \ | sed -e "s,^$libname$shrext\\\\.,," \ | sort -t '.' -n -r -k1,1 -k2,2 -k3,3 -k4,4 -k5,5 \ | sed 1q ) 2>/dev/null` if test -n "$ver" && test -f "$dir/$libname$shrext.$ver" && acl_is_expected_elfclass < "$dir/$libname$shrext.$ver"; then found_dir="$dir" found_so="$dir/$libname$shrext.$ver" fi else eval library_names=\"$acl_library_names_spec\" for f in $library_names; do if test -f "$dir/$f" && acl_is_expected_elfclass < "$dir/$f"; then found_dir="$dir" found_so="$dir/$f" break fi done fi fi fi if test "X$found_dir" = "X"; then if test -f "$dir/$libname.$acl_libext" && ${AR-ar} -p "$dir/$libname.$acl_libext" | acl_is_expected_elfclass; then found_dir="$dir" found_a="$dir/$libname.$acl_libext" fi fi if test "X$found_dir" != "X"; then if test -f "$dir/$libname.la"; then found_la="$dir/$libname.la" fi fi fi fi done fi if test "X$found_dir" = "X"; then for x in $LDFLAGS $LTLIBICONV; do acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval x=\"$x\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" case "$x" in -L*) dir=`echo "X$x" | sed -e 's/^X-L//'` if test -n "$acl_shlibext"; then if test -f "$dir/$libname$shrext" && acl_is_expected_elfclass < "$dir/$libname$shrext"; then found_dir="$dir" found_so="$dir/$libname$shrext" else if test "$acl_library_names_spec" = '$libname$shrext$versuffix'; then ver=`(cd "$dir" && \ for f in "$libname$shrext".*; do echo "$f"; done \ | sed -e "s,^$libname$shrext\\\\.,," \ | sort -t '.' -n -r -k1,1 -k2,2 -k3,3 -k4,4 -k5,5 \ | sed 1q ) 2>/dev/null` if test -n "$ver" && test -f "$dir/$libname$shrext.$ver" && acl_is_expected_elfclass < "$dir/$libname$shrext.$ver"; then found_dir="$dir" found_so="$dir/$libname$shrext.$ver" fi else eval library_names=\"$acl_library_names_spec\" for f in $library_names; do if test -f "$dir/$f" && acl_is_expected_elfclass < "$dir/$f"; then found_dir="$dir" found_so="$dir/$f" break fi done fi fi fi if test "X$found_dir" = "X"; then if test -f "$dir/$libname.$acl_libext" && ${AR-ar} -p "$dir/$libname.$acl_libext" | acl_is_expected_elfclass; then found_dir="$dir" found_a="$dir/$libname.$acl_libext" fi fi if test "X$found_dir" != "X"; then if test -f "$dir/$libname.la"; then found_la="$dir/$libname.la" fi fi ;; esac if test "X$found_dir" != "X"; then break fi done fi if test "X$found_dir" != "X"; then LTLIBICONV="${LTLIBICONV}${LTLIBICONV:+ }-L$found_dir -l$name" if test "X$found_so" != "X"; then if test "$enable_rpath" = no \ || test "X$found_dir" = "X/usr/$acl_libdirstem" \ || test "X$found_dir" = "X/usr/$acl_libdirstem2" \ || test "X$found_dir" = "X/usr/$acl_libdirstem3"; then LIBICONV="${LIBICONV}${LIBICONV:+ }$found_so" else haveit= for x in $ltrpathdirs; do if test "X$x" = "X$found_dir"; then haveit=yes break fi done if test -z "$haveit"; then ltrpathdirs="$ltrpathdirs $found_dir" fi if test "$acl_hardcode_direct" = yes; then LIBICONV="${LIBICONV}${LIBICONV:+ }$found_so" else if test -n "$acl_hardcode_libdir_flag_spec" && test "$acl_hardcode_minus_L" = no; then LIBICONV="${LIBICONV}${LIBICONV:+ }$found_so" haveit= for x in $rpathdirs; do if test "X$x" = "X$found_dir"; then haveit=yes break fi done if test -z "$haveit"; then rpathdirs="$rpathdirs $found_dir" fi else haveit= for x in $LDFLAGS $LIBICONV; do acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval x=\"$x\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" if test "X$x" = "X-L$found_dir"; then haveit=yes break fi done if test -z "$haveit"; then LIBICONV="${LIBICONV}${LIBICONV:+ }-L$found_dir" fi if test "$acl_hardcode_minus_L" != no; then LIBICONV="${LIBICONV}${LIBICONV:+ }$found_so" else LIBICONV="${LIBICONV}${LIBICONV:+ }-l$name" fi fi fi fi else if test "X$found_a" != "X"; then LIBICONV="${LIBICONV}${LIBICONV:+ }$found_a" else LIBICONV="${LIBICONV}${LIBICONV:+ }-L$found_dir -l$name" fi fi additional_includedir= case "$found_dir" in */$acl_libdirstem | */$acl_libdirstem/) basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e "s,/$acl_libdirstem/"'*$,,'` if test "$name" = 'iconv'; then LIBICONV_PREFIX="$basedir" fi additional_includedir="$basedir/include" ;; */$acl_libdirstem2 | */$acl_libdirstem2/) basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e "s,/$acl_libdirstem2/"'*$,,'` if test "$name" = 'iconv'; then LIBICONV_PREFIX="$basedir" fi additional_includedir="$basedir/include" ;; */$acl_libdirstem3 | */$acl_libdirstem3/) basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e "s,/$acl_libdirstem3/"'*$,,'` if test "$name" = 'iconv'; then LIBICONV_PREFIX="$basedir" fi additional_includedir="$basedir/include" ;; esac if test "X$additional_includedir" != "X"; then if test "X$additional_includedir" != "X/usr/include"; then haveit= if test "X$additional_includedir" = "X/usr/local/include"; then if test -n "$GCC"; then case $host_os in linux* | gnu* | k*bsd*-gnu) haveit=yes;; esac fi fi if test -z "$haveit"; then for x in $CPPFLAGS $INCICONV; do acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval x=\"$x\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" if test "X$x" = "X-I$additional_includedir"; then haveit=yes break fi done if test -z "$haveit"; then if test -d "$additional_includedir"; then INCICONV="${INCICONV}${INCICONV:+ }-I$additional_includedir" fi fi fi fi fi if test -n "$found_la"; then save_libdir="$libdir" case "$found_la" in */* | *\\*) . "$found_la" ;; *) . "./$found_la" ;; esac libdir="$save_libdir" for dep in $dependency_libs; do case "$dep" in -L*) dependency_libdir=`echo "X$dep" | sed -e 's/^X-L//'` if test "X$dependency_libdir" != "X/usr/$acl_libdirstem" \ && test "X$dependency_libdir" != "X/usr/$acl_libdirstem2" \ && test "X$dependency_libdir" != "X/usr/$acl_libdirstem3"; then haveit= if test "X$dependency_libdir" = "X/usr/local/$acl_libdirstem" \ || test "X$dependency_libdir" = "X/usr/local/$acl_libdirstem2" \ || test "X$dependency_libdir" = "X/usr/local/$acl_libdirstem3"; then if test -n "$GCC"; then case $host_os in linux* | gnu* | k*bsd*-gnu) haveit=yes;; esac fi fi if test -z "$haveit"; then haveit= for x in $LDFLAGS $LIBICONV; do acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval x=\"$x\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" if test "X$x" = "X-L$dependency_libdir"; then haveit=yes break fi done if test -z "$haveit"; then if test -d "$dependency_libdir"; then LIBICONV="${LIBICONV}${LIBICONV:+ }-L$dependency_libdir" fi fi haveit= for x in $LDFLAGS $LTLIBICONV; do acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval x=\"$x\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" if test "X$x" = "X-L$dependency_libdir"; then haveit=yes break fi done if test -z "$haveit"; then if test -d "$dependency_libdir"; then LTLIBICONV="${LTLIBICONV}${LTLIBICONV:+ }-L$dependency_libdir" fi fi fi fi ;; -R*) dir=`echo "X$dep" | sed -e 's/^X-R//'` if test "$enable_rpath" != no; then haveit= for x in $rpathdirs; do if test "X$x" = "X$dir"; then haveit=yes break fi done if test -z "$haveit"; then rpathdirs="$rpathdirs $dir" fi haveit= for x in $ltrpathdirs; do if test "X$x" = "X$dir"; then haveit=yes break fi done if test -z "$haveit"; then ltrpathdirs="$ltrpathdirs $dir" fi fi ;; -l*) names_next_round="$names_next_round "`echo "X$dep" | sed -e 's/^X-l//'` ;; *.la) names_next_round="$names_next_round "`echo "X$dep" | sed -e 's,^X.*/,,' -e 's,^lib,,' -e 's,\.la$,,'` ;; *) LIBICONV="${LIBICONV}${LIBICONV:+ }$dep" LTLIBICONV="${LTLIBICONV}${LTLIBICONV:+ }$dep" ;; esac done fi else LIBICONV="${LIBICONV}${LIBICONV:+ }-l$name" LTLIBICONV="${LTLIBICONV}${LTLIBICONV:+ }-l$name" fi fi fi done done if test "X$rpathdirs" != "X"; then if test -n "$acl_hardcode_libdir_separator"; then alldirs= for found_dir in $rpathdirs; do alldirs="${alldirs}${alldirs:+$acl_hardcode_libdir_separator}$found_dir" done acl_save_libdir="$libdir" libdir="$alldirs" eval flag=\"$acl_hardcode_libdir_flag_spec\" libdir="$acl_save_libdir" LIBICONV="${LIBICONV}${LIBICONV:+ }$flag" else for found_dir in $rpathdirs; do acl_save_libdir="$libdir" libdir="$found_dir" eval flag=\"$acl_hardcode_libdir_flag_spec\" libdir="$acl_save_libdir" LIBICONV="${LIBICONV}${LIBICONV:+ }$flag" done fi fi if test "X$ltrpathdirs" != "X"; then for found_dir in $ltrpathdirs; do LTLIBICONV="${LTLIBICONV}${LTLIBICONV:+ }-R$found_dir" done fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for CFPreferencesCopyAppValue" >&5 printf %s "checking for CFPreferencesCopyAppValue... " >&6; } if test ${gt_cv_func_CFPreferencesCopyAppValue+y} then : printf %s "(cached) " >&6 else $as_nop gt_save_LIBS="$LIBS" LIBS="$LIBS -Wl,-framework -Wl,CoreFoundation" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int main (void) { CFPreferencesCopyAppValue(NULL, NULL) ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : gt_cv_func_CFPreferencesCopyAppValue=yes else $as_nop gt_cv_func_CFPreferencesCopyAppValue=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS="$gt_save_LIBS" fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $gt_cv_func_CFPreferencesCopyAppValue" >&5 printf "%s\n" "$gt_cv_func_CFPreferencesCopyAppValue" >&6; } if test $gt_cv_func_CFPreferencesCopyAppValue = yes; then printf "%s\n" "#define HAVE_CFPREFERENCESCOPYAPPVALUE 1" >>confdefs.h fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for CFLocaleCopyPreferredLanguages" >&5 printf %s "checking for CFLocaleCopyPreferredLanguages... " >&6; } if test ${gt_cv_func_CFLocaleCopyPreferredLanguages+y} then : printf %s "(cached) " >&6 else $as_nop gt_save_LIBS="$LIBS" LIBS="$LIBS -Wl,-framework -Wl,CoreFoundation" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int main (void) { CFLocaleCopyPreferredLanguages(); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : gt_cv_func_CFLocaleCopyPreferredLanguages=yes else $as_nop gt_cv_func_CFLocaleCopyPreferredLanguages=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS="$gt_save_LIBS" fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $gt_cv_func_CFLocaleCopyPreferredLanguages" >&5 printf "%s\n" "$gt_cv_func_CFLocaleCopyPreferredLanguages" >&6; } if test $gt_cv_func_CFLocaleCopyPreferredLanguages = yes; then printf "%s\n" "#define HAVE_CFLOCALECOPYPREFERREDLANGUAGES 1" >>confdefs.h fi INTL_MACOSX_LIBS= if test $gt_cv_func_CFPreferencesCopyAppValue = yes \ || test $gt_cv_func_CFLocaleCopyPreferredLanguages = yes; then INTL_MACOSX_LIBS="-Wl,-framework -Wl,CoreFoundation" fi LIBINTL= LTLIBINTL= POSUB= case " $gt_needs " in *" need-formatstring-macros "*) gt_api_version=3 ;; *" need-ngettext "*) gt_api_version=2 ;; *) gt_api_version=1 ;; esac gt_func_gnugettext_libc="gt_cv_func_gnugettext${gt_api_version}_libc" gt_func_gnugettext_libintl="gt_cv_func_gnugettext${gt_api_version}_libintl" if test "$USE_NLS" = "yes"; then gt_use_preinstalled_gnugettext=no if test $gt_api_version -ge 3; then gt_revision_test_code=' #ifndef __GNU_GETTEXT_SUPPORTED_REVISION #define __GNU_GETTEXT_SUPPORTED_REVISION(major) ((major) == 0 ? 0 : -1) #endif typedef int array [2 * (__GNU_GETTEXT_SUPPORTED_REVISION(0) >= 1) - 1]; ' else gt_revision_test_code= fi if test $gt_api_version -ge 2; then gt_expression_test_code=' + * ngettext ("", "", 0)' else gt_expression_test_code= fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for GNU gettext in libc" >&5 printf %s "checking for GNU gettext in libc... " >&6; } if eval test \${$gt_func_gnugettext_libc+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #ifndef __GNU_GETTEXT_SUPPORTED_REVISION extern int _nl_msg_cat_cntr; extern int *_nl_domain_bindings; #define __GNU_GETTEXT_SYMBOL_EXPRESSION (_nl_msg_cat_cntr + *_nl_domain_bindings) #else #define __GNU_GETTEXT_SYMBOL_EXPRESSION 0 #endif $gt_revision_test_code int main (void) { bindtextdomain ("", ""); return * gettext ("")$gt_expression_test_code + __GNU_GETTEXT_SYMBOL_EXPRESSION ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : eval "$gt_func_gnugettext_libc=yes" else $as_nop eval "$gt_func_gnugettext_libc=no" fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext fi eval ac_res=\$$gt_func_gnugettext_libc { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 printf "%s\n" "$ac_res" >&6; } if { eval "gt_val=\$$gt_func_gnugettext_libc"; test "$gt_val" != "yes"; }; then am_save_CPPFLAGS="$CPPFLAGS" for element in $INCICONV; do haveit= for x in $CPPFLAGS; do acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval x=\"$x\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" if test "X$x" = "X$element"; then haveit=yes break fi done if test -z "$haveit"; then CPPFLAGS="${CPPFLAGS}${CPPFLAGS:+ }$element" fi done { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for iconv" >&5 printf %s "checking for iconv... " >&6; } if test ${am_cv_func_iconv+y} then : printf %s "(cached) " >&6 else $as_nop am_cv_func_iconv="no, consider installing GNU libiconv" am_cv_lib_iconv=no cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include int main (void) { iconv_t cd = iconv_open("",""); iconv(cd,NULL,NULL,NULL,NULL); iconv_close(cd); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : am_cv_func_iconv=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext if test "$am_cv_func_iconv" != yes; then am_save_LIBS="$LIBS" LIBS="$LIBS $LIBICONV" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include int main (void) { iconv_t cd = iconv_open("",""); iconv(cd,NULL,NULL,NULL,NULL); iconv_close(cd); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : am_cv_lib_iconv=yes am_cv_func_iconv=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS="$am_save_LIBS" fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $am_cv_func_iconv" >&5 printf "%s\n" "$am_cv_func_iconv" >&6; } if test "$am_cv_func_iconv" = yes; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for working iconv" >&5 printf %s "checking for working iconv... " >&6; } if test ${am_cv_func_iconv_works+y} then : printf %s "(cached) " >&6 else $as_nop am_save_LIBS="$LIBS" if test $am_cv_lib_iconv = yes; then LIBS="$LIBS $LIBICONV" fi am_cv_func_iconv_works=no for ac_iconv_const in '' 'const'; do if test "$cross_compiling" = yes then : case "$host_os" in aix* | hpux*) am_cv_func_iconv_works="guessing no" ;; *) am_cv_func_iconv_works="guessing yes" ;; esac else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include #ifndef ICONV_CONST # define ICONV_CONST $ac_iconv_const #endif int main (void) { int result = 0; /* Test against AIX 5.1 bug: Failures are not distinguishable from successful returns. */ { iconv_t cd_utf8_to_88591 = iconv_open ("ISO8859-1", "UTF-8"); if (cd_utf8_to_88591 != (iconv_t)(-1)) { static ICONV_CONST char input[] = "\342\202\254"; /* EURO SIGN */ char buf[10]; ICONV_CONST char *inptr = input; size_t inbytesleft = strlen (input); char *outptr = buf; size_t outbytesleft = sizeof (buf); size_t res = iconv (cd_utf8_to_88591, &inptr, &inbytesleft, &outptr, &outbytesleft); if (res == 0) result |= 1; iconv_close (cd_utf8_to_88591); } } /* Test against Solaris 10 bug: Failures are not distinguishable from successful returns. */ { iconv_t cd_ascii_to_88591 = iconv_open ("ISO8859-1", "646"); if (cd_ascii_to_88591 != (iconv_t)(-1)) { static ICONV_CONST char input[] = "\263"; char buf[10]; ICONV_CONST char *inptr = input; size_t inbytesleft = strlen (input); char *outptr = buf; size_t outbytesleft = sizeof (buf); size_t res = iconv (cd_ascii_to_88591, &inptr, &inbytesleft, &outptr, &outbytesleft); if (res == 0) result |= 2; iconv_close (cd_ascii_to_88591); } } /* Test against AIX 6.1..7.1 bug: Buffer overrun. */ { iconv_t cd_88591_to_utf8 = iconv_open ("UTF-8", "ISO-8859-1"); if (cd_88591_to_utf8 != (iconv_t)(-1)) { static ICONV_CONST char input[] = "\304"; static char buf[2] = { (char)0xDE, (char)0xAD }; ICONV_CONST char *inptr = input; size_t inbytesleft = 1; char *outptr = buf; size_t outbytesleft = 1; size_t res = iconv (cd_88591_to_utf8, &inptr, &inbytesleft, &outptr, &outbytesleft); if (res != (size_t)(-1) || outptr - buf > 1 || buf[1] != (char)0xAD) result |= 4; iconv_close (cd_88591_to_utf8); } } #if 0 /* This bug could be worked around by the caller. */ /* Test against HP-UX 11.11 bug: Positive return value instead of 0. */ { iconv_t cd_88591_to_utf8 = iconv_open ("utf8", "iso88591"); if (cd_88591_to_utf8 != (iconv_t)(-1)) { static ICONV_CONST char input[] = "\304rger mit b\366sen B\374bchen ohne Augenma\337"; char buf[50]; ICONV_CONST char *inptr = input; size_t inbytesleft = strlen (input); char *outptr = buf; size_t outbytesleft = sizeof (buf); size_t res = iconv (cd_88591_to_utf8, &inptr, &inbytesleft, &outptr, &outbytesleft); if ((int)res > 0) result |= 8; iconv_close (cd_88591_to_utf8); } } #endif /* Test against HP-UX 11.11 bug: No converter from EUC-JP to UTF-8 is provided. */ { /* Try standardized names. */ iconv_t cd1 = iconv_open ("UTF-8", "EUC-JP"); /* Try IRIX, OSF/1 names. */ iconv_t cd2 = iconv_open ("UTF-8", "eucJP"); /* Try AIX names. */ iconv_t cd3 = iconv_open ("UTF-8", "IBM-eucJP"); /* Try HP-UX names. */ iconv_t cd4 = iconv_open ("utf8", "eucJP"); if (cd1 == (iconv_t)(-1) && cd2 == (iconv_t)(-1) && cd3 == (iconv_t)(-1) && cd4 == (iconv_t)(-1)) result |= 16; if (cd1 != (iconv_t)(-1)) iconv_close (cd1); if (cd2 != (iconv_t)(-1)) iconv_close (cd2); if (cd3 != (iconv_t)(-1)) iconv_close (cd3); if (cd4 != (iconv_t)(-1)) iconv_close (cd4); } return result; ; return 0; } _ACEOF if ac_fn_c_try_run "$LINENO" then : am_cv_func_iconv_works=yes fi rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ conftest.$ac_objext conftest.beam conftest.$ac_ext fi test "$am_cv_func_iconv_works" = no || break done LIBS="$am_save_LIBS" fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $am_cv_func_iconv_works" >&5 printf "%s\n" "$am_cv_func_iconv_works" >&6; } case "$am_cv_func_iconv_works" in *no) am_func_iconv=no am_cv_lib_iconv=no ;; *) am_func_iconv=yes ;; esac else am_func_iconv=no am_cv_lib_iconv=no fi if test "$am_func_iconv" = yes; then printf "%s\n" "#define HAVE_ICONV 1" >>confdefs.h fi if test "$am_cv_lib_iconv" = yes; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking how to link with libiconv" >&5 printf %s "checking how to link with libiconv... " >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $LIBICONV" >&5 printf "%s\n" "$LIBICONV" >&6; } else CPPFLAGS="$am_save_CPPFLAGS" LIBICONV= LTLIBICONV= fi use_additional=yes acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval additional_includedir=\"$includedir\" eval additional_libdir=\"$libdir\" eval additional_libdir2=\"$exec_prefix/$acl_libdirstem2\" eval additional_libdir3=\"$exec_prefix/$acl_libdirstem3\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" # Check whether --with-libintl-prefix was given. if test ${with_libintl_prefix+y} then : withval=$with_libintl_prefix; if test "X$withval" = "Xno"; then use_additional=no else if test "X$withval" = "X"; then acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval additional_includedir=\"$includedir\" eval additional_libdir=\"$libdir\" eval additional_libdir2=\"$exec_prefix/$acl_libdirstem2\" eval additional_libdir3=\"$exec_prefix/$acl_libdirstem3\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" else additional_includedir="$withval/include" additional_libdir="$withval/$acl_libdirstem" additional_libdir2="$withval/$acl_libdirstem2" additional_libdir3="$withval/$acl_libdirstem3" fi fi fi if test "X$additional_libdir2" = "X$additional_libdir"; then additional_libdir2= fi if test "X$additional_libdir3" = "X$additional_libdir"; then additional_libdir3= fi LIBINTL= LTLIBINTL= INCINTL= LIBINTL_PREFIX= HAVE_LIBINTL= rpathdirs= ltrpathdirs= names_already_handled= names_next_round='intl ' while test -n "$names_next_round"; do names_this_round="$names_next_round" names_next_round= for name in $names_this_round; do already_handled= for n in $names_already_handled; do if test "$n" = "$name"; then already_handled=yes break fi done if test -z "$already_handled"; then names_already_handled="$names_already_handled $name" uppername=`echo "$name" | sed -e 'y|abcdefghijklmnopqrstuvwxyz./+-|ABCDEFGHIJKLMNOPQRSTUVWXYZ____|'` eval value=\"\$HAVE_LIB$uppername\" if test -n "$value"; then if test "$value" = yes; then eval value=\"\$LIB$uppername\" test -z "$value" || LIBINTL="${LIBINTL}${LIBINTL:+ }$value" eval value=\"\$LTLIB$uppername\" test -z "$value" || LTLIBINTL="${LTLIBINTL}${LTLIBINTL:+ }$value" else : fi else found_dir= found_la= found_so= found_a= eval libname=\"$acl_libname_spec\" # typically: libname=lib$name if test -n "$acl_shlibext"; then shrext=".$acl_shlibext" # typically: shrext=.so else shrext= fi if test $use_additional = yes; then for additional_libdir_variable in additional_libdir additional_libdir2 additional_libdir3; do if test "X$found_dir" = "X"; then eval dir=\$$additional_libdir_variable if test -n "$dir"; then if test -n "$acl_shlibext"; then if test -f "$dir/$libname$shrext" && acl_is_expected_elfclass < "$dir/$libname$shrext"; then found_dir="$dir" found_so="$dir/$libname$shrext" else if test "$acl_library_names_spec" = '$libname$shrext$versuffix'; then ver=`(cd "$dir" && \ for f in "$libname$shrext".*; do echo "$f"; done \ | sed -e "s,^$libname$shrext\\\\.,," \ | sort -t '.' -n -r -k1,1 -k2,2 -k3,3 -k4,4 -k5,5 \ | sed 1q ) 2>/dev/null` if test -n "$ver" && test -f "$dir/$libname$shrext.$ver" && acl_is_expected_elfclass < "$dir/$libname$shrext.$ver"; then found_dir="$dir" found_so="$dir/$libname$shrext.$ver" fi else eval library_names=\"$acl_library_names_spec\" for f in $library_names; do if test -f "$dir/$f" && acl_is_expected_elfclass < "$dir/$f"; then found_dir="$dir" found_so="$dir/$f" break fi done fi fi fi if test "X$found_dir" = "X"; then if test -f "$dir/$libname.$acl_libext" && ${AR-ar} -p "$dir/$libname.$acl_libext" | acl_is_expected_elfclass; then found_dir="$dir" found_a="$dir/$libname.$acl_libext" fi fi if test "X$found_dir" != "X"; then if test -f "$dir/$libname.la"; then found_la="$dir/$libname.la" fi fi fi fi done fi if test "X$found_dir" = "X"; then for x in $LDFLAGS $LTLIBINTL; do acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval x=\"$x\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" case "$x" in -L*) dir=`echo "X$x" | sed -e 's/^X-L//'` if test -n "$acl_shlibext"; then if test -f "$dir/$libname$shrext" && acl_is_expected_elfclass < "$dir/$libname$shrext"; then found_dir="$dir" found_so="$dir/$libname$shrext" else if test "$acl_library_names_spec" = '$libname$shrext$versuffix'; then ver=`(cd "$dir" && \ for f in "$libname$shrext".*; do echo "$f"; done \ | sed -e "s,^$libname$shrext\\\\.,," \ | sort -t '.' -n -r -k1,1 -k2,2 -k3,3 -k4,4 -k5,5 \ | sed 1q ) 2>/dev/null` if test -n "$ver" && test -f "$dir/$libname$shrext.$ver" && acl_is_expected_elfclass < "$dir/$libname$shrext.$ver"; then found_dir="$dir" found_so="$dir/$libname$shrext.$ver" fi else eval library_names=\"$acl_library_names_spec\" for f in $library_names; do if test -f "$dir/$f" && acl_is_expected_elfclass < "$dir/$f"; then found_dir="$dir" found_so="$dir/$f" break fi done fi fi fi if test "X$found_dir" = "X"; then if test -f "$dir/$libname.$acl_libext" && ${AR-ar} -p "$dir/$libname.$acl_libext" | acl_is_expected_elfclass; then found_dir="$dir" found_a="$dir/$libname.$acl_libext" fi fi if test "X$found_dir" != "X"; then if test -f "$dir/$libname.la"; then found_la="$dir/$libname.la" fi fi ;; esac if test "X$found_dir" != "X"; then break fi done fi if test "X$found_dir" != "X"; then LTLIBINTL="${LTLIBINTL}${LTLIBINTL:+ }-L$found_dir -l$name" if test "X$found_so" != "X"; then if test "$enable_rpath" = no \ || test "X$found_dir" = "X/usr/$acl_libdirstem" \ || test "X$found_dir" = "X/usr/$acl_libdirstem2" \ || test "X$found_dir" = "X/usr/$acl_libdirstem3"; then LIBINTL="${LIBINTL}${LIBINTL:+ }$found_so" else haveit= for x in $ltrpathdirs; do if test "X$x" = "X$found_dir"; then haveit=yes break fi done if test -z "$haveit"; then ltrpathdirs="$ltrpathdirs $found_dir" fi if test "$acl_hardcode_direct" = yes; then LIBINTL="${LIBINTL}${LIBINTL:+ }$found_so" else if test -n "$acl_hardcode_libdir_flag_spec" && test "$acl_hardcode_minus_L" = no; then LIBINTL="${LIBINTL}${LIBINTL:+ }$found_so" haveit= for x in $rpathdirs; do if test "X$x" = "X$found_dir"; then haveit=yes break fi done if test -z "$haveit"; then rpathdirs="$rpathdirs $found_dir" fi else haveit= for x in $LDFLAGS $LIBINTL; do acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval x=\"$x\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" if test "X$x" = "X-L$found_dir"; then haveit=yes break fi done if test -z "$haveit"; then LIBINTL="${LIBINTL}${LIBINTL:+ }-L$found_dir" fi if test "$acl_hardcode_minus_L" != no; then LIBINTL="${LIBINTL}${LIBINTL:+ }$found_so" else LIBINTL="${LIBINTL}${LIBINTL:+ }-l$name" fi fi fi fi else if test "X$found_a" != "X"; then LIBINTL="${LIBINTL}${LIBINTL:+ }$found_a" else LIBINTL="${LIBINTL}${LIBINTL:+ }-L$found_dir -l$name" fi fi additional_includedir= case "$found_dir" in */$acl_libdirstem | */$acl_libdirstem/) basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e "s,/$acl_libdirstem/"'*$,,'` if test "$name" = 'intl'; then LIBINTL_PREFIX="$basedir" fi additional_includedir="$basedir/include" ;; */$acl_libdirstem2 | */$acl_libdirstem2/) basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e "s,/$acl_libdirstem2/"'*$,,'` if test "$name" = 'intl'; then LIBINTL_PREFIX="$basedir" fi additional_includedir="$basedir/include" ;; */$acl_libdirstem3 | */$acl_libdirstem3/) basedir=`echo "X$found_dir" | sed -e 's,^X,,' -e "s,/$acl_libdirstem3/"'*$,,'` if test "$name" = 'intl'; then LIBINTL_PREFIX="$basedir" fi additional_includedir="$basedir/include" ;; esac if test "X$additional_includedir" != "X"; then if test "X$additional_includedir" != "X/usr/include"; then haveit= if test "X$additional_includedir" = "X/usr/local/include"; then if test -n "$GCC"; then case $host_os in linux* | gnu* | k*bsd*-gnu) haveit=yes;; esac fi fi if test -z "$haveit"; then for x in $CPPFLAGS $INCINTL; do acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval x=\"$x\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" if test "X$x" = "X-I$additional_includedir"; then haveit=yes break fi done if test -z "$haveit"; then if test -d "$additional_includedir"; then INCINTL="${INCINTL}${INCINTL:+ }-I$additional_includedir" fi fi fi fi fi if test -n "$found_la"; then save_libdir="$libdir" case "$found_la" in */* | *\\*) . "$found_la" ;; *) . "./$found_la" ;; esac libdir="$save_libdir" for dep in $dependency_libs; do case "$dep" in -L*) dependency_libdir=`echo "X$dep" | sed -e 's/^X-L//'` if test "X$dependency_libdir" != "X/usr/$acl_libdirstem" \ && test "X$dependency_libdir" != "X/usr/$acl_libdirstem2" \ && test "X$dependency_libdir" != "X/usr/$acl_libdirstem3"; then haveit= if test "X$dependency_libdir" = "X/usr/local/$acl_libdirstem" \ || test "X$dependency_libdir" = "X/usr/local/$acl_libdirstem2" \ || test "X$dependency_libdir" = "X/usr/local/$acl_libdirstem3"; then if test -n "$GCC"; then case $host_os in linux* | gnu* | k*bsd*-gnu) haveit=yes;; esac fi fi if test -z "$haveit"; then haveit= for x in $LDFLAGS $LIBINTL; do acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval x=\"$x\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" if test "X$x" = "X-L$dependency_libdir"; then haveit=yes break fi done if test -z "$haveit"; then if test -d "$dependency_libdir"; then LIBINTL="${LIBINTL}${LIBINTL:+ }-L$dependency_libdir" fi fi haveit= for x in $LDFLAGS $LTLIBINTL; do acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval x=\"$x\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" if test "X$x" = "X-L$dependency_libdir"; then haveit=yes break fi done if test -z "$haveit"; then if test -d "$dependency_libdir"; then LTLIBINTL="${LTLIBINTL}${LTLIBINTL:+ }-L$dependency_libdir" fi fi fi fi ;; -R*) dir=`echo "X$dep" | sed -e 's/^X-R//'` if test "$enable_rpath" != no; then haveit= for x in $rpathdirs; do if test "X$x" = "X$dir"; then haveit=yes break fi done if test -z "$haveit"; then rpathdirs="$rpathdirs $dir" fi haveit= for x in $ltrpathdirs; do if test "X$x" = "X$dir"; then haveit=yes break fi done if test -z "$haveit"; then ltrpathdirs="$ltrpathdirs $dir" fi fi ;; -l*) names_next_round="$names_next_round "`echo "X$dep" | sed -e 's/^X-l//'` ;; *.la) names_next_round="$names_next_round "`echo "X$dep" | sed -e 's,^X.*/,,' -e 's,^lib,,' -e 's,\.la$,,'` ;; *) LIBINTL="${LIBINTL}${LIBINTL:+ }$dep" LTLIBINTL="${LTLIBINTL}${LTLIBINTL:+ }$dep" ;; esac done fi else LIBINTL="${LIBINTL}${LIBINTL:+ }-l$name" LTLIBINTL="${LTLIBINTL}${LTLIBINTL:+ }-l$name" fi fi fi done done if test "X$rpathdirs" != "X"; then if test -n "$acl_hardcode_libdir_separator"; then alldirs= for found_dir in $rpathdirs; do alldirs="${alldirs}${alldirs:+$acl_hardcode_libdir_separator}$found_dir" done acl_save_libdir="$libdir" libdir="$alldirs" eval flag=\"$acl_hardcode_libdir_flag_spec\" libdir="$acl_save_libdir" LIBINTL="${LIBINTL}${LIBINTL:+ }$flag" else for found_dir in $rpathdirs; do acl_save_libdir="$libdir" libdir="$found_dir" eval flag=\"$acl_hardcode_libdir_flag_spec\" libdir="$acl_save_libdir" LIBINTL="${LIBINTL}${LIBINTL:+ }$flag" done fi fi if test "X$ltrpathdirs" != "X"; then for found_dir in $ltrpathdirs; do LTLIBINTL="${LTLIBINTL}${LTLIBINTL:+ }-R$found_dir" done fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for GNU gettext in libintl" >&5 printf %s "checking for GNU gettext in libintl... " >&6; } if eval test \${$gt_func_gnugettext_libintl+y} then : printf %s "(cached) " >&6 else $as_nop gt_save_CPPFLAGS="$CPPFLAGS" CPPFLAGS="$CPPFLAGS $INCINTL" gt_save_LIBS="$LIBS" LIBS="$LIBS $LIBINTL" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #ifndef __GNU_GETTEXT_SUPPORTED_REVISION extern int _nl_msg_cat_cntr; extern #ifdef __cplusplus "C" #endif const char *_nl_expand_alias (const char *); #define __GNU_GETTEXT_SYMBOL_EXPRESSION (_nl_msg_cat_cntr + *_nl_expand_alias ("")) #else #define __GNU_GETTEXT_SYMBOL_EXPRESSION 0 #endif $gt_revision_test_code int main (void) { bindtextdomain ("", ""); return * gettext ("")$gt_expression_test_code + __GNU_GETTEXT_SYMBOL_EXPRESSION ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : eval "$gt_func_gnugettext_libintl=yes" else $as_nop eval "$gt_func_gnugettext_libintl=no" fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext if { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" != yes; } && test -n "$LIBICONV"; then LIBS="$LIBS $LIBICONV" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #ifndef __GNU_GETTEXT_SUPPORTED_REVISION extern int _nl_msg_cat_cntr; extern #ifdef __cplusplus "C" #endif const char *_nl_expand_alias (const char *); #define __GNU_GETTEXT_SYMBOL_EXPRESSION (_nl_msg_cat_cntr + *_nl_expand_alias ("")) #else #define __GNU_GETTEXT_SYMBOL_EXPRESSION 0 #endif $gt_revision_test_code int main (void) { bindtextdomain ("", ""); return * gettext ("")$gt_expression_test_code + __GNU_GETTEXT_SYMBOL_EXPRESSION ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : LIBINTL="$LIBINTL $LIBICONV" LTLIBINTL="$LTLIBINTL $LTLIBICONV" eval "$gt_func_gnugettext_libintl=yes" fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext fi CPPFLAGS="$gt_save_CPPFLAGS" LIBS="$gt_save_LIBS" fi eval ac_res=\$$gt_func_gnugettext_libintl { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_res" >&5 printf "%s\n" "$ac_res" >&6; } fi if { eval "gt_val=\$$gt_func_gnugettext_libc"; test "$gt_val" = "yes"; } \ || { { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" = "yes"; } \ && test "$PACKAGE" != gettext-runtime \ && test "$PACKAGE" != gettext-tools; }; then gt_use_preinstalled_gnugettext=yes else LIBINTL= LTLIBINTL= INCINTL= fi if test -n "$INTL_MACOSX_LIBS"; then if test "$gt_use_preinstalled_gnugettext" = "yes" \ || test "$nls_cv_use_gnu_gettext" = "yes"; then LIBINTL="$LIBINTL $INTL_MACOSX_LIBS" LTLIBINTL="$LTLIBINTL $INTL_MACOSX_LIBS" fi fi if test "$gt_use_preinstalled_gnugettext" = "yes" \ || test "$nls_cv_use_gnu_gettext" = "yes"; then printf "%s\n" "#define ENABLE_NLS 1" >>confdefs.h else USE_NLS=no fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether to use NLS" >&5 printf %s "checking whether to use NLS... " >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $USE_NLS" >&5 printf "%s\n" "$USE_NLS" >&6; } if test "$USE_NLS" = "yes"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking where the gettext function comes from" >&5 printf %s "checking where the gettext function comes from... " >&6; } if test "$gt_use_preinstalled_gnugettext" = "yes"; then if { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" = "yes"; }; then gt_source="external libintl" else gt_source="libc" fi else gt_source="included intl directory" fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $gt_source" >&5 printf "%s\n" "$gt_source" >&6; } fi if test "$USE_NLS" = "yes"; then if test "$gt_use_preinstalled_gnugettext" = "yes"; then if { eval "gt_val=\$$gt_func_gnugettext_libintl"; test "$gt_val" = "yes"; }; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking how to link with libintl" >&5 printf %s "checking how to link with libintl... " >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $LIBINTL" >&5 printf "%s\n" "$LIBINTL" >&6; } for element in $INCINTL; do haveit= for x in $CPPFLAGS; do acl_save_prefix="$prefix" prefix="$acl_final_prefix" acl_save_exec_prefix="$exec_prefix" exec_prefix="$acl_final_exec_prefix" eval x=\"$x\" exec_prefix="$acl_save_exec_prefix" prefix="$acl_save_prefix" if test "X$x" = "X$element"; then haveit=yes break fi done if test -z "$haveit"; then CPPFLAGS="${CPPFLAGS}${CPPFLAGS:+ }$element" fi done fi printf "%s\n" "#define HAVE_GETTEXT 1" >>confdefs.h printf "%s\n" "#define HAVE_DCGETTEXT 1" >>confdefs.h fi POSUB=po fi INTLLIBS="$LIBINTL" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for an ANSI C-conforming const" >&5 printf %s "checking for an ANSI C-conforming const... " >&6; } if test ${ac_cv_c_const+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { #ifndef __cplusplus /* Ultrix mips cc rejects this sort of thing. */ typedef int charset[2]; const charset cs = { 0, 0 }; /* SunOS 4.1.1 cc rejects this. */ char const *const *pcpcc; char **ppc; /* NEC SVR4.0.2 mips cc rejects this. */ struct point {int x, y;}; static struct point const zero = {0,0}; /* IBM XL C 1.02.0.0 rejects this. It does not let you subtract one const X* pointer from another in an arm of an if-expression whose if-part is not a constant expression */ const char *g = "string"; pcpcc = &g + (g ? g-g : 0); /* HPUX 7.0 cc rejects these. */ ++pcpcc; ppc = (char**) pcpcc; pcpcc = (char const *const *) ppc; { /* SCO 3.2v4 cc rejects this sort of thing. */ char tx; char *t = &tx; char const *s = 0 ? (char *) 0 : (char const *) 0; *t++ = 0; if (s) return 0; } { /* Someone thinks the Sun supposedly-ANSI compiler will reject this. */ int x[] = {25, 17}; const int *foo = &x[0]; ++foo; } { /* Sun SC1.0 ANSI compiler rejects this -- but not the above. */ typedef const int *iptr; iptr p = 0; ++p; } { /* IBM XL C 1.02.0.0 rejects this sort of thing, saying "k.c", line 2.27: 1506-025 (S) Operand must be a modifiable lvalue. */ struct s { int j; const int *ap[3]; } bx; struct s *b = &bx; b->j = 5; } { /* ULTRIX-32 V3.1 (Rev 9) vcc rejects this */ const int foo = 10; if (!foo) return 0; } return !cs[0] && !zero.x; #endif ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_cv_c_const=yes else $as_nop ac_cv_c_const=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_const" >&5 printf "%s\n" "$ac_cv_c_const" >&6; } if test $ac_cv_c_const = no; then printf "%s\n" "#define const /**/" >>confdefs.h fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for working volatile" >&5 printf %s "checking for working volatile... " >&6; } if test ${ac_cv_c_volatile+y} then : printf %s "(cached) " >&6 else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { volatile int x; int * volatile y = (int *) 0; return !x && !y; ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_cv_c_volatile=yes else $as_nop ac_cv_c_volatile=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_volatile" >&5 printf "%s\n" "$ac_cv_c_volatile" >&6; } if test $ac_cv_c_volatile = no; then printf "%s\n" "#define volatile /**/" >>confdefs.h fi # Check whether --enable-largefile was given. if test ${enable_largefile+y} then : enableval=$enable_largefile; fi if test "$enable_largefile" != no; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for special C compiler options needed for large files" >&5 printf %s "checking for special C compiler options needed for large files... " >&6; } if test ${ac_cv_sys_largefile_CC+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_sys_largefile_CC=no if test "$GCC" != yes; then ac_save_CC=$CC while :; do # IRIX 6.2 and later do not support large files by default, # so use the C compiler's -n32 option if that helps. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include /* Check that off_t can represent 2**63 - 1 correctly. We can't simply define LARGE_OFF_T to be 9223372036854775807, since some C++ compilers masquerading as C compilers incorrectly reject 9223372036854775807. */ #define LARGE_OFF_T (((off_t) 1 << 31 << 31) - 1 + ((off_t) 1 << 31 << 31)) int off_t_is_large[(LARGE_OFF_T % 2147483629 == 721 && LARGE_OFF_T % 2147483647 == 1) ? 1 : -1]; int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : break fi rm -f core conftest.err conftest.$ac_objext conftest.beam CC="$CC -n32" if ac_fn_c_try_compile "$LINENO" then : ac_cv_sys_largefile_CC=' -n32'; break fi rm -f core conftest.err conftest.$ac_objext conftest.beam break done CC=$ac_save_CC rm -f conftest.$ac_ext fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_sys_largefile_CC" >&5 printf "%s\n" "$ac_cv_sys_largefile_CC" >&6; } if test "$ac_cv_sys_largefile_CC" != no; then CC=$CC$ac_cv_sys_largefile_CC fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for _FILE_OFFSET_BITS value needed for large files" >&5 printf %s "checking for _FILE_OFFSET_BITS value needed for large files... " >&6; } if test ${ac_cv_sys_file_offset_bits+y} then : printf %s "(cached) " >&6 else $as_nop while :; do cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include /* Check that off_t can represent 2**63 - 1 correctly. We can't simply define LARGE_OFF_T to be 9223372036854775807, since some C++ compilers masquerading as C compilers incorrectly reject 9223372036854775807. */ #define LARGE_OFF_T (((off_t) 1 << 31 << 31) - 1 + ((off_t) 1 << 31 << 31)) int off_t_is_large[(LARGE_OFF_T % 2147483629 == 721 && LARGE_OFF_T % 2147483647 == 1) ? 1 : -1]; int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_cv_sys_file_offset_bits=no; break fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #define _FILE_OFFSET_BITS 64 #include /* Check that off_t can represent 2**63 - 1 correctly. We can't simply define LARGE_OFF_T to be 9223372036854775807, since some C++ compilers masquerading as C compilers incorrectly reject 9223372036854775807. */ #define LARGE_OFF_T (((off_t) 1 << 31 << 31) - 1 + ((off_t) 1 << 31 << 31)) int off_t_is_large[(LARGE_OFF_T % 2147483629 == 721 && LARGE_OFF_T % 2147483647 == 1) ? 1 : -1]; int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_cv_sys_file_offset_bits=64; break fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ac_cv_sys_file_offset_bits=unknown break done fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_sys_file_offset_bits" >&5 printf "%s\n" "$ac_cv_sys_file_offset_bits" >&6; } case $ac_cv_sys_file_offset_bits in #( no | unknown) ;; *) printf "%s\n" "#define _FILE_OFFSET_BITS $ac_cv_sys_file_offset_bits" >>confdefs.h ;; esac rm -rf conftest* if test $ac_cv_sys_file_offset_bits = unknown; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for _LARGE_FILES value needed for large files" >&5 printf %s "checking for _LARGE_FILES value needed for large files... " >&6; } if test ${ac_cv_sys_large_files+y} then : printf %s "(cached) " >&6 else $as_nop while :; do cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include /* Check that off_t can represent 2**63 - 1 correctly. We can't simply define LARGE_OFF_T to be 9223372036854775807, since some C++ compilers masquerading as C compilers incorrectly reject 9223372036854775807. */ #define LARGE_OFF_T (((off_t) 1 << 31 << 31) - 1 + ((off_t) 1 << 31 << 31)) int off_t_is_large[(LARGE_OFF_T % 2147483629 == 721 && LARGE_OFF_T % 2147483647 == 1) ? 1 : -1]; int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_cv_sys_large_files=no; break fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #define _LARGE_FILES 1 #include /* Check that off_t can represent 2**63 - 1 correctly. We can't simply define LARGE_OFF_T to be 9223372036854775807, since some C++ compilers masquerading as C compilers incorrectly reject 9223372036854775807. */ #define LARGE_OFF_T (((off_t) 1 << 31 << 31) - 1 + ((off_t) 1 << 31 << 31)) int off_t_is_large[(LARGE_OFF_T % 2147483629 == 721 && LARGE_OFF_T % 2147483647 == 1) ? 1 : -1]; int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_cv_sys_large_files=1; break fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext ac_cv_sys_large_files=unknown break done fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_sys_large_files" >&5 printf "%s\n" "$ac_cv_sys_large_files" >&6; } case $ac_cv_sys_large_files in #( no | unknown) ;; *) printf "%s\n" "#define _LARGE_FILES $ac_cv_sys_large_files" >>confdefs.h ;; esac rm -rf conftest* fi fi # Check whether --enable-shared-libs was given. if test ${enable_shared_libs+y} then : enableval=$enable_shared_libs; ac_cv_enable_shared_libs=$enableval else $as_nop ac_cv_enable_shared_libs="yes" fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether to disable disable shared library support" >&5 printf %s "checking whether to disable disable shared library support... " >&6; } if test ${ac_cv_enable_shared_libs+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_enable_shared_libs="yes" fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_enable_shared_libs" >&5 printf "%s\n" "$ac_cv_enable_shared_libs" >&6; } # Check whether --enable-winapi was given. if test ${enable_winapi+y} then : enableval=$enable_winapi; ac_cv_enable_winapi=$enableval else $as_nop ac_cv_enable_winapi=auto-detect fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether to enable enable WINAPI support for cross-compilation" >&5 printf %s "checking whether to enable enable WINAPI support for cross-compilation... " >&6; } if test ${ac_cv_enable_winapi+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_enable_winapi=auto-detect fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_enable_winapi" >&5 printf "%s\n" "$ac_cv_enable_winapi" >&6; } if test "x$ac_cv_enable_winapi" = xauto-detect then : ac_common_check_winapi_target_string="$target" if test "x$ac_common_check_winapi_target_string" = x then : ac_common_check_winapi_target_string="$host" fi case $ac_common_check_winapi_target_string in #( *mingw*) : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: detected MinGW enabling WINAPI support for cross-compilation" >&5 printf "%s\n" "$as_me: detected MinGW enabling WINAPI support for cross-compilation" >&6;} ac_cv_enable_winapi=yes ;; #( *msys*) : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: detected MSYS enabling WINAPI support for cross-compilation" >&5 printf "%s\n" "$as_me: detected MSYS enabling WINAPI support for cross-compilation" >&6;} ac_cv_enable_winapi=yes ;; #( *) : ac_cv_enable_winapi=no ;; #( *) : ;; esac fi if test "x$ac_cv_enable_winapi" = xyes then : ac_cv_enable_wide_character_type=yes fi if test "x$ac_cv_enable_wide_character_type" = xyes then : printf "%s\n" "#define HAVE_WIDE_CHARACTER_TYPE 1" >>confdefs.h HAVE_WIDE_CHARACTER_TYPE=1 else $as_nop HAVE_WIDE_CHARACTER_TYPE=0 fi ac_fn_c_check_header_compile "$LINENO" "sys/types.h" "ac_cv_header_sys_types_h" "$ac_includes_default" if test "x$ac_cv_header_sys_types_h" = xyes then : printf "%s\n" "#define HAVE_SYS_TYPES_H 1" >>confdefs.h fi ac_fn_c_check_header_compile "$LINENO" "inttypes.h" "ac_cv_header_inttypes_h" "$ac_includes_default" if test "x$ac_cv_header_inttypes_h" = xyes then : printf "%s\n" "#define HAVE_INTTYPES_H 1" >>confdefs.h fi ac_fn_c_check_header_compile "$LINENO" "stdint.h" "ac_cv_header_stdint_h" "$ac_includes_default" if test "x$ac_cv_header_stdint_h" = xyes then : printf "%s\n" "#define HAVE_STDINT_H 1" >>confdefs.h fi ac_fn_c_check_header_compile "$LINENO" "wchar.h" "ac_cv_header_wchar_h" "$ac_includes_default" if test "x$ac_cv_header_wchar_h" = xyes then : printf "%s\n" "#define HAVE_WCHAR_H 1" >>confdefs.h fi if test "x$ac_cv_header_sys_types_h" = xyes then : HAVE_SYS_TYPES_H=1 else $as_nop HAVE_SYS_TYPES_H=0 fi if test "x$ac_cv_header_inttypes_h" = xyes then : HAVE_INTTYPES_H=1 else $as_nop HAVE_INTTYPES_H=0 fi if test "x$ac_cv_header_stdint_h" = xyes then : HAVE_STDINT_H=1 else $as_nop HAVE_STDINT_H=0 fi if test "x$ac_cv_header_wchar_h" = xyes then : HAVE_WCHAR_H=1 else $as_nop HAVE_WCHAR_H=0 fi ac_fn_c_check_type "$LINENO" "mode_t" "ac_cv_type_mode_t" "$ac_includes_default" if test "x$ac_cv_type_mode_t" = xyes then : else $as_nop printf "%s\n" "#define mode_t int" >>confdefs.h fi ac_fn_c_check_type "$LINENO" "off_t" "ac_cv_type_off_t" "$ac_includes_default" if test "x$ac_cv_type_off_t" = xyes then : else $as_nop printf "%s\n" "#define off_t long int" >>confdefs.h fi ac_fn_c_check_type "$LINENO" "size_t" "ac_cv_type_size_t" "$ac_includes_default" if test "x$ac_cv_type_size_t" = xyes then : else $as_nop printf "%s\n" "#define size_t unsigned int" >>confdefs.h fi ac_fn_c_check_type "$LINENO" "size32_t" "ac_cv_type_size32_t" "$ac_includes_default" if test "x$ac_cv_type_size32_t" = xyes then : HAVE_SIZE32_T=1 else $as_nop HAVE_SIZE32_T=0 fi ac_fn_c_check_type "$LINENO" "ssize32_t" "ac_cv_type_ssize32_t" "$ac_includes_default" if test "x$ac_cv_type_ssize32_t" = xyes then : HAVE_SSIZE32_T=1 else $as_nop HAVE_SSIZE32_T=0 fi ac_fn_c_check_type "$LINENO" "size64_t" "ac_cv_type_size64_t" "$ac_includes_default" if test "x$ac_cv_type_size64_t" = xyes then : HAVE_SIZE64_T=1 else $as_nop HAVE_SIZE64_T=0 fi ac_fn_c_check_type "$LINENO" "ssize64_t" "ac_cv_type_ssize64_t" "$ac_includes_default" if test "x$ac_cv_type_ssize64_t" = xyes then : HAVE_SSIZE64_T=1 else $as_nop HAVE_SSIZE64_T=0 fi ac_fn_c_check_type "$LINENO" "off64_t" "ac_cv_type_off64_t" "$ac_includes_default" if test "x$ac_cv_type_off64_t" = xyes then : HAVE_OFF64_T=1 else $as_nop HAVE_OFF64_T=0 fi ac_fn_c_check_type "$LINENO" "ssize_t" "ac_cv_type_ssize_t" "$ac_includes_default" if test "x$ac_cv_type_ssize_t" = xyes then : fi ac_fn_c_check_type "$LINENO" "u64" "ac_cv_type_u64" "$ac_includes_default" if test "x$ac_cv_type_u64" = xyes then : fi # The cast to long int works around a bug in the HP C Compiler # version HP92453-01 B.11.11.23709.GP, which incorrectly rejects # declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. # This bug is HP SR number 8606223364. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking size of int" >&5 printf %s "checking size of int... " >&6; } if test ${ac_cv_sizeof_int+y} then : printf %s "(cached) " >&6 else $as_nop if ac_fn_c_compute_int "$LINENO" "(long int) (sizeof (int))" "ac_cv_sizeof_int" "$ac_includes_default" then : else $as_nop if test "$ac_cv_type_int" = yes; then { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "cannot compute sizeof (int) See \`config.log' for more details" "$LINENO" 5; } else ac_cv_sizeof_int=0 fi fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_sizeof_int" >&5 printf "%s\n" "$ac_cv_sizeof_int" >&6; } printf "%s\n" "#define SIZEOF_INT $ac_cv_sizeof_int" >>confdefs.h # The cast to long int works around a bug in the HP C Compiler # version HP92453-01 B.11.11.23709.GP, which incorrectly rejects # declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. # This bug is HP SR number 8606223364. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking size of long" >&5 printf %s "checking size of long... " >&6; } if test ${ac_cv_sizeof_long+y} then : printf %s "(cached) " >&6 else $as_nop if ac_fn_c_compute_int "$LINENO" "(long int) (sizeof (long))" "ac_cv_sizeof_long" "$ac_includes_default" then : else $as_nop if test "$ac_cv_type_long" = yes; then { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "cannot compute sizeof (long) See \`config.log' for more details" "$LINENO" 5; } else ac_cv_sizeof_long=0 fi fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_sizeof_long" >&5 printf "%s\n" "$ac_cv_sizeof_long" >&6; } printf "%s\n" "#define SIZEOF_LONG $ac_cv_sizeof_long" >>confdefs.h # The cast to long int works around a bug in the HP C Compiler # version HP92453-01 B.11.11.23709.GP, which incorrectly rejects # declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. # This bug is HP SR number 8606223364. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking size of off_t" >&5 printf %s "checking size of off_t... " >&6; } if test ${ac_cv_sizeof_off_t+y} then : printf %s "(cached) " >&6 else $as_nop if ac_fn_c_compute_int "$LINENO" "(long int) (sizeof (off_t))" "ac_cv_sizeof_off_t" "$ac_includes_default" then : else $as_nop if test "$ac_cv_type_off_t" = yes; then { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "cannot compute sizeof (off_t) See \`config.log' for more details" "$LINENO" 5; } else ac_cv_sizeof_off_t=0 fi fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_sizeof_off_t" >&5 printf "%s\n" "$ac_cv_sizeof_off_t" >&6; } printf "%s\n" "#define SIZEOF_OFF_T $ac_cv_sizeof_off_t" >>confdefs.h # The cast to long int works around a bug in the HP C Compiler # version HP92453-01 B.11.11.23709.GP, which incorrectly rejects # declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. # This bug is HP SR number 8606223364. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking size of size_t" >&5 printf %s "checking size of size_t... " >&6; } if test ${ac_cv_sizeof_size_t+y} then : printf %s "(cached) " >&6 else $as_nop if ac_fn_c_compute_int "$LINENO" "(long int) (sizeof (size_t))" "ac_cv_sizeof_size_t" "$ac_includes_default" then : else $as_nop if test "$ac_cv_type_size_t" = yes; then { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "cannot compute sizeof (size_t) See \`config.log' for more details" "$LINENO" 5; } else ac_cv_sizeof_size_t=0 fi fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_sizeof_size_t" >&5 printf "%s\n" "$ac_cv_sizeof_size_t" >&6; } printf "%s\n" "#define SIZEOF_SIZE_T $ac_cv_sizeof_size_t" >>confdefs.h if test "x$ac_cv_header_wchar_h" = xyes then : # The cast to long int works around a bug in the HP C Compiler # version HP92453-01 B.11.11.23709.GP, which incorrectly rejects # declarations like `int a3[[(sizeof (unsigned char)) >= 0]];'. # This bug is HP SR number 8606223364. { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking size of wchar_t" >&5 printf %s "checking size of wchar_t... " >&6; } if test ${ac_cv_sizeof_wchar_t+y} then : printf %s "(cached) " >&6 else $as_nop if ac_fn_c_compute_int "$LINENO" "(long int) (sizeof (wchar_t))" "ac_cv_sizeof_wchar_t" "$ac_includes_default" then : else $as_nop if test "$ac_cv_type_wchar_t" = yes; then { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 77 "cannot compute sizeof (wchar_t) See \`config.log' for more details" "$LINENO" 5; } else ac_cv_sizeof_wchar_t=0 fi fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_sizeof_wchar_t" >&5 printf "%s\n" "$ac_cv_sizeof_wchar_t" >&6; } printf "%s\n" "#define SIZEOF_WCHAR_T $ac_cv_sizeof_wchar_t" >>confdefs.h fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $CC options needed to detect all undeclared functions" >&5 printf %s "checking for $CC options needed to detect all undeclared functions... " >&6; } if test ${ac_cv_c_undeclared_builtin_options+y} then : printf %s "(cached) " >&6 else $as_nop ac_save_CFLAGS=$CFLAGS ac_cv_c_undeclared_builtin_options='cannot detect' for ac_arg in '' -fno-builtin; do CFLAGS="$ac_save_CFLAGS $ac_arg" # This test program should *not* compile successfully. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ int main (void) { (void) strchr; ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : else $as_nop # This test program should compile successfully. # No library function is consistently available on # freestanding implementations, so test against a dummy # declaration. Include always-available headers on the # off chance that they somehow elicit warnings. cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include #include #include extern void ac_decl (int, char *); int main (void) { (void) ac_decl (0, (char *) 0); (void) ac_decl; ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : if test x"$ac_arg" = x then : ac_cv_c_undeclared_builtin_options='none needed' else $as_nop ac_cv_c_undeclared_builtin_options=$ac_arg fi break fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext done CFLAGS=$ac_save_CFLAGS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_c_undeclared_builtin_options" >&5 printf "%s\n" "$ac_cv_c_undeclared_builtin_options" >&6; } case $ac_cv_c_undeclared_builtin_options in #( 'cannot detect') : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot make $CC report undeclared builtins See \`config.log' for more details" "$LINENO" 5; } ;; #( 'none needed') : ac_c_undeclared_builtin_options='' ;; #( *) : ac_c_undeclared_builtin_options=$ac_cv_c_undeclared_builtin_options ;; esac if test "x$ac_cv_enable_winapi" = xyes then : ac_fn_c_check_header_compile "$LINENO" "windows.h" "ac_cv_header_windows_h" "$ac_includes_default" if test "x$ac_cv_header_windows_h" = xyes then : printf "%s\n" "#define HAVE_WINDOWS_H 1" >>confdefs.h fi if test "x$ac_cv_header_windows_h" = xno then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing header: windows.h header is required to compile with winapi support See \`config.log' for more details" "$LINENO" 5; } fi fi if test "x$ac_cv_enable_winapi" = xno then : ac_fn_c_check_header_compile "$LINENO" "libintl.h" "ac_cv_header_libintl_h" "$ac_includes_default" if test "x$ac_cv_header_libintl_h" = xyes then : printf "%s\n" "#define HAVE_LIBINTL_H 1" >>confdefs.h fi fi ac_fn_c_check_header_compile "$LINENO" "limits.h" "ac_cv_header_limits_h" "$ac_includes_default" if test "x$ac_cv_header_limits_h" = xyes then : printf "%s\n" "#define HAVE_LIMITS_H 1" >>confdefs.h fi ac_fn_c_check_header_compile "$LINENO" "stdlib.h" "ac_cv_header_stdlib_h" "$ac_includes_default" if test "x$ac_cv_header_stdlib_h" = xyes then : printf "%s\n" "#define HAVE_STDLIB_H 1" >>confdefs.h fi ac_fn_c_check_header_compile "$LINENO" "string.h" "ac_cv_header_string_h" "$ac_includes_default" if test "x$ac_cv_header_string_h" = xyes then : printf "%s\n" "#define HAVE_STRING_H 1" >>confdefs.h fi ac_fn_c_check_header_compile "$LINENO" "wchar.h" "ac_cv_header_wchar_h" "$ac_includes_default" if test "x$ac_cv_header_wchar_h" = xyes then : printf "%s\n" "#define HAVE_WCHAR_H 1" >>confdefs.h fi ac_fn_c_check_header_compile "$LINENO" "wctype.h" "ac_cv_header_wctype_h" "$ac_includes_default" if test "x$ac_cv_header_wctype_h" = xyes then : printf "%s\n" "#define HAVE_WCTYPE_H 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "fclose" "ac_cv_func_fclose" if test "x$ac_cv_func_fclose" = xyes then : printf "%s\n" "#define HAVE_FCLOSE 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "feof" "ac_cv_func_feof" if test "x$ac_cv_func_feof" = xyes then : printf "%s\n" "#define HAVE_FEOF 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "fgets" "ac_cv_func_fgets" if test "x$ac_cv_func_fgets" = xyes then : printf "%s\n" "#define HAVE_FGETS 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "fopen" "ac_cv_func_fopen" if test "x$ac_cv_func_fopen" = xyes then : printf "%s\n" "#define HAVE_FOPEN 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "fread" "ac_cv_func_fread" if test "x$ac_cv_func_fread" = xyes then : printf "%s\n" "#define HAVE_FREAD 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "fseeko" "ac_cv_func_fseeko" if test "x$ac_cv_func_fseeko" = xyes then : printf "%s\n" "#define HAVE_FSEEKO 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "fseeko64" "ac_cv_func_fseeko64" if test "x$ac_cv_func_fseeko64" = xyes then : printf "%s\n" "#define HAVE_FSEEKO64 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "fwrite" "ac_cv_func_fwrite" if test "x$ac_cv_func_fwrite" = xyes then : printf "%s\n" "#define HAVE_FWRITE 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "vfprintf" "ac_cv_func_vfprintf" if test "x$ac_cv_func_vfprintf" = xyes then : printf "%s\n" "#define HAVE_VFPRINTF 1" >>confdefs.h fi if test "x$ac_cv_func_fclose" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: fclose See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_feof" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: feof See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_fgets" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: fgets See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_fopen" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: fopen See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_fread" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: fread See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_fseeko" != xyes && test "x$ac_cv_func_fseeko64" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: fseeko and fseeko64 See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_fwrite" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: fwrite See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_vfprintf" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: vfprintf See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_enable_wide_character_type" != xno then : ac_fn_c_check_func "$LINENO" "fgetws" "ac_cv_func_fgetws" if test "x$ac_cv_func_fgetws" = xyes then : printf "%s\n" "#define HAVE_FGETWS 1" >>confdefs.h fi if test "x$ac_cv_func_fgetws" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: fgetws See \`config.log' for more details" "$LINENO" 5; } fi fi ac_fn_c_check_func "$LINENO" "free" "ac_cv_func_free" if test "x$ac_cv_func_free" = xyes then : printf "%s\n" "#define HAVE_FREE 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "malloc" "ac_cv_func_malloc" if test "x$ac_cv_func_malloc" = xyes then : printf "%s\n" "#define HAVE_MALLOC 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "memcmp" "ac_cv_func_memcmp" if test "x$ac_cv_func_memcmp" = xyes then : printf "%s\n" "#define HAVE_MEMCMP 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "memcpy" "ac_cv_func_memcpy" if test "x$ac_cv_func_memcpy" = xyes then : printf "%s\n" "#define HAVE_MEMCPY 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "memset" "ac_cv_func_memset" if test "x$ac_cv_func_memset" = xyes then : printf "%s\n" "#define HAVE_MEMSET 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "realloc" "ac_cv_func_realloc" if test "x$ac_cv_func_realloc" = xyes then : printf "%s\n" "#define HAVE_REALLOC 1" >>confdefs.h fi if test "x$ac_cv_func_free" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: free See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_malloc" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: malloc See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_memcmp" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: memcmp See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_memcpy" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: memcpy See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_memset" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: memset See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_realloc" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: realloc See \`config.log' for more details" "$LINENO" 5; } fi ac_fn_c_check_func "$LINENO" "memchr" "ac_cv_func_memchr" if test "x$ac_cv_func_memchr" = xyes then : printf "%s\n" "#define HAVE_MEMCHR 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "memrchr" "ac_cv_func_memrchr" if test "x$ac_cv_func_memrchr" = xyes then : printf "%s\n" "#define HAVE_MEMRCHR 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "snprintf" "ac_cv_func_snprintf" if test "x$ac_cv_func_snprintf" = xyes then : printf "%s\n" "#define HAVE_SNPRINTF 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "sscanf" "ac_cv_func_sscanf" if test "x$ac_cv_func_sscanf" = xyes then : printf "%s\n" "#define HAVE_SSCANF 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "strcasecmp" "ac_cv_func_strcasecmp" if test "x$ac_cv_func_strcasecmp" = xyes then : printf "%s\n" "#define HAVE_STRCASECMP 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "strchr" "ac_cv_func_strchr" if test "x$ac_cv_func_strchr" = xyes then : printf "%s\n" "#define HAVE_STRCHR 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "strlen" "ac_cv_func_strlen" if test "x$ac_cv_func_strlen" = xyes then : printf "%s\n" "#define HAVE_STRLEN 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "strncasecmp" "ac_cv_func_strncasecmp" if test "x$ac_cv_func_strncasecmp" = xyes then : printf "%s\n" "#define HAVE_STRNCASECMP 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "strncmp" "ac_cv_func_strncmp" if test "x$ac_cv_func_strncmp" = xyes then : printf "%s\n" "#define HAVE_STRNCMP 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "strncpy" "ac_cv_func_strncpy" if test "x$ac_cv_func_strncpy" = xyes then : printf "%s\n" "#define HAVE_STRNCPY 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "strnicmp" "ac_cv_func_strnicmp" if test "x$ac_cv_func_strnicmp" = xyes then : printf "%s\n" "#define HAVE_STRNICMP 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "strrchr" "ac_cv_func_strrchr" if test "x$ac_cv_func_strrchr" = xyes then : printf "%s\n" "#define HAVE_STRRCHR 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "strstr" "ac_cv_func_strstr" if test "x$ac_cv_func_strstr" = xyes then : printf "%s\n" "#define HAVE_STRSTR 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "vsnprintf" "ac_cv_func_vsnprintf" if test "x$ac_cv_func_vsnprintf" = xyes then : printf "%s\n" "#define HAVE_VSNPRINTF 1" >>confdefs.h fi if test "x$ac_cv_func_memchr" != xyes && test "x$ac_cv_func_strchr" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing functions: memchr and strchr See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_memcmp" != xyes && test "x$ac_cv_func_strncmp" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing functions: memcmp and strncmp See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_memcpy" != xyes && test "x$ac_cv_func_strncpy" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing functions: memcpy and strncpy See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_memrchr" = xyes then : ac_fn_check_decl "$LINENO" "memrchr" "ac_cv_have_decl_memrchr" "$ac_includes_default" "$ac_c_undeclared_builtin_options" "CFLAGS" if test "x$ac_cv_have_decl_memrchr" = xyes then : ac_have_decl=1 else $as_nop ac_have_decl=0 fi printf "%s\n" "#define HAVE_DECL_MEMRCHR $ac_have_decl" >>confdefs.h if test "x$ac_cv_decl_memrchr" != xyes then : ac_cv_func_memrchr=no fi fi if test "x$ac_cv_func_memrchr" != xyes && test "x$ac_cv_func_strrchr" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing functions: strrchr and memrchr See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_snprintf" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: snprintf See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_sscanf" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: sscanf See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_strlen" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: strlen See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_strcasecmp" != xyes && test "x$ac_cv_func_strncasecmp" != xyes && test "x$ac_cv_func_strnicmp" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing functions: strncasecmp, strcasecmp and strnicmp See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_strstr" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: strstr See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_vsnprintf" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: vsnprintf See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_enable_wide_character_type" != xno then : ac_fn_c_check_func "$LINENO" "swprintf" "ac_cv_func_swprintf" if test "x$ac_cv_func_swprintf" = xyes then : printf "%s\n" "#define HAVE_SWPRINTF 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "towlower" "ac_cv_func_towlower" if test "x$ac_cv_func_towlower" = xyes then : printf "%s\n" "#define HAVE_TOWLOWER 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "wcscasecmp" "ac_cv_func_wcscasecmp" if test "x$ac_cv_func_wcscasecmp" = xyes then : printf "%s\n" "#define HAVE_WCSCASECMP 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "wcschr" "ac_cv_func_wcschr" if test "x$ac_cv_func_wcschr" = xyes then : printf "%s\n" "#define HAVE_WCSCHR 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "wcslen" "ac_cv_func_wcslen" if test "x$ac_cv_func_wcslen" = xyes then : printf "%s\n" "#define HAVE_WCSLEN 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "wcsncasecmp" "ac_cv_func_wcsncasecmp" if test "x$ac_cv_func_wcsncasecmp" = xyes then : printf "%s\n" "#define HAVE_WCSNCASECMP 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "wcsncmp" "ac_cv_func_wcsncmp" if test "x$ac_cv_func_wcsncmp" = xyes then : printf "%s\n" "#define HAVE_WCSNCMP 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "wcsncpy" "ac_cv_func_wcsncpy" if test "x$ac_cv_func_wcsncpy" = xyes then : printf "%s\n" "#define HAVE_WCSNCPY 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "wcsnicmp" "ac_cv_func_wcsnicmp" if test "x$ac_cv_func_wcsnicmp" = xyes then : printf "%s\n" "#define HAVE_WCSNICMP 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "wcsrchr" "ac_cv_func_wcsrchr" if test "x$ac_cv_func_wcsrchr" = xyes then : printf "%s\n" "#define HAVE_WCSRCHR 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "wcsstr" "ac_cv_func_wcsstr" if test "x$ac_cv_func_wcsstr" = xyes then : printf "%s\n" "#define HAVE_WCSSTR 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "wmemchr" "ac_cv_func_wmemchr" if test "x$ac_cv_func_wmemchr" = xyes then : printf "%s\n" "#define HAVE_WMEMCHR 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "wmemcmp" "ac_cv_func_wmemcmp" if test "x$ac_cv_func_wmemcmp" = xyes then : printf "%s\n" "#define HAVE_WMEMCMP 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "wmemcpy" "ac_cv_func_wmemcpy" if test "x$ac_cv_func_wmemcpy" = xyes then : printf "%s\n" "#define HAVE_WMEMCPY 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "wmemrchr" "ac_cv_func_wmemrchr" if test "x$ac_cv_func_wmemrchr" = xyes then : printf "%s\n" "#define HAVE_WMEMRCHR 1" >>confdefs.h fi if test "x$ac_cv_func_swprintf" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: swprintf See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_wmemchr" != xyes && test "x$ac_cv_func_wcschr" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing functions: wmemchr and wcschr See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_wmemcmp" != xyes && test "x$ac_cv_func_wcsncmp" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing functions: wmemcmp and wcsncmp See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_wmemcpy" != xyes && test "x$ac_cv_func_wcsncpy" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing functions: wmemcpy and wcsncpy See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_wmemrchr" != xyes && test "x$ac_cv_func_wcsrchr" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing functions: wmemrchr and wcsrchr See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_wcslen" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: wcslen See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_wcsncasecmp" != xyes && test "x$ac_cv_func_wcscasecmp" != xyes && test "x$ac_cv_func_wcsnicmp" != xyes && test "x$ac_cv_func_towlower" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing functions: wcsncasecmp, wcscasecmp, wcsnicmp and towlower See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_func_wcsstr" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: wcsstr See \`config.log' for more details" "$LINENO" 5; } fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether printf supports the conversion specifier \"%jd\"" >&5 printf %s "checking whether printf supports the conversion specifier \"%jd\"... " >&6; } SAVE_CFLAGS="$CFLAGS" CFLAGS="$CFLAGS -Wall -Werror" ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int main (void) { printf( "%jd" ); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_cv_have_printf_jd=no else $as_nop ac_cv_cv_have_printf_jd=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext if test "x$ac_cv_cv_have_printf_jd" = xyes then : cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include int main (void) { printf( "%jd", (off_t) 10 ); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_cv_have_printf_jd=yes else $as_nop ac_cv_cv_have_printf_jd=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext fi if test "x$ac_cv_cv_have_printf_jd" = xyes then : if test "$cross_compiling" = yes then : ac_cv_cv_have_printf_jd=undetermined else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include int main (void) { char string[ 3 ]; if( snprintf( string, 3, "%jd", (off_t) 10 ) < 0 ) return( 1 ); if( ( string[ 0 ] != '1' ) || ( string[ 1 ] != '0' ) ) return( 1 ); ; return 0; } _ACEOF if ac_fn_c_try_run "$LINENO" then : ac_cv_cv_have_printf_jd=yes else $as_nop ac_cv_cv_have_printf_jd=no fi rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ conftest.$ac_objext conftest.beam conftest.$ac_ext fi fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu CFLAGS="$SAVE_CFLAGS" if test "x$ac_cv_cv_have_printf_jd" = xyes then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } printf "%s\n" "#define HAVE_PRINTF_JD 1" >>confdefs.h else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_cv_have_printf_jd" >&5 printf "%s\n" "$ac_cv_cv_have_printf_jd" >&6; } fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether printf supports the conversion specifier \"%zd\"" >&5 printf %s "checking whether printf supports the conversion specifier \"%zd\"... " >&6; } SAVE_CFLAGS="$CFLAGS" CFLAGS="$CFLAGS -Wall -Werror" ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int main (void) { printf( "%zd" ); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_cv_have_printf_zd=no else $as_nop ac_cv_cv_have_printf_zd=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext if test "x$ac_cv_cv_have_printf_zd" = xyes then : cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include int main (void) { printf( "%zd", (size_t) 10 ); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_cv_have_printf_zd=yes else $as_nop ac_cv_cv_have_printf_zd=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext fi if test "x$ac_cv_cv_have_printf_zd" = xyes then : if test "$cross_compiling" = yes then : ac_cv_cv_have_printf_zd=undetermined else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include int main (void) { char string[ 3 ]; if( snprintf( string, 3, "%zd", (size_t) 10 ) < 0 ) return( 1 ); if( ( string[ 0 ] != '1' ) || ( string[ 1 ] != '0' ) ) return( 1 ); ; return 0; } _ACEOF if ac_fn_c_try_run "$LINENO" then : ac_cv_cv_have_printf_zd=yes else $as_nop ac_cv_cv_have_printf_zd=no fi rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ conftest.$ac_objext conftest.beam conftest.$ac_ext fi fi ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu CFLAGS="$SAVE_CFLAGS" if test "x$ac_cv_cv_have_printf_zd" = xyes then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } printf "%s\n" "#define HAVE_PRINTF_ZD 1" >>confdefs.h else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_cv_have_printf_zd" >&5 printf "%s\n" "$ac_cv_cv_have_printf_zd" >&6; } fi if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then if test -n "$ac_tool_prefix"; then # Extract the first word of "${ac_tool_prefix}pkg-config", so it can be a program name with args. set dummy ${ac_tool_prefix}pkg-config; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_path_PKG_CONFIG+y} then : printf %s "(cached) " >&6 else $as_nop case $PKG_CONFIG in [\\/]* | ?:[\\/]*) ac_cv_path_PKG_CONFIG="$PKG_CONFIG" # Let the user override the test with a path. ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_path_PKG_CONFIG="$as_dir$ac_word$ac_exec_ext" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS ;; esac fi PKG_CONFIG=$ac_cv_path_PKG_CONFIG if test -n "$PKG_CONFIG"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $PKG_CONFIG" >&5 printf "%s\n" "$PKG_CONFIG" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi fi if test -z "$ac_cv_path_PKG_CONFIG"; then ac_pt_PKG_CONFIG=$PKG_CONFIG # Extract the first word of "pkg-config", so it can be a program name with args. set dummy pkg-config; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_path_ac_pt_PKG_CONFIG+y} then : printf %s "(cached) " >&6 else $as_nop case $ac_pt_PKG_CONFIG in [\\/]* | ?:[\\/]*) ac_cv_path_ac_pt_PKG_CONFIG="$ac_pt_PKG_CONFIG" # Let the user override the test with a path. ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_path_ac_pt_PKG_CONFIG="$as_dir$ac_word$ac_exec_ext" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS ;; esac fi ac_pt_PKG_CONFIG=$ac_cv_path_ac_pt_PKG_CONFIG if test -n "$ac_pt_PKG_CONFIG"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_pt_PKG_CONFIG" >&5 printf "%s\n" "$ac_pt_PKG_CONFIG" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi if test "x$ac_pt_PKG_CONFIG" = x; then PKG_CONFIG="" else case $cross_compiling:$ac_tool_warned in yes:) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: using cross tools not prefixed with host triplet" >&5 printf "%s\n" "$as_me: WARNING: using cross tools not prefixed with host triplet" >&2;} ac_tool_warned=yes ;; esac PKG_CONFIG=$ac_pt_PKG_CONFIG fi else PKG_CONFIG="$ac_cv_path_PKG_CONFIG" fi fi if test -n "$PKG_CONFIG"; then _pkg_min_version=0.9.0 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking pkg-config is at least version $_pkg_min_version" >&5 printf %s "checking pkg-config is at least version $_pkg_min_version... " >&6; } if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } PKG_CONFIG="" fi fi ac_fn_check_decl "$LINENO" "strerror_r" "ac_cv_have_decl_strerror_r" "$ac_includes_default" "$ac_c_undeclared_builtin_options" "CFLAGS" if test "x$ac_cv_have_decl_strerror_r" = xyes then : ac_have_decl=1 else $as_nop ac_have_decl=0 fi printf "%s\n" "#define HAVE_DECL_STRERROR_R $ac_have_decl" >>confdefs.h # Check whether --with-libcerror was given. if test ${with_libcerror+y} then : withval=$with_libcerror; ac_cv_with_libcerror=$withval else $as_nop ac_cv_with_libcerror=auto-detect fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether to use search for libcerror in includedir and libdir or in the specified DIR, or no if to use local version" >&5 printf %s "checking whether to use search for libcerror in includedir and libdir or in the specified DIR, or no if to use local version... " >&6; } if test ${ac_cv_with_libcerror+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_with_libcerror=auto-detect fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_with_libcerror" >&5 printf "%s\n" "$ac_cv_with_libcerror" >&6; } if test "x$ac_cv_enable_shared_libs" = xno || test "x$ac_cv_with_libcerror" = xno then : ac_cv_libcerror=no else $as_nop ac_cv_libcerror=check if test "x$ac_cv_with_libcerror" != x && test "x$ac_cv_with_libcerror" != xauto-detect && test "x$ac_cv_with_libcerror" != xyes then : if test -d "$ac_cv_with_libcerror" then : CFLAGS="$CFLAGS -I${ac_cv_with_libcerror}/include" LDFLAGS="$LDFLAGS -L${ac_cv_with_libcerror}/lib" else $as_nop { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "no such directory: $ac_cv_with_libcerror See \`config.log' for more details" "$LINENO" 5; } fi else $as_nop if test "x$cross_compiling" != "xyes" && test "x$PKGCONFIG" != "x" then : pkg_failed=no { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for libcerror >= 20120425" >&5 printf %s "checking for libcerror >= 20120425... " >&6; } if test -n "$libcerror_CFLAGS"; then pkg_cv_libcerror_CFLAGS="$libcerror_CFLAGS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"libcerror >= 20120425\""; } >&5 ($PKG_CONFIG --exists --print-errors "libcerror >= 20120425") 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_libcerror_CFLAGS=`$PKG_CONFIG --cflags "libcerror >= 20120425" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test -n "$libcerror_LIBS"; then pkg_cv_libcerror_LIBS="$libcerror_LIBS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"libcerror >= 20120425\""; } >&5 ($PKG_CONFIG --exists --print-errors "libcerror >= 20120425") 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_libcerror_LIBS=`$PKG_CONFIG --libs "libcerror >= 20120425" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test $pkg_failed = yes; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then _pkg_short_errors_supported=yes else _pkg_short_errors_supported=no fi if test $_pkg_short_errors_supported = yes; then libcerror_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "libcerror >= 20120425" 2>&1` else libcerror_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "libcerror >= 20120425" 2>&1` fi # Put the nasty error message in config.log where it belongs echo "$libcerror_PKG_ERRORS" >&5 ac_cv_libcerror=check elif test $pkg_failed = untried; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } ac_cv_libcerror=check else libcerror_CFLAGS=$pkg_cv_libcerror_CFLAGS libcerror_LIBS=$pkg_cv_libcerror_LIBS { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } ac_cv_libcerror=yes fi fi if test "x$ac_cv_libcerror" = xyes then : ac_cv_libcerror_CPPFLAGS="$pkg_cv_libcerror_CFLAGS" ac_cv_libcerror_LIBADD="$pkg_cv_libcerror_LIBS" fi fi if test "x$ac_cv_libcerror" = xcheck then : ac_fn_c_check_header_compile "$LINENO" "libcerror.h" "ac_cv_header_libcerror_h" "$ac_includes_default" if test "x$ac_cv_header_libcerror_h" = xyes then : printf "%s\n" "#define HAVE_LIBCERROR_H 1" >>confdefs.h fi if test "x$ac_cv_header_libcerror_h" = xno then : ac_cv_libcerror=no else $as_nop ac_cv_libcerror=yes { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for libcerror_get_version in -lcerror" >&5 printf %s "checking for libcerror_get_version in -lcerror... " >&6; } if test ${ac_cv_lib_cerror_libcerror_get_version+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcerror $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char libcerror_get_version (); int main (void) { return libcerror_get_version (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_cerror_libcerror_get_version=yes else $as_nop ac_cv_lib_cerror_libcerror_get_version=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_cerror_libcerror_get_version" >&5 printf "%s\n" "$ac_cv_lib_cerror_libcerror_get_version" >&6; } if test "x$ac_cv_lib_cerror_libcerror_get_version" = xyes then : ac_cv_libcerror_dummy=yes else $as_nop ac_cv_libcerror=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for libcerror_error_free in -lcerror" >&5 printf %s "checking for libcerror_error_free in -lcerror... " >&6; } if test ${ac_cv_lib_cerror_libcerror_error_free+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcerror $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char libcerror_error_free (); int main (void) { return libcerror_error_free (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_cerror_libcerror_error_free=yes else $as_nop ac_cv_lib_cerror_libcerror_error_free=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_cerror_libcerror_error_free" >&5 printf "%s\n" "$ac_cv_lib_cerror_libcerror_error_free" >&6; } if test "x$ac_cv_lib_cerror_libcerror_error_free" = xyes then : ac_cv_libcerror_dummy=yes else $as_nop ac_cv_libcerror=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for libcerror_error_set in -lcerror" >&5 printf %s "checking for libcerror_error_set in -lcerror... " >&6; } if test ${ac_cv_lib_cerror_libcerror_error_set+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcerror $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char libcerror_error_set (); int main (void) { return libcerror_error_set (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_cerror_libcerror_error_set=yes else $as_nop ac_cv_lib_cerror_libcerror_error_set=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_cerror_libcerror_error_set" >&5 printf "%s\n" "$ac_cv_lib_cerror_libcerror_error_set" >&6; } if test "x$ac_cv_lib_cerror_libcerror_error_set" = xyes then : ac_cv_libcerror_dummy=yes else $as_nop ac_cv_libcerror=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for libcerror_error_matches in -lcerror" >&5 printf %s "checking for libcerror_error_matches in -lcerror... " >&6; } if test ${ac_cv_lib_cerror_libcerror_error_matches+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcerror $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char libcerror_error_matches (); int main (void) { return libcerror_error_matches (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_cerror_libcerror_error_matches=yes else $as_nop ac_cv_lib_cerror_libcerror_error_matches=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_cerror_libcerror_error_matches" >&5 printf "%s\n" "$ac_cv_lib_cerror_libcerror_error_matches" >&6; } if test "x$ac_cv_lib_cerror_libcerror_error_matches" = xyes then : ac_cv_libcerror_dummy=yes else $as_nop ac_cv_libcerror=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for libcerror_error_fprint in -lcerror" >&5 printf %s "checking for libcerror_error_fprint in -lcerror... " >&6; } if test ${ac_cv_lib_cerror_libcerror_error_fprint+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcerror $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char libcerror_error_fprint (); int main (void) { return libcerror_error_fprint (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_cerror_libcerror_error_fprint=yes else $as_nop ac_cv_lib_cerror_libcerror_error_fprint=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_cerror_libcerror_error_fprint" >&5 printf "%s\n" "$ac_cv_lib_cerror_libcerror_error_fprint" >&6; } if test "x$ac_cv_lib_cerror_libcerror_error_fprint" = xyes then : ac_cv_libcerror_dummy=yes else $as_nop ac_cv_libcerror=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for libcerror_error_sprint in -lcerror" >&5 printf %s "checking for libcerror_error_sprint in -lcerror... " >&6; } if test ${ac_cv_lib_cerror_libcerror_error_sprint+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcerror $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char libcerror_error_sprint (); int main (void) { return libcerror_error_sprint (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_cerror_libcerror_error_sprint=yes else $as_nop ac_cv_lib_cerror_libcerror_error_sprint=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_cerror_libcerror_error_sprint" >&5 printf "%s\n" "$ac_cv_lib_cerror_libcerror_error_sprint" >&6; } if test "x$ac_cv_lib_cerror_libcerror_error_sprint" = xyes then : ac_cv_libcerror_dummy=yes else $as_nop ac_cv_libcerror=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for libcerror_error_backtrace_fprint in -lcerror" >&5 printf %s "checking for libcerror_error_backtrace_fprint in -lcerror... " >&6; } if test ${ac_cv_lib_cerror_libcerror_error_backtrace_fprint+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcerror $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char libcerror_error_backtrace_fprint (); int main (void) { return libcerror_error_backtrace_fprint (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_cerror_libcerror_error_backtrace_fprint=yes else $as_nop ac_cv_lib_cerror_libcerror_error_backtrace_fprint=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_cerror_libcerror_error_backtrace_fprint" >&5 printf "%s\n" "$ac_cv_lib_cerror_libcerror_error_backtrace_fprint" >&6; } if test "x$ac_cv_lib_cerror_libcerror_error_backtrace_fprint" = xyes then : ac_cv_libcerror_dummy=yes else $as_nop ac_cv_libcerror=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for libcerror_error_backtrace_sprint in -lcerror" >&5 printf %s "checking for libcerror_error_backtrace_sprint in -lcerror... " >&6; } if test ${ac_cv_lib_cerror_libcerror_error_backtrace_sprint+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcerror $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char libcerror_error_backtrace_sprint (); int main (void) { return libcerror_error_backtrace_sprint (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_cerror_libcerror_error_backtrace_sprint=yes else $as_nop ac_cv_lib_cerror_libcerror_error_backtrace_sprint=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_cerror_libcerror_error_backtrace_sprint" >&5 printf "%s\n" "$ac_cv_lib_cerror_libcerror_error_backtrace_sprint" >&6; } if test "x$ac_cv_lib_cerror_libcerror_error_backtrace_sprint" = xyes then : ac_cv_libcerror_dummy=yes else $as_nop ac_cv_libcerror=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for libcerror_system_set_error in -lcerror" >&5 printf %s "checking for libcerror_system_set_error in -lcerror... " >&6; } if test ${ac_cv_lib_cerror_libcerror_system_set_error+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcerror $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char libcerror_system_set_error (); int main (void) { return libcerror_system_set_error (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_cerror_libcerror_system_set_error=yes else $as_nop ac_cv_lib_cerror_libcerror_system_set_error=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_cerror_libcerror_system_set_error" >&5 printf "%s\n" "$ac_cv_lib_cerror_libcerror_system_set_error" >&6; } if test "x$ac_cv_lib_cerror_libcerror_system_set_error" = xyes then : ac_cv_libcerror_dummy=yes else $as_nop ac_cv_libcerror=no fi ac_cv_libcerror_LIBADD="-lcerror" fi fi if test "x$ac_cv_libcerror" != xyes && test "x$ac_cv_with_libcerror" != x && test "x$ac_cv_with_libcerror" != xauto-detect && test "x$ac_cv_with_libcerror" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "unable to find supported libcerror in directory: $ac_cv_with_libcerror See \`config.log' for more details" "$LINENO" 5; } fi fi if test "x$ac_cv_libcerror" = xyes then : printf "%s\n" "#define HAVE_LIBCERROR 1" >>confdefs.h fi if test "x$ac_cv_libcerror" = xyes then : HAVE_LIBCERROR=1 else $as_nop HAVE_LIBCERROR=0 fi if test "x$ac_cv_libcerror" != xyes then : ac_fn_c_check_header_compile "$LINENO" "stdarg.h" "ac_cv_header_stdarg_h" "$ac_includes_default" if test "x$ac_cv_header_stdarg_h" = xyes then : printf "%s\n" "#define HAVE_STDARG_H 1" >>confdefs.h fi ac_fn_c_check_header_compile "$LINENO" "varargs.h" "ac_cv_header_varargs_h" "$ac_includes_default" if test "x$ac_cv_header_varargs_h" = xyes then : printf "%s\n" "#define HAVE_VARARGS_H 1" >>confdefs.h fi if test "x$ac_cv_header_stdarg_h" != xyes && test "x$ac_cv_header_varargs_h" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing headers: stdarg.h and varargs.h See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_enable_wide_character_type" != xno then : ac_fn_c_check_func "$LINENO" "wcstombs" "ac_cv_func_wcstombs" if test "x$ac_cv_func_wcstombs" = xyes then : printf "%s\n" "#define HAVE_WCSTOMBS 1" >>confdefs.h fi if test "x$ac_cv_func_wcstombs" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing function: wcstombs See \`config.log' for more details" "$LINENO" 5; } fi fi if test $ac_cv_have_decl_strerror_r = yes; then # For backward compatibility's sake, define HAVE_STRERROR_R. # (We used to run AC_CHECK_FUNCS_ONCE for strerror_r, as well # as AC_CHECK_DECLS_ONCE.) printf "%s\n" "#define HAVE_STRERROR_R 1" >>confdefs.h fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether strerror_r returns char *" >&5 printf %s "checking whether strerror_r returns char *... " >&6; } if test ${ac_cv_func_strerror_r_char_p+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_func_strerror_r_char_p=no if test $ac_cv_have_decl_strerror_r = yes; then cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include int main (void) { char buf[100]; char x = *strerror_r (0, buf, sizeof buf); char *p = strerror_r (0, buf, sizeof buf); return !p || x; ; return 0; } _ACEOF if ac_fn_c_try_compile "$LINENO" then : ac_cv_func_strerror_r_char_p=yes fi rm -f core conftest.err conftest.$ac_objext conftest.beam conftest.$ac_ext fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_func_strerror_r_char_p" >&5 printf "%s\n" "$ac_cv_func_strerror_r_char_p" >&6; } if test $ac_cv_func_strerror_r_char_p = yes; then printf "%s\n" "#define STRERROR_R_CHAR_P 1" >>confdefs.h fi if test "x$ac_cv_have_decl_strerror_r" != xyes then : ac_fn_c_check_func "$LINENO" "strerror" "ac_cv_func_strerror" if test "x$ac_cv_func_strerror" = xyes then : printf "%s\n" "#define HAVE_STRERROR 1" >>confdefs.h fi if test "x$ac_cv_func_strerror" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing functions: strerror_r and strerror See \`config.log' for more details" "$LINENO" 5; } fi fi ac_cv_libcerror_CPPFLAGS="-I../libcerror -I\$(top_srcdir)/libcerror"; ac_cv_libcerror_LIBADD="../libcerror/libcerror.la"; ac_cv_libcerror=local printf "%s\n" "#define HAVE_LOCAL_LIBCERROR 1" >>confdefs.h HAVE_LOCAL_LIBCERROR=1 fi if test "x$ac_cv_libcerror" = xlocal; then HAVE_LOCAL_LIBCERROR_TRUE= HAVE_LOCAL_LIBCERROR_FALSE='#' else HAVE_LOCAL_LIBCERROR_TRUE='#' HAVE_LOCAL_LIBCERROR_FALSE= fi if test "x$ac_cv_libcerror_CPPFLAGS" != "x" then : LIBCERROR_CPPFLAGS=$ac_cv_libcerror_CPPFLAGS fi if test "x$ac_cv_libcerror_LIBADD" != "x" then : LIBCERROR_LIBADD=$ac_cv_libcerror_LIBADD fi if test "x$ac_cv_libcerror" = xyes then : ax_libcerror_pc_libs_private=-lcerror fi if test "x$ac_cv_libcerror" = xyes then : ax_libcerror_spec_requires=libcerror ax_libcerror_spec_build_requires=libcerror-devel fi # Check whether --with-openssl was given. if test ${with_openssl+y} then : withval=$with_openssl; ac_cv_with_openssl=$withval else $as_nop ac_cv_with_openssl=auto-detect fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether to use search for OpenSSL in includedir and libdir or in the specified DIR, or no if not to use OpenSSL" >&5 printf %s "checking whether to use search for OpenSSL in includedir and libdir or in the specified DIR, or no if not to use OpenSSL... " >&6; } if test ${ac_cv_with_openssl+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_with_openssl=auto-detect fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_with_openssl" >&5 printf "%s\n" "$ac_cv_with_openssl" >&6; } # Check whether --enable-openssl-evp-cipher was given. if test ${enable_openssl_evp_cipher+y} then : enableval=$enable_openssl_evp_cipher; ac_cv_enable_openssl_evp_cipher=$enableval else $as_nop ac_cv_enable_openssl_evp_cipher=auto-detect fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether to enable enable OpenSSL EVP CIPHER support, or no to disable" >&5 printf %s "checking whether to enable enable OpenSSL EVP CIPHER support, or no to disable... " >&6; } if test ${ac_cv_enable_openssl_evp_cipher+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_enable_openssl_evp_cipher=auto-detect fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_enable_openssl_evp_cipher" >&5 printf "%s\n" "$ac_cv_enable_openssl_evp_cipher" >&6; } # Check whether --enable-openssl-evp-md was given. if test ${enable_openssl_evp_md+y} then : enableval=$enable_openssl_evp_md; ac_cv_enable_openssl_evp_md=$enableval else $as_nop ac_cv_enable_openssl_evp_md=auto-detect fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether to enable enable OpenSSL EVP MD support, or no to disable" >&5 printf %s "checking whether to enable enable OpenSSL EVP MD support, or no to disable... " >&6; } if test ${ac_cv_enable_openssl_evp_md+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_enable_openssl_evp_md=auto-detect fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_enable_openssl_evp_md" >&5 printf "%s\n" "$ac_cv_enable_openssl_evp_md" >&6; } if test "x$ac_cv_enable_static_executables" != xyes then : if test "x$ac_cv_enable_shared_libs" = xno || test "x$ac_cv_with_openssl" = xno then : ac_cv_libcrypto=no else $as_nop if test "x$ac_cv_with_openssl" != x && test "x$ac_cv_with_openssl" != xauto-detect && test "x$ac_cv_with_openssl" != xyes then : if test -d "$ac_cv_with_openssl" then : CFLAGS="$CFLAGS -I${ac_cv_with_openssl}/include" LDFLAGS="$LDFLAGS -L${ac_cv_with_openssl}/lib" else $as_nop { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "no such directory: $ac_cv_with_openssl See \`config.log' for more details" "$LINENO" 5; } fi else $as_nop if test "x$cross_compiling" != "xyes" && test "x$PKGCONFIG" != "x" then : pkg_failed=no { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for openssl >= 1.0" >&5 printf %s "checking for openssl >= 1.0... " >&6; } if test -n "$openssl_CFLAGS"; then pkg_cv_openssl_CFLAGS="$openssl_CFLAGS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"openssl >= 1.0\""; } >&5 ($PKG_CONFIG --exists --print-errors "openssl >= 1.0") 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_openssl_CFLAGS=`$PKG_CONFIG --cflags "openssl >= 1.0" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test -n "$openssl_LIBS"; then pkg_cv_openssl_LIBS="$openssl_LIBS" elif test -n "$PKG_CONFIG"; then if test -n "$PKG_CONFIG" && \ { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$PKG_CONFIG --exists --print-errors \"openssl >= 1.0\""; } >&5 ($PKG_CONFIG --exists --print-errors "openssl >= 1.0") 2>&5 ac_status=$? printf "%s\n" "$as_me:${as_lineno-$LINENO}: \$? = $ac_status" >&5 test $ac_status = 0; }; then pkg_cv_openssl_LIBS=`$PKG_CONFIG --libs "openssl >= 1.0" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes else pkg_failed=yes fi else pkg_failed=untried fi if test $pkg_failed = yes; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then _pkg_short_errors_supported=yes else _pkg_short_errors_supported=no fi if test $_pkg_short_errors_supported = yes; then openssl_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "openssl >= 1.0" 2>&1` else openssl_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "openssl >= 1.0" 2>&1` fi # Put the nasty error message in config.log where it belongs echo "$openssl_PKG_ERRORS" >&5 ac_cv_libcrypto=no ac_cv_libcrypto_evp=no elif test $pkg_failed = untried; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } ac_cv_libcrypto=no ac_cv_libcrypto_evp=no else openssl_CFLAGS=$pkg_cv_openssl_CFLAGS openssl_LIBS=$pkg_cv_openssl_LIBS { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: yes" >&5 printf "%s\n" "yes" >&6; } ac_cv_libcrypto=yes ac_cv_libcrypto_evp=yes fi fi if test "x$ac_cv_libcrypto" = xyes then : ac_cv_libcrypto_CPPFLAGS="$pkg_cv_openssl_CFLAGS" ac_cv_libcrypto_LIBADD="$pkg_cv_openssl_LIBS" fi fi if test "x$ac_cv_libcrypto" != xyes then : ac_fn_c_check_header_compile "$LINENO" "openssl/opensslv.h" "ac_cv_header_openssl_opensslv_h" "$ac_includes_default" if test "x$ac_cv_header_openssl_opensslv_h" = xyes then : printf "%s\n" "#define HAVE_OPENSSL_OPENSSLV_H 1" >>confdefs.h fi ac_fn_c_check_header_compile "$LINENO" "openssl/evp.h" "ac_cv_header_openssl_evp_h" "$ac_includes_default" if test "x$ac_cv_header_openssl_evp_h" = xyes then : printf "%s\n" "#define HAVE_OPENSSL_EVP_H 1" >>confdefs.h fi if test "x$ac_cv_header_openssl_evp_h" = xno then : ac_cv_libcrypto=no ac_cv_libcrypto_evp=no else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if openssl/evp.h can be used in combination with zlib.h" >&5 printf %s "checking if openssl/evp.h can be used in combination with zlib.h... " >&6; } if test ${ac_cv_openssl_evp_zlib_compatible+y} then : printf %s "(cached) " >&6 else $as_nop ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include int main (void) { ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_openssl_evp_zlib_compatible=yes else $as_nop ac_cv_openssl_evp_zlib_compatible=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_openssl_evp_zlib_compatible" >&5 printf "%s\n" "$ac_cv_openssl_evp_zlib_compatible" >&6; } if test "x$ac_cv_openssl_evp_zlib_compatible" = xyes then : ac_cv_libcrypto=yes ac_cv_libcrypto_evp=yes else $as_nop ac_cv_libcrypto=no ac_cv_libcrypto_evp=no fi fi if test "x$ac_cv_libcrypto_evp" != xyes && test "$ac_cv_header_openssl_opensslv" = xyes then : ac_cv_libcrypto=yes fi fi if test "x$ac_cv_libcrypto" = xyes && test "x$ac_cv_libcrypto_evp" = xyes then : printf "%s\n" "#define HAVE_OPENSSL_EVP_H 1" >>confdefs.h HAVE_OPENSSL_EVP_H=1 else $as_nop HAVE_OPENSSL_EVP_H=0 fi if test "x$ac_cv_libcrypto" != xno then : printf "%s\n" "#define HAVE_LIBCRYPTO 1" >>confdefs.h ac_cv_libcrypto_CPPFLAGS="$openssl_CFLAGS" ac_cv_libcrypto_LIBADD="$openssl_LIBS" if test "x$ac_cv_libcrypto_LIBADD" = x then : ac_cv_libcrypto_LIBADD="-lcrypto" fi case $host in #( *cygwin*) : ac_cv_libcrypto_LIBADD="$ac_cv_libcrypto_LIBADD -lz" ;; #( *) : ;; esac { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for dlopen in -ldl" >&5 printf %s "checking for dlopen in -ldl... " >&6; } if test ${ac_cv_lib_dl_dlopen+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-ldl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char dlopen (); int main (void) { return dlopen (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_dl_dlopen=yes else $as_nop ac_cv_lib_dl_dlopen=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlopen" >&5 printf "%s\n" "$ac_cv_lib_dl_dlopen" >&6; } if test "x$ac_cv_lib_dl_dlopen" = xyes then : LIBDL_LIBADD="-ldl" fi fi fi fi if test "x$ac_cv_libcrypto_CPPFLAGS" != "x" then : LIBCRYPTO_CPPFLAGS=$ac_cv_libcrypto_CPPFLAGS fi if test "x$ac_cv_libcrypto_LIBADD" != "x" then : LIBCRYPTO_LIBADD=$ac_cv_libcrypto_LIBADD fi if test "x$ac_cv_libcrypto" != xno then : ax_libcrypto_pc_libs_private=-lcrypto fi if test "x$ac_cv_libcrypto" != xno then : ax_libcrypto_spec_requires=openssl ax_libcrypto_spec_build_requires=openssl-devel fi if test "x$ac_cv_libcrypto" != xno then : if test "x$ac_cv_libcrypto_evp" = xyes && test "x$ac_cv_enable_openssl_evp_cipher" != xno && test "x$ac_cv_libcrypto_evp_cipher" != xyes then : ac_cv_libcrypto_evp_cipher=yes { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_new in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_new in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_new+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_new (); int main (void) { return EVP_CIPHER_CTX_new (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_new=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_new=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_new" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_new" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_new" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_dummy=no fi if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_new" = xyes then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_free in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_free in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_free+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_free (); int main (void) { return EVP_CIPHER_CTX_free (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_free=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_free=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_free" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_free" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_free" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_init in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_init in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_init+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_init (); int main (void) { return EVP_CIPHER_CTX_init (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_init=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_init=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_init" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_init" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_init" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_cleanup in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_cleanup in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_cleanup (); int main (void) { return EVP_CIPHER_CTX_cleanup (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for ERR_remove_thread_state in -lcrypto" >&5 printf %s "checking for ERR_remove_thread_state in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_ERR_remove_thread_state+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char ERR_remove_thread_state (); int main (void) { return ERR_remove_thread_state (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_ERR_remove_thread_state=yes else $as_nop ac_cv_lib_crypto_ERR_remove_thread_state=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_ERR_remove_thread_state" >&5 printf "%s\n" "$ac_cv_lib_crypto_ERR_remove_thread_state" >&6; } if test "x$ac_cv_lib_crypto_ERR_remove_thread_state" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CipherInit_ex2 in -lcrypto" >&5 printf %s "checking for EVP_CipherInit_ex2 in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CipherInit_ex2+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CipherInit_ex2 (); int main (void) { return EVP_CipherInit_ex2 (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CipherInit_ex2=yes else $as_nop ac_cv_lib_crypto_EVP_CipherInit_ex2=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CipherInit_ex2" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CipherInit_ex2" >&6; } if test "x$ac_cv_lib_crypto_EVP_CipherInit_ex2" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_dummy=no fi if test "x$ac_cv_lib_crypto_EVP_CipherInit_ex2" = xyes then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_reset in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_reset in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_reset+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_reset (); int main (void) { return EVP_CIPHER_CTX_reset (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_reset=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_reset=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_reset" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_reset" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_reset" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_fetch in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_fetch in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_fetch+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_fetch (); int main (void) { return EVP_CIPHER_fetch (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_fetch=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_fetch=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_fetch" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_fetch" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_fetch" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_free in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_free in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_free+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_free (); int main (void) { return EVP_CIPHER_free (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_free=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_free=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_free" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_free" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_free" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CipherInit_ex in -lcrypto" >&5 printf %s "checking for EVP_CipherInit_ex in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CipherInit_ex+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CipherInit_ex (); int main (void) { return EVP_CipherInit_ex (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CipherInit_ex=yes else $as_nop ac_cv_lib_crypto_EVP_CipherInit_ex=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CipherInit_ex" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CipherInit_ex" >&6; } if test "x$ac_cv_lib_crypto_EVP_CipherInit_ex" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_set_padding in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_set_padding in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_set_padding (); int main (void) { return EVP_CIPHER_CTX_set_padding (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CipherUpdate in -lcrypto" >&5 printf %s "checking for EVP_CipherUpdate in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CipherUpdate+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CipherUpdate (); int main (void) { return EVP_CipherUpdate (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CipherUpdate=yes else $as_nop ac_cv_lib_crypto_EVP_CipherUpdate=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CipherUpdate" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CipherUpdate" >&6; } if test "x$ac_cv_lib_crypto_EVP_CipherUpdate" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CipherFinal_ex in -lcrypto" >&5 printf %s "checking for EVP_CipherFinal_ex in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CipherFinal_ex+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CipherFinal_ex (); int main (void) { return EVP_CipherFinal_ex (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CipherFinal_ex=yes else $as_nop ac_cv_lib_crypto_EVP_CipherFinal_ex=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CipherFinal_ex" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CipherFinal_ex" >&6; } if test "x$ac_cv_lib_crypto_EVP_CipherFinal_ex" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi if test "x$ac_cv_enable_openssl_evp_cipher" = xyes && test "x$ac_cv_libcrypto_evp_cipher" = xno then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing OpenSSL EVP CIPHER support See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_init" = xyes then : printf "%s\n" "#define HAVE_EVP_CIPHER_CTX_INIT 1" >>confdefs.h fi if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup" = xyes then : printf "%s\n" "#define HAVE_EVP_CIPHER_CTX_CLEANUP 1" >>confdefs.h fi if test "x$ac_cv_lib_crypto_EVP_CipherInit_ex2" = xyes then : printf "%s\n" "#define HAVE_EVP_CIPHERINIT_EX2 1" >>confdefs.h fi fi if test "x$ac_cv_libcrypto_evp_cipher" != xyes then : ac_cv_libcrypto_aes_cbc=no else $as_nop ac_cv_libcrypto_aes_cbc=libcrypto_evp { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_aes_128_cbc in -lcrypto" >&5 printf %s "checking for EVP_aes_128_cbc in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_aes_128_cbc+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_aes_128_cbc (); int main (void) { return EVP_aes_128_cbc (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_aes_128_cbc=yes else $as_nop ac_cv_lib_crypto_EVP_aes_128_cbc=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_aes_128_cbc" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_aes_128_cbc" >&6; } if test "x$ac_cv_lib_crypto_EVP_aes_128_cbc" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_aes_cbc=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_aes_192_cbc in -lcrypto" >&5 printf %s "checking for EVP_aes_192_cbc in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_aes_192_cbc+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_aes_192_cbc (); int main (void) { return EVP_aes_192_cbc (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_aes_192_cbc=yes else $as_nop ac_cv_lib_crypto_EVP_aes_192_cbc=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_aes_192_cbc" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_aes_192_cbc" >&6; } if test "x$ac_cv_lib_crypto_EVP_aes_192_cbc" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_aes_cbc=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_aes_256_cbc in -lcrypto" >&5 printf %s "checking for EVP_aes_256_cbc in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_aes_256_cbc+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_aes_256_cbc (); int main (void) { return EVP_aes_256_cbc (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_aes_256_cbc=yes else $as_nop ac_cv_lib_crypto_EVP_aes_256_cbc=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_aes_256_cbc" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_aes_256_cbc" >&6; } if test "x$ac_cv_lib_crypto_EVP_aes_256_cbc" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_aes_cbc=no fi if test "x$ac_cv_lib_crypto_EVP_aes_128_cbc" = xyes && test "x$ac_cv_lib_crypto_EVP_aes_192_cbc" = xyes && test "x$ac_cv_lib_crypto_EVP_aes_256_cbc" = xyes then : printf "%s\n" "#define HAVE_EVP_CRYPTO_AES_CBC 1" >>confdefs.h fi fi if test "x$ac_cv_libcrypto_evp" = xyes && test "x$ac_cv_enable_openssl_evp_cipher" != xno && test "x$ac_cv_libcrypto_evp_cipher" != xyes then : ac_cv_libcrypto_evp_cipher=yes { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_new in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_new in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_new+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_new (); int main (void) { return EVP_CIPHER_CTX_new (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_new=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_new=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_new" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_new" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_new" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_dummy=no fi if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_new" = xyes then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_free in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_free in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_free+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_free (); int main (void) { return EVP_CIPHER_CTX_free (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_free=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_free=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_free" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_free" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_free" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_init in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_init in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_init+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_init (); int main (void) { return EVP_CIPHER_CTX_init (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_init=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_init=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_init" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_init" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_init" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_cleanup in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_cleanup in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_cleanup (); int main (void) { return EVP_CIPHER_CTX_cleanup (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for ERR_remove_thread_state in -lcrypto" >&5 printf %s "checking for ERR_remove_thread_state in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_ERR_remove_thread_state+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char ERR_remove_thread_state (); int main (void) { return ERR_remove_thread_state (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_ERR_remove_thread_state=yes else $as_nop ac_cv_lib_crypto_ERR_remove_thread_state=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_ERR_remove_thread_state" >&5 printf "%s\n" "$ac_cv_lib_crypto_ERR_remove_thread_state" >&6; } if test "x$ac_cv_lib_crypto_ERR_remove_thread_state" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CipherInit_ex2 in -lcrypto" >&5 printf %s "checking for EVP_CipherInit_ex2 in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CipherInit_ex2+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CipherInit_ex2 (); int main (void) { return EVP_CipherInit_ex2 (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CipherInit_ex2=yes else $as_nop ac_cv_lib_crypto_EVP_CipherInit_ex2=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CipherInit_ex2" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CipherInit_ex2" >&6; } if test "x$ac_cv_lib_crypto_EVP_CipherInit_ex2" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_dummy=no fi if test "x$ac_cv_lib_crypto_EVP_CipherInit_ex2" = xyes then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_reset in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_reset in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_reset+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_reset (); int main (void) { return EVP_CIPHER_CTX_reset (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_reset=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_reset=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_reset" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_reset" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_reset" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_fetch in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_fetch in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_fetch+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_fetch (); int main (void) { return EVP_CIPHER_fetch (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_fetch=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_fetch=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_fetch" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_fetch" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_fetch" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_free in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_free in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_free+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_free (); int main (void) { return EVP_CIPHER_free (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_free=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_free=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_free" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_free" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_free" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CipherInit_ex in -lcrypto" >&5 printf %s "checking for EVP_CipherInit_ex in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CipherInit_ex+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CipherInit_ex (); int main (void) { return EVP_CipherInit_ex (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CipherInit_ex=yes else $as_nop ac_cv_lib_crypto_EVP_CipherInit_ex=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CipherInit_ex" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CipherInit_ex" >&6; } if test "x$ac_cv_lib_crypto_EVP_CipherInit_ex" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_set_padding in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_set_padding in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_set_padding (); int main (void) { return EVP_CIPHER_CTX_set_padding (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CipherUpdate in -lcrypto" >&5 printf %s "checking for EVP_CipherUpdate in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CipherUpdate+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CipherUpdate (); int main (void) { return EVP_CipherUpdate (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CipherUpdate=yes else $as_nop ac_cv_lib_crypto_EVP_CipherUpdate=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CipherUpdate" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CipherUpdate" >&6; } if test "x$ac_cv_lib_crypto_EVP_CipherUpdate" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CipherFinal_ex in -lcrypto" >&5 printf %s "checking for EVP_CipherFinal_ex in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CipherFinal_ex+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CipherFinal_ex (); int main (void) { return EVP_CipherFinal_ex (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CipherFinal_ex=yes else $as_nop ac_cv_lib_crypto_EVP_CipherFinal_ex=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CipherFinal_ex" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CipherFinal_ex" >&6; } if test "x$ac_cv_lib_crypto_EVP_CipherFinal_ex" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi if test "x$ac_cv_enable_openssl_evp_cipher" = xyes && test "x$ac_cv_libcrypto_evp_cipher" = xno then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing OpenSSL EVP CIPHER support See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_init" = xyes then : printf "%s\n" "#define HAVE_EVP_CIPHER_CTX_INIT 1" >>confdefs.h fi if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup" = xyes then : printf "%s\n" "#define HAVE_EVP_CIPHER_CTX_CLEANUP 1" >>confdefs.h fi if test "x$ac_cv_lib_crypto_EVP_CipherInit_ex2" = xyes then : printf "%s\n" "#define HAVE_EVP_CIPHERINIT_EX2 1" >>confdefs.h fi fi if test "x$ac_cv_libcrypto_evp_cipher" != xyes then : ac_cv_libcrypto_aes_ecb=no else $as_nop ac_cv_libcrypto_aes_ecb=libcrypto_evp { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_aes_128_ecb in -lcrypto" >&5 printf %s "checking for EVP_aes_128_ecb in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_aes_128_ecb+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_aes_128_ecb (); int main (void) { return EVP_aes_128_ecb (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_aes_128_ecb=yes else $as_nop ac_cv_lib_crypto_EVP_aes_128_ecb=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_aes_128_ecb" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_aes_128_ecb" >&6; } if test "x$ac_cv_lib_crypto_EVP_aes_128_ecb" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_aes_ecb=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_aes_192_ecb in -lcrypto" >&5 printf %s "checking for EVP_aes_192_ecb in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_aes_192_ecb+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_aes_192_ecb (); int main (void) { return EVP_aes_192_ecb (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_aes_192_ecb=yes else $as_nop ac_cv_lib_crypto_EVP_aes_192_ecb=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_aes_192_ecb" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_aes_192_ecb" >&6; } if test "x$ac_cv_lib_crypto_EVP_aes_192_ecb" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_aes_ecb=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_aes_256_ecb in -lcrypto" >&5 printf %s "checking for EVP_aes_256_ecb in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_aes_256_ecb+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_aes_256_ecb (); int main (void) { return EVP_aes_256_ecb (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_aes_256_ecb=yes else $as_nop ac_cv_lib_crypto_EVP_aes_256_ecb=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_aes_256_ecb" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_aes_256_ecb" >&6; } if test "x$ac_cv_lib_crypto_EVP_aes_256_ecb" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_aes_ecb=no fi if test "x$ac_cv_lib_crypto_EVP_aes_128_ecb" = xyes && test "x$ac_cv_lib_crypto_EVP_aes_192_ecb" = xyes && test "x$ac_cv_lib_crypto_EVP_aes_256_ecb" = xyes then : printf "%s\n" "#define HAVE_EVP_CRYPTO_AES_ECB 1" >>confdefs.h fi fi if test "x$ac_cv_libcrypto_aes_cbc" = xno || test "x$ac_cv_libcrypto_aes_ecb" = xno then : ac_cv_libcrypto_aes=no else $as_nop ac_cv_libcrypto_aes=libcrypto_evp fi if test "x$ac_cv_libcrypto_aes_cbc" = xno || test "x$ac_cv_libcrypto_aes_ecb" = xno then : ac_fn_c_check_header_compile "$LINENO" "openssl/aes.h" "ac_cv_header_openssl_aes_h" "$ac_includes_default" if test "x$ac_cv_header_openssl_aes_h" = xyes then : printf "%s\n" "#define HAVE_OPENSSL_AES_H 1" >>confdefs.h fi if test "x$ac_cv_header_openssl_aes_h" = xno then : ac_cv_libcrypto_aes_cbc=no ac_cv_libcrypto_aes_ecb=no else $as_nop ac_cv_libcrypto_aes_cbc=libcrypto ac_cv_libcrypto_aes_ecb=libcrypto { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for AES_set_decrypt_key in -lcrypto" >&5 printf %s "checking for AES_set_decrypt_key in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_AES_set_decrypt_key+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char AES_set_decrypt_key (); int main (void) { return AES_set_decrypt_key (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_AES_set_decrypt_key=yes else $as_nop ac_cv_lib_crypto_AES_set_decrypt_key=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_AES_set_decrypt_key" >&5 printf "%s\n" "$ac_cv_lib_crypto_AES_set_decrypt_key" >&6; } if test "x$ac_cv_lib_crypto_AES_set_decrypt_key" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_aes_cbc=no, ac_cv_libcrypto_aes_ecb=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for AES_set_encrypt_key in -lcrypto" >&5 printf %s "checking for AES_set_encrypt_key in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_AES_set_encrypt_key+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char AES_set_encrypt_key (); int main (void) { return AES_set_encrypt_key (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_AES_set_encrypt_key=yes else $as_nop ac_cv_lib_crypto_AES_set_encrypt_key=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_AES_set_encrypt_key" >&5 printf "%s\n" "$ac_cv_lib_crypto_AES_set_encrypt_key" >&6; } if test "x$ac_cv_lib_crypto_AES_set_encrypt_key" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_aes_cbc=no, ac_cv_libcrypto_aes_ecb=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for AES_cbc_encrypt in -lcrypto" >&5 printf %s "checking for AES_cbc_encrypt in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_AES_cbc_encrypt+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char AES_cbc_encrypt (); int main (void) { return AES_cbc_encrypt (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_AES_cbc_encrypt=yes else $as_nop ac_cv_lib_crypto_AES_cbc_encrypt=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_AES_cbc_encrypt" >&5 printf "%s\n" "$ac_cv_lib_crypto_AES_cbc_encrypt" >&6; } if test "x$ac_cv_lib_crypto_AES_cbc_encrypt" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_aes_cbc=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for AES_ecb_encrypt in -lcrypto" >&5 printf %s "checking for AES_ecb_encrypt in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_AES_ecb_encrypt+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char AES_ecb_encrypt (); int main (void) { return AES_ecb_encrypt (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_AES_ecb_encrypt=yes else $as_nop ac_cv_lib_crypto_AES_ecb_encrypt=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_AES_ecb_encrypt" >&5 printf "%s\n" "$ac_cv_lib_crypto_AES_ecb_encrypt" >&6; } if test "x$ac_cv_lib_crypto_AES_ecb_encrypt" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_aes_ecb=no fi if test "x$ac_cv_lib_crypto_AES_cbc_encrypt" = xyes then : printf "%s\n" "#define HAVE_AES_CBC_ENCRYPT 1" >>confdefs.h fi if test "x$ac_cv_lib_crypto_AES_ecb_encrypt" = xyes then : printf "%s\n" "#define HAVE_AES_ECB_ENCRYPT 1" >>confdefs.h fi fi if test "x$ac_cv_libcrypto" = xno then : if test "x$ac_cv_libcrypto_aes_cbc" = xno || test "x$ac_cv_libcrypto_aes_ecb" = xno then : ac_cv_libcrypto=yes fi fi if test "x$ac_cv_libcrypto_aes_cbc" = xno || test "x$ac_cv_libcrypto_aes_ecb" = xno then : ac_cv_libcrypto_aes=no else $as_nop ac_cv_libcrypto_aes=libcrypto fi fi if test "x$ac_cv_libcrypto_evp" = xyes && test "x$ac_cv_enable_openssl_evp_cipher" != xno && test "x$ac_cv_libcrypto_evp_cipher" != xyes then : ac_cv_libcrypto_evp_cipher=yes { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_new in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_new in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_new+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_new (); int main (void) { return EVP_CIPHER_CTX_new (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_new=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_new=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_new" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_new" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_new" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_dummy=no fi if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_new" = xyes then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_free in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_free in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_free+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_free (); int main (void) { return EVP_CIPHER_CTX_free (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_free=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_free=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_free" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_free" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_free" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_init in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_init in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_init+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_init (); int main (void) { return EVP_CIPHER_CTX_init (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_init=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_init=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_init" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_init" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_init" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_cleanup in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_cleanup in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_cleanup (); int main (void) { return EVP_CIPHER_CTX_cleanup (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for ERR_remove_thread_state in -lcrypto" >&5 printf %s "checking for ERR_remove_thread_state in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_ERR_remove_thread_state+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char ERR_remove_thread_state (); int main (void) { return ERR_remove_thread_state (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_ERR_remove_thread_state=yes else $as_nop ac_cv_lib_crypto_ERR_remove_thread_state=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_ERR_remove_thread_state" >&5 printf "%s\n" "$ac_cv_lib_crypto_ERR_remove_thread_state" >&6; } if test "x$ac_cv_lib_crypto_ERR_remove_thread_state" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CipherInit_ex2 in -lcrypto" >&5 printf %s "checking for EVP_CipherInit_ex2 in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CipherInit_ex2+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CipherInit_ex2 (); int main (void) { return EVP_CipherInit_ex2 (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CipherInit_ex2=yes else $as_nop ac_cv_lib_crypto_EVP_CipherInit_ex2=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CipherInit_ex2" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CipherInit_ex2" >&6; } if test "x$ac_cv_lib_crypto_EVP_CipherInit_ex2" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_dummy=no fi if test "x$ac_cv_lib_crypto_EVP_CipherInit_ex2" = xyes then : { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_reset in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_reset in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_reset+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_reset (); int main (void) { return EVP_CIPHER_CTX_reset (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_reset=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_reset=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_reset" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_reset" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_reset" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_fetch in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_fetch in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_fetch+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_fetch (); int main (void) { return EVP_CIPHER_fetch (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_fetch=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_fetch=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_fetch" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_fetch" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_fetch" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_free in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_free in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_free+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_free (); int main (void) { return EVP_CIPHER_free (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_free=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_free=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_free" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_free" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_free" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi else $as_nop { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CipherInit_ex in -lcrypto" >&5 printf %s "checking for EVP_CipherInit_ex in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CipherInit_ex+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CipherInit_ex (); int main (void) { return EVP_CipherInit_ex (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CipherInit_ex=yes else $as_nop ac_cv_lib_crypto_EVP_CipherInit_ex=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CipherInit_ex" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CipherInit_ex" >&6; } if test "x$ac_cv_lib_crypto_EVP_CipherInit_ex" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CIPHER_CTX_set_padding in -lcrypto" >&5 printf %s "checking for EVP_CIPHER_CTX_set_padding in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CIPHER_CTX_set_padding (); int main (void) { return EVP_CIPHER_CTX_set_padding (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding=yes else $as_nop ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding" >&6; } if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_set_padding" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CipherUpdate in -lcrypto" >&5 printf %s "checking for EVP_CipherUpdate in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CipherUpdate+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CipherUpdate (); int main (void) { return EVP_CipherUpdate (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CipherUpdate=yes else $as_nop ac_cv_lib_crypto_EVP_CipherUpdate=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CipherUpdate" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CipherUpdate" >&6; } if test "x$ac_cv_lib_crypto_EVP_CipherUpdate" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_CipherFinal_ex in -lcrypto" >&5 printf %s "checking for EVP_CipherFinal_ex in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_CipherFinal_ex+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_CipherFinal_ex (); int main (void) { return EVP_CipherFinal_ex (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_CipherFinal_ex=yes else $as_nop ac_cv_lib_crypto_EVP_CipherFinal_ex=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_CipherFinal_ex" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_CipherFinal_ex" >&6; } if test "x$ac_cv_lib_crypto_EVP_CipherFinal_ex" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_evp_cipher=no fi if test "x$ac_cv_enable_openssl_evp_cipher" = xyes && test "x$ac_cv_libcrypto_evp_cipher" = xno then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing OpenSSL EVP CIPHER support See \`config.log' for more details" "$LINENO" 5; } fi if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_init" = xyes then : printf "%s\n" "#define HAVE_EVP_CIPHER_CTX_INIT 1" >>confdefs.h fi if test "x$ac_cv_lib_crypto_EVP_CIPHER_CTX_cleanup" = xyes then : printf "%s\n" "#define HAVE_EVP_CIPHER_CTX_CLEANUP 1" >>confdefs.h fi if test "x$ac_cv_lib_crypto_EVP_CipherInit_ex2" = xyes then : printf "%s\n" "#define HAVE_EVP_CIPHERINIT_EX2 1" >>confdefs.h fi fi if test "x$ac_cv_libcrypto_evp_cipher" != xyes then : ac_cv_libcrypto_aes_xts=no else $as_nop ac_cv_libcrypto_aes_xts=libcrypto_evp { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_aes_128_xts in -lcrypto" >&5 printf %s "checking for EVP_aes_128_xts in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_aes_128_xts+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_aes_128_xts (); int main (void) { return EVP_aes_128_xts (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_aes_128_xts=yes else $as_nop ac_cv_lib_crypto_EVP_aes_128_xts=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_aes_128_xts" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_aes_128_xts" >&6; } if test "x$ac_cv_lib_crypto_EVP_aes_128_xts" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_aes_xts=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for EVP_aes_256_xts in -lcrypto" >&5 printf %s "checking for EVP_aes_256_xts in -lcrypto... " >&6; } if test ${ac_cv_lib_crypto_EVP_aes_256_xts+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-lcrypto $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char EVP_aes_256_xts (); int main (void) { return EVP_aes_256_xts (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_crypto_EVP_aes_256_xts=yes else $as_nop ac_cv_lib_crypto_EVP_aes_256_xts=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_crypto_EVP_aes_256_xts" >&5 printf "%s\n" "$ac_cv_lib_crypto_EVP_aes_256_xts" >&6; } if test "x$ac_cv_lib_crypto_EVP_aes_256_xts" = xyes then : ac_cv_libcrypto_dummy=yes else $as_nop ac_cv_libcrypto_aes_xts=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking if \`EVP_CipherInit_ex' can be used with duplicate keys" >&5 printf %s "checking if \`EVP_CipherInit_ex' can be used with duplicate keys... " >&6; } if test ${ac_cv_openssl_xts_duplicate_keys+y} then : printf %s "(cached) " >&6 else $as_nop ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu ac_cv_libcrypto_backup_LIBS="$LIBS" LIBS="$LIBS $ac_cv_libcrypto_LIBADD" if test "$cross_compiling" = yes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "cannot run test program while cross compiling See \`config.log' for more details" "$LINENO" 5; } else $as_nop cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ #include #include #include int main (void) { unsigned char key[ 16 ] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15 }; int result = 0; #if defined( HAVE_EVP_CIPHER_CTX_INIT ) EVP_CIPHER_CTX ctx; EVP_CIPHER_CTX_init( &ctx ); #else EVP_CIPHER_CTX *ctx = EVP_CIPHER_CTX_new(); #endif result = EVP_CipherInit_ex(ctx, EVP_aes_128_xts(), NULL, key, key, 0); #if defined( HAVE_EVP_CIPHER_CTX_INIT ) EVP_CIPHER_CTX_cleanup( &ctx ); #else EVP_CIPHER_CTX_free( ctx ); #endif if( result != 1 ) return( EXIT_FAILURE ); return( EXIT_SUCCESS ); ; return 0; } _ACEOF if ac_fn_c_try_run "$LINENO" then : ac_cv_openssl_xts_duplicate_keys=yes else $as_nop ac_cv_openssl_xts_duplicate_keys=no fi rm -f core *.core core.conftest.* gmon.out bb.out conftest$ac_exeext \ conftest.$ac_objext conftest.beam conftest.$ac_ext fi LIBS="$ac_cv_libcrypto_backup_LIBS" ac_ext=c ac_cpp='$CPP $CPPFLAGS' ac_compile='$CC -c $CFLAGS $CPPFLAGS conftest.$ac_ext >&5' ac_link='$CC -o conftest$ac_exeext $CFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' ac_compiler_gnu=$ac_cv_c_compiler_gnu fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_openssl_xts_duplicate_keys" >&5 printf "%s\n" "$ac_cv_openssl_xts_duplicate_keys" >&6; } if test "x$ac_cv_openssl_xts_duplicate_keys" = xno then : ac_cv_libcrypto_aes_xts=no else $as_nop if test "x$ac_cv_lib_crypto_EVP_aes_128_xts" = xyes && test "x$ac_cv_lib_crypto_EVP_aes_256_xts" = xyes then : printf "%s\n" "#define HAVE_EVP_CRYPTO_AES_XTS 1" >>confdefs.h fi fi fi fi if test "x$ac_cv_libcrypto" = xno || test "x$ac_cv_libcrypto_aes_cbc" = xno then : ac_cv_libcaes_aes_cbc=local else $as_nop ac_cv_libcaes_aes_cbc=$ac_cv_libcrypto_aes_cbc fi if test "x$ac_cv_libcrypto" = xno || test "x$ac_cv_libcrypto_aes_ecb" = xno then : ac_cv_libcaes_aes_ecb=local else $as_nop ac_cv_libcaes_aes_ecb=$ac_cv_libcrypto_aes_ecb fi if test "x$ac_cv_libcrypto" = xno || test "x$ac_cv_libcrypto_aes_xts" = xno then : ac_cv_libcaes_aes_xts=local else $as_nop ac_cv_libcaes_aes_xts=$ac_cv_libcrypto_aes_xts fi # Check whether --with-pyprefix was given. if test ${with_pyprefix+y} then : withval=$with_pyprefix; ac_cv_with_pyprefix=$withval else $as_nop ac_cv_with_pyprefix=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether to use use \`python-config --prefix' to determine the prefix of pythondir instead of --prefix" >&5 printf %s "checking whether to use use \`python-config --prefix' to determine the prefix of pythondir instead of --prefix... " >&6; } if test ${ac_cv_with_pyprefix+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_with_pyprefix=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_with_pyprefix" >&5 printf "%s\n" "$ac_cv_with_pyprefix" >&6; } # Check whether --enable-python was given. if test ${enable_python+y} then : enableval=$enable_python; ac_cv_enable_python=$enableval else $as_nop ac_cv_enable_python=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether to enable build Python bindings" >&5 printf %s "checking whether to enable build Python bindings... " >&6; } if test ${ac_cv_enable_python+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_enable_python=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_enable_python" >&5 printf "%s\n" "$ac_cv_enable_python" >&6; } # Check whether --with-pythondir was given. if test ${with_pythondir+y} then : withval=$with_pythondir; ac_cv_with_pythondir=$withval else $as_nop ac_cv_with_pythondir=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking whether to use use to specify the Python directory (pythondir)" >&5 printf %s "checking whether to use use to specify the Python directory (pythondir)... " >&6; } if test ${ac_cv_with_pythondir+y} then : printf %s "(cached) " >&6 else $as_nop ac_cv_with_pythondir=no fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_with_pythondir" >&5 printf "%s\n" "$ac_cv_with_pythondir" >&6; } if test "x${ac_cv_enable_python}" != xno then : if test "x${PYTHON_VERSION}" != x then : ax_python_progs="python${PYTHON_VERSION}" else $as_nop ax_python_progs="python python3 python3.12 python3.11 python3.10 python3.9 python3.8 python3.7 python3.6 python3.5 python3.4 python3.3 python3.2 python3.1 python3.0 python2 python2.7 python2.6 python2.5" fi for ac_prog in $ax_python_progs do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_PYTHON+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$PYTHON"; then ac_cv_prog_PYTHON="$PYTHON" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_PYTHON="$ac_prog" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi PYTHON=$ac_cv_prog_PYTHON if test -n "$PYTHON"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $PYTHON" >&5 printf "%s\n" "$PYTHON" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -n "$PYTHON" && break done if test "x${PYTHON}" != x then : ax_prog_python_version=`${PYTHON} -c "import sys; sys.stdout.write('%d.%d' % (sys.version_info[0], sys.version_info[1]))" 2>/dev/null`; ax_prog_python_platform=`${PYTHON} -c "import sys; sys.stdout.write(sys.platform)" 2>/dev/null`; PYTHON_PLATFORM=$ax_prog_python_platform else $as_nop as_fn_error $? "Unable to find python" "$LINENO" 5 fi PYTHON=$PYTHON if test "x${PYTHON_CONFIG}" = x && test "x${PYTHON_VERSION}" != x then : for ac_prog in python${PYTHON_VERSION}-config do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_PYTHON_CONFIG+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$PYTHON_CONFIG"; then ac_cv_prog_PYTHON_CONFIG="$PYTHON_CONFIG" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_PYTHON_CONFIG="$ac_prog" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi PYTHON_CONFIG=$ac_cv_prog_PYTHON_CONFIG if test -n "$PYTHON_CONFIG"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $PYTHON_CONFIG" >&5 printf "%s\n" "$PYTHON_CONFIG" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -n "$PYTHON_CONFIG" && break done fi if test "x${PYTHON_CONFIG}" = x then : for ac_prog in python-config python3-config python3.12-config python3.11-config python3.10-config python3.9-config python3.8-config python3.7-config python3.6-config python3.5-config python3.4-config python3.3-config python3.2-config python3.1-config python3.0-config python2-config python2.7-config python2.6-config python2.5-config do # Extract the first word of "$ac_prog", so it can be a program name with args. set dummy $ac_prog; ac_word=$2 { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for $ac_word" >&5 printf %s "checking for $ac_word... " >&6; } if test ${ac_cv_prog_PYTHON_CONFIG+y} then : printf %s "(cached) " >&6 else $as_nop if test -n "$PYTHON_CONFIG"; then ac_cv_prog_PYTHON_CONFIG="$PYTHON_CONFIG" # Let the user override the test. else as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac for ac_exec_ext in '' $ac_executable_extensions; do if as_fn_executable_p "$as_dir$ac_word$ac_exec_ext"; then ac_cv_prog_PYTHON_CONFIG="$ac_prog" printf "%s\n" "$as_me:${as_lineno-$LINENO}: found $as_dir$ac_word$ac_exec_ext" >&5 break 2 fi done done IFS=$as_save_IFS fi fi PYTHON_CONFIG=$ac_cv_prog_PYTHON_CONFIG if test -n "$PYTHON_CONFIG"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $PYTHON_CONFIG" >&5 printf "%s\n" "$PYTHON_CONFIG" >&6; } else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: no" >&5 printf "%s\n" "no" >&6; } fi test -n "$PYTHON_CONFIG" && break done fi if test "x${PYTHON_CONFIG}" = x then : as_fn_error $? "Unable to find python-config" "$LINENO" 5 fi PYTHON_CONFIG=$PYTHON_CONFIG if test "x${PYTHON_CONFIG}" != x then : PYTHON_INCLUDES=`${PYTHON_CONFIG} --includes 2>/dev/null`; { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for Python includes" >&5 printf %s "checking for Python includes... " >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $PYTHON_INCLUDES" >&5 printf "%s\n" "$PYTHON_INCLUDES" >&6; } PYTHON_LDFLAGS=`${PYTHON_CONFIG} --ldflags 2>/dev/null`; { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for Python libraries" >&5 printf %s "checking for Python libraries... " >&6; } { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $PYTHON_LDFLAGS" >&5 printf "%s\n" "$PYTHON_LDFLAGS" >&6; } case $host_os in #( cygwin*) : PYTHON_LDFLAGS="${PYTHON_LDFLAGS} -no-undefined" ;; #( *) : ;; #( *) : ;; esac BACKUP_CPPFLAGS="${CPPFLAGS}" CPPFLAGS="${CPPFLAGS} ${PYTHON_INCLUDES}" for ac_header in Python.h do : ac_fn_c_check_header_compile "$LINENO" "Python.h" "ac_cv_header_Python_h" "$ac_includes_default" if test "x$ac_cv_header_Python_h" = xyes then : printf "%s\n" "#define HAVE_PYTHON_H 1" >>confdefs.h ac_cv_header_python_h=yes else $as_nop ac_cv_header_python_h=no fi done CPPFLAGS="${BACKUP_CPPFLAGS}" fi if test "x${ac_cv_header_python_h}" != xyes then : ac_cv_enable_python=no else $as_nop ac_cv_enable_python=${ax_prog_python_version} PYTHON_CPPFLAGS=$PYTHON_INCLUDES PYTHON_LDFLAGS=$PYTHON_LDFLAGS if test "x${ac_cv_with_pyprefix}" = x || test "x${ac_cv_with_pyprefix}" = xno then : ax_python_prefix="\${prefix}" else $as_nop ax_python_prefix=`${PYTHON_CONFIG} --prefix 2>/dev/null` fi PYTHON_PREFIX=$ax_python_prefix if test "x${ac_cv_with_pyprefix}" = x || test "x${ac_cv_with_pyprefix}" = xno then : ax_python_exec_prefix="\${exec_prefix}" else $as_nop ax_python_exec_prefix=`${PYTHON_CONFIG} --exec-prefix 2>/dev/null` fi PYTHON_EXEC_PREFIX=$ax_python_exec_prefix ax_python_pythondir_suffix=`${PYTHON} -c "import sys; import distutils.sysconfig; sys.stdout.write(distutils.sysconfig.get_python_lib(0, 0, prefix=''))" 2>/dev/null`; if test "x${ac_cv_with_pythondir}" = x || test "x${ac_cv_with_pythondir}" = xno then : if test "x${ac_cv_with_pyprefix}" = x || test "x${ac_cv_with_pyprefix}" = xno then : ax_python_pythondir="${ax_python_prefix}/${ax_python_pythondir_suffix}" else $as_nop ax_python_pythondir=`${PYTHON} -c "import sys; import distutils.sysconfig; sys.stdout.write(distutils.sysconfig.get_python_lib()) " 2>/dev/null` fi else $as_nop ax_python_pythondir=$ac_cv_with_pythondir fi pythondir=$ax_python_pythondir ax_python_pyexecdir_suffix=`${PYTHON} -c "import sys; import distutils.sysconfig; sys.stdout.write(distutils.sysconfig.get_python_lib(1, 0, prefix=''))" 2>/dev/null`; ax_python_library_dir=`${PYTHON} -c "import sys; import distutils.sysconfig; sys.stdout.write(distutils.sysconfig.get_python_lib(True)) " 2>/dev/null`; if test "x${ac_cv_with_pyprefix}" = x || test "x${ac_cv_with_pyprefix}" = xno then : ax_python_pyexecdir="${ax_python_exec_prefix}/${ax_python_pyexecdir_suffix}" else $as_nop ax_python_pyexecdir=$ax_python_library_dir fi pyexecdir=$ax_python_pyexecdir PYTHON_LIBRARY_DIR=$ax_python_pyexecdir_suffix PYTHON_PACKAGE_DIR=$ax_python_library_dir fi fi if test "x${ac_cv_enable_python}" != xno; then HAVE_PYTHON_TRUE= HAVE_PYTHON_FALSE='#' else HAVE_PYTHON_TRUE='#' HAVE_PYTHON_FALSE= fi if test "x${ac_cv_enable_python}" != xno; then HAVE_PYTHON_TESTS_TRUE= HAVE_PYTHON_TESTS_FALSE='#' else HAVE_PYTHON_TESTS_TRUE='#' HAVE_PYTHON_TESTS_FALSE= fi if test "x${ac_cv_enable_python}" != xno then : ac_fn_c_check_header_compile "$LINENO" "stdarg.h" "ac_cv_header_stdarg_h" "$ac_includes_default" if test "x$ac_cv_header_stdarg_h" = xyes then : printf "%s\n" "#define HAVE_STDARG_H 1" >>confdefs.h fi ac_fn_c_check_header_compile "$LINENO" "varargs.h" "ac_cv_header_varargs_h" "$ac_includes_default" if test "x$ac_cv_header_varargs_h" = xyes then : printf "%s\n" "#define HAVE_VARARGS_H 1" >>confdefs.h fi if test "x$ac_cv_header_stdarg_h" != xyes && test "x$ac_cv_header_varargs_h" != xyes then : { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error 1 "Missing headers: stdarg.h and varargs.h See \`config.log' for more details" "$LINENO" 5; } fi fi if test "x$enable_shared" = xyes then : case $host in #( *cygwin* | *mingw* | *msys*) : printf "%s\n" "#define HAVE_DLLMAIN 1" >>confdefs.h HAVE_DLLMAIN=1 LIBCAES_DLL_EXPORT="-DLIBCAES_DLL_EXPORT" LIBCAES_DLL_IMPORT="-DLIBCAES_DLL_IMPORT" ;; #( *) : ;; esac fi ac_fn_c_check_header_compile "$LINENO" "dlfcn.h" "ac_cv_header_dlfcn_h" "$ac_includes_default" if test "x$ac_cv_header_dlfcn_h" = xyes then : printf "%s\n" "#define HAVE_DLFCN_H 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "fmemopen" "ac_cv_func_fmemopen" if test "x$ac_cv_func_fmemopen" = xyes then : printf "%s\n" "#define HAVE_FMEMOPEN 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "getopt" "ac_cv_func_getopt" if test "x$ac_cv_func_getopt" = xyes then : printf "%s\n" "#define HAVE_GETOPT 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "mkstemp" "ac_cv_func_mkstemp" if test "x$ac_cv_func_mkstemp" = xyes then : printf "%s\n" "#define HAVE_MKSTEMP 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "setenv" "ac_cv_func_setenv" if test "x$ac_cv_func_setenv" = xyes then : printf "%s\n" "#define HAVE_SETENV 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "tzset" "ac_cv_func_tzset" if test "x$ac_cv_func_tzset" = xyes then : printf "%s\n" "#define HAVE_TZSET 1" >>confdefs.h fi ac_fn_c_check_func "$LINENO" "unlink" "ac_cv_func_unlink" if test "x$ac_cv_func_unlink" = xyes then : printf "%s\n" "#define HAVE_UNLINK 1" >>confdefs.h fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking for dlsym in -ldl" >&5 printf %s "checking for dlsym in -ldl... " >&6; } if test ${ac_cv_lib_dl_dlsym+y} then : printf %s "(cached) " >&6 else $as_nop ac_check_lib_save_LIBS=$LIBS LIBS="-ldl $LIBS" cat confdefs.h - <<_ACEOF >conftest.$ac_ext /* end confdefs.h. */ /* Override any GCC internal prototype to avoid an error. Use char because int might match the return type of a GCC builtin and then its argument prototype would still apply. */ char dlsym (); int main (void) { return dlsym (); ; return 0; } _ACEOF if ac_fn_c_try_link "$LINENO" then : ac_cv_lib_dl_dlsym=yes else $as_nop ac_cv_lib_dl_dlsym=no fi rm -f core conftest.err conftest.$ac_objext conftest.beam \ conftest$ac_exeext conftest.$ac_ext LIBS=$ac_check_lib_save_LIBS fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: $ac_cv_lib_dl_dlsym" >&5 printf "%s\n" "$ac_cv_lib_dl_dlsym" >&6; } if test "x$ac_cv_lib_dl_dlsym" = xyes then : printf "%s\n" "#define HAVE_LIBDL 1" >>confdefs.h LIBS="-ldl $LIBS" fi if test "x$lt_cv_prog_gnu_ld" = xyes && test "x$ac_cv_lib_dl_dlsym" = xyes then : printf "%s\n" "#define HAVE_GNU_DL_DLSYM 1" >>confdefs.h fi if test "x${LIB_FUZZING_ENGINE}" != x; then HAVE_LIB_FUZZING_ENGINE_TRUE= HAVE_LIB_FUZZING_ENGINE_FALSE='#' else HAVE_LIB_FUZZING_ENGINE_TRUE='#' HAVE_LIB_FUZZING_ENGINE_FALSE= fi LIB_FUZZING_ENGINE="${LIB_FUZZING_ENGINE}" CFLAGS="$CFLAGS -Wall"; if test "x$ac_cv_libcerror" = xyes || test "x$ac_cv_libcrypto" != xno then : libcaes_spec_requires=Requires: fi DPKG_DATE=`date -R 2> /dev/null` SPEC_DATE=`date +"%a %b %e %Y" 2> /dev/null` ac_config_files="$ac_config_files Makefile" ac_config_files="$ac_config_files include/Makefile" ac_config_files="$ac_config_files common/Makefile" ac_config_files="$ac_config_files libcerror/Makefile" ac_config_files="$ac_config_files libcaes/Makefile" ac_config_files="$ac_config_files pycaes/Makefile" ac_config_files="$ac_config_files po/Makefile.in" ac_config_files="$ac_config_files po/Makevars" ac_config_files="$ac_config_files manuals/Makefile" ac_config_files="$ac_config_files tests/Makefile" ac_config_files="$ac_config_files ossfuzz/Makefile" ac_config_files="$ac_config_files msvscpp/Makefile" ac_config_files="$ac_config_files include/libcaes.h" ac_config_files="$ac_config_files include/libcaes/definitions.h" ac_config_files="$ac_config_files include/libcaes/features.h" ac_config_files="$ac_config_files include/libcaes/types.h" ac_config_files="$ac_config_files libcaes/libcaes_definitions.h" ac_config_files="$ac_config_files common/types.h" ac_config_files="$ac_config_files dpkg/changelog" ac_config_files="$ac_config_files libcaes/libcaes.rc" ac_config_files="$ac_config_files libcaes.pc" ac_config_files="$ac_config_files libcaes.spec" ac_config_files="$ac_config_files setup.cfg" ac_config_headers="$ac_config_headers common/config.h" cat >confcache <<\_ACEOF # This file is a shell script that caches the results of configure # tests run on this system so they can be shared between configure # scripts and configure runs, see configure's option --config-cache. # It is not useful on other systems. If it contains results you don't # want to keep, you may remove or edit it. # # config.status only pays attention to the cache file if you give it # the --recheck option to rerun configure. # # `ac_cv_env_foo' variables (set or unset) will be overridden when # loading this file, other *unset* `ac_cv_foo' will be assigned the # following values. _ACEOF # The following way of writing the cache mishandles newlines in values, # but we know of no workaround that is simple, portable, and efficient. # So, we kill variables containing newlines. # Ultrix sh set writes to stderr and can't be redirected directly, # and sets the high bit in the cache file unless we assign to the vars. ( for ac_var in `(set) 2>&1 | sed -n 's/^\([a-zA-Z_][a-zA-Z0-9_]*\)=.*/\1/p'`; do eval ac_val=\$$ac_var case $ac_val in #( *${as_nl}*) case $ac_var in #( *_cv_*) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: cache variable $ac_var contains a newline" >&5 printf "%s\n" "$as_me: WARNING: cache variable $ac_var contains a newline" >&2;} ;; esac case $ac_var in #( _ | IFS | as_nl) ;; #( BASH_ARGV | BASH_SOURCE) eval $ac_var= ;; #( *) { eval $ac_var=; unset $ac_var;} ;; esac ;; esac done (set) 2>&1 | case $as_nl`(ac_space=' '; set) 2>&1` in #( *${as_nl}ac_space=\ *) # `set' does not quote correctly, so add quotes: double-quote # substitution turns \\\\ into \\, and sed turns \\ into \. sed -n \ "s/'/'\\\\''/g; s/^\\([_$as_cr_alnum]*_cv_[_$as_cr_alnum]*\\)=\\(.*\\)/\\1='\\2'/p" ;; #( *) # `set' quotes correctly as required by POSIX, so do not add quotes. sed -n "/^[_$as_cr_alnum]*_cv_[_$as_cr_alnum]*=/p" ;; esac | sort ) | sed ' /^ac_cv_env_/b end t clear :clear s/^\([^=]*\)=\(.*[{}].*\)$/test ${\1+y} || &/ t end s/^\([^=]*\)=\(.*\)$/\1=${\1=\2}/ :end' >>confcache if diff "$cache_file" confcache >/dev/null 2>&1; then :; else if test -w "$cache_file"; then if test "x$cache_file" != "x/dev/null"; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: updating cache $cache_file" >&5 printf "%s\n" "$as_me: updating cache $cache_file" >&6;} if test ! -f "$cache_file" || test -h "$cache_file"; then cat confcache >"$cache_file" else case $cache_file in #( */* | ?:*) mv -f confcache "$cache_file"$$ && mv -f "$cache_file"$$ "$cache_file" ;; #( *) mv -f confcache "$cache_file" ;; esac fi fi else { printf "%s\n" "$as_me:${as_lineno-$LINENO}: not updating unwritable cache $cache_file" >&5 printf "%s\n" "$as_me: not updating unwritable cache $cache_file" >&6;} fi fi rm -f confcache test "x$prefix" = xNONE && prefix=$ac_default_prefix # Let make expand exec_prefix. test "x$exec_prefix" = xNONE && exec_prefix='${prefix}' DEFS=-DHAVE_CONFIG_H ac_libobjs= ac_ltlibobjs= U= for ac_i in : $LIBOBJS; do test "x$ac_i" = x: && continue # 1. Remove the extension, and $U if already installed. ac_script='s/\$U\././;s/\.o$//;s/\.obj$//' ac_i=`printf "%s\n" "$ac_i" | sed "$ac_script"` # 2. Prepend LIBOBJDIR. When used with automake>=1.10 LIBOBJDIR # will be set to the directory where LIBOBJS objects are built. as_fn_append ac_libobjs " \${LIBOBJDIR}$ac_i\$U.$ac_objext" as_fn_append ac_ltlibobjs " \${LIBOBJDIR}$ac_i"'$U.lo' done LIBOBJS=$ac_libobjs LTLIBOBJS=$ac_ltlibobjs { printf "%s\n" "$as_me:${as_lineno-$LINENO}: checking that generated files are newer than configure" >&5 printf %s "checking that generated files are newer than configure... " >&6; } if test -n "$am_sleep_pid"; then # Hide warnings about reused PIDs. wait $am_sleep_pid 2>/dev/null fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: result: done" >&5 printf "%s\n" "done" >&6; } if test -n "$EXEEXT"; then am__EXEEXT_TRUE= am__EXEEXT_FALSE='#' else am__EXEEXT_TRUE='#' am__EXEEXT_FALSE= fi if test -z "${AMDEP_TRUE}" && test -z "${AMDEP_FALSE}"; then as_fn_error $? "conditional \"AMDEP\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then as_fn_error $? "conditional \"am__fastdepCC\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${am__fastdepCC_TRUE}" && test -z "${am__fastdepCC_FALSE}"; then as_fn_error $? "conditional \"am__fastdepCC\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${am__fastdepCXX_TRUE}" && test -z "${am__fastdepCXX_FALSE}"; then as_fn_error $? "conditional \"am__fastdepCXX\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${HAVE_LOCAL_LIBCERROR_TRUE}" && test -z "${HAVE_LOCAL_LIBCERROR_FALSE}"; then as_fn_error $? "conditional \"HAVE_LOCAL_LIBCERROR\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${HAVE_PYTHON_TRUE}" && test -z "${HAVE_PYTHON_FALSE}"; then as_fn_error $? "conditional \"HAVE_PYTHON\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${HAVE_PYTHON_TESTS_TRUE}" && test -z "${HAVE_PYTHON_TESTS_FALSE}"; then as_fn_error $? "conditional \"HAVE_PYTHON_TESTS\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi if test -z "${HAVE_LIB_FUZZING_ENGINE_TRUE}" && test -z "${HAVE_LIB_FUZZING_ENGINE_FALSE}"; then as_fn_error $? "conditional \"HAVE_LIB_FUZZING_ENGINE\" was never defined. Usually this means the macro was only invoked conditionally." "$LINENO" 5 fi : "${CONFIG_STATUS=./config.status}" ac_write_fail=0 ac_clean_files_save=$ac_clean_files ac_clean_files="$ac_clean_files $CONFIG_STATUS" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: creating $CONFIG_STATUS" >&5 printf "%s\n" "$as_me: creating $CONFIG_STATUS" >&6;} as_write_fail=0 cat >$CONFIG_STATUS <<_ASEOF || as_write_fail=1 #! $SHELL # Generated by $as_me. # Run this file to recreate the current configuration. # Compiler output produced by configure, useful for debugging # configure, is in config.log if it exists. debug=false ac_cs_recheck=false ac_cs_silent=false SHELL=\${CONFIG_SHELL-$SHELL} export SHELL _ASEOF cat >>$CONFIG_STATUS <<\_ASEOF || as_write_fail=1 ## -------------------- ## ## M4sh Initialization. ## ## -------------------- ## # Be more Bourne compatible DUALCASE=1; export DUALCASE # for MKS sh as_nop=: if test ${ZSH_VERSION+y} && (emulate sh) >/dev/null 2>&1 then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else $as_nop case `(set -o) 2>/dev/null` in #( *posix*) : set -o posix ;; #( *) : ;; esac fi # Reset variables that may have inherited troublesome values from # the environment. # IFS needs to be set, to space, tab, and newline, in precisely that order. # (If _AS_PATH_WALK were called with IFS unset, it would have the # side effect of setting IFS to empty, thus disabling word splitting.) # Quoting is to prevent editors from complaining about space-tab. as_nl=' ' export as_nl IFS=" "" $as_nl" PS1='$ ' PS2='> ' PS4='+ ' # Ensure predictable behavior from utilities with locale-dependent output. LC_ALL=C export LC_ALL LANGUAGE=C export LANGUAGE # We cannot yet rely on "unset" to work, but we need these variables # to be unset--not just set to an empty or harmless value--now, to # avoid bugs in old shells (e.g. pre-3.0 UWIN ksh). This construct # also avoids known problems related to "unset" and subshell syntax # in other old shells (e.g. bash 2.01 and pdksh 5.2.14). for as_var in BASH_ENV ENV MAIL MAILPATH CDPATH do eval test \${$as_var+y} \ && ( (unset $as_var) || exit 1) >/dev/null 2>&1 && unset $as_var || : done # Ensure that fds 0, 1, and 2 are open. if (exec 3>&0) 2>/dev/null; then :; else exec 0&1) 2>/dev/null; then :; else exec 1>/dev/null; fi if (exec 3>&2) ; then :; else exec 2>/dev/null; fi # The user is always right. if ${PATH_SEPARATOR+false} :; then PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || PATH_SEPARATOR=';' } fi # Find who we are. Look in the path if we contain no directory separator. as_myself= case $0 in #(( *[\\/]* ) as_myself=$0 ;; *) as_save_IFS=$IFS; IFS=$PATH_SEPARATOR for as_dir in $PATH do IFS=$as_save_IFS case $as_dir in #((( '') as_dir=./ ;; */) ;; *) as_dir=$as_dir/ ;; esac test -r "$as_dir$0" && as_myself=$as_dir$0 && break done IFS=$as_save_IFS ;; esac # We did not find ourselves, most probably we were run as `sh COMMAND' # in which case we are not to be found in the path. if test "x$as_myself" = x; then as_myself=$0 fi if test ! -f "$as_myself"; then printf "%s\n" "$as_myself: error: cannot find myself; rerun with an absolute file name" >&2 exit 1 fi # as_fn_error STATUS ERROR [LINENO LOG_FD] # ---------------------------------------- # Output "`basename $0`: error: ERROR" to stderr. If LINENO and LOG_FD are # provided, also output the error to LOG_FD, referencing LINENO. Then exit the # script with STATUS, using 1 if that was 0. as_fn_error () { as_status=$1; test $as_status -eq 0 && as_status=1 if test "$4"; then as_lineno=${as_lineno-"$3"} as_lineno_stack=as_lineno_stack=$as_lineno_stack printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: $2" >&$4 fi printf "%s\n" "$as_me: error: $2" >&2 as_fn_exit $as_status } # as_fn_error # as_fn_set_status STATUS # ----------------------- # Set $? to STATUS, without forking. as_fn_set_status () { return $1 } # as_fn_set_status # as_fn_exit STATUS # ----------------- # Exit the shell with STATUS, even in a "trap 0" or "set -e" context. as_fn_exit () { set +e as_fn_set_status $1 exit $1 } # as_fn_exit # as_fn_unset VAR # --------------- # Portably unset VAR. as_fn_unset () { { eval $1=; unset $1;} } as_unset=as_fn_unset # as_fn_append VAR VALUE # ---------------------- # Append the text in VALUE to the end of the definition contained in VAR. Take # advantage of any shell optimizations that allow amortized linear growth over # repeated appends, instead of the typical quadratic growth present in naive # implementations. if (eval "as_var=1; as_var+=2; test x\$as_var = x12") 2>/dev/null then : eval 'as_fn_append () { eval $1+=\$2 }' else $as_nop as_fn_append () { eval $1=\$$1\$2 } fi # as_fn_append # as_fn_arith ARG... # ------------------ # Perform arithmetic evaluation on the ARGs, and store the result in the # global $as_val. Take advantage of shells that can avoid forks. The arguments # must be portable across $(()) and expr. if (eval "test \$(( 1 + 1 )) = 2") 2>/dev/null then : eval 'as_fn_arith () { as_val=$(( $* )) }' else $as_nop as_fn_arith () { as_val=`expr "$@" || test $? -eq 1` } fi # as_fn_arith if expr a : '\(a\)' >/dev/null 2>&1 && test "X`expr 00001 : '.*\(...\)'`" = X001; then as_expr=expr else as_expr=false fi if (basename -- /) >/dev/null 2>&1 && test "X`basename -- / 2>&1`" = "X/"; then as_basename=basename else as_basename=false fi if (as_dir=`dirname -- /` && test "X$as_dir" = X/) >/dev/null 2>&1; then as_dirname=dirname else as_dirname=false fi as_me=`$as_basename -- "$0" || $as_expr X/"$0" : '.*/\([^/][^/]*\)/*$' \| \ X"$0" : 'X\(//\)$' \| \ X"$0" : 'X\(/\)' \| . 2>/dev/null || printf "%s\n" X/"$0" | sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/ q } /^X\/\(\/\/\)$/{ s//\1/ q } /^X\/\(\/\).*/{ s//\1/ q } s/.*/./; q'` # Avoid depending upon Character Ranges. as_cr_letters='abcdefghijklmnopqrstuvwxyz' as_cr_LETTERS='ABCDEFGHIJKLMNOPQRSTUVWXYZ' as_cr_Letters=$as_cr_letters$as_cr_LETTERS as_cr_digits='0123456789' as_cr_alnum=$as_cr_Letters$as_cr_digits # Determine whether it's possible to make 'echo' print without a newline. # These variables are no longer used directly by Autoconf, but are AC_SUBSTed # for compatibility with existing Makefiles. ECHO_C= ECHO_N= ECHO_T= case `echo -n x` in #((((( -n*) case `echo 'xy\c'` in *c*) ECHO_T=' ';; # ECHO_T is single tab character. xy) ECHO_C='\c';; *) echo `echo ksh88 bug on AIX 6.1` > /dev/null ECHO_T=' ';; esac;; *) ECHO_N='-n';; esac # For backward compatibility with old third-party macros, we provide # the shell variables $as_echo and $as_echo_n. New code should use # AS_ECHO(["message"]) and AS_ECHO_N(["message"]), respectively. as_echo='printf %s\n' as_echo_n='printf %s' rm -f conf$$ conf$$.exe conf$$.file if test -d conf$$.dir; then rm -f conf$$.dir/conf$$.file else rm -f conf$$.dir mkdir conf$$.dir 2>/dev/null fi if (echo >conf$$.file) 2>/dev/null; then if ln -s conf$$.file conf$$ 2>/dev/null; then as_ln_s='ln -s' # ... but there are two gotchas: # 1) On MSYS, both `ln -s file dir' and `ln file dir' fail. # 2) DJGPP < 2.04 has no symlinks; `ln -s' creates a wrapper executable. # In both cases, we have to default to `cp -pR'. ln -s conf$$.file conf$$.dir 2>/dev/null && test ! -f conf$$.exe || as_ln_s='cp -pR' elif ln conf$$.file conf$$ 2>/dev/null; then as_ln_s=ln else as_ln_s='cp -pR' fi else as_ln_s='cp -pR' fi rm -f conf$$ conf$$.exe conf$$.dir/conf$$.file conf$$.file rmdir conf$$.dir 2>/dev/null # as_fn_mkdir_p # ------------- # Create "$as_dir" as a directory, including parents if necessary. as_fn_mkdir_p () { case $as_dir in #( -*) as_dir=./$as_dir;; esac test -d "$as_dir" || eval $as_mkdir_p || { as_dirs= while :; do case $as_dir in #( *\'*) as_qdir=`printf "%s\n" "$as_dir" | sed "s/'/'\\\\\\\\''/g"`;; #'( *) as_qdir=$as_dir;; esac as_dirs="'$as_qdir' $as_dirs" as_dir=`$as_dirname -- "$as_dir" || $as_expr X"$as_dir" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$as_dir" : 'X\(//\)[^/]' \| \ X"$as_dir" : 'X\(//\)$' \| \ X"$as_dir" : 'X\(/\)' \| . 2>/dev/null || printf "%s\n" X"$as_dir" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` test -d "$as_dir" && break done test -z "$as_dirs" || eval "mkdir $as_dirs" } || test -d "$as_dir" || as_fn_error $? "cannot create directory $as_dir" } # as_fn_mkdir_p if mkdir -p . 2>/dev/null; then as_mkdir_p='mkdir -p "$as_dir"' else test -d ./-p && rmdir ./-p as_mkdir_p=false fi # as_fn_executable_p FILE # ----------------------- # Test if FILE is an executable regular file. as_fn_executable_p () { test -f "$1" && test -x "$1" } # as_fn_executable_p as_test_x='test -x' as_executable_p=as_fn_executable_p # Sed expression to map a string onto a valid CPP name. as_tr_cpp="eval sed 'y%*$as_cr_letters%P$as_cr_LETTERS%;s%[^_$as_cr_alnum]%_%g'" # Sed expression to map a string onto a valid variable name. as_tr_sh="eval sed 'y%*+%pp%;s%[^_$as_cr_alnum]%_%g'" exec 6>&1 ## ----------------------------------- ## ## Main body of $CONFIG_STATUS script. ## ## ----------------------------------- ## _ASEOF test $as_write_fail = 0 && chmod +x $CONFIG_STATUS || ac_write_fail=1 cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # Save the log message, to keep $0 and so on meaningful, and to # report actual input values of CONFIG_FILES etc. instead of their # values after options handling. ac_log=" This file was extended by libcaes $as_me 20240413, which was generated by GNU Autoconf 2.71. Invocation command line was CONFIG_FILES = $CONFIG_FILES CONFIG_HEADERS = $CONFIG_HEADERS CONFIG_LINKS = $CONFIG_LINKS CONFIG_COMMANDS = $CONFIG_COMMANDS $ $0 $@ on `(hostname || uname -n) 2>/dev/null | sed 1q` " _ACEOF case $ac_config_files in *" "*) set x $ac_config_files; shift; ac_config_files=$*;; esac case $ac_config_headers in *" "*) set x $ac_config_headers; shift; ac_config_headers=$*;; esac cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 # Files that config.status was made for. config_files="$ac_config_files" config_headers="$ac_config_headers" config_commands="$ac_config_commands" _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 ac_cs_usage="\ \`$as_me' instantiates files and other configuration actions from templates according to the current configuration. Unless the files and actions are specified as TAGs, all are instantiated by default. Usage: $0 [OPTION]... [TAG]... -h, --help print this help, then exit -V, --version print version number and configuration settings, then exit --config print configuration, then exit -q, --quiet, --silent do not print progress messages -d, --debug don't remove temporary files --recheck update $as_me by reconfiguring in the same conditions --file=FILE[:TEMPLATE] instantiate the configuration file FILE --header=FILE[:TEMPLATE] instantiate the configuration header FILE Configuration files: $config_files Configuration headers: $config_headers Configuration commands: $config_commands Report bugs to ." _ACEOF ac_cs_config=`printf "%s\n" "$ac_configure_args" | sed "$ac_safe_unquote"` ac_cs_config_escaped=`printf "%s\n" "$ac_cs_config" | sed "s/^ //; s/'/'\\\\\\\\''/g"` cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_cs_config='$ac_cs_config_escaped' ac_cs_version="\\ libcaes config.status 20240413 configured by $0, generated by GNU Autoconf 2.71, with options \\"\$ac_cs_config\\" Copyright (C) 2021 Free Software Foundation, Inc. This config.status script is free software; the Free Software Foundation gives unlimited permission to copy, distribute and modify it." ac_pwd='$ac_pwd' srcdir='$srcdir' INSTALL='$INSTALL' MKDIR_P='$MKDIR_P' AWK='$AWK' test -n "\$AWK" || AWK=awk _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # The default lists apply if the user does not specify any file. ac_need_defaults=: while test $# != 0 do case $1 in --*=?*) ac_option=`expr "X$1" : 'X\([^=]*\)='` ac_optarg=`expr "X$1" : 'X[^=]*=\(.*\)'` ac_shift=: ;; --*=) ac_option=`expr "X$1" : 'X\([^=]*\)='` ac_optarg= ac_shift=: ;; *) ac_option=$1 ac_optarg=$2 ac_shift=shift ;; esac case $ac_option in # Handling of the options. -recheck | --recheck | --rechec | --reche | --rech | --rec | --re | --r) ac_cs_recheck=: ;; --version | --versio | --versi | --vers | --ver | --ve | --v | -V ) printf "%s\n" "$ac_cs_version"; exit ;; --config | --confi | --conf | --con | --co | --c ) printf "%s\n" "$ac_cs_config"; exit ;; --debug | --debu | --deb | --de | --d | -d ) debug=: ;; --file | --fil | --fi | --f ) $ac_shift case $ac_optarg in *\'*) ac_optarg=`printf "%s\n" "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; '') as_fn_error $? "missing file argument" ;; esac as_fn_append CONFIG_FILES " '$ac_optarg'" ac_need_defaults=false;; --header | --heade | --head | --hea ) $ac_shift case $ac_optarg in *\'*) ac_optarg=`printf "%s\n" "$ac_optarg" | sed "s/'/'\\\\\\\\''/g"` ;; esac as_fn_append CONFIG_HEADERS " '$ac_optarg'" ac_need_defaults=false;; --he | --h) # Conflict between --help and --header as_fn_error $? "ambiguous option: \`$1' Try \`$0 --help' for more information.";; --help | --hel | -h ) printf "%s\n" "$ac_cs_usage"; exit ;; -q | -quiet | --quiet | --quie | --qui | --qu | --q \ | -silent | --silent | --silen | --sile | --sil | --si | --s) ac_cs_silent=: ;; # This is an error. -*) as_fn_error $? "unrecognized option: \`$1' Try \`$0 --help' for more information." ;; *) as_fn_append ac_config_targets " $1" ac_need_defaults=false ;; esac shift done ac_configure_extra_args= if $ac_cs_silent; then exec 6>/dev/null ac_configure_extra_args="$ac_configure_extra_args --silent" fi _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 if \$ac_cs_recheck; then set X $SHELL '$0' $ac_configure_args \$ac_configure_extra_args --no-create --no-recursion shift \printf "%s\n" "running CONFIG_SHELL=$SHELL \$*" >&6 CONFIG_SHELL='$SHELL' export CONFIG_SHELL exec "\$@" fi _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 exec 5>>config.log { echo sed 'h;s/./-/g;s/^.../## /;s/...$/ ##/;p;x;p;x' <<_ASBOX ## Running $as_me. ## _ASBOX printf "%s\n" "$ac_log" } >&5 _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 # # INIT-COMMANDS # AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}" # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH sed_quote_subst='$sed_quote_subst' double_quote_subst='$double_quote_subst' delay_variable_subst='$delay_variable_subst' macro_version='`$ECHO "$macro_version" | $SED "$delay_single_quote_subst"`' macro_revision='`$ECHO "$macro_revision" | $SED "$delay_single_quote_subst"`' AS='`$ECHO "$AS" | $SED "$delay_single_quote_subst"`' DLLTOOL='`$ECHO "$DLLTOOL" | $SED "$delay_single_quote_subst"`' OBJDUMP='`$ECHO "$OBJDUMP" | $SED "$delay_single_quote_subst"`' enable_shared='`$ECHO "$enable_shared" | $SED "$delay_single_quote_subst"`' enable_static='`$ECHO "$enable_static" | $SED "$delay_single_quote_subst"`' pic_mode='`$ECHO "$pic_mode" | $SED "$delay_single_quote_subst"`' enable_fast_install='`$ECHO "$enable_fast_install" | $SED "$delay_single_quote_subst"`' shared_archive_member_spec='`$ECHO "$shared_archive_member_spec" | $SED "$delay_single_quote_subst"`' SHELL='`$ECHO "$SHELL" | $SED "$delay_single_quote_subst"`' ECHO='`$ECHO "$ECHO" | $SED "$delay_single_quote_subst"`' PATH_SEPARATOR='`$ECHO "$PATH_SEPARATOR" | $SED "$delay_single_quote_subst"`' host_alias='`$ECHO "$host_alias" | $SED "$delay_single_quote_subst"`' host='`$ECHO "$host" | $SED "$delay_single_quote_subst"`' host_os='`$ECHO "$host_os" | $SED "$delay_single_quote_subst"`' build_alias='`$ECHO "$build_alias" | $SED "$delay_single_quote_subst"`' build='`$ECHO "$build" | $SED "$delay_single_quote_subst"`' build_os='`$ECHO "$build_os" | $SED "$delay_single_quote_subst"`' SED='`$ECHO "$SED" | $SED "$delay_single_quote_subst"`' Xsed='`$ECHO "$Xsed" | $SED "$delay_single_quote_subst"`' GREP='`$ECHO "$GREP" | $SED "$delay_single_quote_subst"`' EGREP='`$ECHO "$EGREP" | $SED "$delay_single_quote_subst"`' FGREP='`$ECHO "$FGREP" | $SED "$delay_single_quote_subst"`' LD='`$ECHO "$LD" | $SED "$delay_single_quote_subst"`' NM='`$ECHO "$NM" | $SED "$delay_single_quote_subst"`' LN_S='`$ECHO "$LN_S" | $SED "$delay_single_quote_subst"`' max_cmd_len='`$ECHO "$max_cmd_len" | $SED "$delay_single_quote_subst"`' ac_objext='`$ECHO "$ac_objext" | $SED "$delay_single_quote_subst"`' exeext='`$ECHO "$exeext" | $SED "$delay_single_quote_subst"`' lt_unset='`$ECHO "$lt_unset" | $SED "$delay_single_quote_subst"`' lt_SP2NL='`$ECHO "$lt_SP2NL" | $SED "$delay_single_quote_subst"`' lt_NL2SP='`$ECHO "$lt_NL2SP" | $SED "$delay_single_quote_subst"`' lt_cv_to_host_file_cmd='`$ECHO "$lt_cv_to_host_file_cmd" | $SED "$delay_single_quote_subst"`' lt_cv_to_tool_file_cmd='`$ECHO "$lt_cv_to_tool_file_cmd" | $SED "$delay_single_quote_subst"`' reload_flag='`$ECHO "$reload_flag" | $SED "$delay_single_quote_subst"`' reload_cmds='`$ECHO "$reload_cmds" | $SED "$delay_single_quote_subst"`' FILECMD='`$ECHO "$FILECMD" | $SED "$delay_single_quote_subst"`' deplibs_check_method='`$ECHO "$deplibs_check_method" | $SED "$delay_single_quote_subst"`' file_magic_cmd='`$ECHO "$file_magic_cmd" | $SED "$delay_single_quote_subst"`' file_magic_glob='`$ECHO "$file_magic_glob" | $SED "$delay_single_quote_subst"`' want_nocaseglob='`$ECHO "$want_nocaseglob" | $SED "$delay_single_quote_subst"`' sharedlib_from_linklib_cmd='`$ECHO "$sharedlib_from_linklib_cmd" | $SED "$delay_single_quote_subst"`' AR='`$ECHO "$AR" | $SED "$delay_single_quote_subst"`' lt_ar_flags='`$ECHO "$lt_ar_flags" | $SED "$delay_single_quote_subst"`' AR_FLAGS='`$ECHO "$AR_FLAGS" | $SED "$delay_single_quote_subst"`' archiver_list_spec='`$ECHO "$archiver_list_spec" | $SED "$delay_single_quote_subst"`' STRIP='`$ECHO "$STRIP" | $SED "$delay_single_quote_subst"`' RANLIB='`$ECHO "$RANLIB" | $SED "$delay_single_quote_subst"`' old_postinstall_cmds='`$ECHO "$old_postinstall_cmds" | $SED "$delay_single_quote_subst"`' old_postuninstall_cmds='`$ECHO "$old_postuninstall_cmds" | $SED "$delay_single_quote_subst"`' old_archive_cmds='`$ECHO "$old_archive_cmds" | $SED "$delay_single_quote_subst"`' lock_old_archive_extraction='`$ECHO "$lock_old_archive_extraction" | $SED "$delay_single_quote_subst"`' CC='`$ECHO "$CC" | $SED "$delay_single_quote_subst"`' CFLAGS='`$ECHO "$CFLAGS" | $SED "$delay_single_quote_subst"`' compiler='`$ECHO "$compiler" | $SED "$delay_single_quote_subst"`' GCC='`$ECHO "$GCC" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_pipe='`$ECHO "$lt_cv_sys_global_symbol_pipe" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_cdecl='`$ECHO "$lt_cv_sys_global_symbol_to_cdecl" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_import='`$ECHO "$lt_cv_sys_global_symbol_to_import" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_c_name_address='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address" | $SED "$delay_single_quote_subst"`' lt_cv_sys_global_symbol_to_c_name_address_lib_prefix='`$ECHO "$lt_cv_sys_global_symbol_to_c_name_address_lib_prefix" | $SED "$delay_single_quote_subst"`' lt_cv_nm_interface='`$ECHO "$lt_cv_nm_interface" | $SED "$delay_single_quote_subst"`' nm_file_list_spec='`$ECHO "$nm_file_list_spec" | $SED "$delay_single_quote_subst"`' lt_sysroot='`$ECHO "$lt_sysroot" | $SED "$delay_single_quote_subst"`' lt_cv_truncate_bin='`$ECHO "$lt_cv_truncate_bin" | $SED "$delay_single_quote_subst"`' objdir='`$ECHO "$objdir" | $SED "$delay_single_quote_subst"`' MAGIC_CMD='`$ECHO "$MAGIC_CMD" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_no_builtin_flag='`$ECHO "$lt_prog_compiler_no_builtin_flag" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_pic='`$ECHO "$lt_prog_compiler_pic" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_wl='`$ECHO "$lt_prog_compiler_wl" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_static='`$ECHO "$lt_prog_compiler_static" | $SED "$delay_single_quote_subst"`' lt_cv_prog_compiler_c_o='`$ECHO "$lt_cv_prog_compiler_c_o" | $SED "$delay_single_quote_subst"`' need_locks='`$ECHO "$need_locks" | $SED "$delay_single_quote_subst"`' MANIFEST_TOOL='`$ECHO "$MANIFEST_TOOL" | $SED "$delay_single_quote_subst"`' DSYMUTIL='`$ECHO "$DSYMUTIL" | $SED "$delay_single_quote_subst"`' NMEDIT='`$ECHO "$NMEDIT" | $SED "$delay_single_quote_subst"`' LIPO='`$ECHO "$LIPO" | $SED "$delay_single_quote_subst"`' OTOOL='`$ECHO "$OTOOL" | $SED "$delay_single_quote_subst"`' OTOOL64='`$ECHO "$OTOOL64" | $SED "$delay_single_quote_subst"`' libext='`$ECHO "$libext" | $SED "$delay_single_quote_subst"`' shrext_cmds='`$ECHO "$shrext_cmds" | $SED "$delay_single_quote_subst"`' extract_expsyms_cmds='`$ECHO "$extract_expsyms_cmds" | $SED "$delay_single_quote_subst"`' archive_cmds_need_lc='`$ECHO "$archive_cmds_need_lc" | $SED "$delay_single_quote_subst"`' enable_shared_with_static_runtimes='`$ECHO "$enable_shared_with_static_runtimes" | $SED "$delay_single_quote_subst"`' export_dynamic_flag_spec='`$ECHO "$export_dynamic_flag_spec" | $SED "$delay_single_quote_subst"`' whole_archive_flag_spec='`$ECHO "$whole_archive_flag_spec" | $SED "$delay_single_quote_subst"`' compiler_needs_object='`$ECHO "$compiler_needs_object" | $SED "$delay_single_quote_subst"`' old_archive_from_new_cmds='`$ECHO "$old_archive_from_new_cmds" | $SED "$delay_single_quote_subst"`' old_archive_from_expsyms_cmds='`$ECHO "$old_archive_from_expsyms_cmds" | $SED "$delay_single_quote_subst"`' archive_cmds='`$ECHO "$archive_cmds" | $SED "$delay_single_quote_subst"`' archive_expsym_cmds='`$ECHO "$archive_expsym_cmds" | $SED "$delay_single_quote_subst"`' module_cmds='`$ECHO "$module_cmds" | $SED "$delay_single_quote_subst"`' module_expsym_cmds='`$ECHO "$module_expsym_cmds" | $SED "$delay_single_quote_subst"`' with_gnu_ld='`$ECHO "$with_gnu_ld" | $SED "$delay_single_quote_subst"`' allow_undefined_flag='`$ECHO "$allow_undefined_flag" | $SED "$delay_single_quote_subst"`' no_undefined_flag='`$ECHO "$no_undefined_flag" | $SED "$delay_single_quote_subst"`' hardcode_libdir_flag_spec='`$ECHO "$hardcode_libdir_flag_spec" | $SED "$delay_single_quote_subst"`' hardcode_libdir_separator='`$ECHO "$hardcode_libdir_separator" | $SED "$delay_single_quote_subst"`' hardcode_direct='`$ECHO "$hardcode_direct" | $SED "$delay_single_quote_subst"`' hardcode_direct_absolute='`$ECHO "$hardcode_direct_absolute" | $SED "$delay_single_quote_subst"`' hardcode_minus_L='`$ECHO "$hardcode_minus_L" | $SED "$delay_single_quote_subst"`' hardcode_shlibpath_var='`$ECHO "$hardcode_shlibpath_var" | $SED "$delay_single_quote_subst"`' hardcode_automatic='`$ECHO "$hardcode_automatic" | $SED "$delay_single_quote_subst"`' inherit_rpath='`$ECHO "$inherit_rpath" | $SED "$delay_single_quote_subst"`' link_all_deplibs='`$ECHO "$link_all_deplibs" | $SED "$delay_single_quote_subst"`' always_export_symbols='`$ECHO "$always_export_symbols" | $SED "$delay_single_quote_subst"`' export_symbols_cmds='`$ECHO "$export_symbols_cmds" | $SED "$delay_single_quote_subst"`' exclude_expsyms='`$ECHO "$exclude_expsyms" | $SED "$delay_single_quote_subst"`' include_expsyms='`$ECHO "$include_expsyms" | $SED "$delay_single_quote_subst"`' prelink_cmds='`$ECHO "$prelink_cmds" | $SED "$delay_single_quote_subst"`' postlink_cmds='`$ECHO "$postlink_cmds" | $SED "$delay_single_quote_subst"`' file_list_spec='`$ECHO "$file_list_spec" | $SED "$delay_single_quote_subst"`' variables_saved_for_relink='`$ECHO "$variables_saved_for_relink" | $SED "$delay_single_quote_subst"`' need_lib_prefix='`$ECHO "$need_lib_prefix" | $SED "$delay_single_quote_subst"`' need_version='`$ECHO "$need_version" | $SED "$delay_single_quote_subst"`' version_type='`$ECHO "$version_type" | $SED "$delay_single_quote_subst"`' runpath_var='`$ECHO "$runpath_var" | $SED "$delay_single_quote_subst"`' shlibpath_var='`$ECHO "$shlibpath_var" | $SED "$delay_single_quote_subst"`' shlibpath_overrides_runpath='`$ECHO "$shlibpath_overrides_runpath" | $SED "$delay_single_quote_subst"`' libname_spec='`$ECHO "$libname_spec" | $SED "$delay_single_quote_subst"`' library_names_spec='`$ECHO "$library_names_spec" | $SED "$delay_single_quote_subst"`' soname_spec='`$ECHO "$soname_spec" | $SED "$delay_single_quote_subst"`' install_override_mode='`$ECHO "$install_override_mode" | $SED "$delay_single_quote_subst"`' postinstall_cmds='`$ECHO "$postinstall_cmds" | $SED "$delay_single_quote_subst"`' postuninstall_cmds='`$ECHO "$postuninstall_cmds" | $SED "$delay_single_quote_subst"`' finish_cmds='`$ECHO "$finish_cmds" | $SED "$delay_single_quote_subst"`' finish_eval='`$ECHO "$finish_eval" | $SED "$delay_single_quote_subst"`' hardcode_into_libs='`$ECHO "$hardcode_into_libs" | $SED "$delay_single_quote_subst"`' sys_lib_search_path_spec='`$ECHO "$sys_lib_search_path_spec" | $SED "$delay_single_quote_subst"`' configure_time_dlsearch_path='`$ECHO "$configure_time_dlsearch_path" | $SED "$delay_single_quote_subst"`' configure_time_lt_sys_library_path='`$ECHO "$configure_time_lt_sys_library_path" | $SED "$delay_single_quote_subst"`' hardcode_action='`$ECHO "$hardcode_action" | $SED "$delay_single_quote_subst"`' enable_dlopen='`$ECHO "$enable_dlopen" | $SED "$delay_single_quote_subst"`' enable_dlopen_self='`$ECHO "$enable_dlopen_self" | $SED "$delay_single_quote_subst"`' enable_dlopen_self_static='`$ECHO "$enable_dlopen_self_static" | $SED "$delay_single_quote_subst"`' old_striplib='`$ECHO "$old_striplib" | $SED "$delay_single_quote_subst"`' striplib='`$ECHO "$striplib" | $SED "$delay_single_quote_subst"`' compiler_lib_search_dirs='`$ECHO "$compiler_lib_search_dirs" | $SED "$delay_single_quote_subst"`' predep_objects='`$ECHO "$predep_objects" | $SED "$delay_single_quote_subst"`' postdep_objects='`$ECHO "$postdep_objects" | $SED "$delay_single_quote_subst"`' predeps='`$ECHO "$predeps" | $SED "$delay_single_quote_subst"`' postdeps='`$ECHO "$postdeps" | $SED "$delay_single_quote_subst"`' compiler_lib_search_path='`$ECHO "$compiler_lib_search_path" | $SED "$delay_single_quote_subst"`' LD_CXX='`$ECHO "$LD_CXX" | $SED "$delay_single_quote_subst"`' reload_flag_CXX='`$ECHO "$reload_flag_CXX" | $SED "$delay_single_quote_subst"`' reload_cmds_CXX='`$ECHO "$reload_cmds_CXX" | $SED "$delay_single_quote_subst"`' old_archive_cmds_CXX='`$ECHO "$old_archive_cmds_CXX" | $SED "$delay_single_quote_subst"`' compiler_CXX='`$ECHO "$compiler_CXX" | $SED "$delay_single_quote_subst"`' GCC_CXX='`$ECHO "$GCC_CXX" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_no_builtin_flag_CXX='`$ECHO "$lt_prog_compiler_no_builtin_flag_CXX" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_pic_CXX='`$ECHO "$lt_prog_compiler_pic_CXX" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_wl_CXX='`$ECHO "$lt_prog_compiler_wl_CXX" | $SED "$delay_single_quote_subst"`' lt_prog_compiler_static_CXX='`$ECHO "$lt_prog_compiler_static_CXX" | $SED "$delay_single_quote_subst"`' lt_cv_prog_compiler_c_o_CXX='`$ECHO "$lt_cv_prog_compiler_c_o_CXX" | $SED "$delay_single_quote_subst"`' archive_cmds_need_lc_CXX='`$ECHO "$archive_cmds_need_lc_CXX" | $SED "$delay_single_quote_subst"`' enable_shared_with_static_runtimes_CXX='`$ECHO "$enable_shared_with_static_runtimes_CXX" | $SED "$delay_single_quote_subst"`' export_dynamic_flag_spec_CXX='`$ECHO "$export_dynamic_flag_spec_CXX" | $SED "$delay_single_quote_subst"`' whole_archive_flag_spec_CXX='`$ECHO "$whole_archive_flag_spec_CXX" | $SED "$delay_single_quote_subst"`' compiler_needs_object_CXX='`$ECHO "$compiler_needs_object_CXX" | $SED "$delay_single_quote_subst"`' old_archive_from_new_cmds_CXX='`$ECHO "$old_archive_from_new_cmds_CXX" | $SED "$delay_single_quote_subst"`' old_archive_from_expsyms_cmds_CXX='`$ECHO "$old_archive_from_expsyms_cmds_CXX" | $SED "$delay_single_quote_subst"`' archive_cmds_CXX='`$ECHO "$archive_cmds_CXX" | $SED "$delay_single_quote_subst"`' archive_expsym_cmds_CXX='`$ECHO "$archive_expsym_cmds_CXX" | $SED "$delay_single_quote_subst"`' module_cmds_CXX='`$ECHO "$module_cmds_CXX" | $SED "$delay_single_quote_subst"`' module_expsym_cmds_CXX='`$ECHO "$module_expsym_cmds_CXX" | $SED "$delay_single_quote_subst"`' with_gnu_ld_CXX='`$ECHO "$with_gnu_ld_CXX" | $SED "$delay_single_quote_subst"`' allow_undefined_flag_CXX='`$ECHO "$allow_undefined_flag_CXX" | $SED "$delay_single_quote_subst"`' no_undefined_flag_CXX='`$ECHO "$no_undefined_flag_CXX" | $SED "$delay_single_quote_subst"`' hardcode_libdir_flag_spec_CXX='`$ECHO "$hardcode_libdir_flag_spec_CXX" | $SED "$delay_single_quote_subst"`' hardcode_libdir_separator_CXX='`$ECHO "$hardcode_libdir_separator_CXX" | $SED "$delay_single_quote_subst"`' hardcode_direct_CXX='`$ECHO "$hardcode_direct_CXX" | $SED "$delay_single_quote_subst"`' hardcode_direct_absolute_CXX='`$ECHO "$hardcode_direct_absolute_CXX" | $SED "$delay_single_quote_subst"`' hardcode_minus_L_CXX='`$ECHO "$hardcode_minus_L_CXX" | $SED "$delay_single_quote_subst"`' hardcode_shlibpath_var_CXX='`$ECHO "$hardcode_shlibpath_var_CXX" | $SED "$delay_single_quote_subst"`' hardcode_automatic_CXX='`$ECHO "$hardcode_automatic_CXX" | $SED "$delay_single_quote_subst"`' inherit_rpath_CXX='`$ECHO "$inherit_rpath_CXX" | $SED "$delay_single_quote_subst"`' link_all_deplibs_CXX='`$ECHO "$link_all_deplibs_CXX" | $SED "$delay_single_quote_subst"`' always_export_symbols_CXX='`$ECHO "$always_export_symbols_CXX" | $SED "$delay_single_quote_subst"`' export_symbols_cmds_CXX='`$ECHO "$export_symbols_cmds_CXX" | $SED "$delay_single_quote_subst"`' exclude_expsyms_CXX='`$ECHO "$exclude_expsyms_CXX" | $SED "$delay_single_quote_subst"`' include_expsyms_CXX='`$ECHO "$include_expsyms_CXX" | $SED "$delay_single_quote_subst"`' prelink_cmds_CXX='`$ECHO "$prelink_cmds_CXX" | $SED "$delay_single_quote_subst"`' postlink_cmds_CXX='`$ECHO "$postlink_cmds_CXX" | $SED "$delay_single_quote_subst"`' file_list_spec_CXX='`$ECHO "$file_list_spec_CXX" | $SED "$delay_single_quote_subst"`' hardcode_action_CXX='`$ECHO "$hardcode_action_CXX" | $SED "$delay_single_quote_subst"`' compiler_lib_search_dirs_CXX='`$ECHO "$compiler_lib_search_dirs_CXX" | $SED "$delay_single_quote_subst"`' predep_objects_CXX='`$ECHO "$predep_objects_CXX" | $SED "$delay_single_quote_subst"`' postdep_objects_CXX='`$ECHO "$postdep_objects_CXX" | $SED "$delay_single_quote_subst"`' predeps_CXX='`$ECHO "$predeps_CXX" | $SED "$delay_single_quote_subst"`' postdeps_CXX='`$ECHO "$postdeps_CXX" | $SED "$delay_single_quote_subst"`' compiler_lib_search_path_CXX='`$ECHO "$compiler_lib_search_path_CXX" | $SED "$delay_single_quote_subst"`' LTCC='$LTCC' LTCFLAGS='$LTCFLAGS' compiler='$compiler_DEFAULT' # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$1 _LTECHO_EOF' } # Quote evaled strings. for var in AS \ DLLTOOL \ OBJDUMP \ SHELL \ ECHO \ PATH_SEPARATOR \ SED \ GREP \ EGREP \ FGREP \ LD \ NM \ LN_S \ lt_SP2NL \ lt_NL2SP \ reload_flag \ FILECMD \ deplibs_check_method \ file_magic_cmd \ file_magic_glob \ want_nocaseglob \ sharedlib_from_linklib_cmd \ AR \ archiver_list_spec \ STRIP \ RANLIB \ CC \ CFLAGS \ compiler \ lt_cv_sys_global_symbol_pipe \ lt_cv_sys_global_symbol_to_cdecl \ lt_cv_sys_global_symbol_to_import \ lt_cv_sys_global_symbol_to_c_name_address \ lt_cv_sys_global_symbol_to_c_name_address_lib_prefix \ lt_cv_nm_interface \ nm_file_list_spec \ lt_cv_truncate_bin \ lt_prog_compiler_no_builtin_flag \ lt_prog_compiler_pic \ lt_prog_compiler_wl \ lt_prog_compiler_static \ lt_cv_prog_compiler_c_o \ need_locks \ MANIFEST_TOOL \ DSYMUTIL \ NMEDIT \ LIPO \ OTOOL \ OTOOL64 \ shrext_cmds \ export_dynamic_flag_spec \ whole_archive_flag_spec \ compiler_needs_object \ with_gnu_ld \ allow_undefined_flag \ no_undefined_flag \ hardcode_libdir_flag_spec \ hardcode_libdir_separator \ exclude_expsyms \ include_expsyms \ file_list_spec \ variables_saved_for_relink \ libname_spec \ library_names_spec \ soname_spec \ install_override_mode \ finish_eval \ old_striplib \ striplib \ compiler_lib_search_dirs \ predep_objects \ postdep_objects \ predeps \ postdeps \ compiler_lib_search_path \ LD_CXX \ reload_flag_CXX \ compiler_CXX \ lt_prog_compiler_no_builtin_flag_CXX \ lt_prog_compiler_pic_CXX \ lt_prog_compiler_wl_CXX \ lt_prog_compiler_static_CXX \ lt_cv_prog_compiler_c_o_CXX \ export_dynamic_flag_spec_CXX \ whole_archive_flag_spec_CXX \ compiler_needs_object_CXX \ with_gnu_ld_CXX \ allow_undefined_flag_CXX \ no_undefined_flag_CXX \ hardcode_libdir_flag_spec_CXX \ hardcode_libdir_separator_CXX \ exclude_expsyms_CXX \ include_expsyms_CXX \ file_list_spec_CXX \ compiler_lib_search_dirs_CXX \ predep_objects_CXX \ postdep_objects_CXX \ predeps_CXX \ postdeps_CXX \ compiler_lib_search_path_CXX; do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[\\\\\\\`\\"\\\$]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED \\"\\\$sed_quote_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done # Double-quote double-evaled strings. for var in reload_cmds \ old_postinstall_cmds \ old_postuninstall_cmds \ old_archive_cmds \ extract_expsyms_cmds \ old_archive_from_new_cmds \ old_archive_from_expsyms_cmds \ archive_cmds \ archive_expsym_cmds \ module_cmds \ module_expsym_cmds \ export_symbols_cmds \ prelink_cmds \ postlink_cmds \ postinstall_cmds \ postuninstall_cmds \ finish_cmds \ sys_lib_search_path_spec \ configure_time_dlsearch_path \ configure_time_lt_sys_library_path \ reload_cmds_CXX \ old_archive_cmds_CXX \ old_archive_from_new_cmds_CXX \ old_archive_from_expsyms_cmds_CXX \ archive_cmds_CXX \ archive_expsym_cmds_CXX \ module_cmds_CXX \ module_expsym_cmds_CXX \ export_symbols_cmds_CXX \ prelink_cmds_CXX \ postlink_cmds_CXX; do case \`eval \\\\\$ECHO \\\\""\\\\\$\$var"\\\\"\` in *[\\\\\\\`\\"\\\$]*) eval "lt_\$var=\\\\\\"\\\`\\\$ECHO \\"\\\$\$var\\" | \\\$SED -e \\"\\\$double_quote_subst\\" -e \\"\\\$sed_quote_subst\\" -e \\"\\\$delay_variable_subst\\"\\\`\\\\\\"" ## exclude from sc_prohibit_nested_quotes ;; *) eval "lt_\$var=\\\\\\"\\\$\$var\\\\\\"" ;; esac done ac_aux_dir='$ac_aux_dir' # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes INIT. if test -n "\${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi PACKAGE='$PACKAGE' VERSION='$VERSION' RM='$RM' ofile='$ofile' # Capture the value of obsolete ALL_LINGUAS because we need it to compute # POFILES, UPDATEPOFILES, DUMMYPOFILES, GMOFILES, CATALOGS. OBSOLETE_ALL_LINGUAS="$ALL_LINGUAS" # Capture the value of LINGUAS because we need it to compute CATALOGS. LINGUAS="${LINGUAS-%UNSET%}" _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # Handling of arguments. for ac_config_target in $ac_config_targets do case $ac_config_target in "depfiles") CONFIG_COMMANDS="$CONFIG_COMMANDS depfiles" ;; "libtool") CONFIG_COMMANDS="$CONFIG_COMMANDS libtool" ;; "po-directories") CONFIG_COMMANDS="$CONFIG_COMMANDS po-directories" ;; "Makefile") CONFIG_FILES="$CONFIG_FILES Makefile" ;; "include/Makefile") CONFIG_FILES="$CONFIG_FILES include/Makefile" ;; "common/Makefile") CONFIG_FILES="$CONFIG_FILES common/Makefile" ;; "libcerror/Makefile") CONFIG_FILES="$CONFIG_FILES libcerror/Makefile" ;; "libcaes/Makefile") CONFIG_FILES="$CONFIG_FILES libcaes/Makefile" ;; "pycaes/Makefile") CONFIG_FILES="$CONFIG_FILES pycaes/Makefile" ;; "po/Makefile.in") CONFIG_FILES="$CONFIG_FILES po/Makefile.in" ;; "po/Makevars") CONFIG_FILES="$CONFIG_FILES po/Makevars" ;; "manuals/Makefile") CONFIG_FILES="$CONFIG_FILES manuals/Makefile" ;; "tests/Makefile") CONFIG_FILES="$CONFIG_FILES tests/Makefile" ;; "ossfuzz/Makefile") CONFIG_FILES="$CONFIG_FILES ossfuzz/Makefile" ;; "msvscpp/Makefile") CONFIG_FILES="$CONFIG_FILES msvscpp/Makefile" ;; "include/libcaes.h") CONFIG_FILES="$CONFIG_FILES include/libcaes.h" ;; "include/libcaes/definitions.h") CONFIG_FILES="$CONFIG_FILES include/libcaes/definitions.h" ;; "include/libcaes/features.h") CONFIG_FILES="$CONFIG_FILES include/libcaes/features.h" ;; "include/libcaes/types.h") CONFIG_FILES="$CONFIG_FILES include/libcaes/types.h" ;; "libcaes/libcaes_definitions.h") CONFIG_FILES="$CONFIG_FILES libcaes/libcaes_definitions.h" ;; "common/types.h") CONFIG_FILES="$CONFIG_FILES common/types.h" ;; "dpkg/changelog") CONFIG_FILES="$CONFIG_FILES dpkg/changelog" ;; "libcaes/libcaes.rc") CONFIG_FILES="$CONFIG_FILES libcaes/libcaes.rc" ;; "libcaes.pc") CONFIG_FILES="$CONFIG_FILES libcaes.pc" ;; "libcaes.spec") CONFIG_FILES="$CONFIG_FILES libcaes.spec" ;; "setup.cfg") CONFIG_FILES="$CONFIG_FILES setup.cfg" ;; "common/config.h") CONFIG_HEADERS="$CONFIG_HEADERS common/config.h" ;; *) as_fn_error $? "invalid argument: \`$ac_config_target'" "$LINENO" 5;; esac done # If the user did not use the arguments to specify the items to instantiate, # then the envvar interface is used. Set only those that are not. # We use the long form for the default assignment because of an extremely # bizarre bug on SunOS 4.1.3. if $ac_need_defaults; then test ${CONFIG_FILES+y} || CONFIG_FILES=$config_files test ${CONFIG_HEADERS+y} || CONFIG_HEADERS=$config_headers test ${CONFIG_COMMANDS+y} || CONFIG_COMMANDS=$config_commands fi # Have a temporary directory for convenience. Make it in the build tree # simply because there is no reason against having it here, and in addition, # creating and moving files from /tmp can sometimes cause problems. # Hook for its removal unless debugging. # Note that there is a small window in which the directory will not be cleaned: # after its creation but before its name has been assigned to `$tmp'. $debug || { tmp= ac_tmp= trap 'exit_status=$? : "${ac_tmp:=$tmp}" { test ! -d "$ac_tmp" || rm -fr "$ac_tmp"; } && exit $exit_status ' 0 trap 'as_fn_exit 1' 1 2 13 15 } # Create a (secure) tmp directory for tmp files. { tmp=`(umask 077 && mktemp -d "./confXXXXXX") 2>/dev/null` && test -d "$tmp" } || { tmp=./conf$$-$RANDOM (umask 077 && mkdir "$tmp") } || as_fn_error $? "cannot create a temporary directory in ." "$LINENO" 5 ac_tmp=$tmp # Set up the scripts for CONFIG_FILES section. # No need to generate them if there are no CONFIG_FILES. # This happens for instance with `./config.status config.h'. if test -n "$CONFIG_FILES"; then ac_cr=`echo X | tr X '\015'` # On cygwin, bash can eat \r inside `` if the user requested igncr. # But we know of no other shell where ac_cr would be empty at this # point, so we can use a bashism as a fallback. if test "x$ac_cr" = x; then eval ac_cr=\$\'\\r\' fi ac_cs_awk_cr=`$AWK 'BEGIN { print "a\rb" }' /dev/null` if test "$ac_cs_awk_cr" = "a${ac_cr}b"; then ac_cs_awk_cr='\\r' else ac_cs_awk_cr=$ac_cr fi echo 'BEGIN {' >"$ac_tmp/subs1.awk" && _ACEOF { echo "cat >conf$$subs.awk <<_ACEOF" && echo "$ac_subst_vars" | sed 's/.*/&!$&$ac_delim/' && echo "_ACEOF" } >conf$$subs.sh || as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 ac_delim_num=`echo "$ac_subst_vars" | grep -c '^'` ac_delim='%!_!# ' for ac_last_try in false false false false false :; do . ./conf$$subs.sh || as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 ac_delim_n=`sed -n "s/.*$ac_delim\$/X/p" conf$$subs.awk | grep -c X` if test $ac_delim_n = $ac_delim_num; then break elif $ac_last_try; then as_fn_error $? "could not make $CONFIG_STATUS" "$LINENO" 5 else ac_delim="$ac_delim!$ac_delim _$ac_delim!! " fi done rm -f conf$$subs.sh cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 cat >>"\$ac_tmp/subs1.awk" <<\\_ACAWK && _ACEOF sed -n ' h s/^/S["/; s/!.*/"]=/ p g s/^[^!]*!// :repl t repl s/'"$ac_delim"'$// t delim :nl h s/\(.\{148\}\)..*/\1/ t more1 s/["\\]/\\&/g; s/^/"/; s/$/\\n"\\/ p n b repl :more1 s/["\\]/\\&/g; s/^/"/; s/$/"\\/ p g s/.\{148\}// t nl :delim h s/\(.\{148\}\)..*/\1/ t more2 s/["\\]/\\&/g; s/^/"/; s/$/"/ p b :more2 s/["\\]/\\&/g; s/^/"/; s/$/"\\/ p g s/.\{148\}// t delim ' >$CONFIG_STATUS || ac_write_fail=1 rm -f conf$$subs.awk cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 _ACAWK cat >>"\$ac_tmp/subs1.awk" <<_ACAWK && for (key in S) S_is_set[key] = 1 FS = "" } { line = $ 0 nfields = split(line, field, "@") substed = 0 len = length(field[1]) for (i = 2; i < nfields; i++) { key = field[i] keylen = length(key) if (S_is_set[key]) { value = S[key] line = substr(line, 1, len) "" value "" substr(line, len + keylen + 3) len += length(value) + length(field[++i]) substed = 1 } else len += 1 + keylen } print line } _ACAWK _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 if sed "s/$ac_cr//" < /dev/null > /dev/null 2>&1; then sed "s/$ac_cr\$//; s/$ac_cr/$ac_cs_awk_cr/g" else cat fi < "$ac_tmp/subs1.awk" > "$ac_tmp/subs.awk" \ || as_fn_error $? "could not setup config files machinery" "$LINENO" 5 _ACEOF # VPATH may cause trouble with some makes, so we remove sole $(srcdir), # ${srcdir} and @srcdir@ entries from VPATH if srcdir is ".", strip leading and # trailing colons and then remove the whole line if VPATH becomes empty # (actually we leave an empty line to preserve line numbers). if test "x$srcdir" = x.; then ac_vpsub='/^[ ]*VPATH[ ]*=[ ]*/{ h s/// s/^/:/ s/[ ]*$/:/ s/:\$(srcdir):/:/g s/:\${srcdir}:/:/g s/:@srcdir@:/:/g s/^:*// s/:*$// x s/\(=[ ]*\).*/\1/ G s/\n// s/^[^=]*=[ ]*$// }' fi cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 fi # test -n "$CONFIG_FILES" # Set up the scripts for CONFIG_HEADERS section. # No need to generate them if there are no CONFIG_HEADERS. # This happens for instance with `./config.status Makefile'. if test -n "$CONFIG_HEADERS"; then cat >"$ac_tmp/defines.awk" <<\_ACAWK || BEGIN { _ACEOF # Transform confdefs.h into an awk script `defines.awk', embedded as # here-document in config.status, that substitutes the proper values into # config.h.in to produce config.h. # Create a delimiter string that does not exist in confdefs.h, to ease # handling of long lines. ac_delim='%!_!# ' for ac_last_try in false false :; do ac_tt=`sed -n "/$ac_delim/p" confdefs.h` if test -z "$ac_tt"; then break elif $ac_last_try; then as_fn_error $? "could not make $CONFIG_HEADERS" "$LINENO" 5 else ac_delim="$ac_delim!$ac_delim _$ac_delim!! " fi done # For the awk script, D is an array of macro values keyed by name, # likewise P contains macro parameters if any. Preserve backslash # newline sequences. ac_word_re=[_$as_cr_Letters][_$as_cr_alnum]* sed -n ' s/.\{148\}/&'"$ac_delim"'/g t rset :rset s/^[ ]*#[ ]*define[ ][ ]*/ / t def d :def s/\\$// t bsnl s/["\\]/\\&/g s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ D["\1"]=" \3"/p s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2"/p d :bsnl s/["\\]/\\&/g s/^ \('"$ac_word_re"'\)\(([^()]*)\)[ ]*\(.*\)/P["\1"]="\2"\ D["\1"]=" \3\\\\\\n"\\/p t cont s/^ \('"$ac_word_re"'\)[ ]*\(.*\)/D["\1"]=" \2\\\\\\n"\\/p t cont d :cont n s/.\{148\}/&'"$ac_delim"'/g t clear :clear s/\\$// t bsnlc s/["\\]/\\&/g; s/^/"/; s/$/"/p d :bsnlc s/["\\]/\\&/g; s/^/"/; s/$/\\\\\\n"\\/p b cont ' >$CONFIG_STATUS || ac_write_fail=1 cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 for (key in D) D_is_set[key] = 1 FS = "" } /^[\t ]*#[\t ]*(define|undef)[\t ]+$ac_word_re([\t (]|\$)/ { line = \$ 0 split(line, arg, " ") if (arg[1] == "#") { defundef = arg[2] mac1 = arg[3] } else { defundef = substr(arg[1], 2) mac1 = arg[2] } split(mac1, mac2, "(") #) macro = mac2[1] prefix = substr(line, 1, index(line, defundef) - 1) if (D_is_set[macro]) { # Preserve the white space surrounding the "#". print prefix "define", macro P[macro] D[macro] next } else { # Replace #undef with comments. This is necessary, for example, # in the case of _POSIX_SOURCE, which is predefined and required # on some systems where configure will not decide to define it. if (defundef == "undef") { print "/*", prefix defundef, macro, "*/" next } } } { print } _ACAWK _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 as_fn_error $? "could not setup config headers machinery" "$LINENO" 5 fi # test -n "$CONFIG_HEADERS" eval set X " :F $CONFIG_FILES :H $CONFIG_HEADERS :C $CONFIG_COMMANDS" shift for ac_tag do case $ac_tag in :[FHLC]) ac_mode=$ac_tag; continue;; esac case $ac_mode$ac_tag in :[FHL]*:*);; :L* | :C*:*) as_fn_error $? "invalid tag \`$ac_tag'" "$LINENO" 5;; :[FH]-) ac_tag=-:-;; :[FH]*) ac_tag=$ac_tag:$ac_tag.in;; esac ac_save_IFS=$IFS IFS=: set x $ac_tag IFS=$ac_save_IFS shift ac_file=$1 shift case $ac_mode in :L) ac_source=$1;; :[FH]) ac_file_inputs= for ac_f do case $ac_f in -) ac_f="$ac_tmp/stdin";; *) # Look for the file first in the build tree, then in the source tree # (if the path is not absolute). The absolute path cannot be DOS-style, # because $ac_f cannot contain `:'. test -f "$ac_f" || case $ac_f in [\\/$]*) false;; *) test -f "$srcdir/$ac_f" && ac_f="$srcdir/$ac_f";; esac || as_fn_error 1 "cannot find input file: \`$ac_f'" "$LINENO" 5;; esac case $ac_f in *\'*) ac_f=`printf "%s\n" "$ac_f" | sed "s/'/'\\\\\\\\''/g"`;; esac as_fn_append ac_file_inputs " '$ac_f'" done # Let's still pretend it is `configure' which instantiates (i.e., don't # use $as_me), people would be surprised to read: # /* config.h. Generated by config.status. */ configure_input='Generated from '` printf "%s\n" "$*" | sed 's|^[^:]*/||;s|:[^:]*/|, |g' `' by configure.' if test x"$ac_file" != x-; then configure_input="$ac_file. $configure_input" { printf "%s\n" "$as_me:${as_lineno-$LINENO}: creating $ac_file" >&5 printf "%s\n" "$as_me: creating $ac_file" >&6;} fi # Neutralize special characters interpreted by sed in replacement strings. case $configure_input in #( *\&* | *\|* | *\\* ) ac_sed_conf_input=`printf "%s\n" "$configure_input" | sed 's/[\\\\&|]/\\\\&/g'`;; #( *) ac_sed_conf_input=$configure_input;; esac case $ac_tag in *:-:* | *:-) cat >"$ac_tmp/stdin" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; esac ;; esac ac_dir=`$as_dirname -- "$ac_file" || $as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$ac_file" : 'X\(//\)[^/]' \| \ X"$ac_file" : 'X\(//\)$' \| \ X"$ac_file" : 'X\(/\)' \| . 2>/dev/null || printf "%s\n" X"$ac_file" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` as_dir="$ac_dir"; as_fn_mkdir_p ac_builddir=. case "$ac_dir" in .) ac_dir_suffix= ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_dir_suffix=/`printf "%s\n" "$ac_dir" | sed 's|^\.[\\/]||'` # A ".." for each directory in $ac_dir_suffix. ac_top_builddir_sub=`printf "%s\n" "$ac_dir_suffix" | sed 's|/[^\\/]*|/..|g;s|/||'` case $ac_top_builddir_sub in "") ac_top_builddir_sub=. ac_top_build_prefix= ;; *) ac_top_build_prefix=$ac_top_builddir_sub/ ;; esac ;; esac ac_abs_top_builddir=$ac_pwd ac_abs_builddir=$ac_pwd$ac_dir_suffix # for backward compatibility: ac_top_builddir=$ac_top_build_prefix case $srcdir in .) # We are building in place. ac_srcdir=. ac_top_srcdir=$ac_top_builddir_sub ac_abs_top_srcdir=$ac_pwd ;; [\\/]* | ?:[\\/]* ) # Absolute name. ac_srcdir=$srcdir$ac_dir_suffix; ac_top_srcdir=$srcdir ac_abs_top_srcdir=$srcdir ;; *) # Relative name. ac_srcdir=$ac_top_build_prefix$srcdir$ac_dir_suffix ac_top_srcdir=$ac_top_build_prefix$srcdir ac_abs_top_srcdir=$ac_pwd/$srcdir ;; esac ac_abs_srcdir=$ac_abs_top_srcdir$ac_dir_suffix case $ac_mode in :F) # # CONFIG_FILE # case $INSTALL in [\\/$]* | ?:[\\/]* ) ac_INSTALL=$INSTALL ;; *) ac_INSTALL=$ac_top_build_prefix$INSTALL ;; esac ac_MKDIR_P=$MKDIR_P case $MKDIR_P in [\\/$]* | ?:[\\/]* ) ;; */*) ac_MKDIR_P=$ac_top_build_prefix$MKDIR_P ;; esac _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 # If the template does not know about datarootdir, expand it. # FIXME: This hack should be removed a few years after 2.60. ac_datarootdir_hack=; ac_datarootdir_seen= ac_sed_dataroot=' /datarootdir/ { p q } /@datadir@/p /@docdir@/p /@infodir@/p /@localedir@/p /@mandir@/p' case `eval "sed -n \"\$ac_sed_dataroot\" $ac_file_inputs"` in *datarootdir*) ac_datarootdir_seen=yes;; *@datadir@*|*@docdir@*|*@infodir@*|*@localedir@*|*@mandir@*) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&5 printf "%s\n" "$as_me: WARNING: $ac_file_inputs seems to ignore the --datarootdir setting" >&2;} _ACEOF cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_datarootdir_hack=' s&@datadir@&$datadir&g s&@docdir@&$docdir&g s&@infodir@&$infodir&g s&@localedir@&$localedir&g s&@mandir@&$mandir&g s&\\\${datarootdir}&$datarootdir&g' ;; esac _ACEOF # Neutralize VPATH when `$srcdir' = `.'. # Shell code in configure.ac might set extrasub. # FIXME: do we really want to maintain this feature? cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 ac_sed_extra="$ac_vpsub $extrasub _ACEOF cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 :t /@[a-zA-Z_][a-zA-Z_0-9]*@/!b s|@configure_input@|$ac_sed_conf_input|;t t s&@top_builddir@&$ac_top_builddir_sub&;t t s&@top_build_prefix@&$ac_top_build_prefix&;t t s&@srcdir@&$ac_srcdir&;t t s&@abs_srcdir@&$ac_abs_srcdir&;t t s&@top_srcdir@&$ac_top_srcdir&;t t s&@abs_top_srcdir@&$ac_abs_top_srcdir&;t t s&@builddir@&$ac_builddir&;t t s&@abs_builddir@&$ac_abs_builddir&;t t s&@abs_top_builddir@&$ac_abs_top_builddir&;t t s&@INSTALL@&$ac_INSTALL&;t t s&@MKDIR_P@&$ac_MKDIR_P&;t t $ac_datarootdir_hack " eval sed \"\$ac_sed_extra\" "$ac_file_inputs" | $AWK -f "$ac_tmp/subs.awk" \ >$ac_tmp/out || as_fn_error $? "could not create $ac_file" "$LINENO" 5 test -z "$ac_datarootdir_hack$ac_datarootdir_seen" && { ac_out=`sed -n '/\${datarootdir}/p' "$ac_tmp/out"`; test -n "$ac_out"; } && { ac_out=`sed -n '/^[ ]*datarootdir[ ]*:*=/p' \ "$ac_tmp/out"`; test -z "$ac_out"; } && { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&5 printf "%s\n" "$as_me: WARNING: $ac_file contains a reference to the variable \`datarootdir' which seems to be undefined. Please make sure it is defined" >&2;} rm -f "$ac_tmp/stdin" case $ac_file in -) cat "$ac_tmp/out" && rm -f "$ac_tmp/out";; *) rm -f "$ac_file" && mv "$ac_tmp/out" "$ac_file";; esac \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 ;; :H) # # CONFIG_HEADER # if test x"$ac_file" != x-; then { printf "%s\n" "/* $configure_input */" >&1 \ && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" } >"$ac_tmp/config.h" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 if diff "$ac_file" "$ac_tmp/config.h" >/dev/null 2>&1; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: $ac_file is unchanged" >&5 printf "%s\n" "$as_me: $ac_file is unchanged" >&6;} else rm -f "$ac_file" mv "$ac_tmp/config.h" "$ac_file" \ || as_fn_error $? "could not create $ac_file" "$LINENO" 5 fi else printf "%s\n" "/* $configure_input */" >&1 \ && eval '$AWK -f "$ac_tmp/defines.awk"' "$ac_file_inputs" \ || as_fn_error $? "could not create -" "$LINENO" 5 fi # Compute "$ac_file"'s index in $config_headers. _am_arg="$ac_file" _am_stamp_count=1 for _am_header in $config_headers :; do case $_am_header in $_am_arg | $_am_arg:* ) break ;; * ) _am_stamp_count=`expr $_am_stamp_count + 1` ;; esac done echo "timestamp for $_am_arg" >`$as_dirname -- "$_am_arg" || $as_expr X"$_am_arg" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$_am_arg" : 'X\(//\)[^/]' \| \ X"$_am_arg" : 'X\(//\)$' \| \ X"$_am_arg" : 'X\(/\)' \| . 2>/dev/null || printf "%s\n" X"$_am_arg" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'`/stamp-h$_am_stamp_count ;; :C) { printf "%s\n" "$as_me:${as_lineno-$LINENO}: executing $ac_file commands" >&5 printf "%s\n" "$as_me: executing $ac_file commands" >&6;} ;; esac case $ac_file$ac_mode in "depfiles":C) test x"$AMDEP_TRUE" != x"" || { # Older Autoconf quotes --file arguments for eval, but not when files # are listed without --file. Let's play safe and only enable the eval # if we detect the quoting. # TODO: see whether this extra hack can be removed once we start # requiring Autoconf 2.70 or later. case $CONFIG_FILES in #( *\'*) : eval set x "$CONFIG_FILES" ;; #( *) : set x $CONFIG_FILES ;; #( *) : ;; esac shift # Used to flag and report bootstrapping failures. am_rc=0 for am_mf do # Strip MF so we end up with the name of the file. am_mf=`printf "%s\n" "$am_mf" | sed -e 's/:.*$//'` # Check whether this is an Automake generated Makefile which includes # dependency-tracking related rules and includes. # Grep'ing the whole file directly is not great: AIX grep has a line # limit of 2048, but all sed's we know have understand at least 4000. sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \ || continue am_dirpart=`$as_dirname -- "$am_mf" || $as_expr X"$am_mf" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \ X"$am_mf" : 'X\(//\)[^/]' \| \ X"$am_mf" : 'X\(//\)$' \| \ X"$am_mf" : 'X\(/\)' \| . 2>/dev/null || printf "%s\n" X"$am_mf" | sed '/^X\(.*[^/]\)\/\/*[^/][^/]*\/*$/{ s//\1/ q } /^X\(\/\/\)[^/].*/{ s//\1/ q } /^X\(\/\/\)$/{ s//\1/ q } /^X\(\/\).*/{ s//\1/ q } s/.*/./; q'` am_filepart=`$as_basename -- "$am_mf" || $as_expr X/"$am_mf" : '.*/\([^/][^/]*\)/*$' \| \ X"$am_mf" : 'X\(//\)$' \| \ X"$am_mf" : 'X\(/\)' \| . 2>/dev/null || printf "%s\n" X/"$am_mf" | sed '/^.*\/\([^/][^/]*\)\/*$/{ s//\1/ q } /^X\/\(\/\/\)$/{ s//\1/ q } /^X\/\(\/\).*/{ s//\1/ q } s/.*/./; q'` { echo "$as_me:$LINENO: cd "$am_dirpart" \ && sed -e '/# am--include-marker/d' "$am_filepart" \ | $MAKE -f - am--depfiles" >&5 (cd "$am_dirpart" \ && sed -e '/# am--include-marker/d' "$am_filepart" \ | $MAKE -f - am--depfiles) >&5 2>&5 ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&5 (exit $ac_status); } || am_rc=$? done if test $am_rc -ne 0; then { { printf "%s\n" "$as_me:${as_lineno-$LINENO}: error: in \`$ac_pwd':" >&5 printf "%s\n" "$as_me: error: in \`$ac_pwd':" >&2;} as_fn_error $? "Something went wrong bootstrapping makefile fragments for automatic dependency tracking. If GNU make was not used, consider re-running the configure script with MAKE=\"gmake\" (or whatever is necessary). You can also try re-running configure with the '--disable-dependency-tracking' option to at least be able to build the package (albeit without support for automatic dependency tracking). See \`config.log' for more details" "$LINENO" 5; } fi { am_dirpart=; unset am_dirpart;} { am_filepart=; unset am_filepart;} { am_mf=; unset am_mf;} { am_rc=; unset am_rc;} rm -f conftest-deps.mk } ;; "libtool":C) # See if we are running on zsh, and set the options that allow our # commands through without removal of \ escapes. if test -n "${ZSH_VERSION+set}"; then setopt NO_GLOB_SUBST fi cfgfile=${ofile}T trap "$RM \"$cfgfile\"; exit 1" 1 2 15 $RM "$cfgfile" cat <<_LT_EOF >> "$cfgfile" #! $SHELL # Generated automatically by $as_me ($PACKAGE) $VERSION # Libtool was configured on host `(hostname || uname -n) 2>/dev/null | sed 1q`: # NOTE: Changes made to this file will be lost: look at ltmain.sh. # Provide generalized library-building support services. # Written by Gordon Matzigkeit, 1996 # Copyright (C) 2014 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # GNU Libtool 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 of the License, or # (at your option) any later version. # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program or library that is built # using GNU Libtool, you may include this file under the same # distribution terms that you use for the rest of that program. # # GNU Libtool 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 this program. If not, see . # The names of the tagged configurations supported by this script. available_tags='CXX ' # Configured defaults for sys_lib_dlsearch_path munging. : \${LT_SYS_LIBRARY_PATH="$configure_time_lt_sys_library_path"} # ### BEGIN LIBTOOL CONFIG # Which release of libtool.m4 was used? macro_version=$macro_version macro_revision=$macro_revision # Assembler program. AS=$lt_AS # DLL creation program. DLLTOOL=$lt_DLLTOOL # Object dumper program. OBJDUMP=$lt_OBJDUMP # Whether or not to build shared libraries. build_libtool_libs=$enable_shared # Whether or not to build static libraries. build_old_libs=$enable_static # What type of objects to build. pic_mode=$pic_mode # Whether or not to optimize for fast installation. fast_install=$enable_fast_install # Shared archive member basename,for filename based shared library versioning on AIX. shared_archive_member_spec=$shared_archive_member_spec # Shell to use when invoking shell scripts. SHELL=$lt_SHELL # An echo program that protects backslashes. ECHO=$lt_ECHO # The PATH separator for the build system. PATH_SEPARATOR=$lt_PATH_SEPARATOR # The host system. host_alias=$host_alias host=$host host_os=$host_os # The build system. build_alias=$build_alias build=$build build_os=$build_os # A sed program that does not truncate output. SED=$lt_SED # Sed that helps us avoid accidentally triggering echo(1) options like -n. Xsed="\$SED -e 1s/^X//" # A grep program that handles long lines. GREP=$lt_GREP # An ERE matcher. EGREP=$lt_EGREP # A literal string matcher. FGREP=$lt_FGREP # A BSD- or MS-compatible name lister. NM=$lt_NM # Whether we need soft or hard links. LN_S=$lt_LN_S # What is the maximum length of a command? max_cmd_len=$max_cmd_len # Object file suffix (normally "o"). objext=$ac_objext # Executable file suffix (normally ""). exeext=$exeext # whether the shell understands "unset". lt_unset=$lt_unset # turn spaces into newlines. SP2NL=$lt_lt_SP2NL # turn newlines into spaces. NL2SP=$lt_lt_NL2SP # convert \$build file names to \$host format. to_host_file_cmd=$lt_cv_to_host_file_cmd # convert \$build files to toolchain format. to_tool_file_cmd=$lt_cv_to_tool_file_cmd # A file(cmd) program that detects file types. FILECMD=$lt_FILECMD # Method to check whether dependent libraries are shared objects. deplibs_check_method=$lt_deplibs_check_method # Command to use when deplibs_check_method = "file_magic". file_magic_cmd=$lt_file_magic_cmd # How to find potential files when deplibs_check_method = "file_magic". file_magic_glob=$lt_file_magic_glob # Find potential files using nocaseglob when deplibs_check_method = "file_magic". want_nocaseglob=$lt_want_nocaseglob # Command to associate shared and link libraries. sharedlib_from_linklib_cmd=$lt_sharedlib_from_linklib_cmd # The archiver. AR=$lt_AR # Flags to create an archive (by configure). lt_ar_flags=$lt_ar_flags # Flags to create an archive. AR_FLAGS=\${ARFLAGS-"\$lt_ar_flags"} # How to feed a file listing to the archiver. archiver_list_spec=$lt_archiver_list_spec # A symbol stripping program. STRIP=$lt_STRIP # Commands used to install an old-style archive. RANLIB=$lt_RANLIB old_postinstall_cmds=$lt_old_postinstall_cmds old_postuninstall_cmds=$lt_old_postuninstall_cmds # Whether to use a lock for old archive extraction. lock_old_archive_extraction=$lock_old_archive_extraction # A C compiler. LTCC=$lt_CC # LTCC compiler flags. LTCFLAGS=$lt_CFLAGS # Take the output of nm and produce a listing of raw symbols and C names. global_symbol_pipe=$lt_lt_cv_sys_global_symbol_pipe # Transform the output of nm in a proper C declaration. global_symbol_to_cdecl=$lt_lt_cv_sys_global_symbol_to_cdecl # Transform the output of nm into a list of symbols to manually relocate. global_symbol_to_import=$lt_lt_cv_sys_global_symbol_to_import # Transform the output of nm in a C name address pair. global_symbol_to_c_name_address=$lt_lt_cv_sys_global_symbol_to_c_name_address # Transform the output of nm in a C name address pair when lib prefix is needed. global_symbol_to_c_name_address_lib_prefix=$lt_lt_cv_sys_global_symbol_to_c_name_address_lib_prefix # The name lister interface. nm_interface=$lt_lt_cv_nm_interface # Specify filename containing input files for \$NM. nm_file_list_spec=$lt_nm_file_list_spec # The root where to search for dependent libraries,and where our libraries should be installed. lt_sysroot=$lt_sysroot # Command to truncate a binary pipe. lt_truncate_bin=$lt_lt_cv_truncate_bin # The name of the directory that contains temporary libtool files. objdir=$objdir # Used to examine libraries when file_magic_cmd begins with "file". MAGIC_CMD=$MAGIC_CMD # Must we lock files when doing compilation? need_locks=$lt_need_locks # Manifest tool. MANIFEST_TOOL=$lt_MANIFEST_TOOL # Tool to manipulate archived DWARF debug symbol files on Mac OS X. DSYMUTIL=$lt_DSYMUTIL # Tool to change global to local symbols on Mac OS X. NMEDIT=$lt_NMEDIT # Tool to manipulate fat objects and archives on Mac OS X. LIPO=$lt_LIPO # ldd/readelf like tool for Mach-O binaries on Mac OS X. OTOOL=$lt_OTOOL # ldd/readelf like tool for 64 bit Mach-O binaries on Mac OS X 10.4. OTOOL64=$lt_OTOOL64 # Old archive suffix (normally "a"). libext=$libext # Shared library suffix (normally ".so"). shrext_cmds=$lt_shrext_cmds # The commands to extract the exported symbol list from a shared archive. extract_expsyms_cmds=$lt_extract_expsyms_cmds # Variables whose values should be saved in libtool wrapper scripts and # restored at link time. variables_saved_for_relink=$lt_variables_saved_for_relink # Do we need the "lib" prefix for modules? need_lib_prefix=$need_lib_prefix # Do we need a version for libraries? need_version=$need_version # Library versioning type. version_type=$version_type # Shared library runtime path variable. runpath_var=$runpath_var # Shared library path variable. shlibpath_var=$shlibpath_var # Is shlibpath searched before the hard-coded library search path? shlibpath_overrides_runpath=$shlibpath_overrides_runpath # Format of library name prefix. libname_spec=$lt_libname_spec # List of archive names. First name is the real one, the rest are links. # The last name is the one that the linker finds with -lNAME library_names_spec=$lt_library_names_spec # The coded name of the library, if different from the real name. soname_spec=$lt_soname_spec # Permission mode override for installation of shared libraries. install_override_mode=$lt_install_override_mode # Command to use after installation of a shared archive. postinstall_cmds=$lt_postinstall_cmds # Command to use after uninstallation of a shared archive. postuninstall_cmds=$lt_postuninstall_cmds # Commands used to finish a libtool library installation in a directory. finish_cmds=$lt_finish_cmds # As "finish_cmds", except a single script fragment to be evaled but # not shown. finish_eval=$lt_finish_eval # Whether we should hardcode library paths into libraries. hardcode_into_libs=$hardcode_into_libs # Compile-time system search path for libraries. sys_lib_search_path_spec=$lt_sys_lib_search_path_spec # Detected run-time system search path for libraries. sys_lib_dlsearch_path_spec=$lt_configure_time_dlsearch_path # Explicit LT_SYS_LIBRARY_PATH set during ./configure time. configure_time_lt_sys_library_path=$lt_configure_time_lt_sys_library_path # Whether dlopen is supported. dlopen_support=$enable_dlopen # Whether dlopen of programs is supported. dlopen_self=$enable_dlopen_self # Whether dlopen of statically linked programs is supported. dlopen_self_static=$enable_dlopen_self_static # Commands to strip libraries. old_striplib=$lt_old_striplib striplib=$lt_striplib # The linker used to build libraries. LD=$lt_LD # How to create reloadable object files. reload_flag=$lt_reload_flag reload_cmds=$lt_reload_cmds # Commands used to build an old-style archive. old_archive_cmds=$lt_old_archive_cmds # A language specific compiler. CC=$lt_compiler # Is the compiler the GNU compiler? with_gcc=$GCC # Compiler flag to turn off builtin functions. no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag # Additional compiler flags for building library objects. pic_flag=$lt_lt_prog_compiler_pic # How to pass a linker flag through the compiler. wl=$lt_lt_prog_compiler_wl # Compiler flag to prevent dynamic linking. link_static_flag=$lt_lt_prog_compiler_static # Does compiler simultaneously support -c and -o options? compiler_c_o=$lt_lt_cv_prog_compiler_c_o # Whether or not to add -lc for building shared libraries. build_libtool_need_lc=$archive_cmds_need_lc # Whether or not to disallow shared libs when runtime libs are static. allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes # Compiler flag to allow reflexive dlopens. export_dynamic_flag_spec=$lt_export_dynamic_flag_spec # Compiler flag to generate shared objects directly from archives. whole_archive_flag_spec=$lt_whole_archive_flag_spec # Whether the compiler copes with passing no objects directly. compiler_needs_object=$lt_compiler_needs_object # Create an old-style archive from a shared archive. old_archive_from_new_cmds=$lt_old_archive_from_new_cmds # Create a temporary old-style archive to link instead of a shared archive. old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds # Commands used to build a shared archive. archive_cmds=$lt_archive_cmds archive_expsym_cmds=$lt_archive_expsym_cmds # Commands used to build a loadable module if different from building # a shared archive. module_cmds=$lt_module_cmds module_expsym_cmds=$lt_module_expsym_cmds # Whether we are building with GNU ld or not. with_gnu_ld=$lt_with_gnu_ld # Flag that allows shared libraries with undefined symbols to be built. allow_undefined_flag=$lt_allow_undefined_flag # Flag that enforces no undefined symbols. no_undefined_flag=$lt_no_undefined_flag # Flag to hardcode \$libdir into a binary during linking. # This must work even if \$libdir does not exist hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec # Whether we need a single "-rpath" flag with a separated argument. hardcode_libdir_separator=$lt_hardcode_libdir_separator # Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes # DIR into the resulting binary. hardcode_direct=$hardcode_direct # Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes # DIR into the resulting binary and the resulting library dependency is # "absolute",i.e impossible to change by setting \$shlibpath_var if the # library is relocated. hardcode_direct_absolute=$hardcode_direct_absolute # Set to "yes" if using the -LDIR flag during linking hardcodes DIR # into the resulting binary. hardcode_minus_L=$hardcode_minus_L # Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR # into the resulting binary. hardcode_shlibpath_var=$hardcode_shlibpath_var # Set to "yes" if building a shared library automatically hardcodes DIR # into the library and all subsequent libraries and executables linked # against it. hardcode_automatic=$hardcode_automatic # Set to yes if linker adds runtime paths of dependent libraries # to runtime path list. inherit_rpath=$inherit_rpath # Whether libtool must link a program against all its dependency libraries. link_all_deplibs=$link_all_deplibs # Set to "yes" if exported symbols are required. always_export_symbols=$always_export_symbols # The commands to list exported symbols. export_symbols_cmds=$lt_export_symbols_cmds # Symbols that should not be listed in the preloaded symbols. exclude_expsyms=$lt_exclude_expsyms # Symbols that must always be exported. include_expsyms=$lt_include_expsyms # Commands necessary for linking programs (against libraries) with templates. prelink_cmds=$lt_prelink_cmds # Commands necessary for finishing linking programs. postlink_cmds=$lt_postlink_cmds # Specify filename containing input files. file_list_spec=$lt_file_list_spec # How to hardcode a shared library path into an executable. hardcode_action=$hardcode_action # The directories searched by this compiler when creating a shared library. compiler_lib_search_dirs=$lt_compiler_lib_search_dirs # Dependencies to place before and after the objects being linked to # create a shared library. predep_objects=$lt_predep_objects postdep_objects=$lt_postdep_objects predeps=$lt_predeps postdeps=$lt_postdeps # The library search path used internally by the compiler when linking # a shared library. compiler_lib_search_path=$lt_compiler_lib_search_path # ### END LIBTOOL CONFIG _LT_EOF cat <<'_LT_EOF' >> "$cfgfile" # ### BEGIN FUNCTIONS SHARED WITH CONFIGURE # func_munge_path_list VARIABLE PATH # ----------------------------------- # VARIABLE is name of variable containing _space_ separated list of # directories to be munged by the contents of PATH, which is string # having a format: # "DIR[:DIR]:" # string "DIR[ DIR]" will be prepended to VARIABLE # ":DIR[:DIR]" # string "DIR[ DIR]" will be appended to VARIABLE # "DIRP[:DIRP]::[DIRA:]DIRA" # string "DIRP[ DIRP]" will be prepended to VARIABLE and string # "DIRA[ DIRA]" will be appended to VARIABLE # "DIR[:DIR]" # VARIABLE will be replaced by "DIR[ DIR]" func_munge_path_list () { case x$2 in x) ;; *:) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'` \$$1\" ;; x:*) eval $1=\"\$$1 `$ECHO $2 | $SED 's/:/ /g'`\" ;; *::*) eval $1=\"\$$1\ `$ECHO $2 | $SED -e 's/.*:://' -e 's/:/ /g'`\" eval $1=\"`$ECHO $2 | $SED -e 's/::.*//' -e 's/:/ /g'`\ \$$1\" ;; *) eval $1=\"`$ECHO $2 | $SED 's/:/ /g'`\" ;; esac } # Calculate cc_basename. Skip known compiler wrappers and cross-prefix. func_cc_basename () { for cc_temp in $*""; do case $cc_temp in compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; \-*) ;; *) break;; esac done func_cc_basename_result=`$ECHO "$cc_temp" | $SED "s%.*/%%; s%^$host_alias-%%"` } # ### END FUNCTIONS SHARED WITH CONFIGURE _LT_EOF case $host_os in aix3*) cat <<\_LT_EOF >> "$cfgfile" # AIX sometimes has problems with the GCC collect2 program. For some # reason, if we set the COLLECT_NAMES environment variable, the problems # vanish in a puff of smoke. if test set != "${COLLECT_NAMES+set}"; then COLLECT_NAMES= export COLLECT_NAMES fi _LT_EOF ;; esac ltmain=$ac_aux_dir/ltmain.sh # We use sed instead of cat because bash on DJGPP gets confused if # if finds mixed CR/LF and LF-only lines. Since sed operates in # text mode, it properly converts lines to CR/LF. This bash problem # is reportedly fixed, but why not run on old versions too? $SED '$q' "$ltmain" >> "$cfgfile" \ || (rm -f "$cfgfile"; exit 1) mv -f "$cfgfile" "$ofile" || (rm -f "$ofile" && cp "$cfgfile" "$ofile" && rm -f "$cfgfile") chmod +x "$ofile" cat <<_LT_EOF >> "$ofile" # ### BEGIN LIBTOOL TAG CONFIG: CXX # The linker used to build libraries. LD=$lt_LD_CXX # How to create reloadable object files. reload_flag=$lt_reload_flag_CXX reload_cmds=$lt_reload_cmds_CXX # Commands used to build an old-style archive. old_archive_cmds=$lt_old_archive_cmds_CXX # A language specific compiler. CC=$lt_compiler_CXX # Is the compiler the GNU compiler? with_gcc=$GCC_CXX # Compiler flag to turn off builtin functions. no_builtin_flag=$lt_lt_prog_compiler_no_builtin_flag_CXX # Additional compiler flags for building library objects. pic_flag=$lt_lt_prog_compiler_pic_CXX # How to pass a linker flag through the compiler. wl=$lt_lt_prog_compiler_wl_CXX # Compiler flag to prevent dynamic linking. link_static_flag=$lt_lt_prog_compiler_static_CXX # Does compiler simultaneously support -c and -o options? compiler_c_o=$lt_lt_cv_prog_compiler_c_o_CXX # Whether or not to add -lc for building shared libraries. build_libtool_need_lc=$archive_cmds_need_lc_CXX # Whether or not to disallow shared libs when runtime libs are static. allow_libtool_libs_with_static_runtimes=$enable_shared_with_static_runtimes_CXX # Compiler flag to allow reflexive dlopens. export_dynamic_flag_spec=$lt_export_dynamic_flag_spec_CXX # Compiler flag to generate shared objects directly from archives. whole_archive_flag_spec=$lt_whole_archive_flag_spec_CXX # Whether the compiler copes with passing no objects directly. compiler_needs_object=$lt_compiler_needs_object_CXX # Create an old-style archive from a shared archive. old_archive_from_new_cmds=$lt_old_archive_from_new_cmds_CXX # Create a temporary old-style archive to link instead of a shared archive. old_archive_from_expsyms_cmds=$lt_old_archive_from_expsyms_cmds_CXX # Commands used to build a shared archive. archive_cmds=$lt_archive_cmds_CXX archive_expsym_cmds=$lt_archive_expsym_cmds_CXX # Commands used to build a loadable module if different from building # a shared archive. module_cmds=$lt_module_cmds_CXX module_expsym_cmds=$lt_module_expsym_cmds_CXX # Whether we are building with GNU ld or not. with_gnu_ld=$lt_with_gnu_ld_CXX # Flag that allows shared libraries with undefined symbols to be built. allow_undefined_flag=$lt_allow_undefined_flag_CXX # Flag that enforces no undefined symbols. no_undefined_flag=$lt_no_undefined_flag_CXX # Flag to hardcode \$libdir into a binary during linking. # This must work even if \$libdir does not exist hardcode_libdir_flag_spec=$lt_hardcode_libdir_flag_spec_CXX # Whether we need a single "-rpath" flag with a separated argument. hardcode_libdir_separator=$lt_hardcode_libdir_separator_CXX # Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes # DIR into the resulting binary. hardcode_direct=$hardcode_direct_CXX # Set to "yes" if using DIR/libNAME\$shared_ext during linking hardcodes # DIR into the resulting binary and the resulting library dependency is # "absolute",i.e impossible to change by setting \$shlibpath_var if the # library is relocated. hardcode_direct_absolute=$hardcode_direct_absolute_CXX # Set to "yes" if using the -LDIR flag during linking hardcodes DIR # into the resulting binary. hardcode_minus_L=$hardcode_minus_L_CXX # Set to "yes" if using SHLIBPATH_VAR=DIR during linking hardcodes DIR # into the resulting binary. hardcode_shlibpath_var=$hardcode_shlibpath_var_CXX # Set to "yes" if building a shared library automatically hardcodes DIR # into the library and all subsequent libraries and executables linked # against it. hardcode_automatic=$hardcode_automatic_CXX # Set to yes if linker adds runtime paths of dependent libraries # to runtime path list. inherit_rpath=$inherit_rpath_CXX # Whether libtool must link a program against all its dependency libraries. link_all_deplibs=$link_all_deplibs_CXX # Set to "yes" if exported symbols are required. always_export_symbols=$always_export_symbols_CXX # The commands to list exported symbols. export_symbols_cmds=$lt_export_symbols_cmds_CXX # Symbols that should not be listed in the preloaded symbols. exclude_expsyms=$lt_exclude_expsyms_CXX # Symbols that must always be exported. include_expsyms=$lt_include_expsyms_CXX # Commands necessary for linking programs (against libraries) with templates. prelink_cmds=$lt_prelink_cmds_CXX # Commands necessary for finishing linking programs. postlink_cmds=$lt_postlink_cmds_CXX # Specify filename containing input files. file_list_spec=$lt_file_list_spec_CXX # How to hardcode a shared library path into an executable. hardcode_action=$hardcode_action_CXX # The directories searched by this compiler when creating a shared library. compiler_lib_search_dirs=$lt_compiler_lib_search_dirs_CXX # Dependencies to place before and after the objects being linked to # create a shared library. predep_objects=$lt_predep_objects_CXX postdep_objects=$lt_postdep_objects_CXX predeps=$lt_predeps_CXX postdeps=$lt_postdeps_CXX # The library search path used internally by the compiler when linking # a shared library. compiler_lib_search_path=$lt_compiler_lib_search_path_CXX # ### END LIBTOOL TAG CONFIG: CXX _LT_EOF ;; "po-directories":C) for ac_file in $CONFIG_FILES; do # Support "outfile[:infile[:infile...]]" case "$ac_file" in *:*) ac_file=`echo "$ac_file"|sed 's%:.*%%'` ;; esac # PO directories have a Makefile.in generated from Makefile.in.in. case "$ac_file" in */Makefile.in) # Adjust a relative srcdir. ac_dir=`echo "$ac_file"|sed 's%/[^/][^/]*$%%'` ac_dir_suffix=/`echo "$ac_dir"|sed 's%^\./%%'` ac_dots=`echo "$ac_dir_suffix"|sed 's%/[^/]*%../%g'` # In autoconf-2.13 it is called $ac_given_srcdir. # In autoconf-2.50 it is called $srcdir. test -n "$ac_given_srcdir" || ac_given_srcdir="$srcdir" case "$ac_given_srcdir" in .) top_srcdir=`echo $ac_dots|sed 's%/$%%'` ;; /*) top_srcdir="$ac_given_srcdir" ;; *) top_srcdir="$ac_dots$ac_given_srcdir" ;; esac # Treat a directory as a PO directory if and only if it has a # POTFILES.in file. This allows packages to have multiple PO # directories under different names or in different locations. if test -f "$ac_given_srcdir/$ac_dir/POTFILES.in"; then rm -f "$ac_dir/POTFILES" test -n "$as_me" && echo "$as_me: creating $ac_dir/POTFILES" || echo "creating $ac_dir/POTFILES" gt_tab=`printf '\t'` cat "$ac_given_srcdir/$ac_dir/POTFILES.in" | sed -e "/^#/d" -e "/^[ ${gt_tab}]*\$/d" -e "s,.*, $top_srcdir/& \\\\," | sed -e "\$s/\(.*\) \\\\/\1/" > "$ac_dir/POTFILES" POMAKEFILEDEPS="POTFILES.in" # ALL_LINGUAS, POFILES, UPDATEPOFILES, DUMMYPOFILES, GMOFILES depend # on $ac_dir but don't depend on user-specified configuration # parameters. if test -f "$ac_given_srcdir/$ac_dir/LINGUAS"; then # The LINGUAS file contains the set of available languages. if test -n "$OBSOLETE_ALL_LINGUAS"; then test -n "$as_me" && echo "$as_me: setting ALL_LINGUAS in configure.in is obsolete" || echo "setting ALL_LINGUAS in configure.in is obsolete" fi ALL_LINGUAS=`sed -e "/^#/d" -e "s/#.*//" "$ac_given_srcdir/$ac_dir/LINGUAS"` POMAKEFILEDEPS="$POMAKEFILEDEPS LINGUAS" else # The set of available languages was given in configure.in. ALL_LINGUAS=$OBSOLETE_ALL_LINGUAS fi # Compute POFILES # as $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).po) # Compute UPDATEPOFILES # as $(foreach lang, $(ALL_LINGUAS), $(lang).po-update) # Compute DUMMYPOFILES # as $(foreach lang, $(ALL_LINGUAS), $(lang).nop) # Compute GMOFILES # as $(foreach lang, $(ALL_LINGUAS), $(srcdir)/$(lang).gmo) case "$ac_given_srcdir" in .) srcdirpre= ;; *) srcdirpre='$(srcdir)/' ;; esac POFILES= UPDATEPOFILES= DUMMYPOFILES= GMOFILES= for lang in $ALL_LINGUAS; do POFILES="$POFILES $srcdirpre$lang.po" UPDATEPOFILES="$UPDATEPOFILES $lang.po-update" DUMMYPOFILES="$DUMMYPOFILES $lang.nop" GMOFILES="$GMOFILES $srcdirpre$lang.gmo" done # CATALOGS depends on both $ac_dir and the user's LINGUAS # environment variable. INST_LINGUAS= if test -n "$ALL_LINGUAS"; then for presentlang in $ALL_LINGUAS; do useit=no if test "%UNSET%" != "$LINGUAS"; then desiredlanguages="$LINGUAS" else desiredlanguages="$ALL_LINGUAS" fi for desiredlang in $desiredlanguages; do # Use the presentlang catalog if desiredlang is # a. equal to presentlang, or # b. a variant of presentlang (because in this case, # presentlang can be used as a fallback for messages # which are not translated in the desiredlang catalog). case "$desiredlang" in "$presentlang"*) useit=yes;; esac done if test $useit = yes; then INST_LINGUAS="$INST_LINGUAS $presentlang" fi done fi CATALOGS= if test -n "$INST_LINGUAS"; then for lang in $INST_LINGUAS; do CATALOGS="$CATALOGS $lang.gmo" done fi test -n "$as_me" && echo "$as_me: creating $ac_dir/Makefile" || echo "creating $ac_dir/Makefile" sed -e "/^POTFILES =/r $ac_dir/POTFILES" -e "/^# Makevars/r $ac_given_srcdir/$ac_dir/Makevars" -e "s|@POFILES@|$POFILES|g" -e "s|@UPDATEPOFILES@|$UPDATEPOFILES|g" -e "s|@DUMMYPOFILES@|$DUMMYPOFILES|g" -e "s|@GMOFILES@|$GMOFILES|g" -e "s|@CATALOGS@|$CATALOGS|g" -e "s|@POMAKEFILEDEPS@|$POMAKEFILEDEPS|g" "$ac_dir/Makefile.in" > "$ac_dir/Makefile" for f in "$ac_given_srcdir/$ac_dir"/Rules-*; do if test -f "$f"; then case "$f" in *.orig | *.bak | *~) ;; *) cat "$f" >> "$ac_dir/Makefile" ;; esac fi done fi ;; esac done ;; esac done # for ac_tag as_fn_exit 0 _ACEOF ac_clean_files=$ac_clean_files_save test $ac_write_fail = 0 || as_fn_error $? "write failure creating $CONFIG_STATUS" "$LINENO" 5 # configure is writing to config.log, and then calls config.status. # config.status does its own redirection, appending to config.log. # Unfortunately, on DOS this fails, as config.log is still kept open # by configure, so config.status won't be able to write to it; its # output is simply discarded. So we exec the FD to /dev/null, # effectively closing config.log, so it can be properly (re)opened and # appended to by config.status. When coming back to configure, we # need to make the FD available again. if test "$no_create" != yes; then ac_cs_success=: ac_config_status_args= test "$silent" = yes && ac_config_status_args="$ac_config_status_args --quiet" exec 5>/dev/null $SHELL $CONFIG_STATUS $ac_config_status_args || ac_cs_success=false exec 5>>config.log # Use ||, not &&, to avoid exiting from the if with $? = 1, which # would make configure fail if this is the last instruction. $ac_cs_success || as_fn_exit 1 fi if test -n "$ac_unrecognized_opts" && test "$enable_option_checking" != no; then { printf "%s\n" "$as_me:${as_lineno-$LINENO}: WARNING: unrecognized options: $ac_unrecognized_opts" >&5 printf "%s\n" "$as_me: WARNING: unrecognized options: $ac_unrecognized_opts" >&2;} fi { printf "%s\n" "$as_me:${as_lineno-$LINENO}: Building: libcerror support: $ac_cv_libcerror AES-CBC support: $ac_cv_libcaes_aes_cbc AES-ECB support: $ac_cv_libcaes_aes_ecb AES-XTS support: $ac_cv_libcaes_aes_xts Features: Python (pycaes) support: $ac_cv_enable_python " >&5 printf "%s\n" "$as_me: Building: libcerror support: $ac_cv_libcerror AES-CBC support: $ac_cv_libcaes_aes_cbc AES-ECB support: $ac_cv_libcaes_aes_ecb AES-XTS support: $ac_cv_libcaes_aes_xts Features: Python (pycaes) support: $ac_cv_enable_python " >&6;}; libcaes-20240413/compile0000755000175000017500000001635014606477627015621 0ustar00lordyestalordyesta#! /bin/sh # Wrapper for compilers which do not understand '-c -o'. scriptversion=2018-03-07.03; # UTC # Copyright (C) 1999-2021 Free Software Foundation, Inc. # Written by Tom Tromey . # # This program 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, or (at your option) # any later version. # # This program 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 this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. # This file is maintained in Automake, please report # bugs to or send patches to # . nl=' ' # We need space, tab and new line, in precisely that order. Quoting is # there to prevent tools from complaining about whitespace usage. IFS=" "" $nl" file_conv= # func_file_conv build_file lazy # Convert a $build file to $host form and store it in $file # Currently only supports Windows hosts. If the determined conversion # type is listed in (the comma separated) LAZY, no conversion will # take place. func_file_conv () { file=$1 case $file in / | /[!/]*) # absolute file, and not a UNC file if test -z "$file_conv"; then # lazily determine how to convert abs files case `uname -s` in MINGW*) file_conv=mingw ;; CYGWIN* | MSYS*) file_conv=cygwin ;; *) file_conv=wine ;; esac fi case $file_conv/,$2, in *,$file_conv,*) ;; mingw/*) file=`cmd //C echo "$file " | sed -e 's/"\(.*\) " *$/\1/'` ;; cygwin/* | msys/*) file=`cygpath -m "$file" || echo "$file"` ;; wine/*) file=`winepath -w "$file" || echo "$file"` ;; esac ;; esac } # func_cl_dashL linkdir # Make cl look for libraries in LINKDIR func_cl_dashL () { func_file_conv "$1" if test -z "$lib_path"; then lib_path=$file else lib_path="$lib_path;$file" fi linker_opts="$linker_opts -LIBPATH:$file" } # func_cl_dashl library # Do a library search-path lookup for cl func_cl_dashl () { lib=$1 found=no save_IFS=$IFS IFS=';' for dir in $lib_path $LIB do IFS=$save_IFS if $shared && test -f "$dir/$lib.dll.lib"; then found=yes lib=$dir/$lib.dll.lib break fi if test -f "$dir/$lib.lib"; then found=yes lib=$dir/$lib.lib break fi if test -f "$dir/lib$lib.a"; then found=yes lib=$dir/lib$lib.a break fi done IFS=$save_IFS if test "$found" != yes; then lib=$lib.lib fi } # func_cl_wrapper cl arg... # Adjust compile command to suit cl func_cl_wrapper () { # Assume a capable shell lib_path= shared=: linker_opts= for arg do if test -n "$eat"; then eat= else case $1 in -o) # configure might choose to run compile as 'compile cc -o foo foo.c'. eat=1 case $2 in *.o | *.[oO][bB][jJ]) func_file_conv "$2" set x "$@" -Fo"$file" shift ;; *) func_file_conv "$2" set x "$@" -Fe"$file" shift ;; esac ;; -I) eat=1 func_file_conv "$2" mingw set x "$@" -I"$file" shift ;; -I*) func_file_conv "${1#-I}" mingw set x "$@" -I"$file" shift ;; -l) eat=1 func_cl_dashl "$2" set x "$@" "$lib" shift ;; -l*) func_cl_dashl "${1#-l}" set x "$@" "$lib" shift ;; -L) eat=1 func_cl_dashL "$2" ;; -L*) func_cl_dashL "${1#-L}" ;; -static) shared=false ;; -Wl,*) arg=${1#-Wl,} save_ifs="$IFS"; IFS=',' for flag in $arg; do IFS="$save_ifs" linker_opts="$linker_opts $flag" done IFS="$save_ifs" ;; -Xlinker) eat=1 linker_opts="$linker_opts $2" ;; -*) set x "$@" "$1" shift ;; *.cc | *.CC | *.cxx | *.CXX | *.[cC]++) func_file_conv "$1" set x "$@" -Tp"$file" shift ;; *.c | *.cpp | *.CPP | *.lib | *.LIB | *.Lib | *.OBJ | *.obj | *.[oO]) func_file_conv "$1" mingw set x "$@" "$file" shift ;; *) set x "$@" "$1" shift ;; esac fi shift done if test -n "$linker_opts"; then linker_opts="-link$linker_opts" fi exec "$@" $linker_opts exit 1 } eat= case $1 in '') echo "$0: No command. Try '$0 --help' for more information." 1>&2 exit 1; ;; -h | --h*) cat <<\EOF Usage: compile [--help] [--version] PROGRAM [ARGS] Wrapper for compilers which do not understand '-c -o'. Remove '-o dest.o' from ARGS, run PROGRAM with the remaining arguments, and rename the output as expected. If you are trying to build a whole package this is not the right script to run: please start by reading the file 'INSTALL'. Report bugs to . EOF exit $? ;; -v | --v*) echo "compile $scriptversion" exit $? ;; cl | *[/\\]cl | cl.exe | *[/\\]cl.exe | \ icl | *[/\\]icl | icl.exe | *[/\\]icl.exe ) func_cl_wrapper "$@" # Doesn't return... ;; esac ofile= cfile= for arg do if test -n "$eat"; then eat= else case $1 in -o) # configure might choose to run compile as 'compile cc -o foo foo.c'. # So we strip '-o arg' only if arg is an object. eat=1 case $2 in *.o | *.obj) ofile=$2 ;; *) set x "$@" -o "$2" shift ;; esac ;; *.c) cfile=$1 set x "$@" "$1" shift ;; *) set x "$@" "$1" shift ;; esac fi shift done if test -z "$ofile" || test -z "$cfile"; then # If no '-o' option was seen then we might have been invoked from a # pattern rule where we don't need one. That is ok -- this is a # normal compilation that the losing compiler can handle. If no # '.c' file was seen then we are probably linking. That is also # ok. exec "$@" fi # Name of file we expect compiler to create. cofile=`echo "$cfile" | sed 's|^.*[\\/]||; s|^[a-zA-Z]:||; s/\.c$/.o/'` # Create the lock directory. # Note: use '[/\\:.-]' here to ensure that we don't use the same name # that we are using for the .o file. Also, base the name on the expected # object file name, since that is what matters with a parallel build. lockdir=`echo "$cofile" | sed -e 's|[/\\:.-]|_|g'`.d while true; do if mkdir "$lockdir" >/dev/null 2>&1; then break fi sleep 1 done # FIXME: race condition here if user kills between mkdir and trap. trap "rmdir '$lockdir'; exit 1" 1 2 15 # Run the compile. "$@" ret=$? if test -f "$cofile"; then test "$cofile" = "$ofile" || mv "$cofile" "$ofile" elif test -f "${cofile}bj"; then test "${cofile}bj" = "$ofile" || mv "${cofile}bj" "$ofile" fi rmdir "$lockdir" exit $ret # Local Variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: libcaes-20240413/missing0000755000175000017500000001533614606477627015645 0ustar00lordyestalordyesta#! /bin/sh # Common wrapper for a few potentially missing GNU programs. scriptversion=2018-03-07.03; # UTC # Copyright (C) 1996-2021 Free Software Foundation, Inc. # Originally written by Fran,cois Pinard , 1996. # This program 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, or (at your option) # any later version. # This program 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 this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. if test $# -eq 0; then echo 1>&2 "Try '$0 --help' for more information" exit 1 fi case $1 in --is-lightweight) # Used by our autoconf macros to check whether the available missing # script is modern enough. exit 0 ;; --run) # Back-compat with the calling convention used by older automake. shift ;; -h|--h|--he|--hel|--help) echo "\ $0 [OPTION]... PROGRAM [ARGUMENT]... Run 'PROGRAM [ARGUMENT]...', returning a proper advice when this fails due to PROGRAM being missing or too old. Options: -h, --help display this help and exit -v, --version output version information and exit Supported PROGRAM values: aclocal autoconf autoheader autom4te automake makeinfo bison yacc flex lex help2man Version suffixes to PROGRAM as well as the prefixes 'gnu-', 'gnu', and 'g' are ignored when checking the name. Send bug reports to ." exit $? ;; -v|--v|--ve|--ver|--vers|--versi|--versio|--version) echo "missing $scriptversion (GNU Automake)" exit $? ;; -*) echo 1>&2 "$0: unknown '$1' option" echo 1>&2 "Try '$0 --help' for more information" exit 1 ;; esac # Run the given program, remember its exit status. "$@"; st=$? # If it succeeded, we are done. test $st -eq 0 && exit 0 # Also exit now if we it failed (or wasn't found), and '--version' was # passed; such an option is passed most likely to detect whether the # program is present and works. case $2 in --version|--help) exit $st;; esac # Exit code 63 means version mismatch. This often happens when the user # tries to use an ancient version of a tool on a file that requires a # minimum version. if test $st -eq 63; then msg="probably too old" elif test $st -eq 127; then # Program was missing. msg="missing on your system" else # Program was found and executed, but failed. Give up. exit $st fi perl_URL=https://www.perl.org/ flex_URL=https://github.com/westes/flex gnu_software_URL=https://www.gnu.org/software program_details () { case $1 in aclocal|automake) echo "The '$1' program is part of the GNU Automake package:" echo "<$gnu_software_URL/automake>" echo "It also requires GNU Autoconf, GNU m4 and Perl in order to run:" echo "<$gnu_software_URL/autoconf>" echo "<$gnu_software_URL/m4/>" echo "<$perl_URL>" ;; autoconf|autom4te|autoheader) echo "The '$1' program is part of the GNU Autoconf package:" echo "<$gnu_software_URL/autoconf/>" echo "It also requires GNU m4 and Perl in order to run:" echo "<$gnu_software_URL/m4/>" echo "<$perl_URL>" ;; esac } give_advice () { # Normalize program name to check for. normalized_program=`echo "$1" | sed ' s/^gnu-//; t s/^gnu//; t s/^g//; t'` printf '%s\n' "'$1' is $msg." configure_deps="'configure.ac' or m4 files included by 'configure.ac'" case $normalized_program in autoconf*) echo "You should only need it if you modified 'configure.ac'," echo "or m4 files included by it." program_details 'autoconf' ;; autoheader*) echo "You should only need it if you modified 'acconfig.h' or" echo "$configure_deps." program_details 'autoheader' ;; automake*) echo "You should only need it if you modified 'Makefile.am' or" echo "$configure_deps." program_details 'automake' ;; aclocal*) echo "You should only need it if you modified 'acinclude.m4' or" echo "$configure_deps." program_details 'aclocal' ;; autom4te*) echo "You might have modified some maintainer files that require" echo "the 'autom4te' program to be rebuilt." program_details 'autom4te' ;; bison*|yacc*) echo "You should only need it if you modified a '.y' file." echo "You may want to install the GNU Bison package:" echo "<$gnu_software_URL/bison/>" ;; lex*|flex*) echo "You should only need it if you modified a '.l' file." echo "You may want to install the Fast Lexical Analyzer package:" echo "<$flex_URL>" ;; help2man*) echo "You should only need it if you modified a dependency" \ "of a man page." echo "You may want to install the GNU Help2man package:" echo "<$gnu_software_URL/help2man/>" ;; makeinfo*) echo "You should only need it if you modified a '.texi' file, or" echo "any other file indirectly affecting the aspect of the manual." echo "You might want to install the Texinfo package:" echo "<$gnu_software_URL/texinfo/>" echo "The spurious makeinfo call might also be the consequence of" echo "using a buggy 'make' (AIX, DU, IRIX), in which case you might" echo "want to install GNU make:" echo "<$gnu_software_URL/make/>" ;; *) echo "You might have modified some files without having the proper" echo "tools for further handling them. Check the 'README' file, it" echo "often tells you about the needed prerequisites for installing" echo "this package. You may also peek at any GNU archive site, in" echo "case some other package contains this missing '$1' program." ;; esac } give_advice "$1" | sed -e '1s/^/WARNING: /' \ -e '2,$s/^/ /' >&2 # Propagate the correct exit status (expected to be 127 for a program # not found, 63 for a program that failed due to version mismatch). exit $st # Local variables: # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: libcaes-20240413/msvscpp/0000755000175000017500000000000014606477654015731 5ustar00lordyestalordyestalibcaes-20240413/msvscpp/caes_test_crypt_ccm/0000755000175000017500000000000014606477654021746 5ustar00lordyestalordyestalibcaes-20240413/msvscpp/caes_test_crypt_ccm/caes_test_crypt_ccm.vcproj0000644000175000017500000001103314606473502027172 0ustar00lordyestalordyesta libcaes-20240413/msvscpp/libcaes/0000755000175000017500000000000014606477654017333 5ustar00lordyestalordyestalibcaes-20240413/msvscpp/libcaes/libcaes.vcproj0000644000175000017500000001241714606473415022156 0ustar00lordyestalordyesta libcaes-20240413/msvscpp/caes_test_support/0000755000175000017500000000000014606477654021477 5ustar00lordyestalordyestalibcaes-20240413/msvscpp/caes_test_support/caes_test_support.vcproj0000644000175000017500000001102214606473415026455 0ustar00lordyestalordyesta libcaes-20240413/msvscpp/caes_test_context/0000755000175000017500000000000014606477654021447 5ustar00lordyestalordyestalibcaes-20240413/msvscpp/caes_test_context/caes_test_context.vcproj0000644000175000017500000001140514606473415026402 0ustar00lordyestalordyesta libcaes-20240413/msvscpp/Makefile.am0000644000175000017500000000103114606474417017752 0ustar00lordyestalordyestaMSVSCPP_FILES = \ caes_test_context/caes_test_context.vcproj \ caes_test_crypt_cbc/caes_test_crypt_cbc.vcproj \ caes_test_crypt_ccm/caes_test_crypt_ccm.vcproj \ caes_test_crypt_xts/caes_test_crypt_xts.vcproj \ caes_test_error/caes_test_error.vcproj \ caes_test_support/caes_test_support.vcproj \ caes_test_tweaked_context/caes_test_tweaked_context.vcproj \ libcaes/libcaes.vcproj \ libcerror/libcerror.vcproj \ pycaes/pycaes.vcproj \ libcaes.sln EXTRA_DIST = \ $(MSVSCPP_FILES) DISTCLEANFILES = \ Makefile \ Makefile.in libcaes-20240413/msvscpp/libcaes.sln0000644000175000017500000001612114606473502020036 0ustar00lordyestalordyesta Microsoft Visual Studio Solution File, Format Version 10.00 # Visual C++ Express 2008 Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "caes_test_context", "caes_test_context\caes_test_context.vcproj", "{607FD0AF-D86C-4A9C-A44F-C768A9A1C3A7}" ProjectSection(ProjectDependencies) = postProject {42F15139-E2EE-45FC-BE59-E800D341D7FB} = {42F15139-E2EE-45FC-BE59-E800D341D7FB} {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C} = {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C} EndProjectSection EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "caes_test_crypt_cbc", "caes_test_crypt_cbc\caes_test_crypt_cbc.vcproj", "{1B484756-9F82-4402-B706-0088874A7C30}" ProjectSection(ProjectDependencies) = postProject {42F15139-E2EE-45FC-BE59-E800D341D7FB} = {42F15139-E2EE-45FC-BE59-E800D341D7FB} {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C} = {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C} EndProjectSection EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "caes_test_crypt_ccm", "caes_test_crypt_ccm\caes_test_crypt_ccm.vcproj", "{05D49655-8D33-40DC-9303-F71D19454FFF}" ProjectSection(ProjectDependencies) = postProject {42F15139-E2EE-45FC-BE59-E800D341D7FB} = {42F15139-E2EE-45FC-BE59-E800D341D7FB} {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C} = {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C} EndProjectSection EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "caes_test_crypt_xts", "caes_test_crypt_xts\caes_test_crypt_xts.vcproj", "{B5B94AAD-F957-4739-B185-BDE81BAE9F5E}" ProjectSection(ProjectDependencies) = postProject {42F15139-E2EE-45FC-BE59-E800D341D7FB} = {42F15139-E2EE-45FC-BE59-E800D341D7FB} {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C} = {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C} EndProjectSection EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "caes_test_error", "caes_test_error\caes_test_error.vcproj", "{CE11F0FB-D2A9-499C-B7EE-C1801895C7B4}" ProjectSection(ProjectDependencies) = postProject {42F15139-E2EE-45FC-BE59-E800D341D7FB} = {42F15139-E2EE-45FC-BE59-E800D341D7FB} EndProjectSection EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "caes_test_support", "caes_test_support\caes_test_support.vcproj", "{AB9A5723-EEAE-439A-B324-58BBC3F58F92}" ProjectSection(ProjectDependencies) = postProject {42F15139-E2EE-45FC-BE59-E800D341D7FB} = {42F15139-E2EE-45FC-BE59-E800D341D7FB} EndProjectSection EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "caes_test_tweaked_context", "caes_test_tweaked_context\caes_test_tweaked_context.vcproj", "{F1D67F8B-982B-4AFE-B36A-0C53B9525F82}" ProjectSection(ProjectDependencies) = postProject {42F15139-E2EE-45FC-BE59-E800D341D7FB} = {42F15139-E2EE-45FC-BE59-E800D341D7FB} {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C} = {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C} EndProjectSection EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "libcaes", "libcaes\libcaes.vcproj", "{42F15139-E2EE-45FC-BE59-E800D341D7FB}" ProjectSection(ProjectDependencies) = postProject {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C} = {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C} EndProjectSection EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "pycaes", "pycaes\pycaes.vcproj", "{2C5AF1E9-F9CB-4BAA-B66B-18647FBD9082}" ProjectSection(ProjectDependencies) = postProject {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C} = {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C} {42F15139-E2EE-45FC-BE59-E800D341D7FB} = {42F15139-E2EE-45FC-BE59-E800D341D7FB} EndProjectSection EndProject Project("{8BC9CEB8-8B4A-11D0-8D11-00A0C91BC942}") = "libcerror", "libcerror\libcerror.vcproj", "{BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C}" EndProject Global GlobalSection(SolutionConfigurationPlatforms) = preSolution Release|Win32 = Release|Win32 VSDebug|Win32 = VSDebug|Win32 EndGlobalSection GlobalSection(ProjectConfigurationPlatforms) = postSolution {607FD0AF-D86C-4A9C-A44F-C768A9A1C3A7}.Release|Win32.ActiveCfg = Release|Win32 {607FD0AF-D86C-4A9C-A44F-C768A9A1C3A7}.Release|Win32.Build.0 = Release|Win32 {607FD0AF-D86C-4A9C-A44F-C768A9A1C3A7}.VSDebug|Win32.ActiveCfg = VSDebug|Win32 {607FD0AF-D86C-4A9C-A44F-C768A9A1C3A7}.VSDebug|Win32.Build.0 = VSDebug|Win32 {1B484756-9F82-4402-B706-0088874A7C30}.Release|Win32.ActiveCfg = Release|Win32 {1B484756-9F82-4402-B706-0088874A7C30}.Release|Win32.Build.0 = Release|Win32 {1B484756-9F82-4402-B706-0088874A7C30}.VSDebug|Win32.ActiveCfg = VSDebug|Win32 {1B484756-9F82-4402-B706-0088874A7C30}.VSDebug|Win32.Build.0 = VSDebug|Win32 {05D49655-8D33-40DC-9303-F71D19454FFF}.Release|Win32.ActiveCfg = Release|Win32 {05D49655-8D33-40DC-9303-F71D19454FFF}.Release|Win32.Build.0 = Release|Win32 {05D49655-8D33-40DC-9303-F71D19454FFF}.VSDebug|Win32.ActiveCfg = VSDebug|Win32 {05D49655-8D33-40DC-9303-F71D19454FFF}.VSDebug|Win32.Build.0 = VSDebug|Win32 {B5B94AAD-F957-4739-B185-BDE81BAE9F5E}.Release|Win32.ActiveCfg = Release|Win32 {B5B94AAD-F957-4739-B185-BDE81BAE9F5E}.Release|Win32.Build.0 = Release|Win32 {B5B94AAD-F957-4739-B185-BDE81BAE9F5E}.VSDebug|Win32.ActiveCfg = VSDebug|Win32 {B5B94AAD-F957-4739-B185-BDE81BAE9F5E}.VSDebug|Win32.Build.0 = VSDebug|Win32 {CE11F0FB-D2A9-499C-B7EE-C1801895C7B4}.Release|Win32.ActiveCfg = Release|Win32 {CE11F0FB-D2A9-499C-B7EE-C1801895C7B4}.Release|Win32.Build.0 = Release|Win32 {CE11F0FB-D2A9-499C-B7EE-C1801895C7B4}.VSDebug|Win32.ActiveCfg = VSDebug|Win32 {CE11F0FB-D2A9-499C-B7EE-C1801895C7B4}.VSDebug|Win32.Build.0 = VSDebug|Win32 {AB9A5723-EEAE-439A-B324-58BBC3F58F92}.Release|Win32.ActiveCfg = Release|Win32 {AB9A5723-EEAE-439A-B324-58BBC3F58F92}.Release|Win32.Build.0 = Release|Win32 {AB9A5723-EEAE-439A-B324-58BBC3F58F92}.VSDebug|Win32.ActiveCfg = VSDebug|Win32 {AB9A5723-EEAE-439A-B324-58BBC3F58F92}.VSDebug|Win32.Build.0 = VSDebug|Win32 {F1D67F8B-982B-4AFE-B36A-0C53B9525F82}.Release|Win32.ActiveCfg = Release|Win32 {F1D67F8B-982B-4AFE-B36A-0C53B9525F82}.Release|Win32.Build.0 = Release|Win32 {F1D67F8B-982B-4AFE-B36A-0C53B9525F82}.VSDebug|Win32.ActiveCfg = VSDebug|Win32 {F1D67F8B-982B-4AFE-B36A-0C53B9525F82}.VSDebug|Win32.Build.0 = VSDebug|Win32 {42F15139-E2EE-45FC-BE59-E800D341D7FB}.Release|Win32.ActiveCfg = Release|Win32 {42F15139-E2EE-45FC-BE59-E800D341D7FB}.Release|Win32.Build.0 = Release|Win32 {42F15139-E2EE-45FC-BE59-E800D341D7FB}.VSDebug|Win32.ActiveCfg = VSDebug|Win32 {42F15139-E2EE-45FC-BE59-E800D341D7FB}.VSDebug|Win32.Build.0 = VSDebug|Win32 {2C5AF1E9-F9CB-4BAA-B66B-18647FBD9082}.Release|Win32.ActiveCfg = Release|Win32 {2C5AF1E9-F9CB-4BAA-B66B-18647FBD9082}.Release|Win32.Build.0 = Release|Win32 {2C5AF1E9-F9CB-4BAA-B66B-18647FBD9082}.VSDebug|Win32.ActiveCfg = VSDebug|Win32 {2C5AF1E9-F9CB-4BAA-B66B-18647FBD9082}.VSDebug|Win32.Build.0 = VSDebug|Win32 {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C}.Release|Win32.ActiveCfg = Release|Win32 {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C}.Release|Win32.Build.0 = Release|Win32 {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C}.VSDebug|Win32.ActiveCfg = VSDebug|Win32 {BD3A95FA-A3DE-4B79-A889-A7E5ECA4B69C}.VSDebug|Win32.Build.0 = VSDebug|Win32 EndGlobalSection GlobalSection(SolutionProperties) = preSolution HideSolutionNode = FALSE EndGlobalSection EndGlobal libcaes-20240413/msvscpp/caes_test_error/0000755000175000017500000000000014606477654021114 5ustar00lordyestalordyestalibcaes-20240413/msvscpp/caes_test_error/caes_test_error.vcproj0000644000175000017500000001101414606473415025510 0ustar00lordyestalordyesta libcaes-20240413/msvscpp/caes_test_crypt_cbc/0000755000175000017500000000000014606477654021733 5ustar00lordyestalordyestalibcaes-20240413/msvscpp/caes_test_crypt_cbc/caes_test_crypt_cbc.vcproj0000644000175000017500000001103314606473502027144 0ustar00lordyestalordyesta libcaes-20240413/msvscpp/pycaes/0000755000175000017500000000000014606477654017215 5ustar00lordyestalordyestalibcaes-20240413/msvscpp/pycaes/pycaes.vcproj0000644000175000017500000001261114606473502021713 0ustar00lordyestalordyesta libcaes-20240413/msvscpp/caes_test_crypt_xts/0000755000175000017500000000000014606477654022022 5ustar00lordyestalordyestalibcaes-20240413/msvscpp/caes_test_crypt_xts/caes_test_crypt_xts.vcproj0000644000175000017500000001103314606473502027322 0ustar00lordyestalordyesta libcaes-20240413/msvscpp/Makefile.in0000644000175000017500000003711714606477627020007 0ustar00lordyestalordyesta# Makefile.in generated by automake 1.16.5 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2021 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = msvscpp ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/common.m4 \ $(top_srcdir)/m4/gettext.m4 $(top_srcdir)/m4/host-cpu-c-abi.m4 \ $(top_srcdir)/m4/iconv.m4 $(top_srcdir)/m4/intlmacosx.m4 \ $(top_srcdir)/m4/lib-ld.m4 $(top_srcdir)/m4/lib-link.m4 \ $(top_srcdir)/m4/lib-prefix.m4 $(top_srcdir)/m4/libcerror.m4 \ $(top_srcdir)/m4/libcrypto.m4 $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/nls.m4 $(top_srcdir)/m4/po.m4 \ $(top_srcdir)/m4/progtest.m4 $(top_srcdir)/m4/python.m4 \ $(top_srcdir)/m4/tests.m4 $(top_srcdir)/m4/types.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/common/config.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__extra_recursive_targets = sources-recursive splint-recursive am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CSCOPE = @CSCOPE@ CTAGS = @CTAGS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DPKG_DATE = @DPKG_DATE@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ ETAGS = @ETAGS@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ FILECMD = @FILECMD@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GREP = @GREP@ HAVE_DLLMAIN = @HAVE_DLLMAIN@ HAVE_INTTYPES_H = @HAVE_INTTYPES_H@ HAVE_LIBCERROR = @HAVE_LIBCERROR@ HAVE_LOCAL_LIBCERROR = @HAVE_LOCAL_LIBCERROR@ HAVE_OFF64_T = @HAVE_OFF64_T@ HAVE_OPENSSL_EVP_H = @HAVE_OPENSSL_EVP_H@ HAVE_SIZE32_T = @HAVE_SIZE32_T@ HAVE_SIZE64_T = @HAVE_SIZE64_T@ HAVE_SSIZE32_T = @HAVE_SSIZE32_T@ HAVE_SSIZE64_T = @HAVE_SSIZE64_T@ HAVE_STDINT_H = @HAVE_STDINT_H@ HAVE_SYS_TYPES_H = @HAVE_SYS_TYPES_H@ HAVE_WCHAR_H = @HAVE_WCHAR_H@ HAVE_WIDE_CHARACTER_TYPE = @HAVE_WIDE_CHARACTER_TYPE@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBCAES_DLL_EXPORT = @LIBCAES_DLL_EXPORT@ LIBCAES_DLL_IMPORT = @LIBCAES_DLL_IMPORT@ LIBCERROR_CPPFLAGS = @LIBCERROR_CPPFLAGS@ LIBCERROR_LIBADD = @LIBCERROR_LIBADD@ LIBCRYPTO_CPPFLAGS = @LIBCRYPTO_CPPFLAGS@ LIBCRYPTO_LIBADD = @LIBCRYPTO_LIBADD@ LIBDL_LIBADD = @LIBDL_LIBADD@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIB_FUZZING_ENGINE = @LIB_FUZZING_ENGINE@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGMERGE = @MSGMERGE@ MSGMERGE_FOR_MSGFMT_OPTION = @MSGMERGE_FOR_MSGFMT_OPTION@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ PKGCONFIG = @PKGCONFIG@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ PYTHON = @PYTHON@ PYTHON_CONFIG = @PYTHON_CONFIG@ PYTHON_CPPFLAGS = @PYTHON_CPPFLAGS@ PYTHON_EXEC_PREFIX = @PYTHON_EXEC_PREFIX@ PYTHON_LDFLAGS = @PYTHON_LDFLAGS@ PYTHON_LIBRARY_DIR = @PYTHON_LIBRARY_DIR@ PYTHON_PACKAGE_DIR = @PYTHON_PACKAGE_DIR@ PYTHON_PLATFORM = @PYTHON_PLATFORM@ PYTHON_PREFIX = @PYTHON_PREFIX@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ SPEC_DATE = @SPEC_DATE@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ ax_libcerror_pc_libs_private = @ax_libcerror_pc_libs_private@ ax_libcerror_spec_build_requires = @ax_libcerror_spec_build_requires@ ax_libcerror_spec_requires = @ax_libcerror_spec_requires@ ax_libcrypto_pc_libs_private = @ax_libcrypto_pc_libs_private@ ax_libcrypto_spec_build_requires = @ax_libcrypto_spec_build_requires@ ax_libcrypto_spec_requires = @ax_libcrypto_spec_requires@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libcaes_spec_requires = @libcaes_spec_requires@ libcerror_CFLAGS = @libcerror_CFLAGS@ libcerror_LIBS = @libcerror_LIBS@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ openssl_CFLAGS = @openssl_CFLAGS@ openssl_LIBS = @openssl_LIBS@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ pyexecdir = @pyexecdir@ pythondir = @pythondir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ MSVSCPP_FILES = \ caes_test_context/caes_test_context.vcproj \ caes_test_crypt_cbc/caes_test_crypt_cbc.vcproj \ caes_test_crypt_ccm/caes_test_crypt_ccm.vcproj \ caes_test_crypt_xts/caes_test_crypt_xts.vcproj \ caes_test_error/caes_test_error.vcproj \ caes_test_support/caes_test_support.vcproj \ caes_test_tweaked_context/caes_test_tweaked_context.vcproj \ libcaes/libcaes.vcproj \ libcerror/libcerror.vcproj \ pycaes/pycaes.vcproj \ libcaes.sln EXTRA_DIST = \ $(MSVSCPP_FILES) DISTCLEANFILES = \ Makefile \ Makefile.in all: all-am .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu msvscpp/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu msvscpp/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs sources-local: splint-local: tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile installdirs: install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) -test -z "$(DISTCLEANFILES)" || rm -f $(DISTCLEANFILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: sources: sources-am sources-am: sources-local splint: splint-am splint-am: splint-local uninstall-am: .MAKE: install-am install-strip .PHONY: all all-am check check-am clean clean-generic clean-libtool \ cscopelist-am ctags-am distclean distclean-generic \ distclean-libtool distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am install-dvi \ install-dvi-am install-exec install-exec-am install-html \ install-html-am install-info install-info-am install-man \ install-pdf install-pdf-am install-ps install-ps-am \ install-strip installcheck installcheck-am installdirs \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ sources-am sources-local splint-am splint-local tags-am \ uninstall uninstall-am .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: libcaes-20240413/msvscpp/caes_test_tweaked_context/0000755000175000017500000000000014606477654023153 5ustar00lordyestalordyestalibcaes-20240413/msvscpp/caes_test_tweaked_context/caes_test_tweaked_context.vcproj0000644000175000017500000001143514606473415031615 0ustar00lordyestalordyesta libcaes-20240413/msvscpp/libcerror/0000755000175000017500000000000014606477654017714 5ustar00lordyestalordyestalibcaes-20240413/msvscpp/libcerror/libcerror.vcproj0000644000175000017500000001061014606473415023111 0ustar00lordyestalordyesta libcaes-20240413/AUTHORS0000644000175000017500000000031014606473412015264 0ustar00lordyestalordyestaAcknowledgements: libcaes Copyright (C) 2011-2024, Joachim Metz Additional credits go to: * Omar Choudary for providing initial AES-XTS support libcaes-20240413/README0000644000175000017500000000044714606473411015106 0ustar00lordyestalordyestalibcaes is a library to support cross-platform AES encryption. Project information: * Status: alpha * Licence: LGPLv3+ For more information see: * Project documentation: https://github.com/libyal/libcaes/wiki/Home * How to build from source: https://github.com/libyal/libcaes/wiki/Building libcaes-20240413/INSTALL0000644000175000017500000003662614606477627015304 0ustar00lordyestalordyestaInstallation Instructions ************************* Copyright (C) 1994-1996, 1999-2002, 2004-2017, 2020-2021 Free Software Foundation, Inc. Copying and distribution of this file, with or without modification, are permitted in any medium without royalty provided the copyright notice and this notice are preserved. This file is offered as-is, without warranty of any kind. Basic Installation ================== Briefly, the shell command './configure && make && make install' should configure, build, and install this package. The following more-detailed instructions are generic; see the 'README' file for instructions specific to this package. Some packages provide this 'INSTALL' file but do not implement all of the features documented below. The lack of an optional feature in a given package is not necessarily a bug. More recommendations for GNU packages can be found in *note Makefile Conventions: (standards)Makefile Conventions. The 'configure' shell script attempts to guess correct values for various system-dependent variables used during compilation. It uses those values to create a 'Makefile' in each directory of the package. It may also create one or more '.h' files containing system-dependent definitions. Finally, it creates a shell script 'config.status' that you can run in the future to recreate the current configuration, and a file 'config.log' containing compiler output (useful mainly for debugging 'configure'). It can also use an optional file (typically called 'config.cache' and enabled with '--cache-file=config.cache' or simply '-C') that saves the results of its tests to speed up reconfiguring. Caching is disabled by default to prevent problems with accidental use of stale cache files. If you need to do unusual things to compile the package, please try to figure out how 'configure' could check whether to do them, and mail diffs or instructions to the address given in the 'README' so they can be considered for the next release. If you are using the cache, and at some point 'config.cache' contains results you don't want to keep, you may remove or edit it. The file 'configure.ac' (or 'configure.in') is used to create 'configure' by a program called 'autoconf'. You need 'configure.ac' if you want to change it or regenerate 'configure' using a newer version of 'autoconf'. The simplest way to compile this package is: 1. 'cd' to the directory containing the package's source code and type './configure' to configure the package for your system. Running 'configure' might take a while. While running, it prints some messages telling which features it is checking for. 2. Type 'make' to compile the package. 3. Optionally, type 'make check' to run any self-tests that come with the package, generally using the just-built uninstalled binaries. 4. Type 'make install' to install the programs and any data files and documentation. When installing into a prefix owned by root, it is recommended that the package be configured and built as a regular user, and only the 'make install' phase executed with root privileges. 5. Optionally, type 'make installcheck' to repeat any self-tests, but this time using the binaries in their final installed location. This target does not install anything. Running this target as a regular user, particularly if the prior 'make install' required root privileges, verifies that the installation completed correctly. 6. You can remove the program binaries and object files from the source code directory by typing 'make clean'. To also remove the files that 'configure' created (so you can compile the package for a different kind of computer), type 'make distclean'. There is also a 'make maintainer-clean' target, but that is intended mainly for the package's developers. If you use it, you may have to get all sorts of other programs in order to regenerate files that came with the distribution. 7. Often, you can also type 'make uninstall' to remove the installed files again. In practice, not all packages have tested that uninstallation works correctly, even though it is required by the GNU Coding Standards. 8. Some packages, particularly those that use Automake, provide 'make distcheck', which can by used by developers to test that all other targets like 'make install' and 'make uninstall' work correctly. This target is generally not run by end users. Compilers and Options ===================== Some systems require unusual options for compilation or linking that the 'configure' script does not know about. Run './configure --help' for details on some of the pertinent environment variables. You can give 'configure' initial values for configuration parameters by setting variables in the command line or in the environment. Here is an example: ./configure CC=c99 CFLAGS=-g LIBS=-lposix *Note Defining Variables::, for more details. Compiling For Multiple Architectures ==================================== You can compile the package for more than one kind of computer at the same time, by placing the object files for each architecture in their own directory. To do this, you can use GNU 'make'. 'cd' to the directory where you want the object files and executables to go and run the 'configure' script. 'configure' automatically checks for the source code in the directory that 'configure' is in and in '..'. This is known as a "VPATH" build. With a non-GNU 'make', it is safer to compile the package for one architecture at a time in the source code directory. After you have installed the package for one architecture, use 'make distclean' before reconfiguring for another architecture. On MacOS X 10.5 and later systems, you can create libraries and executables that work on multiple system types--known as "fat" or "universal" binaries--by specifying multiple '-arch' options to the compiler but only a single '-arch' option to the preprocessor. Like this: ./configure CC="gcc -arch i386 -arch x86_64 -arch ppc -arch ppc64" \ CXX="g++ -arch i386 -arch x86_64 -arch ppc -arch ppc64" \ CPP="gcc -E" CXXCPP="g++ -E" This is not guaranteed to produce working output in all cases, you may have to build one architecture at a time and combine the results using the 'lipo' tool if you have problems. Installation Names ================== By default, 'make install' installs the package's commands under '/usr/local/bin', include files under '/usr/local/include', etc. You can specify an installation prefix other than '/usr/local' by giving 'configure' the option '--prefix=PREFIX', where PREFIX must be an absolute file name. You can specify separate installation prefixes for architecture-specific files and architecture-independent files. If you pass the option '--exec-prefix=PREFIX' to 'configure', the package uses PREFIX as the prefix for installing programs and libraries. Documentation and other data files still use the regular prefix. In addition, if you use an unusual directory layout you can give options like '--bindir=DIR' to specify different values for particular kinds of files. Run 'configure --help' for a list of the directories you can set and what kinds of files go in them. In general, the default for these options is expressed in terms of '${prefix}', so that specifying just '--prefix' will affect all of the other directory specifications that were not explicitly provided. The most portable way to affect installation locations is to pass the correct locations to 'configure'; however, many packages provide one or both of the following shortcuts of passing variable assignments to the 'make install' command line to change installation locations without having to reconfigure or recompile. The first method involves providing an override variable for each affected directory. For example, 'make install prefix=/alternate/directory' will choose an alternate location for all directory configuration variables that were expressed in terms of '${prefix}'. Any directories that were specified during 'configure', but not in terms of '${prefix}', must each be overridden at install time for the entire installation to be relocated. The approach of makefile variable overrides for each directory variable is required by the GNU Coding Standards, and ideally causes no recompilation. However, some platforms have known limitations with the semantics of shared libraries that end up requiring recompilation when using this method, particularly noticeable in packages that use GNU Libtool. The second method involves providing the 'DESTDIR' variable. For example, 'make install DESTDIR=/alternate/directory' will prepend '/alternate/directory' before all installation names. The approach of 'DESTDIR' overrides is not required by the GNU Coding Standards, and does not work on platforms that have drive letters. On the other hand, it does better at avoiding recompilation issues, and works well even when some directory options were not specified in terms of '${prefix}' at 'configure' time. Optional Features ================= If the package supports it, you can cause programs to be installed with an extra prefix or suffix on their names by giving 'configure' the option '--program-prefix=PREFIX' or '--program-suffix=SUFFIX'. Some packages pay attention to '--enable-FEATURE' options to 'configure', where FEATURE indicates an optional part of the package. They may also pay attention to '--with-PACKAGE' options, where PACKAGE is something like 'gnu-as' or 'x' (for the X Window System). The 'README' should mention any '--enable-' and '--with-' options that the package recognizes. For packages that use the X Window System, 'configure' can usually find the X include and library files automatically, but if it doesn't, you can use the 'configure' options '--x-includes=DIR' and '--x-libraries=DIR' to specify their locations. Some packages offer the ability to configure how verbose the execution of 'make' will be. For these packages, running './configure --enable-silent-rules' sets the default to minimal output, which can be overridden with 'make V=1'; while running './configure --disable-silent-rules' sets the default to verbose, which can be overridden with 'make V=0'. Particular systems ================== On HP-UX, the default C compiler is not ANSI C compatible. If GNU CC is not installed, it is recommended to use the following options in order to use an ANSI C compiler: ./configure CC="cc -Ae -D_XOPEN_SOURCE=500" and if that doesn't work, install pre-built binaries of GCC for HP-UX. HP-UX 'make' updates targets which have the same timestamps as their prerequisites, which makes it generally unusable when shipped generated files such as 'configure' are involved. Use GNU 'make' instead. On OSF/1 a.k.a. Tru64, some versions of the default C compiler cannot parse its '' header file. The option '-nodtk' can be used as a workaround. If GNU CC is not installed, it is therefore recommended to try ./configure CC="cc" and if that doesn't work, try ./configure CC="cc -nodtk" On Solaris, don't put '/usr/ucb' early in your 'PATH'. This directory contains several dysfunctional programs; working variants of these programs are available in '/usr/bin'. So, if you need '/usr/ucb' in your 'PATH', put it _after_ '/usr/bin'. On Haiku, software installed for all users goes in '/boot/common', not '/usr/local'. It is recommended to use the following options: ./configure --prefix=/boot/common Specifying the System Type ========================== There may be some features 'configure' cannot figure out automatically, but needs to determine by the type of machine the package will run on. Usually, assuming the package is built to be run on the _same_ architectures, 'configure' can figure that out, but if it prints a message saying it cannot guess the machine type, give it the '--build=TYPE' option. TYPE can either be a short name for the system type, such as 'sun4', or a canonical name which has the form: CPU-COMPANY-SYSTEM where SYSTEM can have one of these forms: OS KERNEL-OS See the file 'config.sub' for the possible values of each field. If 'config.sub' isn't included in this package, then this package doesn't need to know the machine type. If you are _building_ compiler tools for cross-compiling, you should use the option '--target=TYPE' to select the type of system they will produce code for. If you want to _use_ a cross compiler, that generates code for a platform different from the build platform, you should specify the "host" platform (i.e., that on which the generated programs will eventually be run) with '--host=TYPE'. Sharing Defaults ================ If you want to set default values for 'configure' scripts to share, you can create a site shell script called 'config.site' that gives default values for variables like 'CC', 'cache_file', and 'prefix'. 'configure' looks for 'PREFIX/share/config.site' if it exists, then 'PREFIX/etc/config.site' if it exists. Or, you can set the 'CONFIG_SITE' environment variable to the location of the site script. A warning: not all 'configure' scripts look for a site script. Defining Variables ================== Variables not defined in a site shell script can be set in the environment passed to 'configure'. However, some packages may run configure again during the build, and the customized values of these variables may be lost. In order to avoid this problem, you should set them in the 'configure' command line, using 'VAR=value'. For example: ./configure CC=/usr/local2/bin/gcc causes the specified 'gcc' to be used as the C compiler (unless it is overridden in the site shell script). Unfortunately, this technique does not work for 'CONFIG_SHELL' due to an Autoconf limitation. Until the limitation is lifted, you can use this workaround: CONFIG_SHELL=/bin/bash ./configure CONFIG_SHELL=/bin/bash 'configure' Invocation ====================== 'configure' recognizes the following options to control how it operates. '--help' '-h' Print a summary of all of the options to 'configure', and exit. '--help=short' '--help=recursive' Print a summary of the options unique to this package's 'configure', and exit. The 'short' variant lists options used only in the top level, while the 'recursive' variant lists options also present in any nested packages. '--version' '-V' Print the version of Autoconf used to generate the 'configure' script, and exit. '--cache-file=FILE' Enable the cache: use and save the results of the tests in FILE, traditionally 'config.cache'. FILE defaults to '/dev/null' to disable caching. '--config-cache' '-C' Alias for '--cache-file=config.cache'. '--quiet' '--silent' '-q' Do not print messages saying which checks are being made. To suppress all normal output, redirect it to '/dev/null' (any error messages will still be shown). '--srcdir=DIR' Look for the package's source code in directory DIR. Usually 'configure' can determine that directory automatically. '--prefix=DIR' Use DIR as the installation prefix. *note Installation Names:: for more details, including other options available for fine-tuning the installation locations. '--no-create' '-n' Run the configure checks, but stop before creating any output files. 'configure' also accepts some other, not widely useful, options. Run 'configure --help' for more details. libcaes-20240413/pyproject.toml0000644000175000017500000000013314606473411017132 0ustar00lordyestalordyesta[build-system] requires = ["setuptools", "wheel"] build-backend = "setuptools.build_meta" libcaes-20240413/setup.cfg.in0000644000175000017500000000074014606473411016450 0ustar00lordyestalordyesta[metadata] name = libcaes-python version = @VERSION@ description = Python bindings module for libcaes long_description = Python bindings module for libcaes long_description_content_type = text/plain author = Joachim Metz author_email = joachim.metz@gmail.com license = GNU Lesser General Public License v3 or later (LGPLv3+) license_files = COPYING COPYING.LESSER classifiers = Development Status :: 3 - Alpha Programming Language :: Python [options] python_requires = >=3.7 libcaes-20240413/config.sub0000755000175000017500000010572414606477627016232 0ustar00lordyestalordyesta#!/usr/bin/sh # Configuration validation subroutine script. # Copyright 1992-2023 Free Software Foundation, Inc. # shellcheck disable=SC2006,SC2268 # see below for rationale timestamp='2023-06-23' # This file 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 3 of the License, or # (at your option) any later version. # # This program 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 this program; if not, see . # # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that # program. This Exception is an additional permission under section 7 # of the GNU General Public License, version 3 ("GPLv3"). # Please send patches to . # # Configuration subroutine to validate and canonicalize a configuration type. # Supply the specified configuration type as an argument. # If it is invalid, we print an error message on stderr and exit with code 1. # Otherwise, we print the canonical config type on stdout and succeed. # You can get the latest version of this script from: # https://git.savannah.gnu.org/cgit/config.git/plain/config.sub # This file is supposed to be the same for all GNU packages # and recognize all the CPU types, system types and aliases # that are meaningful with *any* GNU software. # Each package is responsible for reporting which valid configurations # it does not support. The user should be able to distinguish # a failure to support a valid configuration from a meaningless # configuration. # The goal of this file is to map all the various variations of a given # machine specification into a single specification in the form: # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM # or in some cases, the newer four-part form: # CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM # It is wrong to echo any other type of specification. # The "shellcheck disable" line above the timestamp inhibits complaints # about features and limitations of the classic Bourne shell that were # superseded or lifted in POSIX. However, this script identifies a wide # variety of pre-POSIX systems that do not have POSIX shells at all, and # even some reasonably current systems (Solaris 10 as case-in-point) still # have a pre-POSIX /bin/sh. me=`echo "$0" | sed -e 's,.*/,,'` usage="\ Usage: $0 [OPTION] CPU-MFR-OPSYS or ALIAS Canonicalize a configuration name. Options: -h, --help print this help, then exit -t, --time-stamp print date of last modification, then exit -v, --version print version number, then exit Report bugs and patches to ." version="\ GNU config.sub ($timestamp) Copyright 1992-2023 Free Software Foundation, Inc. This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE." help=" Try '$me --help' for more information." # Parse command line while test $# -gt 0 ; do case $1 in --time-stamp | --time* | -t ) echo "$timestamp" ; exit ;; --version | -v ) echo "$version" ; exit ;; --help | --h* | -h ) echo "$usage"; exit ;; -- ) # Stop option processing shift; break ;; - ) # Use stdin as input. break ;; -* ) echo "$me: invalid option $1$help" >&2 exit 1 ;; *local*) # First pass through any local machine types. echo "$1" exit ;; * ) break ;; esac done case $# in 0) echo "$me: missing argument$help" >&2 exit 1;; 1) ;; *) echo "$me: too many arguments$help" >&2 exit 1;; esac # Split fields of configuration type # shellcheck disable=SC2162 saved_IFS=$IFS IFS="-" read field1 field2 field3 field4 <&2 exit 1 ;; *-*-*-*) basic_machine=$field1-$field2 basic_os=$field3-$field4 ;; *-*-*) # Ambiguous whether COMPANY is present, or skipped and KERNEL-OS is two # parts maybe_os=$field2-$field3 case $maybe_os in nto-qnx* | linux-* | uclinux-uclibc* \ | uclinux-gnu* | kfreebsd*-gnu* | knetbsd*-gnu* | netbsd*-gnu* \ | netbsd*-eabi* | kopensolaris*-gnu* | cloudabi*-eabi* \ | storm-chaos* | os2-emx* | rtmk-nova* | managarm-*) basic_machine=$field1 basic_os=$maybe_os ;; android-linux) basic_machine=$field1-unknown basic_os=linux-android ;; *) basic_machine=$field1-$field2 basic_os=$field3 ;; esac ;; *-*) # A lone config we happen to match not fitting any pattern case $field1-$field2 in decstation-3100) basic_machine=mips-dec basic_os= ;; *-*) # Second component is usually, but not always the OS case $field2 in # Prevent following clause from handling this valid os sun*os*) basic_machine=$field1 basic_os=$field2 ;; zephyr*) basic_machine=$field1-unknown basic_os=$field2 ;; # Manufacturers dec* | mips* | sequent* | encore* | pc533* | sgi* | sony* \ | att* | 7300* | 3300* | delta* | motorola* | sun[234]* \ | unicom* | ibm* | next | hp | isi* | apollo | altos* \ | convergent* | ncr* | news | 32* | 3600* | 3100* \ | hitachi* | c[123]* | convex* | sun | crds | omron* | dg \ | ultra | tti* | harris | dolphin | highlevel | gould \ | cbm | ns | masscomp | apple | axis | knuth | cray \ | microblaze* | sim | cisco \ | oki | wec | wrs | winbond) basic_machine=$field1-$field2 basic_os= ;; *) basic_machine=$field1 basic_os=$field2 ;; esac ;; esac ;; *) # Convert single-component short-hands not valid as part of # multi-component configurations. case $field1 in 386bsd) basic_machine=i386-pc basic_os=bsd ;; a29khif) basic_machine=a29k-amd basic_os=udi ;; adobe68k) basic_machine=m68010-adobe basic_os=scout ;; alliant) basic_machine=fx80-alliant basic_os= ;; altos | altos3068) basic_machine=m68k-altos basic_os= ;; am29k) basic_machine=a29k-none basic_os=bsd ;; amdahl) basic_machine=580-amdahl basic_os=sysv ;; amiga) basic_machine=m68k-unknown basic_os= ;; amigaos | amigados) basic_machine=m68k-unknown basic_os=amigaos ;; amigaunix | amix) basic_machine=m68k-unknown basic_os=sysv4 ;; apollo68) basic_machine=m68k-apollo basic_os=sysv ;; apollo68bsd) basic_machine=m68k-apollo basic_os=bsd ;; aros) basic_machine=i386-pc basic_os=aros ;; aux) basic_machine=m68k-apple basic_os=aux ;; balance) basic_machine=ns32k-sequent basic_os=dynix ;; blackfin) basic_machine=bfin-unknown basic_os=linux ;; cegcc) basic_machine=arm-unknown basic_os=cegcc ;; convex-c1) basic_machine=c1-convex basic_os=bsd ;; convex-c2) basic_machine=c2-convex basic_os=bsd ;; convex-c32) basic_machine=c32-convex basic_os=bsd ;; convex-c34) basic_machine=c34-convex basic_os=bsd ;; convex-c38) basic_machine=c38-convex basic_os=bsd ;; cray) basic_machine=j90-cray basic_os=unicos ;; crds | unos) basic_machine=m68k-crds basic_os= ;; da30) basic_machine=m68k-da30 basic_os= ;; decstation | pmax | pmin | dec3100 | decstatn) basic_machine=mips-dec basic_os= ;; delta88) basic_machine=m88k-motorola basic_os=sysv3 ;; dicos) basic_machine=i686-pc basic_os=dicos ;; djgpp) basic_machine=i586-pc basic_os=msdosdjgpp ;; ebmon29k) basic_machine=a29k-amd basic_os=ebmon ;; es1800 | OSE68k | ose68k | ose | OSE) basic_machine=m68k-ericsson basic_os=ose ;; gmicro) basic_machine=tron-gmicro basic_os=sysv ;; go32) basic_machine=i386-pc basic_os=go32 ;; h8300hms) basic_machine=h8300-hitachi basic_os=hms ;; h8300xray) basic_machine=h8300-hitachi basic_os=xray ;; h8500hms) basic_machine=h8500-hitachi basic_os=hms ;; harris) basic_machine=m88k-harris basic_os=sysv3 ;; hp300 | hp300hpux) basic_machine=m68k-hp basic_os=hpux ;; hp300bsd) basic_machine=m68k-hp basic_os=bsd ;; hppaosf) basic_machine=hppa1.1-hp basic_os=osf ;; hppro) basic_machine=hppa1.1-hp basic_os=proelf ;; i386mach) basic_machine=i386-mach basic_os=mach ;; isi68 | isi) basic_machine=m68k-isi basic_os=sysv ;; m68knommu) basic_machine=m68k-unknown basic_os=linux ;; magnum | m3230) basic_machine=mips-mips basic_os=sysv ;; merlin) basic_machine=ns32k-utek basic_os=sysv ;; mingw64) basic_machine=x86_64-pc basic_os=mingw64 ;; mingw32) basic_machine=i686-pc basic_os=mingw32 ;; mingw32ce) basic_machine=arm-unknown basic_os=mingw32ce ;; monitor) basic_machine=m68k-rom68k basic_os=coff ;; morphos) basic_machine=powerpc-unknown basic_os=morphos ;; moxiebox) basic_machine=moxie-unknown basic_os=moxiebox ;; msdos) basic_machine=i386-pc basic_os=msdos ;; msys) basic_machine=i686-pc basic_os=msys ;; mvs) basic_machine=i370-ibm basic_os=mvs ;; nacl) basic_machine=le32-unknown basic_os=nacl ;; ncr3000) basic_machine=i486-ncr basic_os=sysv4 ;; netbsd386) basic_machine=i386-pc basic_os=netbsd ;; netwinder) basic_machine=armv4l-rebel basic_os=linux ;; news | news700 | news800 | news900) basic_machine=m68k-sony basic_os=newsos ;; news1000) basic_machine=m68030-sony basic_os=newsos ;; necv70) basic_machine=v70-nec basic_os=sysv ;; nh3000) basic_machine=m68k-harris basic_os=cxux ;; nh[45]000) basic_machine=m88k-harris basic_os=cxux ;; nindy960) basic_machine=i960-intel basic_os=nindy ;; mon960) basic_machine=i960-intel basic_os=mon960 ;; nonstopux) basic_machine=mips-compaq basic_os=nonstopux ;; os400) basic_machine=powerpc-ibm basic_os=os400 ;; OSE68000 | ose68000) basic_machine=m68000-ericsson basic_os=ose ;; os68k) basic_machine=m68k-none basic_os=os68k ;; paragon) basic_machine=i860-intel basic_os=osf ;; parisc) basic_machine=hppa-unknown basic_os=linux ;; psp) basic_machine=mipsallegrexel-sony basic_os=psp ;; pw32) basic_machine=i586-unknown basic_os=pw32 ;; rdos | rdos64) basic_machine=x86_64-pc basic_os=rdos ;; rdos32) basic_machine=i386-pc basic_os=rdos ;; rom68k) basic_machine=m68k-rom68k basic_os=coff ;; sa29200) basic_machine=a29k-amd basic_os=udi ;; sei) basic_machine=mips-sei basic_os=seiux ;; sequent) basic_machine=i386-sequent basic_os= ;; sps7) basic_machine=m68k-bull basic_os=sysv2 ;; st2000) basic_machine=m68k-tandem basic_os= ;; stratus) basic_machine=i860-stratus basic_os=sysv4 ;; sun2) basic_machine=m68000-sun basic_os= ;; sun2os3) basic_machine=m68000-sun basic_os=sunos3 ;; sun2os4) basic_machine=m68000-sun basic_os=sunos4 ;; sun3) basic_machine=m68k-sun basic_os= ;; sun3os3) basic_machine=m68k-sun basic_os=sunos3 ;; sun3os4) basic_machine=m68k-sun basic_os=sunos4 ;; sun4) basic_machine=sparc-sun basic_os= ;; sun4os3) basic_machine=sparc-sun basic_os=sunos3 ;; sun4os4) basic_machine=sparc-sun basic_os=sunos4 ;; sun4sol2) basic_machine=sparc-sun basic_os=solaris2 ;; sun386 | sun386i | roadrunner) basic_machine=i386-sun basic_os= ;; sv1) basic_machine=sv1-cray basic_os=unicos ;; symmetry) basic_machine=i386-sequent basic_os=dynix ;; t3e) basic_machine=alphaev5-cray basic_os=unicos ;; t90) basic_machine=t90-cray basic_os=unicos ;; toad1) basic_machine=pdp10-xkl basic_os=tops20 ;; tpf) basic_machine=s390x-ibm basic_os=tpf ;; udi29k) basic_machine=a29k-amd basic_os=udi ;; ultra3) basic_machine=a29k-nyu basic_os=sym1 ;; v810 | necv810) basic_machine=v810-nec basic_os=none ;; vaxv) basic_machine=vax-dec basic_os=sysv ;; vms) basic_machine=vax-dec basic_os=vms ;; vsta) basic_machine=i386-pc basic_os=vsta ;; vxworks960) basic_machine=i960-wrs basic_os=vxworks ;; vxworks68) basic_machine=m68k-wrs basic_os=vxworks ;; vxworks29k) basic_machine=a29k-wrs basic_os=vxworks ;; xbox) basic_machine=i686-pc basic_os=mingw32 ;; ymp) basic_machine=ymp-cray basic_os=unicos ;; *) basic_machine=$1 basic_os= ;; esac ;; esac # Decode 1-component or ad-hoc basic machines case $basic_machine in # Here we handle the default manufacturer of certain CPU types. It is in # some cases the only manufacturer, in others, it is the most popular. w89k) cpu=hppa1.1 vendor=winbond ;; op50n) cpu=hppa1.1 vendor=oki ;; op60c) cpu=hppa1.1 vendor=oki ;; ibm*) cpu=i370 vendor=ibm ;; orion105) cpu=clipper vendor=highlevel ;; mac | mpw | mac-mpw) cpu=m68k vendor=apple ;; pmac | pmac-mpw) cpu=powerpc vendor=apple ;; # Recognize the various machine names and aliases which stand # for a CPU type and a company and sometimes even an OS. 3b1 | 7300 | 7300-att | att-7300 | pc7300 | safari | unixpc) cpu=m68000 vendor=att ;; 3b*) cpu=we32k vendor=att ;; bluegene*) cpu=powerpc vendor=ibm basic_os=cnk ;; decsystem10* | dec10*) cpu=pdp10 vendor=dec basic_os=tops10 ;; decsystem20* | dec20*) cpu=pdp10 vendor=dec basic_os=tops20 ;; delta | 3300 | motorola-3300 | motorola-delta \ | 3300-motorola | delta-motorola) cpu=m68k vendor=motorola ;; dpx2*) cpu=m68k vendor=bull basic_os=sysv3 ;; encore | umax | mmax) cpu=ns32k vendor=encore ;; elxsi) cpu=elxsi vendor=elxsi basic_os=${basic_os:-bsd} ;; fx2800) cpu=i860 vendor=alliant ;; genix) cpu=ns32k vendor=ns ;; h3050r* | hiux*) cpu=hppa1.1 vendor=hitachi basic_os=hiuxwe2 ;; hp3k9[0-9][0-9] | hp9[0-9][0-9]) cpu=hppa1.0 vendor=hp ;; hp9k2[0-9][0-9] | hp9k31[0-9]) cpu=m68000 vendor=hp ;; hp9k3[2-9][0-9]) cpu=m68k vendor=hp ;; hp9k6[0-9][0-9] | hp6[0-9][0-9]) cpu=hppa1.0 vendor=hp ;; hp9k7[0-79][0-9] | hp7[0-79][0-9]) cpu=hppa1.1 vendor=hp ;; hp9k78[0-9] | hp78[0-9]) # FIXME: really hppa2.0-hp cpu=hppa1.1 vendor=hp ;; hp9k8[67]1 | hp8[67]1 | hp9k80[24] | hp80[24] | hp9k8[78]9 | hp8[78]9 | hp9k893 | hp893) # FIXME: really hppa2.0-hp cpu=hppa1.1 vendor=hp ;; hp9k8[0-9][13679] | hp8[0-9][13679]) cpu=hppa1.1 vendor=hp ;; hp9k8[0-9][0-9] | hp8[0-9][0-9]) cpu=hppa1.0 vendor=hp ;; i*86v32) cpu=`echo "$1" | sed -e 's/86.*/86/'` vendor=pc basic_os=sysv32 ;; i*86v4*) cpu=`echo "$1" | sed -e 's/86.*/86/'` vendor=pc basic_os=sysv4 ;; i*86v) cpu=`echo "$1" | sed -e 's/86.*/86/'` vendor=pc basic_os=sysv ;; i*86sol2) cpu=`echo "$1" | sed -e 's/86.*/86/'` vendor=pc basic_os=solaris2 ;; j90 | j90-cray) cpu=j90 vendor=cray basic_os=${basic_os:-unicos} ;; iris | iris4d) cpu=mips vendor=sgi case $basic_os in irix*) ;; *) basic_os=irix4 ;; esac ;; miniframe) cpu=m68000 vendor=convergent ;; *mint | mint[0-9]* | *MiNT | *MiNT[0-9]*) cpu=m68k vendor=atari basic_os=mint ;; news-3600 | risc-news) cpu=mips vendor=sony basic_os=newsos ;; next | m*-next) cpu=m68k vendor=next case $basic_os in openstep*) ;; nextstep*) ;; ns2*) basic_os=nextstep2 ;; *) basic_os=nextstep3 ;; esac ;; np1) cpu=np1 vendor=gould ;; op50n-* | op60c-*) cpu=hppa1.1 vendor=oki basic_os=proelf ;; pa-hitachi) cpu=hppa1.1 vendor=hitachi basic_os=hiuxwe2 ;; pbd) cpu=sparc vendor=tti ;; pbb) cpu=m68k vendor=tti ;; pc532) cpu=ns32k vendor=pc532 ;; pn) cpu=pn vendor=gould ;; power) cpu=power vendor=ibm ;; ps2) cpu=i386 vendor=ibm ;; rm[46]00) cpu=mips vendor=siemens ;; rtpc | rtpc-*) cpu=romp vendor=ibm ;; sde) cpu=mipsisa32 vendor=sde basic_os=${basic_os:-elf} ;; simso-wrs) cpu=sparclite vendor=wrs basic_os=vxworks ;; tower | tower-32) cpu=m68k vendor=ncr ;; vpp*|vx|vx-*) cpu=f301 vendor=fujitsu ;; w65) cpu=w65 vendor=wdc ;; w89k-*) cpu=hppa1.1 vendor=winbond basic_os=proelf ;; none) cpu=none vendor=none ;; leon|leon[3-9]) cpu=sparc vendor=$basic_machine ;; leon-*|leon[3-9]-*) cpu=sparc vendor=`echo "$basic_machine" | sed 's/-.*//'` ;; *-*) # shellcheck disable=SC2162 saved_IFS=$IFS IFS="-" read cpu vendor <&2 exit 1 ;; esac ;; esac # Here we canonicalize certain aliases for manufacturers. case $vendor in digital*) vendor=dec ;; commodore*) vendor=cbm ;; *) ;; esac # Decode manufacturer-specific aliases for certain operating systems. if test x$basic_os != x then # First recognize some ad-hoc cases, or perhaps split kernel-os, or else just # set os. case $basic_os in gnu/linux*) kernel=linux os=`echo "$basic_os" | sed -e 's|gnu/linux|gnu|'` ;; os2-emx) kernel=os2 os=`echo "$basic_os" | sed -e 's|os2-emx|emx|'` ;; nto-qnx*) kernel=nto os=`echo "$basic_os" | sed -e 's|nto-qnx|qnx|'` ;; *-*) # shellcheck disable=SC2162 saved_IFS=$IFS IFS="-" read kernel os <&2 exit 1 ;; esac # As a final step for OS-related things, validate the OS-kernel combination # (given a valid OS), if there is a kernel. case $kernel-$os in linux-gnu* | linux-dietlibc* | linux-android* | linux-newlib* \ | linux-musl* | linux-relibc* | linux-uclibc* | linux-mlibc* ) ;; uclinux-uclibc* ) ;; managarm-mlibc* | managarm-kernel* ) ;; -dietlibc* | -newlib* | -musl* | -relibc* | -uclibc* | -mlibc* ) # These are just libc implementations, not actual OSes, and thus # require a kernel. echo "Invalid configuration '$1': libc '$os' needs explicit kernel." 1>&2 exit 1 ;; -kernel* ) echo "Invalid configuration '$1': '$os' needs explicit kernel." 1>&2 exit 1 ;; *-kernel* ) echo "Invalid configuration '$1': '$kernel' does not support '$os'." 1>&2 exit 1 ;; kfreebsd*-gnu* | kopensolaris*-gnu*) ;; vxworks-simlinux | vxworks-simwindows | vxworks-spe) ;; nto-qnx*) ;; os2-emx) ;; *-eabi* | *-gnueabi*) ;; -*) # Blank kernel with real OS is always fine. ;; *-*) echo "Invalid configuration '$1': Kernel '$kernel' not known to work with OS '$os'." 1>&2 exit 1 ;; esac # Here we handle the case where we know the os, and the CPU type, but not the # manufacturer. We pick the logical manufacturer. case $vendor in unknown) case $cpu-$os in *-riscix*) vendor=acorn ;; *-sunos*) vendor=sun ;; *-cnk* | *-aix*) vendor=ibm ;; *-beos*) vendor=be ;; *-hpux*) vendor=hp ;; *-mpeix*) vendor=hp ;; *-hiux*) vendor=hitachi ;; *-unos*) vendor=crds ;; *-dgux*) vendor=dg ;; *-luna*) vendor=omron ;; *-genix*) vendor=ns ;; *-clix*) vendor=intergraph ;; *-mvs* | *-opened*) vendor=ibm ;; *-os400*) vendor=ibm ;; s390-* | s390x-*) vendor=ibm ;; *-ptx*) vendor=sequent ;; *-tpf*) vendor=ibm ;; *-vxsim* | *-vxworks* | *-windiss*) vendor=wrs ;; *-aux*) vendor=apple ;; *-hms*) vendor=hitachi ;; *-mpw* | *-macos*) vendor=apple ;; *-*mint | *-mint[0-9]* | *-*MiNT | *-MiNT[0-9]*) vendor=atari ;; *-vos*) vendor=stratus ;; esac ;; esac echo "$cpu-$vendor-${kernel:+$kernel-}$os" exit # Local variables: # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-start: "timestamp='" # time-stamp-format: "%:y-%02m-%02d" # time-stamp-end: "'" # End: libcaes-20240413/setup.py0000755000175000017500000002207614606473411015745 0ustar00lordyestalordyesta#!/usr/bin/env python # # Script to build and install Python-bindings. # Version: 20230909 from __future__ import print_function import copy import datetime import glob import gzip import platform import os import shlex import shutil import subprocess import sys import tarfile import zipfile from distutils.ccompiler import new_compiler from setuptools import Extension from setuptools import setup from setuptools.command.build_ext import build_ext from setuptools.command.sdist import sdist if (sys.version_info[0], sys.version_info[1]) < (3, 7): print(("Unsupported Python version: {0:s}, version 3.7 or higher " "required.").format(sys.version)) sys.exit(1) class custom_build_ext(build_ext): """Custom handler for the build_ext command.""" def _RunCommand(self, command): """Runs the command.""" arguments = shlex.split(command) process = subprocess.Popen( arguments, stderr=subprocess.PIPE, stdout=subprocess.PIPE, universal_newlines=True) if not process: raise RuntimeError("Running: {0:s} failed.".format(command)) output, error = process.communicate() if process.returncode != 0: error = "\n".join(error.split("\n")[-5:]) raise RuntimeError("Running: {0:s} failed with error:\n{1:s}.".format( command, error)) return output def build_extensions(self): """Set up the build extensions.""" # TODO: move build customization here? build_ext.build_extensions(self) def run(self): """Runs the build extension.""" compiler = new_compiler(compiler=self.compiler) if compiler.compiler_type == "msvc": self.define = [ ("_CRT_SECURE_NO_WARNINGS", ""), ("UNICODE", ""), ] else: command = "sh configure --disable-nls --disable-shared-libs" output = self._RunCommand(command) print_line = False for line in output.split("\n"): line = line.rstrip() if line == "configure:": print_line = True if print_line: print(line) self.define = [ ("HAVE_CONFIG_H", ""), ] build_ext.run(self) class custom_sdist(sdist): """Custom handler for the sdist command.""" def run(self): """Builds a source distribution (sdist) package.""" if self.formats != ["gztar"] and self.formats != ["zip"]: print("'setup.py sdist' unsupported format.") sys.exit(1) if glob.glob("*.tar.gz"): print("'setup.py sdist' remove existing *.tar.gz files from " "source directory.") sys.exit(1) command = "make dist" exit_code = subprocess.call(command, shell=True) if exit_code != 0: raise RuntimeError("Running: {0:s} failed.".format(command)) if not os.path.exists(self.dist_dir): os.mkdir(self.dist_dir) source_package_file = glob.glob("*.tar.gz")[0] source_package_prefix, _, source_package_suffix = ( source_package_file.partition("-")) sdist_package_file = "{0:s}-python-{1:s}".format( source_package_prefix, source_package_suffix) sdist_package_file = os.path.join(self.dist_dir, sdist_package_file) os.rename(source_package_file, sdist_package_file) # Create and add the PKG-INFO file to the source package. with gzip.open(sdist_package_file, "rb") as input_file: with open(sdist_package_file[:-3], "wb") as output_file: shutil.copyfileobj(input_file, output_file) os.remove(sdist_package_file) self.distribution.metadata.write_pkg_info(".") pkg_info_path = "{0:s}-{1:s}/PKG-INFO".format( source_package_prefix, source_package_suffix[:-7]) with tarfile.open(sdist_package_file[:-3], "a:") as tar_file: tar_file.add("PKG-INFO", arcname=pkg_info_path) os.remove("PKG-INFO") with open(sdist_package_file[:-3], "rb") as input_file: with gzip.open(sdist_package_file, "wb") as output_file: shutil.copyfileobj(input_file, output_file) os.remove(sdist_package_file[:-3]) # Convert the .tar.gz into a .zip if self.formats == ["zip"]: zip_sdist_package_file = "{0:s}.zip".format(sdist_package_file[:-7]) with tarfile.open(sdist_package_file, "r|gz") as tar_file: with zipfile.ZipFile( zip_sdist_package_file, "w", zipfile.ZIP_DEFLATED) as zip_file: for tar_file_entry in tar_file: file_entry = tar_file.extractfile(tar_file_entry) if tar_file_entry.isfile(): modification_time = datetime.datetime.fromtimestamp( tar_file_entry.mtime) zip_modification_time = ( modification_time.year, modification_time.month, modification_time.day, modification_time.hour, modification_time.minute, modification_time.second) zip_info = zipfile.ZipInfo( date_time=zip_modification_time, filename=tar_file_entry.name) zip_info.external_attr = (tar_file_entry.mode & 0xff) << 16 file_data = file_entry.read() zip_file.writestr(zip_info, file_data) os.remove(sdist_package_file) sdist_package_file = zip_sdist_package_file # Inform distutils what files were created. dist_files = getattr(self.distribution, "dist_files", []) dist_files.append(("sdist", "", sdist_package_file)) class ProjectInformation(object): """Project information.""" def __init__(self): """Initializes project information.""" super(ProjectInformation, self).__init__() self.include_directories = [] self.library_name = None self.library_names = [] self.library_version = None self._ReadConfigureAc() self._ReadMakefileAm() @property def module_name(self): """The Python module name.""" return "py{0:s}".format(self.library_name[3:]) def _ReadConfigureAc(self): """Reads configure.ac to initialize the project information.""" with open("configure.ac", "r", encoding="utf-8") as file_object: found_ac_init = False found_library_name = False for line in file_object.readlines(): line = line.strip() if found_library_name: library_version = line[1:-2] self.library_version = library_version break elif found_ac_init: library_name = line[1:-2] self.library_name = library_name found_library_name = True elif line.startswith("AC_INIT"): found_ac_init = True if not self.library_name or not self.library_version: raise RuntimeError( "Unable to find library name and version in: configure.ac") def _ReadMakefileAm(self): """Reads Makefile.am to initialize the project information.""" if not self.library_name: raise RuntimeError("Missing library name") with open("Makefile.am", "r", encoding="utf-8") as file_object: found_subdirs = False for line in file_object.readlines(): line = line.strip() if found_subdirs: library_name, _, _ = line.partition(" ") self.include_directories.append(library_name) if library_name.startswith("lib"): self.library_names.append(library_name) if library_name == self.library_name: break elif line.startswith("SUBDIRS"): found_subdirs = True if not self.include_directories or not self.library_names: raise RuntimeError( "Unable to find include directories and library names in: " "Makefile.am") project_information = ProjectInformation() CMDCLASS = { "build_ext": custom_build_ext, "sdist": custom_sdist} SOURCES = [] # TODO: replace by detection of MSC DEFINE_MACROS = [] if platform.system() == "Windows": DEFINE_MACROS.append(("WINVER", "0x0501")) # TODO: determine how to handle third party DLLs. for library_name in project_information.library_names: if library_name != project_information.library_name: definition = "HAVE_LOCAL_{0:s}".format(library_name.upper()) DEFINE_MACROS.append((definition, "")) # Put everything inside the Python module to prevent issues with finding # shared libaries since pip does not integrate well with the system package # management. for library_name in project_information.library_names: for source_file in glob.glob(os.path.join(library_name, "*.[ly]")): generated_source_file = "{0:s}.c".format(source_file[:-2]) if not os.path.exists(generated_source_file): raise RuntimeError("Missing generated source file: {0:s}".format( generated_source_file)) source_files = glob.glob(os.path.join(library_name, "*.c")) SOURCES.extend(source_files) source_files = glob.glob(os.path.join(project_information.module_name, "*.c")) SOURCES.extend(source_files) # TODO: find a way to detect missing python.h # e.g. on Ubuntu python-dev is not installed by python-pip setup_args = dict( cmdclass=CMDCLASS, ext_modules=[ Extension( project_information.module_name, define_macros=DEFINE_MACROS, include_dirs=project_information.include_directories, libraries=[], library_dirs=[], sources=SOURCES ) ] ) setup(**setup_args) libcaes-20240413/acinclude.m40000644000175000017500000000272114606473502016415 0ustar00lordyestalordyestadnl Checks for required headers and functions dnl dnl Version: 20220529 dnl Function to detect if libcaes dependencies are available AC_DEFUN([AX_LIBCAES_CHECK_LOCAL], [dnl Check for libcrypto (openssl) support AX_LIBCRYPTO_CHECK_ENABLE AS_IF( [test "x$ac_cv_libcrypto" != xno], [AX_LIBCRYPTO_CHECK_AES AX_LIBCRYPTO_CHECK_AES_XTS]) dnl Fallback to local versions if necessary AS_IF( [test "x$ac_cv_libcrypto" = xno || test "x$ac_cv_libcrypto_aes_cbc" = xno], [ac_cv_libcaes_aes_cbc=local], [ac_cv_libcaes_aes_cbc=$ac_cv_libcrypto_aes_cbc]) AS_IF( [test "x$ac_cv_libcrypto" = xno || test "x$ac_cv_libcrypto_aes_ecb" = xno], [ac_cv_libcaes_aes_ecb=local], [ac_cv_libcaes_aes_ecb=$ac_cv_libcrypto_aes_ecb]) AS_IF( [test "x$ac_cv_libcrypto" = xno || test "x$ac_cv_libcrypto_aes_xts" = xno], [ac_cv_libcaes_aes_xts=local], [ac_cv_libcaes_aes_xts=$ac_cv_libcrypto_aes_xts]) ]) dnl Function to check if DLL support is needed AC_DEFUN([AX_LIBCAES_CHECK_DLL_SUPPORT], [AS_IF( [test "x$enable_shared" = xyes], [AS_CASE( [$host], [*cygwin* | *mingw* | *msys*], [AC_DEFINE( [HAVE_DLLMAIN], [1], [Define to 1 to enable the DllMain function.]) AC_SUBST( [HAVE_DLLMAIN], [1]) AC_SUBST( [LIBCAES_DLL_EXPORT], ["-DLIBCAES_DLL_EXPORT"]) AC_SUBST( [LIBCAES_DLL_IMPORT], ["-DLIBCAES_DLL_IMPORT"]) ]) ]) ]) libcaes-20240413/libcaes.spec0000644000175000017500000000366414606477645016525 0ustar00lordyestalordyestaName: libcaes Version: 20240413 Release: 1 Summary: Library to support cross-platform AES encryption Group: System Environment/Libraries License: LGPL-3.0-or-later Source: %{name}-%{version}.tar.gz URL: https://github.com/libyal/libcaes Requires: openssl BuildRequires: gcc openssl-devel %description -n libcaes Library to support cross-platform AES encryption %package -n libcaes-static Summary: Library to support cross-platform AES encryption Group: Development/Libraries Requires: libcaes = %{version}-%{release} %description -n libcaes-static Static library version of libcaes. %package -n libcaes-devel Summary: Header files and libraries for developing applications for libcaes Group: Development/Libraries Requires: libcaes = %{version}-%{release} %description -n libcaes-devel Header files and libraries for developing applications for libcaes. %package -n libcaes-python3 Summary: Python 3 bindings for libcaes Group: System Environment/Libraries Requires: libcaes = %{version}-%{release} python3 BuildRequires: python3-devel python3-setuptools %description -n libcaes-python3 Python 3 bindings for libcaes %prep %setup -q %build %configure --prefix=/usr --libdir=%{_libdir} --mandir=%{_mandir} --enable-python make %{?_smp_mflags} %install rm -rf %{buildroot} %make_install %clean rm -rf %{buildroot} %post -p /sbin/ldconfig %postun -p /sbin/ldconfig %files -n libcaes %license COPYING COPYING.LESSER %doc AUTHORS README %{_libdir}/*.so.* %files -n libcaes-static %license COPYING COPYING.LESSER %doc AUTHORS README %{_libdir}/*.a %files -n libcaes-devel %license COPYING COPYING.LESSER %doc AUTHORS README %{_libdir}/*.so %{_libdir}/pkgconfig/libcaes.pc %{_includedir}/* %{_mandir}/man3/* %files -n libcaes-python3 %license COPYING COPYING.LESSER %doc AUTHORS README %{_libdir}/python3*/site-packages/*.a %{_libdir}/python3*/site-packages/*.so %changelog * Sat Apr 13 2024 Joachim Metz 20240413-1 - Auto-generated libcaes-20240413/config.rpath0000755000175000017500000004421614533041420016526 0ustar00lordyestalordyesta#! /bin/sh # Output a system dependent set of variables, describing how to set the # run time search path of shared libraries in an executable. # # Copyright 1996-2020 Free Software Foundation, Inc. # Taken from GNU libtool, 2001 # Originally by Gordon Matzigkeit , 1996 # # This file is free software; the Free Software Foundation gives # unlimited permission to copy and/or distribute it, with or without # modifications, as long as this notice is preserved. # # The first argument passed to this file is the canonical host specification, # CPU_TYPE-MANUFACTURER-OPERATING_SYSTEM # or # CPU_TYPE-MANUFACTURER-KERNEL-OPERATING_SYSTEM # The environment variables CC, GCC, LDFLAGS, LD, with_gnu_ld # should be set by the caller. # # The set of defined variables is at the end of this script. # Known limitations: # - On IRIX 6.5 with CC="cc", the run time search patch must not be longer # than 256 bytes, otherwise the compiler driver will dump core. The only # known workaround is to choose shorter directory names for the build # directory and/or the installation directory. # All known linkers require a '.a' archive for static linking (except MSVC, # which needs '.lib'). libext=a shrext=.so host="$1" host_cpu=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\1/'` host_vendor=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\2/'` host_os=`echo "$host" | sed 's/^\([^-]*\)-\([^-]*\)-\(.*\)$/\3/'` # Code taken from libtool.m4's _LT_CC_BASENAME. for cc_temp in $CC""; do case $cc_temp in compile | *[\\/]compile | ccache | *[\\/]ccache ) ;; distcc | *[\\/]distcc | purify | *[\\/]purify ) ;; \-*) ;; *) break;; esac done cc_basename=`echo "$cc_temp" | sed -e 's%^.*/%%'` # Code taken from libtool.m4's _LT_COMPILER_PIC. wl= if test "$GCC" = yes; then wl='-Wl,' else case "$host_os" in aix*) wl='-Wl,' ;; mingw* | cygwin* | pw32* | os2* | cegcc*) ;; hpux9* | hpux10* | hpux11*) wl='-Wl,' ;; irix5* | irix6* | nonstopux*) wl='-Wl,' ;; linux* | k*bsd*-gnu | kopensolaris*-gnu) case $cc_basename in ecc*) wl='-Wl,' ;; icc* | ifort*) wl='-Wl,' ;; lf95*) wl='-Wl,' ;; nagfor*) wl='-Wl,-Wl,,' ;; pgcc* | pgf77* | pgf90* | pgf95* | pgfortran*) wl='-Wl,' ;; ccc*) wl='-Wl,' ;; xl* | bgxl* | bgf* | mpixl*) wl='-Wl,' ;; como) wl='-lopt=' ;; *) case `$CC -V 2>&1 | sed 5q` in *Sun\ F* | *Sun*Fortran*) wl= ;; *Sun\ C*) wl='-Wl,' ;; esac ;; esac ;; newsos6) ;; *nto* | *qnx*) ;; osf3* | osf4* | osf5*) wl='-Wl,' ;; rdos*) ;; solaris*) case $cc_basename in f77* | f90* | f95* | sunf77* | sunf90* | sunf95*) wl='-Qoption ld ' ;; *) wl='-Wl,' ;; esac ;; sunos4*) wl='-Qoption ld ' ;; sysv4 | sysv4.2uw2* | sysv4.3*) wl='-Wl,' ;; sysv4*MP*) ;; sysv5* | unixware* | sco3.2v5* | sco5v6* | OpenUNIX*) wl='-Wl,' ;; unicos*) wl='-Wl,' ;; uts4*) ;; esac fi # Code taken from libtool.m4's _LT_LINKER_SHLIBS. hardcode_libdir_flag_spec= hardcode_libdir_separator= hardcode_direct=no hardcode_minus_L=no case "$host_os" in cygwin* | mingw* | pw32* | cegcc*) # FIXME: the MSVC++ port hasn't been tested in a loooong time # When not using gcc, we currently assume that we are using # Microsoft Visual C++. if test "$GCC" != yes; then with_gnu_ld=no fi ;; interix*) # we just hope/assume this is gcc and not c89 (= MSVC++) with_gnu_ld=yes ;; openbsd*) with_gnu_ld=no ;; esac ld_shlibs=yes if test "$with_gnu_ld" = yes; then # Set some defaults for GNU ld with shared library support. These # are reset later if shared libraries are not supported. Putting them # here allows them to be overridden if necessary. # Unlike libtool, we use -rpath here, not --rpath, since the documented # option of GNU ld is called -rpath, not --rpath. hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' case "$host_os" in aix[3-9]*) # On AIX/PPC, the GNU linker is very broken if test "$host_cpu" != ia64; then ld_shlibs=no fi ;; amigaos*) case "$host_cpu" in powerpc) ;; m68k) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; beos*) if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then : else ld_shlibs=no fi ;; cygwin* | mingw* | pw32* | cegcc*) # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. hardcode_libdir_flag_spec='-L$libdir' if $LD --help 2>&1 | grep 'auto-import' > /dev/null; then : else ld_shlibs=no fi ;; haiku*) ;; interix[3-9]*) hardcode_direct=no hardcode_libdir_flag_spec='${wl}-rpath,$libdir' ;; gnu* | linux* | tpf* | k*bsd*-gnu | kopensolaris*-gnu) if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then : else ld_shlibs=no fi ;; netbsd*) ;; solaris*) if $LD -v 2>&1 | grep 'BFD 2\.8' > /dev/null; then ld_shlibs=no elif $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then : else ld_shlibs=no fi ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX*) case `$LD -v 2>&1` in *\ [01].* | *\ 2.[0-9].* | *\ 2.1[0-5].*) ld_shlibs=no ;; *) if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then hardcode_libdir_flag_spec='`test -z "$SCOABSPATH" && echo ${wl}-rpath,$libdir`' else ld_shlibs=no fi ;; esac ;; sunos4*) hardcode_direct=yes ;; *) if $LD --help 2>&1 | grep ': supported targets:.* elf' > /dev/null; then : else ld_shlibs=no fi ;; esac if test "$ld_shlibs" = no; then hardcode_libdir_flag_spec= fi else case "$host_os" in aix3*) # Note: this linker hardcodes the directories in LIBPATH if there # are no directories specified by -L. hardcode_minus_L=yes if test "$GCC" = yes; then # Neither direct hardcoding nor static linking is supported with a # broken collect2. hardcode_direct=unsupported fi ;; aix[4-9]*) if test "$host_cpu" = ia64; then # On IA64, the linker does run time linking by default, so we don't # have to do anything special. aix_use_runtimelinking=no else aix_use_runtimelinking=no # Test if we are trying to use run time linking or normal # AIX style linking. If -brtl is somewhere in LDFLAGS, we # need to do runtime linking. case $host_os in aix4.[23]|aix4.[23].*|aix[5-9]*) for ld_flag in $LDFLAGS; do if (test $ld_flag = "-brtl" || test $ld_flag = "-Wl,-brtl"); then aix_use_runtimelinking=yes break fi done ;; esac fi hardcode_direct=yes hardcode_libdir_separator=':' if test "$GCC" = yes; then case $host_os in aix4.[012]|aix4.[012].*) collect2name=`${CC} -print-prog-name=collect2` if test -f "$collect2name" && \ strings "$collect2name" | grep resolve_lib_name >/dev/null then # We have reworked collect2 : else # We have old collect2 hardcode_direct=unsupported hardcode_minus_L=yes hardcode_libdir_flag_spec='-L$libdir' hardcode_libdir_separator= fi ;; esac fi # Begin _LT_AC_SYS_LIBPATH_AIX. echo 'int main () { return 0; }' > conftest.c ${CC} ${LDFLAGS} conftest.c -o conftest aix_libpath=`dump -H conftest 2>/dev/null | sed -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } }'` if test -z "$aix_libpath"; then aix_libpath=`dump -HX64 conftest 2>/dev/null | sed -n -e '/Import File Strings/,/^$/ { /^0/ { s/^0 *\(.*\)$/\1/; p; } }'` fi if test -z "$aix_libpath"; then aix_libpath="/usr/lib:/lib" fi rm -f conftest.c conftest # End _LT_AC_SYS_LIBPATH_AIX. if test "$aix_use_runtimelinking" = yes; then hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" else if test "$host_cpu" = ia64; then hardcode_libdir_flag_spec='${wl}-R $libdir:/usr/lib:/lib' else hardcode_libdir_flag_spec='${wl}-blibpath:$libdir:'"$aix_libpath" fi fi ;; amigaos*) case "$host_cpu" in powerpc) ;; m68k) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; esac ;; bsdi[45]*) ;; cygwin* | mingw* | pw32* | cegcc*) # When not using gcc, we currently assume that we are using # Microsoft Visual C++. # hardcode_libdir_flag_spec is actually meaningless, as there is # no search path for DLLs. hardcode_libdir_flag_spec=' ' libext=lib ;; darwin* | rhapsody*) hardcode_direct=no if { case $cc_basename in ifort*) true;; *) test "$GCC" = yes;; esac; }; then : else ld_shlibs=no fi ;; dgux*) hardcode_libdir_flag_spec='-L$libdir' ;; freebsd2.[01]*) hardcode_direct=yes hardcode_minus_L=yes ;; freebsd* | dragonfly*) hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes ;; hpux9*) hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' hardcode_libdir_separator=: hardcode_direct=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes ;; hpux10*) if test "$with_gnu_ld" = no; then hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' hardcode_libdir_separator=: hardcode_direct=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes fi ;; hpux11*) if test "$with_gnu_ld" = no; then hardcode_libdir_flag_spec='${wl}+b ${wl}$libdir' hardcode_libdir_separator=: case $host_cpu in hppa*64*|ia64*) hardcode_direct=no ;; *) hardcode_direct=yes # hardcode_minus_L: Not really in the search PATH, # but as the default location of the library. hardcode_minus_L=yes ;; esac fi ;; irix5* | irix6* | nonstopux*) hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator=: ;; netbsd*) hardcode_libdir_flag_spec='-R$libdir' hardcode_direct=yes ;; newsos6) hardcode_direct=yes hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator=: ;; *nto* | *qnx*) ;; openbsd*) if test -f /usr/libexec/ld.so; then hardcode_direct=yes if test -z "`echo __ELF__ | $CC -E - | grep __ELF__`" || test "$host_os-$host_cpu" = "openbsd2.8-powerpc"; then hardcode_libdir_flag_spec='${wl}-rpath,$libdir' else case "$host_os" in openbsd[01].* | openbsd2.[0-7] | openbsd2.[0-7].*) hardcode_libdir_flag_spec='-R$libdir' ;; *) hardcode_libdir_flag_spec='${wl}-rpath,$libdir' ;; esac fi else ld_shlibs=no fi ;; os2*) hardcode_libdir_flag_spec='-L$libdir' hardcode_minus_L=yes ;; osf3*) hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' hardcode_libdir_separator=: ;; osf4* | osf5*) if test "$GCC" = yes; then hardcode_libdir_flag_spec='${wl}-rpath ${wl}$libdir' else # Both cc and cxx compiler support -rpath directly hardcode_libdir_flag_spec='-rpath $libdir' fi hardcode_libdir_separator=: ;; solaris*) hardcode_libdir_flag_spec='-R$libdir' ;; sunos4*) hardcode_libdir_flag_spec='-L$libdir' hardcode_direct=yes hardcode_minus_L=yes ;; sysv4) case $host_vendor in sni) hardcode_direct=yes # is this really true??? ;; siemens) hardcode_direct=no ;; motorola) hardcode_direct=no #Motorola manual says yes, but my tests say they lie ;; esac ;; sysv4.3*) ;; sysv4*MP*) if test -d /usr/nec; then ld_shlibs=yes fi ;; sysv4*uw2* | sysv5OpenUNIX* | sysv5UnixWare7.[01].[10]* | unixware7* | sco3.2v5.0.[024]*) ;; sysv5* | sco3.2v5* | sco5v6*) hardcode_libdir_flag_spec='`test -z "$SCOABSPATH" && echo ${wl}-R,$libdir`' hardcode_libdir_separator=':' ;; uts4*) hardcode_libdir_flag_spec='-L$libdir' ;; *) ld_shlibs=no ;; esac fi # Check dynamic linker characteristics # Code taken from libtool.m4's _LT_SYS_DYNAMIC_LINKER. # Unlike libtool.m4, here we don't care about _all_ names of the library, but # only about the one the linker finds when passed -lNAME. This is the last # element of library_names_spec in libtool.m4, or possibly two of them if the # linker has special search rules. library_names_spec= # the last element of library_names_spec in libtool.m4 libname_spec='lib$name' case "$host_os" in aix3*) library_names_spec='$libname.a' ;; aix[4-9]*) library_names_spec='$libname$shrext' ;; amigaos*) case "$host_cpu" in powerpc*) library_names_spec='$libname$shrext' ;; m68k) library_names_spec='$libname.a' ;; esac ;; beos*) library_names_spec='$libname$shrext' ;; bsdi[45]*) library_names_spec='$libname$shrext' ;; cygwin* | mingw* | pw32* | cegcc*) shrext=.dll library_names_spec='$libname.dll.a $libname.lib' ;; darwin* | rhapsody*) shrext=.dylib library_names_spec='$libname$shrext' ;; dgux*) library_names_spec='$libname$shrext' ;; freebsd[23].*) library_names_spec='$libname$shrext$versuffix' ;; freebsd* | dragonfly*) library_names_spec='$libname$shrext' ;; gnu*) library_names_spec='$libname$shrext' ;; haiku*) library_names_spec='$libname$shrext' ;; hpux9* | hpux10* | hpux11*) case $host_cpu in ia64*) shrext=.so ;; hppa*64*) shrext=.sl ;; *) shrext=.sl ;; esac library_names_spec='$libname$shrext' ;; interix[3-9]*) library_names_spec='$libname$shrext' ;; irix5* | irix6* | nonstopux*) library_names_spec='$libname$shrext' case "$host_os" in irix5* | nonstopux*) libsuff= shlibsuff= ;; *) case $LD in *-32|*"-32 "|*-melf32bsmip|*"-melf32bsmip ") libsuff= shlibsuff= ;; *-n32|*"-n32 "|*-melf32bmipn32|*"-melf32bmipn32 ") libsuff=32 shlibsuff=N32 ;; *-64|*"-64 "|*-melf64bmip|*"-melf64bmip ") libsuff=64 shlibsuff=64 ;; *) libsuff= shlibsuff= ;; esac ;; esac ;; linux*oldld* | linux*aout* | linux*coff*) ;; linux* | k*bsd*-gnu | kopensolaris*-gnu) library_names_spec='$libname$shrext' ;; knetbsd*-gnu) library_names_spec='$libname$shrext' ;; netbsd*) library_names_spec='$libname$shrext' ;; newsos6) library_names_spec='$libname$shrext' ;; *nto* | *qnx*) library_names_spec='$libname$shrext' ;; openbsd*) library_names_spec='$libname$shrext$versuffix' ;; os2*) libname_spec='$name' shrext=.dll library_names_spec='$libname.a' ;; osf3* | osf4* | osf5*) library_names_spec='$libname$shrext' ;; rdos*) ;; solaris*) library_names_spec='$libname$shrext' ;; sunos4*) library_names_spec='$libname$shrext$versuffix' ;; sysv4 | sysv4.3*) library_names_spec='$libname$shrext' ;; sysv4*MP*) library_names_spec='$libname$shrext' ;; sysv5* | sco3.2v5* | sco5v6* | unixware* | OpenUNIX* | sysv4*uw2*) library_names_spec='$libname$shrext' ;; tpf*) library_names_spec='$libname$shrext' ;; uts4*) library_names_spec='$libname$shrext' ;; esac sed_quote_subst='s/\(["`$\\]\)/\\\1/g' escaped_wl=`echo "X$wl" | sed -e 's/^X//' -e "$sed_quote_subst"` shlibext=`echo "$shrext" | sed -e 's,^\.,,'` escaped_libname_spec=`echo "X$libname_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` escaped_library_names_spec=`echo "X$library_names_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` escaped_hardcode_libdir_flag_spec=`echo "X$hardcode_libdir_flag_spec" | sed -e 's/^X//' -e "$sed_quote_subst"` LC_ALL=C sed -e 's/^\([a-zA-Z0-9_]*\)=/acl_cv_\1=/' < * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _PYCAES_CRYPT_MODES_H ) #define _PYCAES_CRYPT_MODES_H #include #include #include "pycaes_libcaes.h" #include "pycaes_python.h" #if defined( __cplusplus ) extern "C" { #endif typedef struct pycaes_crypt_modes pycaes_crypt_modes_t; struct pycaes_crypt_modes { /* Python object initialization */ PyObject_HEAD }; extern PyTypeObject pycaes_crypt_modes_type_object; int pycaes_crypt_modes_init_type( PyTypeObject *type_object ); PyObject *pycaes_crypt_modes_new( void ); int pycaes_crypt_modes_init( pycaes_crypt_modes_t *definitions_object ); void pycaes_crypt_modes_free( pycaes_crypt_modes_t *definitions_object ); #if defined( __cplusplus ) } #endif #endif /* !defined( _PYCAES_CRYPT_MODES_H ) */ libcaes-20240413/pycaes/pycaes_python.h0000644000175000017500000000375614606473412020557 0ustar00lordyestalordyesta/* * The python header wrapper * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _PYCAES_PYTHON_H ) #define _PYCAES_PYTHON_H #include #if PY_MAJOR_VERSION < 3 /* Fix defines in pyconfig.h */ #undef _POSIX_C_SOURCE #undef _XOPEN_SOURCE /* Fix defines in pyport.h */ #undef HAVE_FSTAT #undef HAVE_STAT #undef HAVE_SSIZE_T #undef HAVE_INT32_T #undef HAVE_UINT32_T #undef HAVE_INT64_T #undef HAVE_UINT64_T #endif /* PY_MAJOR_VERSION < 3 */ /* Define PY_SSIZE_T_CLEAN to silence: * DeprecationWarning: PY_SSIZE_T_CLEAN will be required for '#' formats * * PY_SSIZE_T_CLEAN was introduced in Python 2.5 */ #define PY_SSIZE_T_CLEAN #include /* Python compatibility macros */ #if !defined( PyMODINIT_FUNC ) #if PY_MAJOR_VERSION >= 3 #define PyMODINIT_FUNC PyObject * #else #define PyMODINIT_FUNC void #endif #endif /* !defined( PyMODINIT_FUNC ) */ #if !defined( PyVarObject_HEAD_INIT ) #define PyVarObject_HEAD_INIT( type, size ) \ PyObject_HEAD_INIT( type ) \ size, #endif /* !defined( PyVarObject_HEAD_INIT ) */ #if PY_MAJOR_VERSION >= 3 #define Py_TPFLAGS_HAVE_ITER 0 #endif #if !defined( Py_TYPE ) #define Py_TYPE( object ) \ ( ( (PyObject *) object )->ob_type ) #endif /* !defined( Py_TYPE ) */ #endif /* !defined( _PYCAES_PYTHON_H ) */ libcaes-20240413/pycaes/pycaes_unused.h0000644000175000017500000000256014606473412020531 0ustar00lordyestalordyesta/* * Definitions to silence compiler warnings about unused function attributes/parameters. * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _PYCAES_UNUSED_H ) #define _PYCAES_UNUSED_H #include #if !defined( PYCAES_ATTRIBUTE_UNUSED ) #if defined( __GNUC__ ) && __GNUC__ >= 3 #define PYCAES_ATTRIBUTE_UNUSED __attribute__ ((__unused__)) #else #define PYCAES_ATTRIBUTE_UNUSED #endif #endif #if defined( _MSC_VER ) #define PYCAES_UNREFERENCED_PARAMETER( parameter ) \ UNREFERENCED_PARAMETER( parameter ); #else #define PYCAES_UNREFERENCED_PARAMETER( parameter ) \ /* parameter */ #endif #endif /* !defined( _PYCAES_UNUSED_H ) */ libcaes-20240413/pycaes/pycaes_context.c0000644000175000017500000001635114606473502020710 0ustar00lordyestalordyesta/* * Python object wrapper of libcaes_context_t * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #if defined( HAVE_STDLIB_H ) || defined( HAVE_WINAPI ) #include #endif #include "pycaes_context.h" #include "pycaes_error.h" #include "pycaes_libcaes.h" #include "pycaes_libcerror.h" #include "pycaes_python.h" #include "pycaes_unused.h" PyMethodDef pycaes_context_object_methods[] = { { "set_key", (PyCFunction) pycaes_context_set_key, METH_VARARGS | METH_KEYWORDS, "set_key(mode, key) -> None\n" "\n" "Sets the key for a specific crypt mode." }, /* Sentinel */ { NULL, NULL, 0, NULL } }; PyGetSetDef pycaes_context_object_get_set_definitions[] = { /* Sentinel */ { NULL, NULL, NULL, NULL, NULL } }; PyTypeObject pycaes_context_type_object = { PyVarObject_HEAD_INIT( NULL, 0 ) /* tp_name */ "pycaes.context", /* tp_basicsize */ sizeof( pycaes_context_t ), /* tp_itemsize */ 0, /* tp_dealloc */ (destructor) pycaes_context_free, /* tp_print */ 0, /* tp_getattr */ 0, /* tp_setattr */ 0, /* tp_compare */ 0, /* tp_repr */ 0, /* tp_as_number */ 0, /* tp_as_sequence */ 0, /* tp_as_mapping */ 0, /* tp_hash */ 0, /* tp_call */ 0, /* tp_str */ 0, /* tp_getattro */ 0, /* tp_setattro */ 0, /* tp_as_buffer */ 0, /* tp_flags */ Py_TPFLAGS_DEFAULT, /* tp_doc */ "pycaes context object (wraps libcaes_context_t)", /* tp_traverse */ 0, /* tp_clear */ 0, /* tp_richcompare */ 0, /* tp_weaklistoffset */ 0, /* tp_iter */ 0, /* tp_iternext */ 0, /* tp_methods */ pycaes_context_object_methods, /* tp_members */ 0, /* tp_getset */ pycaes_context_object_get_set_definitions, /* tp_base */ 0, /* tp_dict */ 0, /* tp_descr_get */ 0, /* tp_descr_set */ 0, /* tp_dictoffset */ 0, /* tp_init */ (initproc) pycaes_context_init, /* tp_alloc */ 0, /* tp_new */ 0, /* tp_free */ 0, /* tp_is_gc */ 0, /* tp_bases */ NULL, /* tp_mro */ NULL, /* tp_cache */ NULL, /* tp_subclasses */ NULL, /* tp_weaklist */ NULL, /* tp_del */ 0 }; /* Creates a new context object * Returns a Python object if successful or NULL on error */ PyObject *pycaes_context_new( void ) { pycaes_context_t *pycaes_context = NULL; static char *function = "pycaes_context_new"; pycaes_context = PyObject_New( struct pycaes_context, &pycaes_context_type_object ); if( pycaes_context == NULL ) { PyErr_Format( PyExc_MemoryError, "%s: unable to initialize context.", function ); goto on_error; } if( pycaes_context_init( pycaes_context ) != 0 ) { PyErr_Format( PyExc_MemoryError, "%s: unable to initialize context.", function ); goto on_error; } return( (PyObject *) pycaes_context ); on_error: if( pycaes_context != NULL ) { Py_DecRef( (PyObject *) pycaes_context ); } return( NULL ); } /* Initializes a context object * Returns 0 if successful or -1 on error */ int pycaes_context_init( pycaes_context_t *pycaes_context ) { libcerror_error_t *error = NULL; static char *function = "pycaes_context_init"; if( pycaes_context == NULL ) { PyErr_Format( PyExc_ValueError, "%s: invalid context.", function ); return( -1 ); } pycaes_context->context = NULL; if( libcaes_context_initialize( &( pycaes_context->context ), &error ) != 1 ) { pycaes_error_raise( error, PyExc_MemoryError, "%s: unable to initialize context.", function ); libcerror_error_free( &error ); return( -1 ); } return( 0 ); } /* Frees a context object */ void pycaes_context_free( pycaes_context_t *pycaes_context ) { struct _typeobject *ob_type = NULL; libcerror_error_t *error = NULL; static char *function = "pycaes_context_free"; int result = 0; if( pycaes_context == NULL ) { PyErr_Format( PyExc_ValueError, "%s: invalid context.", function ); return; } if( pycaes_context->context == NULL ) { PyErr_Format( PyExc_ValueError, "%s: invalid context - missing libcaes context.", function ); return; } ob_type = Py_TYPE( pycaes_context ); if( ob_type == NULL ) { PyErr_Format( PyExc_ValueError, "%s: missing ob_type.", function ); return; } if( ob_type->tp_free == NULL ) { PyErr_Format( PyExc_ValueError, "%s: invalid ob_type - missing tp_free.", function ); return; } Py_BEGIN_ALLOW_THREADS result = libcaes_context_free( &( pycaes_context->context ), &error ); Py_END_ALLOW_THREADS if( result != 1 ) { pycaes_error_raise( error, PyExc_MemoryError, "%s: unable to free libcaes context.", function ); libcerror_error_free( &error ); } ob_type->tp_free( (PyObject*) pycaes_context ); } /* Sets the key * Returns a Python object if successful or NULL on error */ PyObject *pycaes_context_set_key( pycaes_context_t *pycaes_context, PyObject *arguments, PyObject *keywords ) { PyObject *string_object = NULL; libcerror_error_t *error = NULL; static char *function = "pycaes_context_set_key"; char *key_data = NULL; static char *keyword_list[] = { "mode", "key", NULL }; Py_ssize_t key_data_size = 0; int mode = 0; int result = 0; if( pycaes_context == NULL ) { PyErr_Format( PyExc_ValueError, "%s: invalid context.", function ); return( NULL ); } if( PyArg_ParseTupleAndKeywords( arguments, keywords, "iO", keyword_list, &mode, &string_object ) == 0 ) { return( NULL ); } #if PY_MAJOR_VERSION >= 3 key_data = PyBytes_AsString( string_object ); key_data_size = PyBytes_Size( string_object ); #else key_data = PyString_AsString( string_object ); key_data_size = PyString_Size( string_object ); #endif if( ( key_data_size < 0 ) || ( key_data_size > (Py_ssize_t) ( SSIZE_MAX / 8 ) ) ) { PyErr_Format( PyExc_ValueError, "%s: invalid argument key data size value out of bounds.", function ); return( NULL ); } Py_BEGIN_ALLOW_THREADS result = libcaes_context_set_key( pycaes_context->context, mode, (uint8_t *) key_data, (size_t) ( key_data_size * 8 ), &error ); Py_END_ALLOW_THREADS if( result != 1 ) { pycaes_error_raise( error, PyExc_ValueError, "%s: unable to set key.", function ); libcerror_error_free( &error ); return( NULL ); } Py_IncRef( Py_None ); return( Py_None ); } libcaes-20240413/pycaes/pycaes_libcerror.h0000644000175000017500000000263014606473412021207 0ustar00lordyestalordyesta/* * The libcerror header wrapper * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _PYCAES_LIBCERROR_H ) #define _PYCAES_LIBCERROR_H #include /* Define HAVE_LOCAL_LIBCERROR for local use of libcerror */ #if defined( HAVE_LOCAL_LIBCERROR ) #include #include #include #include #else /* If libtool DLL support is enabled set LIBCERROR_DLL_IMPORT * before including libcerror.h */ #if defined( _WIN32 ) && defined( DLL_IMPORT ) #define LIBCERROR_DLL_IMPORT #endif #include #endif /* defined( HAVE_LOCAL_LIBCERROR ) */ #endif /* !defined( _PYCAES_LIBCERROR_H ) */ libcaes-20240413/pycaes/pycaes_crypt_modes.c0000644000175000017500000001257314606473412021556 0ustar00lordyestalordyesta/* * Python object definition of the libcaes crypt modes * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #if defined( HAVE_STDLIB_H ) || defined( HAVE_WINAPI ) #include #endif #include "pycaes_crypt_modes.h" #include "pycaes_libcaes.h" #include "pycaes_python.h" #include "pycaes_unused.h" PyTypeObject pycaes_crypt_modes_type_object = { PyVarObject_HEAD_INIT( NULL, 0 ) /* tp_name */ "pycaes.crypt_modes", /* tp_basicsize */ sizeof( pycaes_crypt_modes_t ), /* tp_itemsize */ 0, /* tp_dealloc */ (destructor) pycaes_crypt_modes_free, /* tp_print */ 0, /* tp_getattr */ 0, /* tp_setattr */ 0, /* tp_compare */ 0, /* tp_repr */ 0, /* tp_as_number */ 0, /* tp_as_sequence */ 0, /* tp_as_mapping */ 0, /* tp_hash */ 0, /* tp_call */ 0, /* tp_str */ 0, /* tp_getattro */ 0, /* tp_setattro */ 0, /* tp_as_buffer */ 0, /* tp_flags */ Py_TPFLAGS_DEFAULT, /* tp_doc */ "pycaes crypt modes object (wraps LIBCAES_CRYPT_MODES)", /* tp_traverse */ 0, /* tp_clear */ 0, /* tp_richcompare */ 0, /* tp_weaklistoffset */ 0, /* tp_iter */ 0, /* tp_iternext */ 0, /* tp_methods */ 0, /* tp_members */ 0, /* tp_getset */ 0, /* tp_base */ 0, /* tp_dict */ 0, /* tp_descr_get */ 0, /* tp_descr_set */ 0, /* tp_dictoffset */ 0, /* tp_init */ (initproc) pycaes_crypt_modes_init, /* tp_alloc */ 0, /* tp_new */ 0, /* tp_free */ 0, /* tp_is_gc */ 0, /* tp_bases */ NULL, /* tp_mro */ NULL, /* tp_cache */ NULL, /* tp_subclasses */ NULL, /* tp_weaklist */ NULL, /* tp_del */ 0 }; /* Initializes the type object * Returns 1 if successful or -1 on error */ int pycaes_crypt_modes_init_type( PyTypeObject *type_object ) { PyObject *value_object = NULL; if( type_object == NULL ) { return( -1 ); } type_object->tp_dict = PyDict_New(); if( type_object->tp_dict == NULL ) { return( -1 ); } #if PY_MAJOR_VERSION >= 3 value_object = PyLong_FromLong( LIBCAES_CRYPT_MODE_DECRYPT ); #else value_object = PyInt_FromLong( LIBCAES_CRYPT_MODE_DECRYPT ); #endif if( PyDict_SetItemString( type_object->tp_dict, "DECRYPT", value_object ) != 0 ) { goto on_error; } #if PY_MAJOR_VERSION >= 3 value_object = PyLong_FromLong( LIBCAES_CRYPT_MODE_ENCRYPT ); #else value_object = PyInt_FromLong( LIBCAES_CRYPT_MODE_ENCRYPT ); #endif if( PyDict_SetItemString( type_object->tp_dict, "ENCRYPT", value_object ) != 0 ) { goto on_error; } return( 1 ); on_error: if( type_object->tp_dict != NULL ) { Py_DecRef( type_object->tp_dict ); type_object->tp_dict = NULL; } return( -1 ); } /* Creates a new crypt modes object * Returns a Python object if successful or NULL on error */ PyObject *pycaes_crypt_modes_new( void ) { pycaes_crypt_modes_t *definitions_object = NULL; static char *function = "pycaes_crypt_modes_new"; definitions_object = PyObject_New( struct pycaes_crypt_modes, &pycaes_crypt_modes_type_object ); if( definitions_object == NULL ) { PyErr_Format( PyExc_MemoryError, "%s: unable to create definitions object.", function ); goto on_error; } if( pycaes_crypt_modes_init( definitions_object ) != 0 ) { PyErr_Format( PyExc_MemoryError, "%s: unable to initialize definitions object.", function ); goto on_error; } return( (PyObject *) definitions_object ); on_error: if( definitions_object != NULL ) { Py_DecRef( (PyObject *) definitions_object ); } return( NULL ); } /* Initializes a crypt modes object * Returns 0 if successful or -1 on error */ int pycaes_crypt_modes_init( pycaes_crypt_modes_t *definitions_object ) { static char *function = "pycaes_crypt_modes_init"; if( definitions_object == NULL ) { PyErr_Format( PyExc_TypeError, "%s: invalid definitions object.", function ); return( -1 ); } return( 0 ); } /* Frees a crypt modes object */ void pycaes_crypt_modes_free( pycaes_crypt_modes_t *definitions_object ) { struct _typeobject *ob_type = NULL; static char *function = "pycaes_crypt_modes_free"; if( definitions_object == NULL ) { PyErr_Format( PyExc_TypeError, "%s: invalid definitions object.", function ); return; } ob_type = Py_TYPE( definitions_object ); if( ob_type == NULL ) { PyErr_Format( PyExc_ValueError, "%s: missing ob_type.", function ); return; } if( ob_type->tp_free == NULL ) { PyErr_Format( PyExc_ValueError, "%s: invalid ob_type - missing tp_free.", function ); return; } ob_type->tp_free( (PyObject*) definitions_object ); } libcaes-20240413/pycaes/Makefile.am0000644000175000017500000000133314606475344017550 0ustar00lordyestalordyestaif HAVE_PYTHON AM_CFLAGS = \ -I../include -I$(top_srcdir)/include \ -I../common -I$(top_srcdir)/common \ @LIBCERROR_CPPFLAGS@ \ @LIBCAES_DLL_IMPORT@ pyexec_LTLIBRARIES = pycaes.la pycaes_la_SOURCES = \ pycaes.c pycaes.h \ pycaes_context.c pycaes_context.h \ pycaes_crypt.c pycaes_crypt.h \ pycaes_crypt_modes.c pycaes_crypt_modes.h \ pycaes_error.c pycaes_error.h \ pycaes_libcaes.h \ pycaes_libcerror.h \ pycaes_python.h \ pycaes_tweaked_context.c pycaes_tweaked_context.h \ pycaes_unused.h pycaes_la_LIBADD = \ @LIBCERROR_LIBADD@ \ ../libcaes/libcaes.la pycaes_la_CPPFLAGS = $(PYTHON_CPPFLAGS) pycaes_la_LDFLAGS = -module -avoid-version $(PYTHON_LDFLAGS) endif DISTCLEANFILES = \ Makefile \ Makefile.in libcaes-20240413/pycaes/pycaes_error.h0000644000175000017500000000277314606473412020365 0ustar00lordyestalordyesta/* * Error functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _PYCAES_ERROR_H ) #define _PYCAES_ERROR_H #include #include #include "pycaes_libcerror.h" #include "pycaes_python.h" #define PYCAES_ERROR_STRING_SIZE 2048 #if defined( __cplusplus ) extern "C" { #endif void pycaes_error_fetch( libcerror_error_t **error, int error_domain, int error_code, const char *format_string, ... ); void pycaes_error_fetch_and_raise( PyObject *exception_object, const char *format_string, ... ); void pycaes_error_raise( libcerror_error_t *error, PyObject *exception_object, const char *format_string, ... ); #if defined( __cplusplus ) } #endif #endif /* !defined( _PYCAES_ERROR_H ) */ libcaes-20240413/pycaes/pycaes_crypt.h0000644000175000017500000000331614606473412020367 0ustar00lordyestalordyesta/* * Python definition of the libcaes crypt functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _PYCAES_CRYPT_H ) #define _PYCAES_CRYPT_H #include #include #include "pycaes_libcaes.h" #include "pycaes_python.h" #if defined( __cplusplus ) extern "C" { #endif PyObject *pycaes_crypt_cbc( PyObject *self, PyObject *arguments, PyObject *keywords ); PyObject *pycaes_crypt_ccm( PyObject *self, PyObject *arguments, PyObject *keywords ); #ifdef TODO PyObject *pycaes_crypt_cfb( PyObject *self, PyObject *arguments, PyObject *keywords ); #endif PyObject *pycaes_crypt_ecb( PyObject *self, PyObject *arguments, PyObject *keywords ); PyObject *pycaes_crypt_xts( PyObject *self, PyObject *arguments, PyObject *keywords ); #if defined( __cplusplus ) } #endif #endif /* !defined( _PYCAES_CRYPT_H ) */ libcaes-20240413/pycaes/pycaes_tweaked_context.c0000644000175000017500000002136114606473502022411 0ustar00lordyestalordyesta/* * Python object wrapper of libcaes_tweaked_context_t * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #if defined( HAVE_STDLIB_H ) || defined( HAVE_WINAPI ) #include #endif #include "pycaes_error.h" #include "pycaes_libcaes.h" #include "pycaes_libcerror.h" #include "pycaes_python.h" #include "pycaes_tweaked_context.h" #include "pycaes_unused.h" PyMethodDef pycaes_tweaked_context_object_methods[] = { { "set_keys", (PyCFunction) pycaes_tweaked_context_set_keys, METH_VARARGS | METH_KEYWORDS, "set_keys(mode, key, tweak_key) -> None\n" "\n" "Sets the key and tweak key for a specific crypt mode." }, /* Sentinel */ { NULL, NULL, 0, NULL } }; PyGetSetDef pycaes_tweaked_context_object_get_set_definitions[] = { /* Sentinel */ { NULL, NULL, NULL, NULL, NULL } }; PyTypeObject pycaes_tweaked_context_type_object = { PyVarObject_HEAD_INIT( NULL, 0 ) /* tp_name */ "pycaes.tweaked_context", /* tp_basicsize */ sizeof( pycaes_tweaked_context_t ), /* tp_itemsize */ 0, /* tp_dealloc */ (destructor) pycaes_tweaked_context_free, /* tp_print */ 0, /* tp_getattr */ 0, /* tp_setattr */ 0, /* tp_compare */ 0, /* tp_repr */ 0, /* tp_as_number */ 0, /* tp_as_sequence */ 0, /* tp_as_mapping */ 0, /* tp_hash */ 0, /* tp_call */ 0, /* tp_str */ 0, /* tp_getattro */ 0, /* tp_setattro */ 0, /* tp_as_buffer */ 0, /* tp_flags */ Py_TPFLAGS_DEFAULT, /* tp_doc */ "pycaes tweaked context object (wraps libcaes_tweaked_context_t)", /* tp_traverse */ 0, /* tp_clear */ 0, /* tp_richcompare */ 0, /* tp_weaklistoffset */ 0, /* tp_iter */ 0, /* tp_iternext */ 0, /* tp_methods */ pycaes_tweaked_context_object_methods, /* tp_members */ 0, /* tp_getset */ pycaes_tweaked_context_object_get_set_definitions, /* tp_base */ 0, /* tp_dict */ 0, /* tp_descr_get */ 0, /* tp_descr_set */ 0, /* tp_dictoffset */ 0, /* tp_init */ (initproc) pycaes_tweaked_context_init, /* tp_alloc */ 0, /* tp_new */ 0, /* tp_free */ 0, /* tp_is_gc */ 0, /* tp_bases */ NULL, /* tp_mro */ NULL, /* tp_cache */ NULL, /* tp_subclasses */ NULL, /* tp_weaklist */ NULL, /* tp_del */ 0 }; /* Creates a new tweaked context object * Returns a Python object if successful or NULL on error */ PyObject *pycaes_tweaked_context_new( void ) { pycaes_tweaked_context_t *pycaes_tweaked_context = NULL; static char *function = "pycaes_tweaked_context_new"; pycaes_tweaked_context = PyObject_New( struct pycaes_tweaked_context, &pycaes_tweaked_context_type_object ); if( pycaes_tweaked_context == NULL ) { PyErr_Format( PyExc_MemoryError, "%s: unable to initialize tweaked context.", function ); goto on_error; } if( pycaes_tweaked_context_init( pycaes_tweaked_context ) != 0 ) { PyErr_Format( PyExc_MemoryError, "%s: unable to initialize tweaked context.", function ); goto on_error; } return( (PyObject *) pycaes_tweaked_context ); on_error: if( pycaes_tweaked_context != NULL ) { Py_DecRef( (PyObject *) pycaes_tweaked_context ); } return( NULL ); } /* Initializes a tweaked context object * Returns 0 if successful or -1 on error */ int pycaes_tweaked_context_init( pycaes_tweaked_context_t *pycaes_tweaked_context ) { libcerror_error_t *error = NULL; static char *function = "pycaes_tweaked_context_init"; if( pycaes_tweaked_context == NULL ) { PyErr_Format( PyExc_ValueError, "%s: invalid tweaked context.", function ); return( -1 ); } pycaes_tweaked_context->tweaked_context = NULL; if( libcaes_tweaked_context_initialize( &( pycaes_tweaked_context->tweaked_context ), &error ) != 1 ) { pycaes_error_raise( error, PyExc_MemoryError, "%s: unable to initialize tweaked context.", function ); libcerror_error_free( &error ); return( -1 ); } return( 0 ); } /* Frees a tweaked context object */ void pycaes_tweaked_context_free( pycaes_tweaked_context_t *pycaes_tweaked_context ) { struct _typeobject *ob_type = NULL; libcerror_error_t *error = NULL; static char *function = "pycaes_tweaked_context_free"; int result = 0; if( pycaes_tweaked_context == NULL ) { PyErr_Format( PyExc_ValueError, "%s: invalid tweaked context.", function ); return; } if( pycaes_tweaked_context->tweaked_context == NULL ) { PyErr_Format( PyExc_ValueError, "%s: invalid tweaked context - missing libcaes tweaked context.", function ); return; } ob_type = Py_TYPE( pycaes_tweaked_context ); if( ob_type == NULL ) { PyErr_Format( PyExc_ValueError, "%s: missing ob_type.", function ); return; } if( ob_type->tp_free == NULL ) { PyErr_Format( PyExc_ValueError, "%s: invalid ob_type - missing tp_free.", function ); return; } Py_BEGIN_ALLOW_THREADS result = libcaes_tweaked_context_free( &( pycaes_tweaked_context->tweaked_context ), &error ); Py_END_ALLOW_THREADS if( result != 1 ) { pycaes_error_raise( error, PyExc_MemoryError, "%s: unable to free libcaes tweaked context.", function ); libcerror_error_free( &error ); } ob_type->tp_free( (PyObject*) pycaes_tweaked_context ); } /* Sets the keys * Returns a Python object if successful or NULL on error */ PyObject *pycaes_tweaked_context_set_keys( pycaes_tweaked_context_t *pycaes_tweaked_context, PyObject *arguments, PyObject *keywords ) { PyObject *key_string_object = NULL; PyObject *tweak_key_string_object = NULL; libcerror_error_t *error = NULL; static char *function = "pycaes_tweaked_context_set_key"; char *key_data = NULL; static char *keyword_list[] = { "mode", "key", "tweak_key", NULL }; char *tweak_key_data = NULL; Py_ssize_t key_data_size = 0; Py_ssize_t tweak_key_data_size = 0; int mode = 0; int result = 0; if( pycaes_tweaked_context == NULL ) { PyErr_Format( PyExc_ValueError, "%s: invalid tweaked context.", function ); return( NULL ); } if( PyArg_ParseTupleAndKeywords( arguments, keywords, "iOO", keyword_list, &mode, &key_string_object, &tweak_key_string_object ) == 0 ) { return( NULL ); } #if PY_MAJOR_VERSION >= 3 key_data = PyBytes_AsString( key_string_object ); key_data_size = PyBytes_Size( key_string_object ); #else key_data = PyString_AsString( key_string_object ); key_data_size = PyString_Size( key_string_object ); #endif if( ( key_data_size < 0 ) || ( key_data_size > (Py_ssize_t) ( SSIZE_MAX / 8 ) ) ) { PyErr_Format( PyExc_ValueError, "%s: invalid key data size value out of bounds.", function ); return( NULL ); } #if PY_MAJOR_VERSION >= 3 tweak_key_data = PyBytes_AsString( tweak_key_string_object ); tweak_key_data_size = PyBytes_Size( tweak_key_string_object ); #else tweak_key_data = PyString_AsString( tweak_key_string_object ); tweak_key_data_size = PyString_Size( tweak_key_string_object ); #endif if( ( tweak_key_data_size < 0 ) || ( tweak_key_data_size > (Py_ssize_t) ( SSIZE_MAX / 8 ) ) ) { PyErr_Format( PyExc_ValueError, "%s: invalid tweak key data size value out of bounds.", function ); return( NULL ); } Py_BEGIN_ALLOW_THREADS result = libcaes_tweaked_context_set_keys( pycaes_tweaked_context->tweaked_context, mode, (uint8_t *) key_data, (size_t) ( key_data_size * 8 ), (uint8_t *) tweak_key_data, (size_t) ( tweak_key_data_size * 8 ), &error ); Py_END_ALLOW_THREADS if( result != 1 ) { pycaes_error_raise( error, PyExc_ValueError, "%s: unable to set keys.", function ); libcerror_error_free( &error ); return( NULL ); } Py_IncRef( Py_None ); return( Py_None ); } libcaes-20240413/pycaes/pycaes.h0000644000175000017500000000243014606473412017142 0ustar00lordyestalordyesta/* * Python bindings module for libcaes (pycaes) * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _PYCAES_H ) #define _PYCAES_H #include #include #include "pycaes_python.h" #if defined( __cplusplus ) extern "C" { #endif PyObject *pycaes_get_version( PyObject *self, PyObject *arguments ); #if PY_MAJOR_VERSION >= 3 PyMODINIT_FUNC PyInit_pycaes( void ); #else PyMODINIT_FUNC initpycaes( void ); #endif #if defined( __cplusplus ) } #endif #endif /* !defined( _PYCAES_H ) */ libcaes-20240413/pycaes/pycaes_error.c0000644000175000017500000002246614606473412020361 0ustar00lordyestalordyesta/* * Error functions * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include #include #if defined( HAVE_STDARG_H ) || defined( WINAPI ) #include #elif defined( HAVE_VARARGS_H ) #include #else #error Missing headers stdarg.h and varargs.h #endif #include "pycaes_error.h" #include "pycaes_libcerror.h" #include "pycaes_python.h" #if defined( HAVE_STDARG_H ) || defined( WINAPI ) #define VARARGS( function, error, error_domain, error_code, type, argument ) \ function( error, error_domain, error_code, type argument, ... ) #define VASTART( argument_list, type, name ) \ va_start( argument_list, name ) #define VAEND( argument_list ) \ va_end( argument_list ) #elif defined( HAVE_VARARGS_H ) #define VARARGS( function, error, error_domain, error_code, type, argument ) \ function( error, error_domain, error_code, va_alist ) va_dcl #define VASTART( argument_list, type, name ) \ { type name; va_start( argument_list ); name = va_arg( argument_list, type ) #define VAEND( argument_list ) \ va_end( argument_list ); } #endif /* Fetches an error */ void VARARGS( pycaes_error_fetch, libcerror_error_t **error, int error_domain, int error_code, const char *, format_string ) { va_list argument_list; char error_string[ PYCAES_ERROR_STRING_SIZE ]; PyObject *exception_traceback = NULL; PyObject *exception_type = NULL; PyObject *exception_value = NULL; PyObject *string_object = NULL; static char *function = "pycaes_error_fetch"; char *exception_string = NULL; size_t error_string_length = 0; int print_count = 0; #if PY_MAJOR_VERSION >= 3 PyObject *utf8_string_object = NULL; #endif if( format_string == NULL ) { PyErr_Format( PyExc_ValueError, "%s: missing format string.", function ); return; } VASTART( argument_list, const char *, format_string ); print_count = PyOS_vsnprintf( error_string, PYCAES_ERROR_STRING_SIZE, format_string, argument_list ); VAEND( argument_list ); if( print_count < 0 ) { PyErr_Format( PyExc_ValueError, "%s: unable to format error string.", function ); return; } error_string_length = narrow_string_length( error_string ); if( ( error_string_length >= 1 ) && ( error_string[ error_string_length - 1 ] == '.' ) ) { error_string[ error_string_length - 1 ] = 0; } PyErr_Fetch( &exception_type, &exception_value, &exception_traceback ); string_object = PyObject_Repr( exception_value ); #if PY_MAJOR_VERSION >= 3 utf8_string_object = PyUnicode_AsUTF8String( string_object ); if( utf8_string_object != NULL ) { exception_string = PyBytes_AsString( utf8_string_object ); } #else exception_string = PyString_AsString( string_object ); #endif if( exception_string != NULL ) { libcerror_error_set( error, error_domain, error_code, "%s with error: %s.", error_string, exception_string ); } else { libcerror_error_set( error, error_domain, error_code, "%s.", error_string ); } #if PY_MAJOR_VERSION >= 3 if( utf8_string_object != NULL ) { Py_DecRef( utf8_string_object ); } #endif Py_DecRef( string_object ); return; } #undef VARARGS #undef VASTART #undef VAEND #if defined( HAVE_STDARG_H ) || defined( WINAPI ) #define VARARGS( function, exception_object, type, argument ) \ function( exception_object, type argument, ... ) #define VASTART( argument_list, type, name ) \ va_start( argument_list, name ) #define VAEND( argument_list ) \ va_end( argument_list ) #elif defined( HAVE_VARARGS_H ) #define VARARGS( function, exception_object, type, argument ) \ function( exception_object, va_alist ) va_dcl #define VASTART( argument_list, type, name ) \ { type name; va_start( argument_list ); name = va_arg( argument_list, type ) #define VAEND( argument_list ) \ va_end( argument_list ); } #endif /* Fetches and raises an error */ void VARARGS( pycaes_error_fetch_and_raise, PyObject *exception_object, const char *, format_string ) { va_list argument_list; char error_string[ PYCAES_ERROR_STRING_SIZE ]; PyObject *exception_traceback = NULL; PyObject *exception_type = NULL; PyObject *exception_value = NULL; PyObject *string_object = NULL; static char *function = "pycaes_error_fetch_and_raise"; char *exception_string = NULL; size_t error_string_length = 0; int print_count = 0; #if PY_MAJOR_VERSION >= 3 PyObject *utf8_string_object = NULL; #endif if( format_string == NULL ) { PyErr_Format( PyExc_ValueError, "%s: missing format string.", function ); return; } VASTART( argument_list, const char *, format_string ); print_count = PyOS_vsnprintf( error_string, PYCAES_ERROR_STRING_SIZE, format_string, argument_list ); VAEND( argument_list ); if( print_count < 0 ) { PyErr_Format( PyExc_ValueError, "%s: unable to format exception string.", function ); return; } error_string_length = narrow_string_length( error_string ); if( ( error_string_length >= 1 ) && ( error_string[ error_string_length - 1 ] == '.' ) ) { error_string[ error_string_length - 1 ] = 0; } PyErr_Fetch( &exception_type, &exception_value, &exception_traceback ); string_object = PyObject_Repr( exception_value ); #if PY_MAJOR_VERSION >= 3 utf8_string_object = PyUnicode_AsUTF8String( string_object ); if( utf8_string_object != NULL ) { exception_string = PyBytes_AsString( utf8_string_object ); } #else exception_string = PyString_AsString( string_object ); #endif if( exception_string != NULL ) { PyErr_Format( exception_object, "%s with error: %s.", error_string, exception_string ); } else { PyErr_Format( exception_object, "%s.", error_string ); } Py_DecRef( string_object ); return; } #undef VARARGS #undef VASTART #undef VAEND #if defined( HAVE_STDARG_H ) || defined( WINAPI ) #define VARARGS( function, error, exception_object, type, argument ) \ function( error, exception_object, type argument, ... ) #define VASTART( argument_list, type, name ) \ va_start( argument_list, name ) #define VAEND( argument_list ) \ va_end( argument_list ) #elif defined( HAVE_VARARGS_H ) #define VARARGS( function, error, exception_object, type, argument ) \ function( error, exception_object, va_alist ) va_dcl #define VASTART( argument_list, type, name ) \ { type name; va_start( argument_list ); name = va_arg( argument_list, type ) #define VAEND( argument_list ) \ va_end( argument_list ); } #endif /* Raises an error */ void VARARGS( pycaes_error_raise, libcerror_error_t *error, PyObject *exception_object, const char *, format_string ) { va_list argument_list; char error_string[ PYCAES_ERROR_STRING_SIZE ]; char exception_string[ PYCAES_ERROR_STRING_SIZE ]; static char *function = "pycaes_error_raise"; size_t error_string_index = 0; int print_count = 0; if( format_string == NULL ) { PyErr_Format( PyExc_ValueError, "%s: missing format string.", function ); return; } VASTART( argument_list, const char *, format_string ); print_count = PyOS_vsnprintf( exception_string, PYCAES_ERROR_STRING_SIZE, format_string, argument_list ); VAEND( argument_list ); if( print_count < 0 ) { PyErr_Format( PyExc_ValueError, "%s: unable to format exception string.", function ); return; } if( error != NULL ) { if( libcerror_error_backtrace_sprint( error, error_string, PYCAES_ERROR_STRING_SIZE ) != -1 ) { while( error_string_index < PYCAES_ERROR_STRING_SIZE ) { if( error_string[ error_string_index ] == 0 ) { break; } if( ( error_string[ error_string_index ] == '\n' ) || ( error_string[ error_string_index ] == '\r' ) ) { error_string[ error_string_index ] = ' '; } error_string_index++; } if( error_string_index >= PYCAES_ERROR_STRING_SIZE ) { error_string[ PYCAES_ERROR_STRING_SIZE - 1 ] = 0; } PyErr_Format( exception_object, "%s %s", exception_string, error_string ); return; } } PyErr_Format( exception_object, "%s", exception_string ); return; } #undef VARARGS #undef VASTART #undef VAEND libcaes-20240413/pycaes/pycaes_context.h0000644000175000017500000000331314606473502020707 0ustar00lordyestalordyesta/* * Python object wrapper of libcaes_context_t * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _PYCAES_CONTEXT_H ) #define _PYCAES_CONTEXT_H #include #include #include "pycaes_libcaes.h" #include "pycaes_python.h" #if defined( __cplusplus ) extern "C" { #endif typedef struct pycaes_context pycaes_context_t; struct pycaes_context { /* Python object initialization */ PyObject_HEAD /* The libcaes context */ libcaes_context_t *context; }; extern PyMethodDef pycaes_context_object_methods[]; extern PyTypeObject pycaes_context_type_object; PyObject *pycaes_context_new( void ); int pycaes_context_init( pycaes_context_t *pycaes_context ); void pycaes_context_free( pycaes_context_t *pycaes_context ); PyObject *pycaes_context_set_key( pycaes_context_t *pycaes_context, PyObject *arguments, PyObject *keywords ); #if defined( __cplusplus ) } #endif #endif /* !defined( _PYCAES_CONTEXT_H ) */ libcaes-20240413/pycaes/pycaes.c0000644000175000017500000001421714606473502017143 0ustar00lordyestalordyesta/* * Python bindings module for libcaes (pycaes) * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include #if defined( HAVE_STDLIB_H ) || defined( HAVE_WINAPI ) #include #endif #include "pycaes.h" #include "pycaes_context.h" #include "pycaes_crypt.h" #include "pycaes_crypt_modes.h" #include "pycaes_libcaes.h" #include "pycaes_libcerror.h" #include "pycaes_python.h" #include "pycaes_tweaked_context.h" #include "pycaes_unused.h" /* The pycaes module methods */ PyMethodDef pycaes_module_methods[] = { { "get_version", (PyCFunction) pycaes_get_version, METH_NOARGS, "get_version() -> String\n" "\n" "Retrieves the version." }, { "crypt_cbc", (PyCFunction) pycaes_crypt_cbc, METH_VARARGS | METH_KEYWORDS, "crypt_cbc(context, mode, initialization_vector, data) -> Bytes\n" "\n" "De- or encrypts a block of data using AES-CBC (Cipher Block Chaining)." }, { "crypt_ccm", (PyCFunction) pycaes_crypt_ccm, METH_VARARGS | METH_KEYWORDS, "crypt_ccm(context, mode, nonce, data) -> Bytes\n" "\n" "De- or encrypts a block of data using AES-CCM (Counter with CBC-MAC)." }, #ifdef TODO { "crypt_cfb", (PyCFunction) pycaes_crypt_cfb, METH_VARARGS | METH_KEYWORDS, "crypt_cfb(context, mode, initialization_vector, data) -> Bytes\n" "\n" "De- or encrypts a block of data using AES-CFB (Cipher Feedback Mode)." }, #endif { "crypt_ecb", (PyCFunction) pycaes_crypt_ecb, METH_VARARGS | METH_KEYWORDS, "crypt_ecb(context, mode, data) -> Bytes\n" "\n" "De- or encrypts a block of data using AES-ECB (Electronic CodeBook)." }, { "crypt_xts", (PyCFunction) pycaes_crypt_xts, METH_VARARGS | METH_KEYWORDS, "crypt_xts(tweaked_context, mode, tweak_value, data) -> Bytes\n" "\n" "De- or encrypts a block of data using AES-XTS (XEX-based tweaked-codebook mode with ciphertext stealing)." }, /* Sentinel */ { NULL, NULL, 0, NULL } }; /* Retrieves the pycaes/libcaes version * Returns a Python object if successful or NULL on error */ PyObject *pycaes_get_version( PyObject *self PYCAES_ATTRIBUTE_UNUSED, PyObject *arguments PYCAES_ATTRIBUTE_UNUSED ) { const char *version_string = NULL; size_t version_string_length = 0; PYCAES_UNREFERENCED_PARAMETER( self ) PYCAES_UNREFERENCED_PARAMETER( arguments ) Py_BEGIN_ALLOW_THREADS version_string = libcaes_get_version(); Py_END_ALLOW_THREADS version_string_length = narrow_string_length( version_string ); /* Pass the string length to PyUnicode_DecodeUTF8 * otherwise it makes the end of string character is part * of the string */ return( PyUnicode_DecodeUTF8( version_string, (Py_ssize_t) version_string_length, NULL ) ); } #if PY_MAJOR_VERSION >= 3 /* The pycaes module definition */ PyModuleDef pycaes_module_definition = { PyModuleDef_HEAD_INIT, /* m_name */ "pycaes", /* m_doc */ "Python libcaes module (pycaes).", /* m_size */ -1, /* m_methods */ pycaes_module_methods, /* m_reload */ NULL, /* m_traverse */ NULL, /* m_clear */ NULL, /* m_free */ NULL, }; #endif /* PY_MAJOR_VERSION >= 3 */ /* Initializes the pycaes module */ #if PY_MAJOR_VERSION >= 3 PyMODINIT_FUNC PyInit_pycaes( void ) #else PyMODINIT_FUNC initpycaes( void ) #endif { PyObject *module = NULL; PyGILState_STATE gil_state = 0; #if defined( HAVE_DEBUG_OUTPUT ) libcaes_notify_set_stream( stderr, NULL ); libcaes_notify_set_verbose( 1 ); #endif /* Create the module * This function must be called before grabbing the GIL * otherwise the module will segfault on a version mismatch */ #if PY_MAJOR_VERSION >= 3 module = PyModule_Create( &pycaes_module_definition ); #else module = Py_InitModule3( "pycaes", pycaes_module_methods, "Python libcaes module (pycaes)." ); #endif if( module == NULL ) { #if PY_MAJOR_VERSION >= 3 return( NULL ); #else return; #endif } #if PY_VERSION_HEX < 0x03070000 PyEval_InitThreads(); #endif gil_state = PyGILState_Ensure(); /* Setup the context type object */ pycaes_context_type_object.tp_new = PyType_GenericNew; if( PyType_Ready( &pycaes_context_type_object ) < 0 ) { goto on_error; } Py_IncRef( (PyObject *) &pycaes_context_type_object ); PyModule_AddObject( module, "context", (PyObject *) &pycaes_context_type_object ); /* Setup the crypt modes type object */ pycaes_crypt_modes_type_object.tp_new = PyType_GenericNew; if( pycaes_crypt_modes_init_type( &pycaes_crypt_modes_type_object ) != 1 ) { goto on_error; } if( PyType_Ready( &pycaes_crypt_modes_type_object ) < 0 ) { goto on_error; } Py_IncRef( (PyObject *) &pycaes_crypt_modes_type_object ); PyModule_AddObject( module, "crypt_modes", (PyObject *) &pycaes_crypt_modes_type_object ); /* Setup the tweaked context type object */ pycaes_tweaked_context_type_object.tp_new = PyType_GenericNew; if( PyType_Ready( &pycaes_tweaked_context_type_object ) < 0 ) { goto on_error; } Py_IncRef( (PyObject *) &pycaes_tweaked_context_type_object ); PyModule_AddObject( module, "tweaked_context", (PyObject *) &pycaes_tweaked_context_type_object ); PyGILState_Release( gil_state ); #if PY_MAJOR_VERSION >= 3 return( module ); #else return; #endif on_error: PyGILState_Release( gil_state ); #if PY_MAJOR_VERSION >= 3 return( NULL ); #else return; #endif } libcaes-20240413/pycaes/pycaes_libcaes.h0000644000175000017500000000170514606473412020630 0ustar00lordyestalordyesta/* * The internal libcaes header * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _PYCAES_LIBCAES_H ) #define _PYCAES_LIBCAES_H #include #include #endif /* !defined( _PYCAES_LIBCAES_H ) */ libcaes-20240413/pycaes/pycaes_crypt.c0000644000175000017500000005144414606473412020367 0ustar00lordyestalordyesta/* * Python definition of the libcaes crypt functions * * Copyright (C) 2010-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #if defined( HAVE_STDLIB_H ) || defined( HAVE_WINAPI ) #include #endif #include "pycaes_context.h" #include "pycaes_crypt.h" #include "pycaes_error.h" #include "pycaes_libcaes.h" #include "pycaes_python.h" #include "pycaes_tweaked_context.h" #include "pycaes_unused.h" /* De- or encrypts a block of data using AES-CBC (Cipher Block Chaining) * The size of the data must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ PyObject *pycaes_crypt_cbc( PyObject *self PYCAES_ATTRIBUTE_UNUSED, PyObject *arguments, PyObject *keywords ) { libcerror_error_t *error = NULL; pycaes_context_t *pycaes_context = NULL; PyObject *context_object = NULL; PyObject *initialization_vector_string_object = NULL; PyObject *input_data_string_object = NULL; PyObject *output_data_string_object = NULL; static char *function = "pycaes_crypt_cbc"; static char *keyword_list[] = { "context", "mode", "initialization_vector", "data", NULL }; char *initialization_vector_data = NULL; char *input_data = NULL; char *output_data = NULL; Py_ssize_t initialization_vector_data_size = 0; Py_ssize_t input_data_size = 0; int mode = 0; int result = 0; PYCAES_UNREFERENCED_PARAMETER( self ) if( PyArg_ParseTupleAndKeywords( arguments, keywords, "OiOO", keyword_list, &context_object, &mode, &initialization_vector_string_object, &input_data_string_object ) == 0 ) { return( NULL ); } result = PyObject_IsInstance( context_object, (PyObject *) &pycaes_context_type_object ); if( result == -1 ) { return( NULL ); } else if( result != 1 ) { PyErr_Format( PyExc_TypeError, "%s: unsupported type of argument context value.", function ); return( NULL ); } pycaes_context = (pycaes_context_t *) context_object; #if PY_MAJOR_VERSION >= 3 initialization_vector_data = PyBytes_AsString( initialization_vector_string_object ); initialization_vector_data_size = PyBytes_Size( initialization_vector_string_object ); #else initialization_vector_data = PyString_AsString( initialization_vector_string_object ); initialization_vector_data_size = PyString_Size( initialization_vector_string_object ); #endif if( ( initialization_vector_data_size < 0 ) || ( initialization_vector_data_size > (Py_ssize_t) SSIZE_MAX ) ) { PyErr_Format( PyExc_ValueError, "%s: invalid argument initialization vector data size value out of bounds.", function ); return( NULL ); } #if PY_MAJOR_VERSION >= 3 input_data = PyBytes_AsString( input_data_string_object ); input_data_size = PyBytes_Size( input_data_string_object ); #else input_data = PyString_AsString( input_data_string_object ); input_data_size = PyString_Size( input_data_string_object ); #endif if( ( input_data_size < 0 ) || ( input_data_size > (Py_ssize_t) SSIZE_MAX ) ) { PyErr_Format( PyExc_ValueError, "%s: invalid argument input data size value out of bounds.", function ); return( NULL ); } #if PY_MAJOR_VERSION >= 3 output_data_string_object = PyBytes_FromStringAndSize( NULL, input_data_size ); output_data = PyBytes_AsString( output_data_string_object ); #else output_data_string_object = PyString_FromStringAndSize( NULL, input_data_size ); output_data = PyString_AsString( output_data_string_object ); #endif Py_BEGIN_ALLOW_THREADS result = libcaes_crypt_cbc( pycaes_context->context, mode, (uint8_t *) initialization_vector_data, (size_t) initialization_vector_data_size, (uint8_t *) input_data, (size_t) input_data_size, (uint8_t *) output_data, (size_t) input_data_size, &error ); Py_END_ALLOW_THREADS if( result != 1 ) { pycaes_error_raise( error, PyExc_IOError, "%s: unable to crypt data.", function ); libcerror_error_free( &error ); Py_DecRef( (PyObject *) output_data_string_object ); return( NULL ); } return( output_data_string_object ); } /* De- or encrypts a block of data using AES-CCM (Counter with CBC-MAC) * Note that the key must be set in encryption mode (LIBCAES_CRYPT_MODE_ENCRYPT) for both de- and encryption. * Returns 1 if successful or -1 on error */ PyObject *pycaes_crypt_ccm( PyObject *self PYCAES_ATTRIBUTE_UNUSED, PyObject *arguments, PyObject *keywords ) { libcerror_error_t *error = NULL; pycaes_context_t *pycaes_context = NULL; PyObject *context_object = NULL; PyObject *nonce_string_object = NULL; PyObject *input_data_string_object = NULL; PyObject *output_data_string_object = NULL; static char *function = "pycaes_crypt_ccm"; static char *keyword_list[] = { "context", "mode", "nonce", "data", NULL }; char *nonce_data = NULL; char *input_data = NULL; char *output_data = NULL; Py_ssize_t nonce_data_size = 0; Py_ssize_t input_data_size = 0; int mode = 0; int result = 0; PYCAES_UNREFERENCED_PARAMETER( self ) if( PyArg_ParseTupleAndKeywords( arguments, keywords, "OiOO", keyword_list, &context_object, &mode, &nonce_string_object, &input_data_string_object ) == 0 ) { return( NULL ); } result = PyObject_IsInstance( context_object, (PyObject *) &pycaes_context_type_object ); if( result == -1 ) { return( NULL ); } else if( result != 1 ) { PyErr_Format( PyExc_TypeError, "%s: unsupported type of argument context value.", function ); return( NULL ); } pycaes_context = (pycaes_context_t *) context_object; #if PY_MAJOR_VERSION >= 3 nonce_data = PyBytes_AsString( nonce_string_object ); nonce_data_size = PyBytes_Size( nonce_string_object ); #else nonce_data = PyString_AsString( nonce_string_object ); nonce_data_size = PyString_Size( nonce_string_object ); #endif if( ( nonce_data_size < 0 ) || ( nonce_data_size > (Py_ssize_t) SSIZE_MAX ) ) { PyErr_Format( PyExc_ValueError, "%s: invalid argument nonce data size value out of bounds.", function ); return( NULL ); } #if PY_MAJOR_VERSION >= 3 input_data = PyBytes_AsString( input_data_string_object ); input_data_size = PyBytes_Size( input_data_string_object ); #else input_data = PyString_AsString( input_data_string_object ); input_data_size = PyString_Size( input_data_string_object ); #endif if( ( input_data_size < 0 ) || ( input_data_size > (Py_ssize_t) SSIZE_MAX ) ) { PyErr_Format( PyExc_ValueError, "%s: invalid argument input data size value out of bounds.", function ); return( NULL ); } #if PY_MAJOR_VERSION >= 3 output_data_string_object = PyBytes_FromStringAndSize( NULL, input_data_size ); output_data = PyBytes_AsString( output_data_string_object ); #else output_data_string_object = PyString_FromStringAndSize( NULL, input_data_size ); output_data = PyString_AsString( output_data_string_object ); #endif Py_BEGIN_ALLOW_THREADS result = libcaes_crypt_ccm( pycaes_context->context, mode, (uint8_t *) nonce_data, (size_t) nonce_data_size, (uint8_t *) input_data, (size_t) input_data_size, (uint8_t *) output_data, (size_t) input_data_size, &error ); Py_END_ALLOW_THREADS if( result != 1 ) { pycaes_error_raise( error, PyExc_IOError, "%s: unable to crypt data.", function ); libcerror_error_free( &error ); Py_DecRef( (PyObject *) output_data_string_object ); return( NULL ); } return( output_data_string_object ); } #ifdef TODO /* De- or encrypts a block of data using AES-CFB (Cipher Feedback Mode) * Returns 1 if successful or -1 on error */ PyObject *pycaes_crypt_cfb( PyObject *self PYCAES_ATTRIBUTE_UNUSED, PyObject *arguments, PyObject *keywords ) { libcerror_error_t *error = NULL; pycaes_context_t *pycaes_context = NULL; PyObject *context_object = NULL; PyObject *initialization_vector_string_object = NULL; PyObject *input_data_string_object = NULL; PyObject *output_data_string_object = NULL; static char *function = "pycaes_crypt_cfb"; static char *keyword_list[] = { "context", "mode", "initialization_vector", "data", NULL }; char *initialization_vector_data = NULL; char *input_data = NULL; char *output_data = NULL; Py_ssize_t initialization_vector_data_size = 0; Py_ssize_t input_data_size = 0; int mode = 0; int result = 0; PYCAES_UNREFERENCED_PARAMETER( self ) if( PyArg_ParseTupleAndKeywords( arguments, keywords, "OiOO", keyword_list, &context_object, &mode, &initialization_vector_string_object, &input_data_string_object ) == 0 ) { return( NULL ); } result = PyObject_IsInstance( context_object, (PyObject *) &pycaes_context_type_object ); if( result == -1 ) { return( NULL ); } else if( result != 1 ) { PyErr_Format( PyExc_TypeError, "%s: unsupported type of argument context value.", function ); return( NULL ); } pycaes_context = (pycaes_context_t *) context_object; #if PY_MAJOR_VERSION >= 3 initialization_vector_data = PyBytes_AsString( initialization_vector_string_object ); initialization_vector_data_size = PyBytes_Size( initialization_vector_string_object ); #else initialization_vector_data = PyString_AsString( initialization_vector_string_object ); initialization_vector_data_size = PyString_Size( initialization_vector_string_object ); #endif if( ( initialization_vector_data_size < 0 ) || ( initialization_vector_data_size > (Py_ssize_t) SSIZE_MAX ) ) { PyErr_Format( PyExc_ValueError, "%s: invalid argument initialization vector data size value out of bounds.", function ); return( NULL ); } #if PY_MAJOR_VERSION >= 3 input_data = PyBytes_AsString( input_data_string_object ); input_data_size = PyBytes_Size( input_data_string_object ); #else input_data = PyString_AsString( input_data_string_object ); input_data_size = PyString_Size( input_data_string_object ); #endif if( ( input_data_size < 0 ) || ( input_data_size > (Py_ssize_t) SSIZE_MAX ) ) { PyErr_Format( PyExc_ValueError, "%s: invalid argument input data size value out of bounds.", function ); return( NULL ); } #if PY_MAJOR_VERSION >= 3 output_data_string_object = PyBytes_FromStringAndSize( NULL, input_data_size ); output_data = PyBytes_AsString( output_data_string_object ); #else output_data_string_object = PyString_FromStringAndSize( NULL, input_data_size ); output_data = PyString_AsString( output_data_string_object ); #endif Py_BEGIN_ALLOW_THREADS result = libcaes_crypt_cfb( pycaes_context->context, mode, (uint8_t *) initialization_vector_data, (size_t) initialization_vector_data_size, (uint8_t *) input_data, (size_t) input_data_size, (uint8_t *) output_data, (size_t) input_data_size, &error ); Py_END_ALLOW_THREADS if( result != 1 ) { pycaes_error_raise( error, PyExc_IOError, "%s: unable to crypt data.", function ); libcerror_error_free( &error ); Py_DecRef( (PyObject *) output_data_string_object ); return( NULL ); } return( output_data_string_object ); } #endif /* TODO */ /* De- or encrypts a block of data using AES-ECB (Electronic CodeBook) * The size of the data must be a multitude of the AES block size (16 byte) * Returns 1 if successful or -1 on error */ PyObject *pycaes_crypt_ecb( PyObject *self PYCAES_ATTRIBUTE_UNUSED, PyObject *arguments, PyObject *keywords ) { libcerror_error_t *error = NULL; pycaes_context_t *pycaes_context = NULL; PyObject *context_object = NULL; PyObject *input_data_string_object = NULL; PyObject *output_data_string_object = NULL; static char *function = "pycaes_crypt_ecb"; static char *keyword_list[] = { "context", "mode", "data", NULL }; char *input_data = NULL; char *output_data = NULL; Py_ssize_t input_data_size = 0; int mode = 0; int result = 0; PYCAES_UNREFERENCED_PARAMETER( self ) if( PyArg_ParseTupleAndKeywords( arguments, keywords, "OiO", keyword_list, &context_object, &mode, &input_data_string_object ) == 0 ) { return( NULL ); } result = PyObject_IsInstance( context_object, (PyObject *) &pycaes_context_type_object ); if( result == -1 ) { return( NULL ); } else if( result != 1 ) { PyErr_Format( PyExc_TypeError, "%s: unsupported type of argument context value.", function ); return( NULL ); } pycaes_context = (pycaes_context_t *) context_object; #if PY_MAJOR_VERSION >= 3 input_data = PyBytes_AsString( input_data_string_object ); input_data_size = PyBytes_Size( input_data_string_object ); #else input_data = PyString_AsString( input_data_string_object ); input_data_size = PyString_Size( input_data_string_object ); #endif if( ( input_data_size < 0 ) || ( input_data_size > (Py_ssize_t) SSIZE_MAX ) ) { PyErr_Format( PyExc_ValueError, "%s: invalid argument input data size value out of bounds.", function ); return( NULL ); } #if PY_MAJOR_VERSION >= 3 output_data_string_object = PyBytes_FromStringAndSize( NULL, input_data_size ); output_data = PyBytes_AsString( output_data_string_object ); #else output_data_string_object = PyString_FromStringAndSize( NULL, input_data_size ); output_data = PyString_AsString( output_data_string_object ); #endif Py_BEGIN_ALLOW_THREADS result = libcaes_crypt_ecb( pycaes_context->context, mode, (uint8_t *) input_data, (size_t) input_data_size, (uint8_t *) output_data, (size_t) input_data_size, &error ); Py_END_ALLOW_THREADS if( result != 1 ) { pycaes_error_raise( error, PyExc_IOError, "%s: unable to crypt data.", function ); libcerror_error_free( &error ); Py_DecRef( (PyObject *) output_data_string_object ); return( NULL ); } return( output_data_string_object ); } /* De- or encrypts a block of data using AES-XTS (XEX-based tweaked-codebook mode with ciphertext stealing) * Returns 1 if successful or -1 on error */ PyObject *pycaes_crypt_xts( PyObject *self PYCAES_ATTRIBUTE_UNUSED, PyObject *arguments, PyObject *keywords ) { libcerror_error_t *error = NULL; pycaes_tweaked_context_t *pycaes_context = NULL; PyObject *context_object = NULL; PyObject *tweak_value_string_object = NULL; PyObject *input_data_string_object = NULL; PyObject *output_data_string_object = NULL; static char *function = "pycaes_crypt_xts"; static char *keyword_list[] = { "context", "mode", "tweak_value", "data", NULL }; char *tweak_value_data = NULL; char *input_data = NULL; char *output_data = NULL; Py_ssize_t tweak_value_data_size = 0; Py_ssize_t input_data_size = 0; int mode = 0; int result = 0; PYCAES_UNREFERENCED_PARAMETER( self ) if( PyArg_ParseTupleAndKeywords( arguments, keywords, "OiOO", keyword_list, &context_object, &mode, &tweak_value_string_object, &input_data_string_object ) == 0 ) { return( NULL ); } result = PyObject_IsInstance( context_object, (PyObject *) &pycaes_tweaked_context_type_object ); if( result == -1 ) { return( NULL ); } else if( result != 1 ) { PyErr_Format( PyExc_TypeError, "%s: unsupported type of argument context value.", function ); return( NULL ); } pycaes_context = (pycaes_tweaked_context_t *) context_object; #if PY_MAJOR_VERSION >= 3 tweak_value_data = PyBytes_AsString( tweak_value_string_object ); tweak_value_data_size = PyBytes_Size( tweak_value_string_object ); #else tweak_value_data = PyString_AsString( tweak_value_string_object ); tweak_value_data_size = PyString_Size( tweak_value_string_object ); #endif if( ( tweak_value_data_size < 0 ) || ( tweak_value_data_size > (Py_ssize_t) SSIZE_MAX ) ) { PyErr_Format( PyExc_ValueError, "%s: invalid argument tweak value data size value out of bounds.", function ); return( NULL ); } #if PY_MAJOR_VERSION >= 3 input_data = PyBytes_AsString( input_data_string_object ); input_data_size = PyBytes_Size( input_data_string_object ); #else input_data = PyString_AsString( input_data_string_object ); input_data_size = PyString_Size( input_data_string_object ); #endif if( ( input_data_size < 0 ) || ( input_data_size > (Py_ssize_t) SSIZE_MAX ) ) { PyErr_Format( PyExc_ValueError, "%s: invalid argument input data size value out of bounds.", function ); return( NULL ); } #if PY_MAJOR_VERSION >= 3 output_data_string_object = PyBytes_FromStringAndSize( NULL, input_data_size ); output_data = PyBytes_AsString( output_data_string_object ); #else output_data_string_object = PyString_FromStringAndSize( NULL, input_data_size ); output_data = PyString_AsString( output_data_string_object ); #endif Py_BEGIN_ALLOW_THREADS result = libcaes_crypt_xts( pycaes_context->tweaked_context, mode, (uint8_t *) tweak_value_data, (size_t) tweak_value_data_size, (uint8_t *) input_data, (size_t) input_data_size, (uint8_t *) output_data, (size_t) input_data_size, &error ); Py_END_ALLOW_THREADS if( result != 1 ) { pycaes_error_raise( error, PyExc_IOError, "%s: unable to crypt data.", function ); libcerror_error_free( &error ); Py_DecRef( (PyObject *) output_data_string_object ); return( NULL ); } return( output_data_string_object ); } libcaes-20240413/pycaes/Makefile.in0000644000175000017500000010142714606477627017574 0ustar00lordyestalordyesta# Makefile.in generated by automake 1.16.5 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2021 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = pycaes ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/common.m4 \ $(top_srcdir)/m4/gettext.m4 $(top_srcdir)/m4/host-cpu-c-abi.m4 \ $(top_srcdir)/m4/iconv.m4 $(top_srcdir)/m4/intlmacosx.m4 \ $(top_srcdir)/m4/lib-ld.m4 $(top_srcdir)/m4/lib-link.m4 \ $(top_srcdir)/m4/lib-prefix.m4 $(top_srcdir)/m4/libcerror.m4 \ $(top_srcdir)/m4/libcrypto.m4 $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/nls.m4 $(top_srcdir)/m4/po.m4 \ $(top_srcdir)/m4/progtest.m4 $(top_srcdir)/m4/python.m4 \ $(top_srcdir)/m4/tests.m4 $(top_srcdir)/m4/types.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/common/config.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(pyexecdir)" LTLIBRARIES = $(pyexec_LTLIBRARIES) @HAVE_PYTHON_TRUE@pycaes_la_DEPENDENCIES = ../libcaes/libcaes.la am__pycaes_la_SOURCES_DIST = pycaes.c pycaes.h pycaes_context.c \ pycaes_context.h pycaes_crypt.c pycaes_crypt.h \ pycaes_crypt_modes.c pycaes_crypt_modes.h pycaes_error.c \ pycaes_error.h pycaes_libcaes.h pycaes_libcerror.h \ pycaes_python.h pycaes_tweaked_context.c \ pycaes_tweaked_context.h pycaes_unused.h @HAVE_PYTHON_TRUE@am_pycaes_la_OBJECTS = pycaes_la-pycaes.lo \ @HAVE_PYTHON_TRUE@ pycaes_la-pycaes_context.lo \ @HAVE_PYTHON_TRUE@ pycaes_la-pycaes_crypt.lo \ @HAVE_PYTHON_TRUE@ pycaes_la-pycaes_crypt_modes.lo \ @HAVE_PYTHON_TRUE@ pycaes_la-pycaes_error.lo \ @HAVE_PYTHON_TRUE@ pycaes_la-pycaes_tweaked_context.lo pycaes_la_OBJECTS = $(am_pycaes_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = pycaes_la_LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(pycaes_la_LDFLAGS) $(LDFLAGS) -o $@ @HAVE_PYTHON_TRUE@am_pycaes_la_rpath = -rpath $(pyexecdir) AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)/common depcomp = $(SHELL) $(top_srcdir)/depcomp am__maybe_remake_depfiles = depfiles am__depfiles_remade = ./$(DEPDIR)/pycaes_la-pycaes.Plo \ ./$(DEPDIR)/pycaes_la-pycaes_context.Plo \ ./$(DEPDIR)/pycaes_la-pycaes_crypt.Plo \ ./$(DEPDIR)/pycaes_la-pycaes_crypt_modes.Plo \ ./$(DEPDIR)/pycaes_la-pycaes_error.Plo \ ./$(DEPDIR)/pycaes_la-pycaes_tweaked_context.Plo am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(pycaes_la_SOURCES) DIST_SOURCES = $(am__pycaes_la_SOURCES_DIST) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__extra_recursive_targets = sources-recursive splint-recursive am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CSCOPE = @CSCOPE@ CTAGS = @CTAGS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DPKG_DATE = @DPKG_DATE@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ ETAGS = @ETAGS@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ FILECMD = @FILECMD@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GREP = @GREP@ HAVE_DLLMAIN = @HAVE_DLLMAIN@ HAVE_INTTYPES_H = @HAVE_INTTYPES_H@ HAVE_LIBCERROR = @HAVE_LIBCERROR@ HAVE_LOCAL_LIBCERROR = @HAVE_LOCAL_LIBCERROR@ HAVE_OFF64_T = @HAVE_OFF64_T@ HAVE_OPENSSL_EVP_H = @HAVE_OPENSSL_EVP_H@ HAVE_SIZE32_T = @HAVE_SIZE32_T@ HAVE_SIZE64_T = @HAVE_SIZE64_T@ HAVE_SSIZE32_T = @HAVE_SSIZE32_T@ HAVE_SSIZE64_T = @HAVE_SSIZE64_T@ HAVE_STDINT_H = @HAVE_STDINT_H@ HAVE_SYS_TYPES_H = @HAVE_SYS_TYPES_H@ HAVE_WCHAR_H = @HAVE_WCHAR_H@ HAVE_WIDE_CHARACTER_TYPE = @HAVE_WIDE_CHARACTER_TYPE@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBCAES_DLL_EXPORT = @LIBCAES_DLL_EXPORT@ LIBCAES_DLL_IMPORT = @LIBCAES_DLL_IMPORT@ LIBCERROR_CPPFLAGS = @LIBCERROR_CPPFLAGS@ LIBCERROR_LIBADD = @LIBCERROR_LIBADD@ LIBCRYPTO_CPPFLAGS = @LIBCRYPTO_CPPFLAGS@ LIBCRYPTO_LIBADD = @LIBCRYPTO_LIBADD@ LIBDL_LIBADD = @LIBDL_LIBADD@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIB_FUZZING_ENGINE = @LIB_FUZZING_ENGINE@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGMERGE = @MSGMERGE@ MSGMERGE_FOR_MSGFMT_OPTION = @MSGMERGE_FOR_MSGFMT_OPTION@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ PKGCONFIG = @PKGCONFIG@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ PYTHON = @PYTHON@ PYTHON_CONFIG = @PYTHON_CONFIG@ PYTHON_CPPFLAGS = @PYTHON_CPPFLAGS@ PYTHON_EXEC_PREFIX = @PYTHON_EXEC_PREFIX@ PYTHON_LDFLAGS = @PYTHON_LDFLAGS@ PYTHON_LIBRARY_DIR = @PYTHON_LIBRARY_DIR@ PYTHON_PACKAGE_DIR = @PYTHON_PACKAGE_DIR@ PYTHON_PLATFORM = @PYTHON_PLATFORM@ PYTHON_PREFIX = @PYTHON_PREFIX@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ SPEC_DATE = @SPEC_DATE@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ ax_libcerror_pc_libs_private = @ax_libcerror_pc_libs_private@ ax_libcerror_spec_build_requires = @ax_libcerror_spec_build_requires@ ax_libcerror_spec_requires = @ax_libcerror_spec_requires@ ax_libcrypto_pc_libs_private = @ax_libcrypto_pc_libs_private@ ax_libcrypto_spec_build_requires = @ax_libcrypto_spec_build_requires@ ax_libcrypto_spec_requires = @ax_libcrypto_spec_requires@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libcaes_spec_requires = @libcaes_spec_requires@ libcerror_CFLAGS = @libcerror_CFLAGS@ libcerror_LIBS = @libcerror_LIBS@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ openssl_CFLAGS = @openssl_CFLAGS@ openssl_LIBS = @openssl_LIBS@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ pyexecdir = @pyexecdir@ pythondir = @pythondir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ @HAVE_PYTHON_TRUE@AM_CFLAGS = \ @HAVE_PYTHON_TRUE@ -I../include -I$(top_srcdir)/include \ @HAVE_PYTHON_TRUE@ -I../common -I$(top_srcdir)/common \ @HAVE_PYTHON_TRUE@ @LIBCERROR_CPPFLAGS@ \ @HAVE_PYTHON_TRUE@ @LIBCAES_DLL_IMPORT@ @HAVE_PYTHON_TRUE@pyexec_LTLIBRARIES = pycaes.la @HAVE_PYTHON_TRUE@pycaes_la_SOURCES = \ @HAVE_PYTHON_TRUE@ pycaes.c pycaes.h \ @HAVE_PYTHON_TRUE@ pycaes_context.c pycaes_context.h \ @HAVE_PYTHON_TRUE@ pycaes_crypt.c pycaes_crypt.h \ @HAVE_PYTHON_TRUE@ pycaes_crypt_modes.c pycaes_crypt_modes.h \ @HAVE_PYTHON_TRUE@ pycaes_error.c pycaes_error.h \ @HAVE_PYTHON_TRUE@ pycaes_libcaes.h \ @HAVE_PYTHON_TRUE@ pycaes_libcerror.h \ @HAVE_PYTHON_TRUE@ pycaes_python.h \ @HAVE_PYTHON_TRUE@ pycaes_tweaked_context.c pycaes_tweaked_context.h \ @HAVE_PYTHON_TRUE@ pycaes_unused.h @HAVE_PYTHON_TRUE@pycaes_la_LIBADD = \ @HAVE_PYTHON_TRUE@ @LIBCERROR_LIBADD@ \ @HAVE_PYTHON_TRUE@ ../libcaes/libcaes.la @HAVE_PYTHON_TRUE@pycaes_la_CPPFLAGS = $(PYTHON_CPPFLAGS) @HAVE_PYTHON_TRUE@pycaes_la_LDFLAGS = -module -avoid-version $(PYTHON_LDFLAGS) DISTCLEANFILES = \ Makefile \ Makefile.in all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu pycaes/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu pycaes/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-pyexecLTLIBRARIES: $(pyexec_LTLIBRARIES) @$(NORMAL_INSTALL) @list='$(pyexec_LTLIBRARIES)'; test -n "$(pyexecdir)" || list=; \ list2=; for p in $$list; do \ if test -f $$p; then \ list2="$$list2 $$p"; \ else :; fi; \ done; \ test -z "$$list2" || { \ echo " $(MKDIR_P) '$(DESTDIR)$(pyexecdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(pyexecdir)" || exit 1; \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 '$(DESTDIR)$(pyexecdir)'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL) $(INSTALL_STRIP_FLAG) $$list2 "$(DESTDIR)$(pyexecdir)"; \ } uninstall-pyexecLTLIBRARIES: @$(NORMAL_UNINSTALL) @list='$(pyexec_LTLIBRARIES)'; test -n "$(pyexecdir)" || list=; \ for p in $$list; do \ $(am__strip_dir) \ echo " $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f '$(DESTDIR)$(pyexecdir)/$$f'"; \ $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=uninstall rm -f "$(DESTDIR)$(pyexecdir)/$$f"; \ done clean-pyexecLTLIBRARIES: -test -z "$(pyexec_LTLIBRARIES)" || rm -f $(pyexec_LTLIBRARIES) @list='$(pyexec_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } pycaes.la: $(pycaes_la_OBJECTS) $(pycaes_la_DEPENDENCIES) $(EXTRA_pycaes_la_DEPENDENCIES) $(AM_V_CCLD)$(pycaes_la_LINK) $(am_pycaes_la_rpath) $(pycaes_la_OBJECTS) $(pycaes_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pycaes_la-pycaes.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pycaes_la-pycaes_context.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pycaes_la-pycaes_crypt.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pycaes_la-pycaes_crypt_modes.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pycaes_la-pycaes_error.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/pycaes_la-pycaes_tweaked_context.Plo@am__quote@ # am--include-marker $(am__depfiles_remade): @$(MKDIR_P) $(@D) @echo '# dummy' >$@-t && $(am__mv) $@-t $@ am--depfiles: $(am__depfiles_remade) .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< pycaes_la-pycaes.lo: pycaes.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(pycaes_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT pycaes_la-pycaes.lo -MD -MP -MF $(DEPDIR)/pycaes_la-pycaes.Tpo -c -o pycaes_la-pycaes.lo `test -f 'pycaes.c' || echo '$(srcdir)/'`pycaes.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/pycaes_la-pycaes.Tpo $(DEPDIR)/pycaes_la-pycaes.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='pycaes.c' object='pycaes_la-pycaes.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(pycaes_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o pycaes_la-pycaes.lo `test -f 'pycaes.c' || echo '$(srcdir)/'`pycaes.c pycaes_la-pycaes_context.lo: pycaes_context.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(pycaes_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT pycaes_la-pycaes_context.lo -MD -MP -MF $(DEPDIR)/pycaes_la-pycaes_context.Tpo -c -o pycaes_la-pycaes_context.lo `test -f 'pycaes_context.c' || echo '$(srcdir)/'`pycaes_context.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/pycaes_la-pycaes_context.Tpo $(DEPDIR)/pycaes_la-pycaes_context.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='pycaes_context.c' object='pycaes_la-pycaes_context.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(pycaes_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o pycaes_la-pycaes_context.lo `test -f 'pycaes_context.c' || echo '$(srcdir)/'`pycaes_context.c pycaes_la-pycaes_crypt.lo: pycaes_crypt.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(pycaes_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT pycaes_la-pycaes_crypt.lo -MD -MP -MF $(DEPDIR)/pycaes_la-pycaes_crypt.Tpo -c -o pycaes_la-pycaes_crypt.lo `test -f 'pycaes_crypt.c' || echo '$(srcdir)/'`pycaes_crypt.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/pycaes_la-pycaes_crypt.Tpo $(DEPDIR)/pycaes_la-pycaes_crypt.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='pycaes_crypt.c' object='pycaes_la-pycaes_crypt.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(pycaes_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o pycaes_la-pycaes_crypt.lo `test -f 'pycaes_crypt.c' || echo '$(srcdir)/'`pycaes_crypt.c pycaes_la-pycaes_crypt_modes.lo: pycaes_crypt_modes.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(pycaes_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT pycaes_la-pycaes_crypt_modes.lo -MD -MP -MF $(DEPDIR)/pycaes_la-pycaes_crypt_modes.Tpo -c -o pycaes_la-pycaes_crypt_modes.lo `test -f 'pycaes_crypt_modes.c' || echo '$(srcdir)/'`pycaes_crypt_modes.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/pycaes_la-pycaes_crypt_modes.Tpo $(DEPDIR)/pycaes_la-pycaes_crypt_modes.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='pycaes_crypt_modes.c' object='pycaes_la-pycaes_crypt_modes.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(pycaes_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o pycaes_la-pycaes_crypt_modes.lo `test -f 'pycaes_crypt_modes.c' || echo '$(srcdir)/'`pycaes_crypt_modes.c pycaes_la-pycaes_error.lo: pycaes_error.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(pycaes_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT pycaes_la-pycaes_error.lo -MD -MP -MF $(DEPDIR)/pycaes_la-pycaes_error.Tpo -c -o pycaes_la-pycaes_error.lo `test -f 'pycaes_error.c' || echo '$(srcdir)/'`pycaes_error.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/pycaes_la-pycaes_error.Tpo $(DEPDIR)/pycaes_la-pycaes_error.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='pycaes_error.c' object='pycaes_la-pycaes_error.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(pycaes_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o pycaes_la-pycaes_error.lo `test -f 'pycaes_error.c' || echo '$(srcdir)/'`pycaes_error.c pycaes_la-pycaes_tweaked_context.lo: pycaes_tweaked_context.c @am__fastdepCC_TRUE@ $(AM_V_CC)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(pycaes_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -MT pycaes_la-pycaes_tweaked_context.lo -MD -MP -MF $(DEPDIR)/pycaes_la-pycaes_tweaked_context.Tpo -c -o pycaes_la-pycaes_tweaked_context.lo `test -f 'pycaes_tweaked_context.c' || echo '$(srcdir)/'`pycaes_tweaked_context.c @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/pycaes_la-pycaes_tweaked_context.Tpo $(DEPDIR)/pycaes_la-pycaes_tweaked_context.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='pycaes_tweaked_context.c' object='pycaes_la-pycaes_tweaked_context.lo' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(pycaes_la_CPPFLAGS) $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) -c -o pycaes_la-pycaes_tweaked_context.lo `test -f 'pycaes_tweaked_context.c' || echo '$(srcdir)/'`pycaes_tweaked_context.c mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs sources-local: splint-local: ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: for dir in "$(DESTDIR)$(pyexecdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) -test -z "$(DISTCLEANFILES)" || rm -f $(DISTCLEANFILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-pyexecLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -f ./$(DEPDIR)/pycaes_la-pycaes.Plo -rm -f ./$(DEPDIR)/pycaes_la-pycaes_context.Plo -rm -f ./$(DEPDIR)/pycaes_la-pycaes_crypt.Plo -rm -f ./$(DEPDIR)/pycaes_la-pycaes_crypt_modes.Plo -rm -f ./$(DEPDIR)/pycaes_la-pycaes_error.Plo -rm -f ./$(DEPDIR)/pycaes_la-pycaes_tweaked_context.Plo -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-pyexecLTLIBRARIES install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f ./$(DEPDIR)/pycaes_la-pycaes.Plo -rm -f ./$(DEPDIR)/pycaes_la-pycaes_context.Plo -rm -f ./$(DEPDIR)/pycaes_la-pycaes_crypt.Plo -rm -f ./$(DEPDIR)/pycaes_la-pycaes_crypt_modes.Plo -rm -f ./$(DEPDIR)/pycaes_la-pycaes_error.Plo -rm -f ./$(DEPDIR)/pycaes_la-pycaes_tweaked_context.Plo -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: sources: sources-am sources-am: sources-local splint: splint-am splint-am: splint-local uninstall-am: uninstall-pyexecLTLIBRARIES .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am am--depfiles check check-am clean \ clean-generic clean-libtool clean-pyexecLTLIBRARIES \ cscopelist-am ctags ctags-am distclean distclean-compile \ distclean-generic distclean-libtool distclean-tags distdir dvi \ dvi-am html html-am info info-am install install-am \ install-data install-data-am install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-info install-info-am install-man install-pdf \ install-pdf-am install-ps install-ps-am \ install-pyexecLTLIBRARIES install-strip installcheck \ installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ sources-am sources-local splint-am splint-local tags tags-am \ uninstall uninstall-am uninstall-pyexecLTLIBRARIES .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: libcaes-20240413/pycaes/pycaes_tweaked_context.h0000644000175000017500000000357414606473502022424 0ustar00lordyestalordyesta/* * Python object wrapper of libcaes_tweaked_context_t * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _PYCAES_TWEAKED_CONTEXT_H ) #define _PYCAES_TWEAKED_CONTEXT_H #include #include #include "pycaes_libcaes.h" #include "pycaes_python.h" #if defined( __cplusplus ) extern "C" { #endif typedef struct pycaes_tweaked_context pycaes_tweaked_context_t; struct pycaes_tweaked_context { /* Python object initialization */ PyObject_HEAD /* The libcaes tweaked context */ libcaes_tweaked_context_t *tweaked_context; }; extern PyMethodDef pycaes_tweaked_context_object_methods[]; extern PyTypeObject pycaes_tweaked_context_type_object; PyObject *pycaes_tweaked_context_new( void ); int pycaes_tweaked_context_init( pycaes_tweaked_context_t *pycaes_tweaked_context ); void pycaes_tweaked_context_free( pycaes_tweaked_context_t *pycaes_tweaked_context ); PyObject *pycaes_tweaked_context_set_keys( pycaes_tweaked_context_t *pycaes_tweaked_context, PyObject *arguments, PyObject *keywords ); #if defined( __cplusplus ) } #endif #endif /* !defined( _PYCAES_TWEAKED_CONTEXT_H ) */ libcaes-20240413/test-driver0000755000175000017500000001141714606477627016440 0ustar00lordyestalordyesta#! /bin/sh # test-driver - basic testsuite driver script. scriptversion=2018-03-07.03; # UTC # Copyright (C) 2011-2021 Free Software Foundation, Inc. # # This program 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, or (at your option) # any later version. # # This program 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 this program. If not, see . # As a special exception to the GNU General Public License, if you # distribute this file as part of a program that contains a # configuration script generated by Autoconf, you may include it under # the same distribution terms that you use for the rest of that program. # This file is maintained in Automake, please report # bugs to or send patches to # . # Make unconditional expansion of undefined variables an error. This # helps a lot in preventing typo-related bugs. set -u usage_error () { echo "$0: $*" >&2 print_usage >&2 exit 2 } print_usage () { cat <"$log_file" "$@" >>"$log_file" 2>&1 estatus=$? if test $enable_hard_errors = no && test $estatus -eq 99; then tweaked_estatus=1 else tweaked_estatus=$estatus fi case $tweaked_estatus:$expect_failure in 0:yes) col=$red res=XPASS recheck=yes gcopy=yes;; 0:*) col=$grn res=PASS recheck=no gcopy=no;; 77:*) col=$blu res=SKIP recheck=no gcopy=yes;; 99:*) col=$mgn res=ERROR recheck=yes gcopy=yes;; *:yes) col=$lgn res=XFAIL recheck=no gcopy=yes;; *:*) col=$red res=FAIL recheck=yes gcopy=yes;; esac # Report the test outcome and exit status in the logs, so that one can # know whether the test passed or failed simply by looking at the '.log' # file, without the need of also peaking into the corresponding '.trs' # file (automake bug#11814). echo "$res $test_name (exit status: $estatus)" >>"$log_file" # Report outcome to console. echo "${col}${res}${std}: $test_name" # Register the test result, and other relevant metadata. echo ":test-result: $res" > $trs_file echo ":global-test-result: $res" >> $trs_file echo ":recheck: $recheck" >> $trs_file echo ":copy-in-global-log: $gcopy" >> $trs_file # Local Variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-start: "scriptversion=" # time-stamp-format: "%:y-%02m-%02d.%02H" # time-stamp-time-zone: "UTC0" # time-stamp-end: "; # UTC" # End: libcaes-20240413/ChangeLog0000644000175000017500000000131714533041420015763 0ustar00lordyestalordyestaTODO * look into supporting input buffer == output buffer for optimization * CCM add separate function for authentication data support * add OFB suport ? * add restriction that context should be used in the mode the keys were set ? does not work for CCM complete CFB suport * implement libcaes_crypt_cfb * add API function * add fuzz target Tests: * move crypt tests into context * integrate test runner into tests * add pycaes ECB and XTS encryption tests * add tests - CFB - OFB ? - XTS (add more test vectors?) 256-bit - make sure to test non-16 byte aligned data for the different implementations 20130331 * see `git log' for more recent change log * Initial stand-alone version based on earlier work libcaes-20240413/manuals/0000755000175000017500000000000014606477654015676 5ustar00lordyestalordyestalibcaes-20240413/manuals/libcaes.30000644000175000017500000000614414606473413017356 0ustar00lordyestalordyesta.Dd March 18, 2019 .Dt libcaes 3 .Os libcaes .Sh NAME .Nm libcaes.h .Nd Library to support cross-platform AES encryption .Sh SYNOPSIS .In libcaes.h .Pp Support functions .Ft const char * .Fn libcaes_get_version "void" .Pp Error functions .Ft void .Fn libcaes_error_free "libcaes_error_t **error" .Ft int .Fn libcaes_error_fprint "libcaes_error_t *error" "FILE *stream" .Ft int .Fn libcaes_error_sprint "libcaes_error_t *error" "char *string" "size_t size" .Ft int .Fn libcaes_error_backtrace_fprint "libcaes_error_t *error" "FILE *stream" .Ft int .Fn libcaes_error_backtrace_sprint "libcaes_error_t *error" "char *string" "size_t size" .Pp Context functions .Ft int .Fn libcaes_context_initialize "libcaes_context_t **context" "libcaes_error_t **error" .Ft int .Fn libcaes_context_free "libcaes_context_t **context" "libcaes_error_t **error" .Ft int .Fn libcaes_context_set_key "libcaes_context_t *context" "int mode" "const uint8_t *key" "size_t key_bit_size" "libcaes_error_t **error" .Ft int .Fn libcaes_crypt_cbc "libcaes_context_t *context" "int mode" "const uint8_t *initialization_vector" "size_t initialization_vector_size" "const uint8_t *input_data" "size_t input_data_size" "uint8_t *output_data" "size_t output_data_size" "libcaes_error_t **error" .Ft int .Fn libcaes_crypt_ccm "libcaes_context_t *context" "int mode" "const uint8_t *nonce" "size_t nonce_size" "const uint8_t *input_data" "size_t input_data_size" "uint8_t *output_data" "size_t output_data_size" "libcaes_error_t **error" .Ft int .Fn libcaes_crypt_ecb "libcaes_context_t *context" "int mode" "const uint8_t *input_data" "size_t input_data_size" "uint8_t *output_data" "size_t output_data_size" "libcaes_error_t **error" .Pp Tweaked context functions .Ft int .Fn libcaes_tweaked_context_initialize "libcaes_tweaked_context_t **tweaked_context" "libcaes_error_t **error" .Ft int .Fn libcaes_tweaked_context_free "libcaes_tweaked_context_t **tweaked_context" "libcaes_error_t **error" .Ft int .Fn libcaes_tweaked_context_set_keys "libcaes_tweaked_context_t *tweaked_context" "int mode" "const uint8_t *key" "size_t key_bit_size" "const uint8_t *tweak_key" "size_t tweak_key_bit_size" "libcaes_error_t **error" .Ft int .Fn libcaes_crypt_xts "libcaes_tweaked_context_t *tweaked_context" "int mode" "const uint8_t *tweak_value" "size_t tweak_value_size" "const uint8_t *input_data" "size_t input_data_size" "uint8_t *output_data" "size_t output_data_size" "libcaes_error_t **error" .Sh DESCRIPTION The .Fn libcaes_get_version function is used to retrieve the library version. .Sh RETURN VALUES Most of the functions return NULL or \-1 on error, dependent on the return type. For the actual return values see "libcaes.h". .Sh ENVIRONMENT None .Sh FILES None .Sh BUGS Please report bugs of any kind on the project issue tracker: https://github.com/libyal/libcaes/issues .Sh AUTHOR These man pages are generated from "libcaes.h". .Sh COPYRIGHT Copyright (C) 2011-2024, Joachim Metz . .sp This is free software; see the source for copying conditions. There is NO warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. .Sh SEE ALSO the libcaes.h include file libcaes-20240413/manuals/Makefile.am0000644000175000017500000000014114606474523017716 0ustar00lordyestalordyestaman_MANS = \ libcaes.3 EXTRA_DIST = \ libcaes.3 DISTCLEANFILES = \ Makefile \ Makefile.in libcaes-20240413/manuals/Makefile.in0000644000175000017500000004427514606477627017757 0ustar00lordyestalordyesta# Makefile.in generated by automake 1.16.5 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2021 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = manuals ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/common.m4 \ $(top_srcdir)/m4/gettext.m4 $(top_srcdir)/m4/host-cpu-c-abi.m4 \ $(top_srcdir)/m4/iconv.m4 $(top_srcdir)/m4/intlmacosx.m4 \ $(top_srcdir)/m4/lib-ld.m4 $(top_srcdir)/m4/lib-link.m4 \ $(top_srcdir)/m4/lib-prefix.m4 $(top_srcdir)/m4/libcerror.m4 \ $(top_srcdir)/m4/libcrypto.m4 $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/nls.m4 $(top_srcdir)/m4/po.m4 \ $(top_srcdir)/m4/progtest.m4 $(top_srcdir)/m4/python.m4 \ $(top_srcdir)/m4/tests.m4 $(top_srcdir)/m4/types.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/common/config.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } man3dir = $(mandir)/man3 am__installdirs = "$(DESTDIR)$(man3dir)" NROFF = nroff MANS = $(man_MANS) am__extra_recursive_targets = sources-recursive splint-recursive am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) am__DIST_COMMON = $(srcdir)/Makefile.in DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CSCOPE = @CSCOPE@ CTAGS = @CTAGS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DPKG_DATE = @DPKG_DATE@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ ETAGS = @ETAGS@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ FILECMD = @FILECMD@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GREP = @GREP@ HAVE_DLLMAIN = @HAVE_DLLMAIN@ HAVE_INTTYPES_H = @HAVE_INTTYPES_H@ HAVE_LIBCERROR = @HAVE_LIBCERROR@ HAVE_LOCAL_LIBCERROR = @HAVE_LOCAL_LIBCERROR@ HAVE_OFF64_T = @HAVE_OFF64_T@ HAVE_OPENSSL_EVP_H = @HAVE_OPENSSL_EVP_H@ HAVE_SIZE32_T = @HAVE_SIZE32_T@ HAVE_SIZE64_T = @HAVE_SIZE64_T@ HAVE_SSIZE32_T = @HAVE_SSIZE32_T@ HAVE_SSIZE64_T = @HAVE_SSIZE64_T@ HAVE_STDINT_H = @HAVE_STDINT_H@ HAVE_SYS_TYPES_H = @HAVE_SYS_TYPES_H@ HAVE_WCHAR_H = @HAVE_WCHAR_H@ HAVE_WIDE_CHARACTER_TYPE = @HAVE_WIDE_CHARACTER_TYPE@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBCAES_DLL_EXPORT = @LIBCAES_DLL_EXPORT@ LIBCAES_DLL_IMPORT = @LIBCAES_DLL_IMPORT@ LIBCERROR_CPPFLAGS = @LIBCERROR_CPPFLAGS@ LIBCERROR_LIBADD = @LIBCERROR_LIBADD@ LIBCRYPTO_CPPFLAGS = @LIBCRYPTO_CPPFLAGS@ LIBCRYPTO_LIBADD = @LIBCRYPTO_LIBADD@ LIBDL_LIBADD = @LIBDL_LIBADD@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIB_FUZZING_ENGINE = @LIB_FUZZING_ENGINE@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGMERGE = @MSGMERGE@ MSGMERGE_FOR_MSGFMT_OPTION = @MSGMERGE_FOR_MSGFMT_OPTION@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ PKGCONFIG = @PKGCONFIG@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ PYTHON = @PYTHON@ PYTHON_CONFIG = @PYTHON_CONFIG@ PYTHON_CPPFLAGS = @PYTHON_CPPFLAGS@ PYTHON_EXEC_PREFIX = @PYTHON_EXEC_PREFIX@ PYTHON_LDFLAGS = @PYTHON_LDFLAGS@ PYTHON_LIBRARY_DIR = @PYTHON_LIBRARY_DIR@ PYTHON_PACKAGE_DIR = @PYTHON_PACKAGE_DIR@ PYTHON_PLATFORM = @PYTHON_PLATFORM@ PYTHON_PREFIX = @PYTHON_PREFIX@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ SPEC_DATE = @SPEC_DATE@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ ax_libcerror_pc_libs_private = @ax_libcerror_pc_libs_private@ ax_libcerror_spec_build_requires = @ax_libcerror_spec_build_requires@ ax_libcerror_spec_requires = @ax_libcerror_spec_requires@ ax_libcrypto_pc_libs_private = @ax_libcrypto_pc_libs_private@ ax_libcrypto_spec_build_requires = @ax_libcrypto_spec_build_requires@ ax_libcrypto_spec_requires = @ax_libcrypto_spec_requires@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libcaes_spec_requires = @libcaes_spec_requires@ libcerror_CFLAGS = @libcerror_CFLAGS@ libcerror_LIBS = @libcerror_LIBS@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ openssl_CFLAGS = @openssl_CFLAGS@ openssl_LIBS = @openssl_LIBS@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ pyexecdir = @pyexecdir@ pythondir = @pythondir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ man_MANS = \ libcaes.3 EXTRA_DIST = \ libcaes.3 DISTCLEANFILES = \ Makefile \ Makefile.in all: all-am .SUFFIXES: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu manuals/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu manuals/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs install-man3: $(man_MANS) @$(NORMAL_INSTALL) @list1=''; \ list2='$(man_MANS)'; \ test -n "$(man3dir)" \ && test -n "`echo $$list1$$list2`" \ || exit 0; \ echo " $(MKDIR_P) '$(DESTDIR)$(man3dir)'"; \ $(MKDIR_P) "$(DESTDIR)$(man3dir)" || exit 1; \ { for i in $$list1; do echo "$$i"; done; \ if test -n "$$list2"; then \ for i in $$list2; do echo "$$i"; done \ | sed -n '/\.3[a-z]*$$/p'; \ fi; \ } | while read p; do \ if test -f $$p; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; echo "$$p"; \ done | \ sed -e 'n;s,.*/,,;p;h;s,.*\.,,;s,^[^3][0-9a-z]*$$,3,;x' \ -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,' | \ sed 'N;N;s,\n, ,g' | { \ list=; while read file base inst; do \ if test "$$base" = "$$inst"; then list="$$list $$file"; else \ echo " $(INSTALL_DATA) '$$file' '$(DESTDIR)$(man3dir)/$$inst'"; \ $(INSTALL_DATA) "$$file" "$(DESTDIR)$(man3dir)/$$inst" || exit $$?; \ fi; \ done; \ for i in $$list; do echo "$$i"; done | $(am__base_list) | \ while read files; do \ test -z "$$files" || { \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(man3dir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(man3dir)" || exit $$?; }; \ done; } uninstall-man3: @$(NORMAL_UNINSTALL) @list=''; test -n "$(man3dir)" || exit 0; \ files=`{ for i in $$list; do echo "$$i"; done; \ l2='$(man_MANS)'; for i in $$l2; do echo "$$i"; done | \ sed -n '/\.3[a-z]*$$/p'; \ } | sed -e 's,.*/,,;h;s,.*\.,,;s,^[^3][0-9a-z]*$$,3,;x' \ -e 's,\.[0-9a-z]*$$,,;$(transform);G;s,\n,.,'`; \ dir='$(DESTDIR)$(man3dir)'; $(am__uninstall_files_from_dir) sources-local: splint-local: tags TAGS: ctags CTAGS: cscope cscopelist: distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(MANS) installdirs: for dir in "$(DESTDIR)$(man3dir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) -test -z "$(DISTCLEANFILES)" || rm -f $(DISTCLEANFILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f Makefile distclean-am: clean-am distclean-generic dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-man install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-man3 install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: sources: sources-am sources-am: sources-local splint: splint-am splint-am: splint-local uninstall-am: uninstall-man uninstall-man: uninstall-man3 .MAKE: install-am install-strip .PHONY: all all-am check check-am clean clean-generic clean-libtool \ cscopelist-am ctags-am distclean distclean-generic \ distclean-libtool distdir dvi dvi-am html html-am info info-am \ install install-am install-data install-data-am install-dvi \ install-dvi-am install-exec install-exec-am install-html \ install-html-am install-info install-info-am install-man \ install-man3 install-pdf install-pdf-am install-ps \ install-ps-am install-strip installcheck installcheck-am \ installdirs maintainer-clean maintainer-clean-generic \ mostlyclean mostlyclean-generic mostlyclean-libtool pdf pdf-am \ ps ps-am sources-am sources-local splint-am splint-local \ tags-am uninstall uninstall-am uninstall-man uninstall-man3 .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: libcaes-20240413/tests/0000755000175000017500000000000014606477654015400 5ustar00lordyestalordyestalibcaes-20240413/tests/caes_test_context.c0000644000175000017500000450723014606473557021273 0ustar00lordyestalordyesta/* * Library context type test program * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include #include #if defined( HAVE_STDLIB_H ) || defined( WINAPI ) #include #endif #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) /* No additional includes necessary */ #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) #include #endif #if defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) #define __USE_GNU #include #undef __USE_GNU #endif #include "caes_test_libcaes.h" #include "caes_test_libcerror.h" #include "caes_test_macros.h" #include "caes_test_memory.h" #include "caes_test_unused.h" /* Make sure libcaes_definitions.h is included first to define LIBCAES_HAVE_AES_SUPPORT */ #include "../libcaes/libcaes_definitions.h" #include "../libcaes/libcaes_context.h" #if defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_EBC_ENCRYPT ) ) static int (*caes_test_real_AES_set_encrypt_key)(const unsigned char *, const int, AES_KEY *) = NULL; static int (*caes_test_real_AES_set_decrypt_key)(const unsigned char *, const int, AES_KEY *) = NULL; int caes_test_AES_set_encrypt_key_attempts_before_fail = -1; int caes_test_AES_set_decrypt_key_attempts_before_fail = -1; #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && ( defined( HAVE_EVP_CRYPTO_AES_CBC ) || defined( HAVE_EVP_CRYPTO_AES_ECB ) ) static int (*caes_test_real_EVP_CIPHER_CTX_set_padding)(EVP_CIPHER_CTX *, int) = NULL; static int (*caes_test_real_EVP_CipherInit_ex)(EVP_CIPHER_CTX *, const EVP_CIPHER *, ENGINE *, const unsigned char *, const unsigned char *, int) = NULL; static int (*caes_test_real_EVP_CipherUpdate)(EVP_CIPHER_CTX *, unsigned char *, int *, const unsigned char *, int) = NULL; int caes_test_EVP_CIPHER_CTX_set_padding_attempts_before_fail = -1; int caes_test_EVP_CipherInit_ex_attempts_before_fail = -1; int caes_test_EVP_CipherUpdate_attempts_before_fail = -1; #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_EBC_ENCRYPT ) ) */ #endif /* defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) */ typedef struct caes_test_context_test_vector caes_test_context_test_vector_t; struct caes_test_context_test_vector { /* The description */ const char *description; /* The mode */ int mode; /* The key */ uint8_t key[ 64 ]; /* The key bit size */ size_t key_bit_size; /* The initialization vector */ uint8_t initialization_vector[ 16 ]; /* The initialization vector size */ size_t initialization_vector_size; /* The input data */ uint8_t input_data[ 16 ]; /* The input data size */ size_t input_data_size; /* The expected output data */ uint8_t output_data[ 16 ]; /* The expected output data size */ size_t output_data_size; }; caes_test_context_test_vector_t caes_context_aes_cbc_test_vectors[ 24 ] = { { "NIST SP800-38A test vector AES-CBC 128-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }, 16, { 0x6b, 0xc1, 0xbe, 0xe2, 0x2e, 0x40, 0x9f, 0x96, 0xe9, 0x3d, 0x7e, 0x11, 0x73, 0x93, 0x17, 0x2a }, 16, { 0x76, 0x49, 0xab, 0xac, 0x81, 0x19, 0xb2, 0x46, 0xce, 0xe9, 0x8e, 0x9b, 0x12, 0xe9, 0x19, 0x7d }, 16 }, { "NIST SP800-38A test vector AES-CBC 128-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }, 16, { 0x76, 0x49, 0xab, 0xac, 0x81, 0x19, 0xb2, 0x46, 0xce, 0xe9, 0x8e, 0x9b, 0x12, 0xe9, 0x19, 0x7d }, 16, { 0x6b, 0xc1, 0xbe, 0xe2, 0x2e, 0x40, 0x9f, 0x96, 0xe9, 0x3d, 0x7e, 0x11, 0x73, 0x93, 0x17, 0x2a }, 16 }, { "NIST SP800-38A test vector AES-CBC 128-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x76, 0x49, 0xab, 0xac, 0x81, 0x19, 0xb2, 0x46, 0xce, 0xe9, 0x8e, 0x9b, 0x12, 0xe9, 0x19, 0x7d }, 16, { 0xae, 0x2d, 0x8a, 0x57, 0x1e, 0x03, 0xac, 0x9c, 0x9e, 0xb7, 0x6f, 0xac, 0x45, 0xaf, 0x8e, 0x51 }, 16, { 0x50, 0x86, 0xcb, 0x9b, 0x50, 0x72, 0x19, 0xee, 0x95, 0xdb, 0x11, 0x3a, 0x91, 0x76, 0x78, 0xb2 }, 16 }, { "NIST SP800-38A test vector AES-CBC 128-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x76, 0x49, 0xab, 0xac, 0x81, 0x19, 0xb2, 0x46, 0xce, 0xe9, 0x8e, 0x9b, 0x12, 0xe9, 0x19, 0x7d }, 16, { 0x50, 0x86, 0xcb, 0x9b, 0x50, 0x72, 0x19, 0xee, 0x95, 0xdb, 0x11, 0x3a, 0x91, 0x76, 0x78, 0xb2 }, 16, { 0xae, 0x2d, 0x8a, 0x57, 0x1e, 0x03, 0xac, 0x9c, 0x9e, 0xb7, 0x6f, 0xac, 0x45, 0xaf, 0x8e, 0x51 }, 16 }, { "NIST SP800-38A test vector AES-CBC 128-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x50, 0x86, 0xcb, 0x9b, 0x50, 0x72, 0x19, 0xee, 0x95, 0xdb, 0x11, 0x3a, 0x91, 0x76, 0x78, 0xb2 }, 16, { 0x30, 0xc8, 0x1c, 0x46, 0xa3, 0x5c, 0xe4, 0x11, 0xe5, 0xfb, 0xc1, 0x19, 0x1a, 0x0a, 0x52, 0xef }, 16, { 0x73, 0xbe, 0xd6, 0xb8, 0xe3, 0xc1, 0x74, 0x3b, 0x71, 0x16, 0xe6, 0x9e, 0x22, 0x22, 0x95, 0x16 }, 16 }, { "NIST SP800-38A test vector AES-CBC 128-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x50, 0x86, 0xcb, 0x9b, 0x50, 0x72, 0x19, 0xee, 0x95, 0xdb, 0x11, 0x3a, 0x91, 0x76, 0x78, 0xb2 }, 16, { 0x73, 0xbe, 0xd6, 0xb8, 0xe3, 0xc1, 0x74, 0x3b, 0x71, 0x16, 0xe6, 0x9e, 0x22, 0x22, 0x95, 0x16 }, 16, { 0x30, 0xc8, 0x1c, 0x46, 0xa3, 0x5c, 0xe4, 0x11, 0xe5, 0xfb, 0xc1, 0x19, 0x1a, 0x0a, 0x52, 0xef }, 16 }, { "NIST SP800-38A test vector AES-CBC 128-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x73, 0xbe, 0xd6, 0xb8, 0xe3, 0xc1, 0x74, 0x3b, 0x71, 0x16, 0xe6, 0x9e, 0x22, 0x22, 0x95, 0x16 }, 16, { 0xf6, 0x9f, 0x24, 0x45, 0xdf, 0x4f, 0x9b, 0x17, 0xad, 0x2b, 0x41, 0x7b, 0xe6, 0x6c, 0x37, 0x10 }, 16, { 0x3f, 0xf1, 0xca, 0xa1, 0x68, 0x1f, 0xac, 0x09, 0x12, 0x0e, 0xca, 0x30, 0x75, 0x86, 0xe1, 0xa7 }, 16 }, { "NIST SP800-38A test vector AES-CBC 128-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x73, 0xbe, 0xd6, 0xb8, 0xe3, 0xc1, 0x74, 0x3b, 0x71, 0x16, 0xe6, 0x9e, 0x22, 0x22, 0x95, 0x16 }, 16, { 0x3f, 0xf1, 0xca, 0xa1, 0x68, 0x1f, 0xac, 0x09, 0x12, 0x0e, 0xca, 0x30, 0x75, 0x86, 0xe1, 0xa7 }, 16, { 0xf6, 0x9f, 0x24, 0x45, 0xdf, 0x4f, 0x9b, 0x17, 0xad, 0x2b, 0x41, 0x7b, 0xe6, 0x6c, 0x37, 0x10 }, 16 }, { "NIST SP800-38A test vector AES-CBC 192-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }, 16, { 0x6b, 0xc1, 0xbe, 0xe2, 0x2e, 0x40, 0x9f, 0x96, 0xe9, 0x3d, 0x7e, 0x11, 0x73, 0x93, 0x17, 0x2a }, 16, { 0x4f, 0x02, 0x1d, 0xb2, 0x43, 0xbc, 0x63, 0x3d, 0x71, 0x78, 0x18, 0x3a, 0x9f, 0xa0, 0x71, 0xe8 }, 16 }, { "NIST SP800-38A test vector AES-CBC 192-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }, 16, { 0x4f, 0x02, 0x1d, 0xb2, 0x43, 0xbc, 0x63, 0x3d, 0x71, 0x78, 0x18, 0x3a, 0x9f, 0xa0, 0x71, 0xe8 }, 16, { 0x6b, 0xc1, 0xbe, 0xe2, 0x2e, 0x40, 0x9f, 0x96, 0xe9, 0x3d, 0x7e, 0x11, 0x73, 0x93, 0x17, 0x2a }, 16 }, { "NIST SP800-38A test vector AES-CBC 192-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0x4f, 0x02, 0x1d, 0xb2, 0x43, 0xbc, 0x63, 0x3d, 0x71, 0x78, 0x18, 0x3a, 0x9f, 0xa0, 0x71, 0xe8 }, 16, { 0xae, 0x2d, 0x8a, 0x57, 0x1e, 0x03, 0xac, 0x9c, 0x9e, 0xb7, 0x6f, 0xac, 0x45, 0xaf, 0x8e, 0x51 }, 16, { 0xb4, 0xd9, 0xad, 0xa9, 0xad, 0x7d, 0xed, 0xf4, 0xe5, 0xe7, 0x38, 0x76, 0x3f, 0x69, 0x14, 0x5a }, 16 }, { "NIST SP800-38A test vector AES-CBC 192-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0x4f, 0x02, 0x1d, 0xb2, 0x43, 0xbc, 0x63, 0x3d, 0x71, 0x78, 0x18, 0x3a, 0x9f, 0xa0, 0x71, 0xe8 }, 16, { 0xb4, 0xd9, 0xad, 0xa9, 0xad, 0x7d, 0xed, 0xf4, 0xe5, 0xe7, 0x38, 0x76, 0x3f, 0x69, 0x14, 0x5a }, 16, { 0xae, 0x2d, 0x8a, 0x57, 0x1e, 0x03, 0xac, 0x9c, 0x9e, 0xb7, 0x6f, 0xac, 0x45, 0xaf, 0x8e, 0x51 }, 16 }, { "NIST SP800-38A test vector AES-CBC 192-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0xb4, 0xd9, 0xad, 0xa9, 0xad, 0x7d, 0xed, 0xf4, 0xe5, 0xe7, 0x38, 0x76, 0x3f, 0x69, 0x14, 0x5a }, 16, { 0x30, 0xc8, 0x1c, 0x46, 0xa3, 0x5c, 0xe4, 0x11, 0xe5, 0xfb, 0xc1, 0x19, 0x1a, 0x0a, 0x52, 0xef }, 16, { 0x57, 0x1b, 0x24, 0x20, 0x12, 0xfb, 0x7a, 0xe0, 0x7f, 0xa9, 0xba, 0xac, 0x3d, 0xf1, 0x02, 0xe0 }, 16 }, { "NIST SP800-38A test vector AES-CBC 192-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0xb4, 0xd9, 0xad, 0xa9, 0xad, 0x7d, 0xed, 0xf4, 0xe5, 0xe7, 0x38, 0x76, 0x3f, 0x69, 0x14, 0x5a }, 16, { 0x57, 0x1b, 0x24, 0x20, 0x12, 0xfb, 0x7a, 0xe0, 0x7f, 0xa9, 0xba, 0xac, 0x3d, 0xf1, 0x02, 0xe0 }, 16, { 0x30, 0xc8, 0x1c, 0x46, 0xa3, 0x5c, 0xe4, 0x11, 0xe5, 0xfb, 0xc1, 0x19, 0x1a, 0x0a, 0x52, 0xef }, 16 }, { "NIST SP800-38A test vector AES-CBC 192-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0x57, 0x1b, 0x24, 0x20, 0x12, 0xfb, 0x7a, 0xe0, 0x7f, 0xa9, 0xba, 0xac, 0x3d, 0xf1, 0x02, 0xe0 }, 16, { 0xf6, 0x9f, 0x24, 0x45, 0xdf, 0x4f, 0x9b, 0x17, 0xad, 0x2b, 0x41, 0x7b, 0xe6, 0x6c, 0x37, 0x10 }, 16, { 0x08, 0xb0, 0xe2, 0x79, 0x88, 0x59, 0x88, 0x81, 0xd9, 0x20, 0xa9, 0xe6, 0x4f, 0x56, 0x15, 0xcd }, 16 }, { "NIST SP800-38A test vector AES-CBC 192-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0x57, 0x1b, 0x24, 0x20, 0x12, 0xfb, 0x7a, 0xe0, 0x7f, 0xa9, 0xba, 0xac, 0x3d, 0xf1, 0x02, 0xe0 }, 16, { 0x08, 0xb0, 0xe2, 0x79, 0x88, 0x59, 0x88, 0x81, 0xd9, 0x20, 0xa9, 0xe6, 0x4f, 0x56, 0x15, 0xcd }, 16, { 0xf6, 0x9f, 0x24, 0x45, 0xdf, 0x4f, 0x9b, 0x17, 0xad, 0x2b, 0x41, 0x7b, 0xe6, 0x6c, 0x37, 0x10 }, 16 }, { "NIST SP800-38A test vector AES-CBC 256-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }, 16, { 0x6b, 0xc1, 0xbe, 0xe2, 0x2e, 0x40, 0x9f, 0x96, 0xe9, 0x3d, 0x7e, 0x11, 0x73, 0x93, 0x17, 0x2a }, 16, { 0xf5, 0x8c, 0x4c, 0x04, 0xd6, 0xe5, 0xf1, 0xba, 0x77, 0x9e, 0xab, 0xfb, 0x5f, 0x7b, 0xfb, 0xd6 }, 16 }, { "NIST SP800-38A test vector AES-CBC 256-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }, 16, { 0xf5, 0x8c, 0x4c, 0x04, 0xd6, 0xe5, 0xf1, 0xba, 0x77, 0x9e, 0xab, 0xfb, 0x5f, 0x7b, 0xfb, 0xd6 }, 16, { 0x6b, 0xc1, 0xbe, 0xe2, 0x2e, 0x40, 0x9f, 0x96, 0xe9, 0x3d, 0x7e, 0x11, 0x73, 0x93, 0x17, 0x2a }, 16 }, { "NIST SP800-38A test vector AES-CBC 256-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0xf5, 0x8c, 0x4c, 0x04, 0xd6, 0xe5, 0xf1, 0xba, 0x77, 0x9e, 0xab, 0xfb, 0x5f, 0x7b, 0xfb, 0xd6 }, 16, { 0xae, 0x2d, 0x8a, 0x57, 0x1e, 0x03, 0xac, 0x9c, 0x9e, 0xb7, 0x6f, 0xac, 0x45, 0xaf, 0x8e, 0x51 }, 16, { 0x9c, 0xfc, 0x4e, 0x96, 0x7e, 0xdb, 0x80, 0x8d, 0x67, 0x9f, 0x77, 0x7b, 0xc6, 0x70, 0x2c, 0x7d }, 16 }, { "NIST SP800-38A test vector AES-CBC 256-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0xf5, 0x8c, 0x4c, 0x04, 0xd6, 0xe5, 0xf1, 0xba, 0x77, 0x9e, 0xab, 0xfb, 0x5f, 0x7b, 0xfb, 0xd6 }, 16, { 0x9c, 0xfc, 0x4e, 0x96, 0x7e, 0xdb, 0x80, 0x8d, 0x67, 0x9f, 0x77, 0x7b, 0xc6, 0x70, 0x2c, 0x7d }, 16, { 0xae, 0x2d, 0x8a, 0x57, 0x1e, 0x03, 0xac, 0x9c, 0x9e, 0xb7, 0x6f, 0xac, 0x45, 0xaf, 0x8e, 0x51 }, 16 }, { "NIST SP800-38A test vector AES-CBC 256-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0x9c, 0xfc, 0x4e, 0x96, 0x7e, 0xdb, 0x80, 0x8d, 0x67, 0x9f, 0x77, 0x7b, 0xc6, 0x70, 0x2c, 0x7d }, 16, { 0x30, 0xc8, 0x1c, 0x46, 0xa3, 0x5c, 0xe4, 0x11, 0xe5, 0xfb, 0xc1, 0x19, 0x1a, 0x0a, 0x52, 0xef }, 16, { 0x39, 0xf2, 0x33, 0x69, 0xa9, 0xd9, 0xba, 0xcf, 0xa5, 0x30, 0xe2, 0x63, 0x04, 0x23, 0x14, 0x61 }, 16 }, { "NIST SP800-38A test vector AES-CBC 256-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0x9c, 0xfc, 0x4e, 0x96, 0x7e, 0xdb, 0x80, 0x8d, 0x67, 0x9f, 0x77, 0x7b, 0xc6, 0x70, 0x2c, 0x7d }, 16, { 0x39, 0xf2, 0x33, 0x69, 0xa9, 0xd9, 0xba, 0xcf, 0xa5, 0x30, 0xe2, 0x63, 0x04, 0x23, 0x14, 0x61 }, 16, { 0x30, 0xc8, 0x1c, 0x46, 0xa3, 0x5c, 0xe4, 0x11, 0xe5, 0xfb, 0xc1, 0x19, 0x1a, 0x0a, 0x52, 0xef }, 16 }, { "NIST SP800-38A test vector AES-CBC 256-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0x39, 0xf2, 0x33, 0x69, 0xa9, 0xd9, 0xba, 0xcf, 0xa5, 0x30, 0xe2, 0x63, 0x04, 0x23, 0x14, 0x61 }, 16, { 0xf6, 0x9f, 0x24, 0x45, 0xdf, 0x4f, 0x9b, 0x17, 0xad, 0x2b, 0x41, 0x7b, 0xe6, 0x6c, 0x37, 0x10 }, 16, { 0xb2, 0xeb, 0x05, 0xe2, 0xc3, 0x9b, 0xe9, 0xfc, 0xda, 0x6c, 0x19, 0x07, 0x8c, 0x6a, 0x9d, 0x1b }, 16 }, { "NIST SP800-38A test vector AES-CBC 256-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0x39, 0xf2, 0x33, 0x69, 0xa9, 0xd9, 0xba, 0xcf, 0xa5, 0x30, 0xe2, 0x63, 0x04, 0x23, 0x14, 0x61 }, 16, { 0xb2, 0xeb, 0x05, 0xe2, 0xc3, 0x9b, 0xe9, 0xfc, 0xda, 0x6c, 0x19, 0x07, 0x8c, 0x6a, 0x9d, 0x1b }, 16, { 0xf6, 0x9f, 0x24, 0x45, 0xdf, 0x4f, 0x9b, 0x17, 0xad, 0x2b, 0x41, 0x7b, 0xe6, 0x6c, 0x37, 0x10 }, 16 }, }; /* TODO: Values from NIST KAT-AES CFBVarKey128.rsp, CFBVarKey192.rsp and CFBVarKey256.rsp */ caes_test_context_test_vector_t caes_context_aes_cfb_test_vectors[ 8 ] = { { "NIST SP800-38A test vector AES-CFB 128-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }, 16, { 0x6b, 0xc1, 0xbe, 0xe2, 0x2e, 0x40, 0x9f, 0x96, 0xe9, 0x3d, 0x7e, 0x11, 0x73, 0x93, 0x17, 0x2a }, 16, { 0x3b, 0x3f, 0xd9, 0x2e, 0xb7, 0x2d, 0xad, 0x20, 0x33, 0x34, 0x49, 0xf8, 0xe8, 0x3c, 0xfb, 0x4a }, 16 }, { "NIST SP800-38A test vector AES-CFB 128-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }, 16, { 0x6b, 0xc1, 0xbe, 0xe2, 0x2e, 0x40, 0x9f, 0x96, 0xe9, 0x3d, 0x7e, 0x11, 0x73, 0x93, 0x17, 0x2a }, 16, { 0x3b, 0x3f, 0xd9, 0x2e, 0xb7, 0x2d, 0xad, 0x20, 0x33, 0x34, 0x49, 0xf8, 0xe8, 0x3c, 0xfb, 0x4a }, 16 }, { "NIST SP800-38A test vector AES-CFB 128-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x3b, 0x3f, 0xd9, 0x2e, 0xb7, 0x2d, 0xad, 0x20, 0x33, 0x34, 0x49, 0xf8, 0xe8, 0x3c, 0xfb, 0x4a }, 16, { 0xae, 0x2d, 0x8a, 0x57, 0x1e, 0x03, 0xac, 0x9c, 0x9e, 0xb7, 0x6f, 0xac, 0x45, 0xaf, 0x8e, 0x51 }, 16, { 0xc8, 0xa6, 0x45, 0x37, 0xa0, 0xb3, 0xa9, 0x3f, 0xcd, 0xe3, 0xcd, 0xad, 0x9f, 0x1c, 0xe5, 0x8b }, 16 }, { "NIST SP800-38A test vector AES-CFB 128-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x3b, 0x3f, 0xd9, 0x2e, 0xb7, 0x2d, 0xad, 0x20, 0x33, 0x34, 0x49, 0xf8, 0xe8, 0x3c, 0xfb, 0x4a }, 16, { 0xae, 0x2d, 0x8a, 0x57, 0x1e, 0x03, 0xac, 0x9c, 0x9e, 0xb7, 0x6f, 0xac, 0x45, 0xaf, 0x8e, 0x51 }, 16, { 0xc8, 0xa6, 0x45, 0x37, 0xa0, 0xb3, 0xa9, 0x3f, 0xcd, 0xe3, 0xcd, 0xad, 0x9f, 0x1c, 0xe5, 0x8b }, 16 }, { "NIST SP800-38A test vector AES-CFB 128-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0xc8, 0xa6, 0x45, 0x37, 0xa0, 0xb3, 0xa9, 0x3f, 0xcd, 0xe3, 0xcd, 0xad, 0x9f, 0x1c, 0xe5, 0x8b }, 16, { 0x30, 0xc8, 0x1c, 0x46, 0xa3, 0x5c, 0xe4, 0x11, 0xe5, 0xfb, 0xc1, 0x19, 0x1a, 0x0a, 0x52, 0xef }, 16, { 0x26, 0x75, 0x1f, 0x67, 0xa3, 0xcb, 0xb1, 0x40, 0xb1, 0x80, 0x8c, 0xf1, 0x87, 0xa4, 0xf4, 0xdf }, 16 }, { "NIST SP800-38A test vector AES-CFB 128-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0xc8, 0xa6, 0x45, 0x37, 0xa0, 0xb3, 0xa9, 0x3f, 0xcd, 0xe3, 0xcd, 0xad, 0x9f, 0x1c, 0xe5, 0x8b }, 16, { 0x30, 0xc8, 0x1c, 0x46, 0xa3, 0x5c, 0xe4, 0x11, 0xe5, 0xfb, 0xc1, 0x19, 0x1a, 0x0a, 0x52, 0xef }, 16, { 0x26, 0x75, 0x1f, 0x67, 0xa3, 0xcb, 0xb1, 0x40, 0xb1, 0x80, 0x8c, 0xf1, 0x87, 0xa4, 0xf4, 0xdf }, 16 }, { "NIST SP800-38A test vector AES-CFB 128-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x26, 0x75, 0x1f, 0x67, 0xa3, 0xcb, 0xb1, 0x40, 0xb1, 0x80, 0x8c, 0xf1, 0x87, 0xa4, 0xf4, 0xdf }, 16, { 0xf6, 0x9f, 0x24, 0x45, 0xdf, 0x4f, 0x9b, 0x17, 0xad, 0x2b, 0x41, 0x7b, 0xe6, 0x6c, 0x37, 0x10 }, 16, { 0xc0, 0x4b, 0x05, 0x35, 0x7c, 0x5d, 0x1c, 0x0e, 0xea, 0xc4, 0xc6, 0x6f, 0x9f, 0xf7, 0xf2, 0xe6 }, 16 }, { "NIST SP800-38A test vector AES-CFB 128-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x26, 0x75, 0x1f, 0x67, 0xa3, 0xcb, 0xb1, 0x40, 0xb1, 0x80, 0x8c, 0xf1, 0x87, 0xa4, 0xf4, 0xdf }, 16, { 0xf6, 0x9f, 0x24, 0x45, 0xdf, 0x4f, 0x9b, 0x17, 0xad, 0x2b, 0x41, 0x7b, 0xe6, 0x6c, 0x37, 0x10 }, 16, { 0xc0, 0x4b, 0x05, 0x35, 0x7c, 0x5d, 0x1c, 0x0e, 0xea, 0xc4, 0xc6, 0x6f, 0x9f, 0xf7, 0xf2, 0xe6 }, 16 }, }; /* TODO # For all CFB128 encrypts and decrypts, the transformed sequence is # AES-bits-CFB:key:IV/ciphertext':plaintext:ciphertext:encdec # CFB128-AES192.Encrypt AES-192-CFB:8E73B0F7DA0E6452C810F32B809079E562F8EAD2522C6B7B:000102030405060708090A0B0C0D0E0F:6BC1BEE22E409F96E93D7E117393172A:CDC80D6FDDF18CAB34C25909C99A4174:1 AES-192-CFB:8E73B0F7DA0E6452C810F32B809079E562F8EAD2522C6B7B:CDC80D6FDDF18CAB34C25909C99A4174:AE2D8A571E03AC9C9EB76FAC45AF8E51:67CE7F7F81173621961A2B70171D3D7A:1 AES-192-CFB:8E73B0F7DA0E6452C810F32B809079E562F8EAD2522C6B7B:67CE7F7F81173621961A2B70171D3D7A:30C81C46A35CE411E5FBC1191A0A52EF:2E1E8A1DD59B88B1C8E60FED1EFAC4C9:1 AES-192-CFB:8E73B0F7DA0E6452C810F32B809079E562F8EAD2522C6B7B:2E1E8A1DD59B88B1C8E60FED1EFAC4C9:F69F2445DF4F9B17AD2B417BE66C3710:C05F9F9CA9834FA042AE8FBA584B09FF:1 # CFB128-AES192.Decrypt AES-192-CFB:8E73B0F7DA0E6452C810F32B809079E562F8EAD2522C6B7B:000102030405060708090A0B0C0D0E0F:6BC1BEE22E409F96E93D7E117393172A:CDC80D6FDDF18CAB34C25909C99A4174:0 AES-192-CFB:8E73B0F7DA0E6452C810F32B809079E562F8EAD2522C6B7B:CDC80D6FDDF18CAB34C25909C99A4174:AE2D8A571E03AC9C9EB76FAC45AF8E51:67CE7F7F81173621961A2B70171D3D7A:0 AES-192-CFB:8E73B0F7DA0E6452C810F32B809079E562F8EAD2522C6B7B:67CE7F7F81173621961A2B70171D3D7A:30C81C46A35CE411E5FBC1191A0A52EF:2E1E8A1DD59B88B1C8E60FED1EFAC4C9:0 AES-192-CFB:8E73B0F7DA0E6452C810F32B809079E562F8EAD2522C6B7B:2E1E8A1DD59B88B1C8E60FED1EFAC4C9:F69F2445DF4F9B17AD2B417BE66C3710:C05F9F9CA9834FA042AE8FBA584B09FF:0 # CFB128-AES256.Encrypt AES-256-CFB:603DEB1015CA71BE2B73AEF0857D77811F352C073B6108D72D9810A30914DFF4:000102030405060708090A0B0C0D0E0F:6BC1BEE22E409F96E93D7E117393172A:DC7E84BFDA79164B7ECD8486985D3860:1 AES-256-CFB:603DEB1015CA71BE2B73AEF0857D77811F352C073B6108D72D9810A30914DFF4:DC7E84BFDA79164B7ECD8486985D3860:AE2D8A571E03AC9C9EB76FAC45AF8E51:39FFED143B28B1C832113C6331E5407B:1 AES-256-CFB:603DEB1015CA71BE2B73AEF0857D77811F352C073B6108D72D9810A30914DFF4:39FFED143B28B1C832113C6331E5407B:30C81C46A35CE411E5FBC1191A0A52EF:DF10132415E54B92A13ED0A8267AE2F9:1 AES-256-CFB:603DEB1015CA71BE2B73AEF0857D77811F352C073B6108D72D9810A30914DFF4:DF10132415E54B92A13ED0A8267AE2F9:F69F2445DF4F9B17AD2B417BE66C3710:75A385741AB9CEF82031623D55B1E471:1 # CFB128-AES256.Decrypt AES-256-CFB:603DEB1015CA71BE2B73AEF0857D77811F352C073B6108D72D9810A30914DFF4:000102030405060708090A0B0C0D0E0F:6BC1BEE22E409F96E93D7E117393172A:DC7E84BFDA79164B7ECD8486985D3860:0 AES-256-CFB:603DEB1015CA71BE2B73AEF0857D77811F352C073B6108D72D9810A30914DFF4:DC7E84BFDA79164B7ECD8486985D3860:AE2D8A571E03AC9C9EB76FAC45AF8E51:39FFED143B28B1C832113C6331E5407B:0 AES-256-CFB:603DEB1015CA71BE2B73AEF0857D77811F352C073B6108D72D9810A30914DFF4:39FFED143B28B1C832113C6331E5407B:30C81C46A35CE411E5FBC1191A0A52EF:DF10132415E54B92A13ED0A8267AE2F9:0 AES-256-CFB:603DEB1015CA71BE2B73AEF0857D77811F352C073B6108D72D9810A30914DFF4:DF10132415E54B92A13ED0A8267AE2F9:F69F2445DF4F9B17AD2B417BE66C3710:75A385741AB9CEF82031623D55B1E471:0 */ caes_test_context_test_vector_t caes_context_aes_ecb_test_vectors[ 1950 ] = { { "FIPS-197 test vector AES-ECB 128-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xaa, 0xbb, 0xcc, 0xdd, 0xee, 0xff }, 16, { 0x69, 0xc4, 0xe0, 0xd8, 0x6a, 0x7b, 0x04, 0x30, 0xd8, 0xcd, 0xb7, 0x80, 0x70, 0xb4, 0xc5, 0x5a }, 16 }, { "FIPS-197 test vector 1 AES-ECB 128-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x69, 0xc4, 0xe0, 0xd8, 0x6a, 0x7b, 0x04, 0x30, 0xd8, 0xcd, 0xb7, 0x80, 0x70, 0xb4, 0xc5, 0x5a }, 16, { 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xaa, 0xbb, 0xcc, 0xdd, 0xee, 0xff }, 16 }, { "FIPS-197 test vector 2 AES-ECB 192-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xaa, 0xbb, 0xcc, 0xdd, 0xee, 0xff }, 16, { 0xdd, 0xa9, 0x7c, 0xa4, 0x86, 0x4c, 0xdf, 0xe0, 0x6e, 0xaf, 0x70, 0xa0, 0xec, 0x0d, 0x71, 0x91 }, 16 }, { "FIPS-197 test vector 2 AES-ECB 192-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdd, 0xa9, 0x7c, 0xa4, 0x86, 0x4c, 0xdf, 0xe0, 0x6e, 0xaf, 0x70, 0xa0, 0xec, 0x0d, 0x71, 0x91 }, 16, { 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xaa, 0xbb, 0xcc, 0xdd, 0xee, 0xff }, 16 }, { "FIPS-197 test vector 2 AES-ECB 256-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 0x1e, 0x1f }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xaa, 0xbb, 0xcc, 0xdd, 0xee, 0xff }, 16, { 0x8e, 0xa2, 0xb7, 0xca, 0x51, 0x67, 0x45, 0xbf, 0xea, 0xfc, 0x49, 0x90, 0x4b, 0x49, 0x60, 0x89 }, 16 }, { "FIPS-197 test vector 2 AES-ECB 256-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f, 0x10, 0x11, 0x12, 0x13, 0x14, 0x15, 0x16, 0x17, 0x18, 0x19, 0x1a, 0x1b, 0x1c, 0x1d, 0x1e, 0x1f }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8e, 0xa2, 0xb7, 0xca, 0x51, 0x67, 0x45, 0xbf, 0xea, 0xfc, 0x49, 0x90, 0x4b, 0x49, 0x60, 0x89 }, 16, { 0x00, 0x11, 0x22, 0x33, 0x44, 0x55, 0x66, 0x77, 0x88, 0x99, 0xaa, 0xbb, 0xcc, 0xdd, 0xee, 0xff }, 16 }, { "NIST SP800-38A test vector AES-ECB 128-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6b, 0xc1, 0xbe, 0xe2, 0x2e, 0x40, 0x9f, 0x96, 0xe9, 0x3d, 0x7e, 0x11, 0x73, 0x93, 0x17, 0x2a }, 16, { 0x3a, 0xd7, 0x7b, 0xb4, 0x0d, 0x7a, 0x36, 0x60, 0xa8, 0x9e, 0xca, 0xf3, 0x24, 0x66, 0xef, 0x97 }, 16 }, { "NIST SP800-38A test vector AES-ECB 128-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0xd7, 0x7b, 0xb4, 0x0d, 0x7a, 0x36, 0x60, 0xa8, 0x9e, 0xca, 0xf3, 0x24, 0x66, 0xef, 0x97 }, 16, { 0x6b, 0xc1, 0xbe, 0xe2, 0x2e, 0x40, 0x9f, 0x96, 0xe9, 0x3d, 0x7e, 0x11, 0x73, 0x93, 0x17, 0x2a }, 16 }, { "NIST SP800-38A test vector AES-ECB 128-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xae, 0x2d, 0x8a, 0x57, 0x1e, 0x03, 0xac, 0x9c, 0x9e, 0xb7, 0x6f, 0xac, 0x45, 0xaf, 0x8e, 0x51 }, 16, { 0xf5, 0xd3, 0xd5, 0x85, 0x03, 0xb9, 0x69, 0x9d, 0xe7, 0x85, 0x89, 0x5a, 0x96, 0xfd, 0xba, 0xaf }, 16 }, { "NIST SP800-38A test vector AES-ECB 128-bit encrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf5, 0xd3, 0xd5, 0x85, 0x03, 0xb9, 0x69, 0x9d, 0xe7, 0x85, 0x89, 0x5a, 0x96, 0xfd, 0xba, 0xaf }, 16, { 0xae, 0x2d, 0x8a, 0x57, 0x1e, 0x03, 0xac, 0x9c, 0x9e, 0xb7, 0x6f, 0xac, 0x45, 0xaf, 0x8e, 0x51 }, 16 }, { "NIST SP800-38A test vector AES-ECB 128-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x30, 0xc8, 0x1c, 0x46, 0xa3, 0x5c, 0xe4, 0x11, 0xe5, 0xfb, 0xc1, 0x19, 0x1a, 0x0a, 0x52, 0xef }, 16, { 0x43, 0xb1, 0xcd, 0x7f, 0x59, 0x8e, 0xce, 0x23, 0x88, 0x1b, 0x00, 0xe3, 0xed, 0x03, 0x06, 0x88 }, 16 }, { "NIST SP800-38A test vector AES-ECB 128-bit encrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x43, 0xb1, 0xcd, 0x7f, 0x59, 0x8e, 0xce, 0x23, 0x88, 0x1b, 0x00, 0xe3, 0xed, 0x03, 0x06, 0x88 }, 16, { 0x30, 0xc8, 0x1c, 0x46, 0xa3, 0x5c, 0xe4, 0x11, 0xe5, 0xfb, 0xc1, 0x19, 0x1a, 0x0a, 0x52, 0xef }, 16 }, { "NIST SP800-38A test vector AES-ECB 128-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf6, 0x9f, 0x24, 0x45, 0xdf, 0x4f, 0x9b, 0x17, 0xad, 0x2b, 0x41, 0x7b, 0xe6, 0x6c, 0x37, 0x10 }, 16, { 0x7b, 0x0c, 0x78, 0x5e, 0x27, 0xe8, 0xad, 0x3f, 0x82, 0x23, 0x20, 0x71, 0x04, 0x72, 0x5d, 0xd4 }, 16 }, { "NIST SP800-38A test vector AES-ECB 128-bit encrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x2b, 0x7e, 0x15, 0x16, 0x28, 0xae, 0xd2, 0xa6, 0xab, 0xf7, 0x15, 0x88, 0x09, 0xcf, 0x4f, 0x3c }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7b, 0x0c, 0x78, 0x5e, 0x27, 0xe8, 0xad, 0x3f, 0x82, 0x23, 0x20, 0x71, 0x04, 0x72, 0x5d, 0xd4 }, 16, { 0xf6, 0x9f, 0x24, 0x45, 0xdf, 0x4f, 0x9b, 0x17, 0xad, 0x2b, 0x41, 0x7b, 0xe6, 0x6c, 0x37, 0x10 }, 16 }, { "NIST SP800-38A test vector AES-ECB 192-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6b, 0xc1, 0xbe, 0xe2, 0x2e, 0x40, 0x9f, 0x96, 0xe9, 0x3d, 0x7e, 0x11, 0x73, 0x93, 0x17, 0x2a }, 16, { 0xbd, 0x33, 0x4f, 0x1d, 0x6e, 0x45, 0xf2, 0x5f, 0xf7, 0x12, 0xa2, 0x14, 0x57, 0x1f, 0xa5, 0xcc }, 16 }, { "NIST SP800-38A test vector AES-ECB 192-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbd, 0x33, 0x4f, 0x1d, 0x6e, 0x45, 0xf2, 0x5f, 0xf7, 0x12, 0xa2, 0x14, 0x57, 0x1f, 0xa5, 0xcc }, 16, { 0x6b, 0xc1, 0xbe, 0xe2, 0x2e, 0x40, 0x9f, 0x96, 0xe9, 0x3d, 0x7e, 0x11, 0x73, 0x93, 0x17, 0x2a }, 16 }, { "NIST SP800-38A test vector AES-ECB 192-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xae, 0x2d, 0x8a, 0x57, 0x1e, 0x03, 0xac, 0x9c, 0x9e, 0xb7, 0x6f, 0xac, 0x45, 0xaf, 0x8e, 0x51 }, 16, { 0x97, 0x41, 0x04, 0x84, 0x6d, 0x0a, 0xd3, 0xad, 0x77, 0x34, 0xec, 0xb3, 0xec, 0xee, 0x4e, 0xef }, 16 }, { "NIST SP800-38A test vector AES-ECB 192-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0x41, 0x04, 0x84, 0x6d, 0x0a, 0xd3, 0xad, 0x77, 0x34, 0xec, 0xb3, 0xec, 0xee, 0x4e, 0xef }, 16, { 0xae, 0x2d, 0x8a, 0x57, 0x1e, 0x03, 0xac, 0x9c, 0x9e, 0xb7, 0x6f, 0xac, 0x45, 0xaf, 0x8e, 0x51 }, 16 }, { "NIST SP800-38A test vector AES-ECB 192-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x30, 0xc8, 0x1c, 0x46, 0xa3, 0x5c, 0xe4, 0x11, 0xe5, 0xfb, 0xc1, 0x19, 0x1a, 0x0a, 0x52, 0xef }, 16, { 0xef, 0x7a, 0xfd, 0x22, 0x70, 0xe2, 0xe6, 0x0a, 0xdc, 0xe0, 0xba, 0x2f, 0xac, 0xe6, 0x44, 0x4e }, 16 }, { "NIST SP800-38A test vector AES-ECB 192-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xef, 0x7a, 0xfd, 0x22, 0x70, 0xe2, 0xe6, 0x0a, 0xdc, 0xe0, 0xba, 0x2f, 0xac, 0xe6, 0x44, 0x4e }, 16, { 0x30, 0xc8, 0x1c, 0x46, 0xa3, 0x5c, 0xe4, 0x11, 0xe5, 0xfb, 0xc1, 0x19, 0x1a, 0x0a, 0x52, 0xef }, 16 }, { "NIST SP800-38A test vector AES-ECB 192-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf6, 0x9f, 0x24, 0x45, 0xdf, 0x4f, 0x9b, 0x17, 0xad, 0x2b, 0x41, 0x7b, 0xe6, 0x6c, 0x37, 0x10 }, 16, { 0x9a, 0x4b, 0x41, 0xba, 0x73, 0x8d, 0x6c, 0x72, 0xfb, 0x16, 0x69, 0x16, 0x03, 0xc1, 0x8e, 0x0e }, 16 }, { "NIST SP800-38A test vector AES-ECB 192-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x8e, 0x73, 0xb0, 0xf7, 0xda, 0x0e, 0x64, 0x52, 0xc8, 0x10, 0xf3, 0x2b, 0x80, 0x90, 0x79, 0xe5, 0x62, 0xf8, 0xea, 0xd2, 0x52, 0x2c, 0x6b, 0x7b }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9a, 0x4b, 0x41, 0xba, 0x73, 0x8d, 0x6c, 0x72, 0xfb, 0x16, 0x69, 0x16, 0x03, 0xc1, 0x8e, 0x0e }, 16, { 0xf6, 0x9f, 0x24, 0x45, 0xdf, 0x4f, 0x9b, 0x17, 0xad, 0x2b, 0x41, 0x7b, 0xe6, 0x6c, 0x37, 0x10 }, 16 }, { "NIST SP800-38A test vector AES-ECB 256-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6b, 0xc1, 0xbe, 0xe2, 0x2e, 0x40, 0x9f, 0x96, 0xe9, 0x3d, 0x7e, 0x11, 0x73, 0x93, 0x17, 0x2a }, 16, { 0xf3, 0xee, 0xd1, 0xbd, 0xb5, 0xd2, 0xa0, 0x3c, 0x06, 0x4b, 0x5a, 0x7e, 0x3d, 0xb1, 0x81, 0xf8 }, 16 }, { "NIST SP800-38A test vector AES-ECB 256-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf3, 0xee, 0xd1, 0xbd, 0xb5, 0xd2, 0xa0, 0x3c, 0x06, 0x4b, 0x5a, 0x7e, 0x3d, 0xb1, 0x81, 0xf8 }, 16, { 0x6b, 0xc1, 0xbe, 0xe2, 0x2e, 0x40, 0x9f, 0x96, 0xe9, 0x3d, 0x7e, 0x11, 0x73, 0x93, 0x17, 0x2a }, 16 }, { "NIST SP800-38A test vector AES-ECB 256-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xae, 0x2d, 0x8a, 0x57, 0x1e, 0x03, 0xac, 0x9c, 0x9e, 0xb7, 0x6f, 0xac, 0x45, 0xaf, 0x8e, 0x51 }, 16, { 0x59, 0x1c, 0xcb, 0x10, 0xd4, 0x10, 0xed, 0x26, 0xdc, 0x5b, 0xa7, 0x4a, 0x31, 0x36, 0x28, 0x70 }, 16 }, { "NIST SP800-38A test vector AES-ECB 256-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x59, 0x1c, 0xcb, 0x10, 0xd4, 0x10, 0xed, 0x26, 0xdc, 0x5b, 0xa7, 0x4a, 0x31, 0x36, 0x28, 0x70 }, 16, { 0xae, 0x2d, 0x8a, 0x57, 0x1e, 0x03, 0xac, 0x9c, 0x9e, 0xb7, 0x6f, 0xac, 0x45, 0xaf, 0x8e, 0x51 }, 16 }, { "NIST SP800-38A test vector AES-ECB 256-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x30, 0xc8, 0x1c, 0x46, 0xa3, 0x5c, 0xe4, 0x11, 0xe5, 0xfb, 0xc1, 0x19, 0x1a, 0x0a, 0x52, 0xef }, 16, { 0xb6, 0xed, 0x21, 0xb9, 0x9c, 0xa6, 0xf4, 0xf9, 0xf1, 0x53, 0xe7, 0xb1, 0xbe, 0xaf, 0xed, 0x1d }, 16 }, { "NIST SP800-38A test vector AES-ECB 256-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb6, 0xed, 0x21, 0xb9, 0x9c, 0xa6, 0xf4, 0xf9, 0xf1, 0x53, 0xe7, 0xb1, 0xbe, 0xaf, 0xed, 0x1d }, 16, { 0x30, 0xc8, 0x1c, 0x46, 0xa3, 0x5c, 0xe4, 0x11, 0xe5, 0xfb, 0xc1, 0x19, 0x1a, 0x0a, 0x52, 0xef }, 16 }, { "NIST SP800-38A test vector AES-ECB 256-bit encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf6, 0x9f, 0x24, 0x45, 0xdf, 0x4f, 0x9b, 0x17, 0xad, 0x2b, 0x41, 0x7b, 0xe6, 0x6c, 0x37, 0x10 }, 16, { 0x23, 0x30, 0x4b, 0x7a, 0x39, 0xf9, 0xf3, 0xff, 0x06, 0x7d, 0x8d, 0x8f, 0x9e, 0x24, 0xec, 0xc7 }, 16 }, { "NIST SP800-38A test vector AES-ECB 256-bit decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x60, 0x3d, 0xeb, 0x10, 0x15, 0xca, 0x71, 0xbe, 0x2b, 0x73, 0xae, 0xf0, 0x85, 0x7d, 0x77, 0x81, 0x1f, 0x35, 0x2c, 0x07, 0x3b, 0x61, 0x08, 0xd7, 0x2d, 0x98, 0x10, 0xa3, 0x09, 0x14, 0xdf, 0xf4 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x23, 0x30, 0x4b, 0x7a, 0x39, 0xf9, 0xf3, 0xff, 0x06, 0x7d, 0x8d, 0x8f, 0x9e, 0x24, 0xec, 0xc7 }, 16, { 0xf6, 0x9f, 0x24, 0x45, 0xdf, 0x4f, 0x9b, 0x17, 0xad, 0x2b, 0x41, 0x7b, 0xe6, 0x6c, 0x37, 0x10 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 0 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0e, 0xdd, 0x33, 0xd3, 0xc6, 0x21, 0xe5, 0x46, 0x45, 0x5b, 0xd8, 0xba, 0x14, 0x18, 0xbe, 0xc8 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 1 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4b, 0xc3, 0xf8, 0x83, 0x45, 0x0c, 0x11, 0x3c, 0x64, 0xca, 0x42, 0xe1, 0x11, 0x2a, 0x9e, 0x87 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 2 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x72, 0xa1, 0xda, 0x77, 0x0f, 0x5d, 0x7a, 0xc4, 0xc9, 0xef, 0x94, 0xd8, 0x22, 0xaf, 0xfd, 0x97 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 3 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0x00, 0x14, 0xd6, 0x34, 0xe2, 0xb7, 0x65, 0x07, 0x77, 0xe8, 0xe8, 0x4d, 0x03, 0xcc, 0xd8 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 4 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf1, 0x7e, 0x79, 0xae, 0xd0, 0xdb, 0x7e, 0x27, 0x9e, 0x95, 0x5b, 0x5f, 0x49, 0x38, 0x75, 0xa7 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 5 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9e, 0xd5, 0xa7, 0x51, 0x36, 0xa9, 0x40, 0xd0, 0x96, 0x3d, 0xa3, 0x79, 0xdb, 0x4a, 0xf2, 0x6a }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 6 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc4, 0x29, 0x5f, 0x83, 0x46, 0x5c, 0x77, 0x55, 0xe8, 0xfa, 0x36, 0x4b, 0xac, 0x6a, 0x7e, 0xa5 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 7 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb1, 0xd7, 0x58, 0x25, 0x6b, 0x28, 0xfd, 0x85, 0x0a, 0xd4, 0x94, 0x42, 0x08, 0xcf, 0x11, 0x55 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 8 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x42, 0xff, 0xb3, 0x4c, 0x74, 0x3d, 0xe4, 0xd8, 0x8c, 0xa3, 0x80, 0x11, 0xc9, 0x90, 0x89, 0x0b }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 9 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x99, 0x58, 0xf0, 0xec, 0xea, 0x8b, 0x21, 0x72, 0xc0, 0xc1, 0x99, 0x5f, 0x91, 0x82, 0xc0, 0xf3 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 10 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x95, 0x6d, 0x77, 0x98, 0xfa, 0xc2, 0x0f, 0x82, 0xa8, 0x82, 0x3f, 0x98, 0x4d, 0x06, 0xf7, 0xf5 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 11 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa0, 0x1b, 0xf4, 0x4f, 0x2d, 0x16, 0xbe, 0x92, 0x8c, 0xa4, 0x4a, 0xaf, 0x7b, 0x9b, 0x10, 0x6b }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 12 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb5, 0xf1, 0xa3, 0x3e, 0x50, 0xd4, 0x0d, 0x10, 0x37, 0x64, 0xc7, 0x6b, 0xd4, 0xc6, 0xb6, 0xf8 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 13 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x26, 0x37, 0x05, 0x0c, 0x9f, 0xc0, 0xd4, 0x81, 0x7e, 0x2d, 0x69, 0xde, 0x87, 0x8a, 0xee, 0x8d }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 14 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0x3e, 0xcb, 0xe4, 0xa4, 0x53, 0x26, 0x9a, 0x0d, 0xd2, 0x60, 0x69, 0x46, 0x7f, 0xb5, 0xb5 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 15 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0xd0, 0x75, 0x4f, 0xe6, 0x8f, 0x11, 0xb9, 0xe3, 0x75, 0xd0, 0x70, 0xa6, 0x08, 0xc8, 0x84 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 16 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc6, 0xa0, 0xb3, 0xe9, 0x98, 0xd0, 0x50, 0x68, 0xa5, 0x39, 0x97, 0x78, 0x40, 0x52, 0x00, 0xb4 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 17 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdf, 0x55, 0x6a, 0x33, 0x43, 0x8d, 0xb8, 0x7b, 0xc4, 0x1b, 0x17, 0x52, 0xc5, 0x5e, 0x5e, 0x49 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 18 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0xfb, 0x12, 0x8d, 0x3a, 0x1a, 0xf6, 0xe5, 0x48, 0x52, 0x1b, 0xb9, 0x62, 0xbf, 0x1f, 0x05 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 19 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x26, 0x29, 0x8e, 0x9c, 0x1d, 0xb5, 0x17, 0xc2, 0x15, 0xfa, 0xdf, 0xb7, 0xd2, 0xa8, 0xd6, 0x91 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 20 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa6, 0xcb, 0x76, 0x1d, 0x61, 0xf8, 0x29, 0x2d, 0x0d, 0xf3, 0x93, 0xa2, 0x79, 0xad, 0x03, 0x80 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 21 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x12, 0xac, 0xd8, 0x9b, 0x13, 0xcd, 0x5f, 0x87, 0x26, 0xe3, 0x4d, 0x44, 0xfd, 0x48, 0x61, 0x08 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 22 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x95, 0xb1, 0x70, 0x3f, 0xc5, 0x7b, 0xa0, 0x9f, 0xe0, 0xc3, 0x58, 0x0f, 0xeb, 0xdd, 0x7e, 0xd4 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 23 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xde, 0x11, 0x72, 0x2d, 0x89, 0x3e, 0x9f, 0x91, 0x21, 0xc3, 0x81, 0xbe, 0xcc, 0x1d, 0xa5, 0x9a }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 24 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6d, 0x11, 0x4c, 0xcb, 0x27, 0xbf, 0x39, 0x10, 0x12, 0xe8, 0x97, 0x4c, 0x54, 0x6d, 0x9b, 0xf2 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 25 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5c, 0xe3, 0x7e, 0x17, 0xeb, 0x46, 0x46, 0xec, 0xfa, 0xc2, 0x9b, 0x9c, 0xc3, 0x8d, 0x93, 0x40 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 26 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x18, 0xc1, 0xb6, 0xe2, 0x15, 0x71, 0x22, 0x05, 0x6d, 0x02, 0x43, 0xd8, 0xa1, 0x65, 0xcd, 0xdb }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 27 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x99, 0x69, 0x3e, 0x6a, 0x59, 0xd1, 0x36, 0x6c, 0x74, 0xd8, 0x23, 0x56, 0x2d, 0x7e, 0x14, 0x31 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 28 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6c, 0x7c, 0x64, 0xdc, 0x84, 0xa8, 0xbb, 0xa7, 0x58, 0xed, 0x17, 0xeb, 0x02, 0x5a, 0x57, 0xe3 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 29 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe1, 0x7b, 0xc7, 0x9f, 0x30, 0xea, 0xab, 0x2f, 0xac, 0x2c, 0xbb, 0xe3, 0x45, 0x8d, 0x68, 0x7a }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 30 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0x14, 0xbc, 0x20, 0x28, 0x00, 0x9b, 0x92, 0x3f, 0x0b, 0x01, 0x91, 0x5c, 0xe5, 0xe7, 0xc4 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 31 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9c, 0x28, 0x52, 0x4a, 0x16, 0xa1, 0xe1, 0xc1, 0x45, 0x29, 0x71, 0xca, 0xa8, 0xd1, 0x34, 0x76 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 32 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xed, 0x62, 0xe1, 0x63, 0x63, 0x63, 0x83, 0x60, 0xfd, 0xd6, 0xad, 0x62, 0x11, 0x27, 0x94, 0xf0 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 33 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5a, 0x86, 0x88, 0xf0, 0xb2, 0xa2, 0xc1, 0x62, 0x24, 0xc1, 0x61, 0x65, 0x8f, 0xfd, 0x40, 0x44 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 34 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x23, 0xf7, 0x10, 0x84, 0x2b, 0x9b, 0xb9, 0xc3, 0x2f, 0x26, 0x64, 0x8c, 0x78, 0x68, 0x07, 0xca }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 35 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x44, 0xa9, 0x8b, 0xf1, 0x1e, 0x16, 0x3f, 0x63, 0x2c, 0x47, 0xec, 0x6a, 0x49, 0x68, 0x3a, 0x89 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 36 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0f, 0x18, 0xaf, 0xf9, 0x42, 0x74, 0x69, 0x6d, 0x9b, 0x61, 0x84, 0x8b, 0xd5, 0x0a, 0xc5, 0xe5 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 37 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x82, 0x40, 0x85, 0x71, 0xc3, 0xe2, 0x42, 0x45, 0x40, 0x20, 0x7f, 0x83, 0x3b, 0x6d, 0xda, 0x69 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 38 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x30, 0x3f, 0xf9, 0x96, 0x94, 0x7f, 0x0c, 0x7d, 0x1f, 0x43, 0xc8, 0xf3, 0x02, 0x7b, 0x9b, 0x75 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 39 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7d, 0xf4, 0xda, 0xf4, 0xad, 0x29, 0xa3, 0x61, 0x5a, 0x9b, 0x6e, 0xce, 0x5c, 0x99, 0x51, 0x8a }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 40 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc7, 0x29, 0x54, 0xa4, 0x8d, 0x07, 0x74, 0xdb, 0x0b, 0x49, 0x71, 0xc5, 0x26, 0x26, 0x04, 0x15 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 41 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1d, 0xf9, 0xb7, 0x61, 0x12, 0xdc, 0x65, 0x31, 0xe0, 0x7d, 0x2c, 0xfd, 0xa0, 0x44, 0x11, 0xf0 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 42 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8e, 0x4d, 0x8e, 0x69, 0x91, 0x19, 0xe1, 0xfc, 0x87, 0x54, 0x5a, 0x64, 0x7f, 0xb1, 0xd3, 0x4f }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 43 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe6, 0xc4, 0x80, 0x7a, 0xe1, 0x1f, 0x36, 0xf0, 0x91, 0xc5, 0x7d, 0x9f, 0xb6, 0x85, 0x48, 0xd1 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 44 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8e, 0xbf, 0x73, 0xaa, 0xd4, 0x9c, 0x82, 0x00, 0x7f, 0x77, 0xa5, 0xc1, 0xcc, 0xec, 0x6a, 0xb4 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 45 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4f, 0xb2, 0x88, 0xcc, 0x20, 0x40, 0x04, 0x90, 0x01, 0xd2, 0xc7, 0x58, 0x5a, 0xd1, 0x23, 0xfc }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 46 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x04, 0x49, 0x71, 0x10, 0xef, 0xb9, 0xdc, 0xeb, 0x13, 0xe2, 0xb1, 0x3f, 0xb4, 0x46, 0x55, 0x64 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 47 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x75, 0x55, 0x0e, 0x6c, 0xb5, 0xa8, 0x8e, 0x49, 0x63, 0x4c, 0x9a, 0xb6, 0x9e, 0xda, 0x04, 0x30 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 48 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb6, 0x76, 0x84, 0x73, 0xce, 0x98, 0x43, 0xea, 0x66, 0xa8, 0x14, 0x05, 0xdd, 0x50, 0xb3, 0x45 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 49 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcb, 0x2f, 0x43, 0x03, 0x83, 0xf9, 0x08, 0x4e, 0x03, 0xa6, 0x53, 0x57, 0x1e, 0x06, 0x5d, 0xe6 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 50 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0x4e, 0x66, 0xc0, 0x7b, 0xae, 0x3e, 0x79, 0xfb, 0x7d, 0x21, 0x08, 0x47, 0xa3, 0xb0, 0xba }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 51 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7b, 0x90, 0x78, 0x51, 0x25, 0x50, 0x5f, 0xad, 0x59, 0xb1, 0x3c, 0x18, 0x6d, 0xd6, 0x6c, 0xe3 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 52 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8b, 0x52, 0x7a, 0x6a, 0xeb, 0xda, 0xec, 0x9e, 0xae, 0xf8, 0xed, 0xa2, 0xcb, 0x77, 0x83, 0xe5 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 53 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x43, 0xfd, 0xaf, 0x53, 0xeb, 0xbc, 0x98, 0x80, 0xc2, 0x28, 0x61, 0x7d, 0x6a, 0x9b, 0x54, 0x8b }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 54 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x53, 0x78, 0x61, 0x04, 0xb9, 0x74, 0x4b, 0x98, 0xf0, 0x52, 0xc4, 0x6f, 0x1c, 0x85, 0x0d, 0x0b }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 55 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb5, 0xab, 0x30, 0x13, 0xdd, 0x1e, 0x61, 0xdf, 0x06, 0xcb, 0xaf, 0x34, 0xca, 0x2a, 0xee, 0x78 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 56 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x74, 0x70, 0x46, 0x9b, 0xe9, 0x72, 0x30, 0x30, 0xfd, 0xcc, 0x73, 0xa8, 0xcd, 0x4f, 0xbb, 0x10 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 57 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa3, 0x5a, 0x63, 0xf5, 0x34, 0x3e, 0xbe, 0x9e, 0xf8, 0x16, 0x7b, 0xcb, 0x48, 0xad, 0x12, 0x2e }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 58 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfd, 0x86, 0x87, 0xf0, 0x75, 0x7a, 0x21, 0x0e, 0x9f, 0xdf, 0x18, 0x12, 0x04, 0xc3, 0x08, 0x63 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 59 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7a, 0x18, 0x1e, 0x84, 0xbd, 0x54, 0x57, 0xd2, 0x6a, 0x88, 0xfb, 0xae, 0x96, 0x01, 0x8f, 0xb0 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 60 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x65, 0x33, 0x17, 0xb9, 0x36, 0x2b, 0x6f, 0x9b, 0x9e, 0x1a, 0x58, 0x0e, 0x68, 0xd4, 0x94, 0xb5 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 61 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x99, 0x5c, 0x9d, 0xc0, 0xb6, 0x89, 0xf0, 0x3c, 0x45, 0x86, 0x7b, 0x5f, 0xaa, 0x5c, 0x18, 0xd1 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 62 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x77, 0xa4, 0xd9, 0x6d, 0x56, 0xdd, 0xa3, 0x98, 0xb9, 0xaa, 0xbe, 0xcf, 0xc7, 0x57, 0x29, 0xfd }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 63 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x84, 0xbe, 0x19, 0xe0, 0x53, 0x63, 0x5f, 0x09, 0xf2, 0x66, 0x5e, 0x7b, 0xae, 0x85, 0xb4, 0x2d }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 64 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x32, 0xcd, 0x65, 0x28, 0x42, 0x92, 0x6a, 0xea, 0x4a, 0xa6, 0x13, 0x7b, 0xb2, 0xbe, 0x2b, 0x5e }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 65 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x49, 0x3d, 0x4a, 0x4f, 0x38, 0xeb, 0xb3, 0x37, 0xd1, 0x0a, 0xa8, 0x4e, 0x91, 0x71, 0xa5, 0x54 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 66 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd9, 0xbf, 0xf7, 0xff, 0x45, 0x4b, 0x0e, 0xc5, 0xa4, 0xa2, 0xa6, 0x95, 0x66, 0xe2, 0xcb, 0x84 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 67 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x35, 0x35, 0xd5, 0x65, 0xac, 0xe3, 0xf3, 0x1e, 0xb2, 0x49, 0xba, 0x2c, 0xc6, 0x76, 0x5d, 0x7a }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 68 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf6, 0x0e, 0x91, 0xfc, 0x32, 0x69, 0xee, 0xcf, 0x32, 0x31, 0xc6, 0xe9, 0x94, 0x56, 0x97, 0xc6 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 69 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xab, 0x69, 0xcf, 0xad, 0xf5, 0x1f, 0x8e, 0x60, 0x4d, 0x9c, 0xc3, 0x71, 0x82, 0xf6, 0x63, 0x5a }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 70 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x78, 0x66, 0x37, 0x3f, 0x24, 0xa0, 0xb6, 0xed, 0x56, 0xe0, 0xd9, 0x6f, 0xcd, 0xaf, 0xb8, 0x77 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 71 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1e, 0xa4, 0x48, 0xc2, 0xaa, 0xc9, 0x54, 0xf5, 0xd8, 0x12, 0xe9, 0xd7, 0x84, 0x94, 0x44, 0x6a }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 72 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xac, 0xc5, 0x59, 0x9d, 0xd8, 0xac, 0x02, 0x23, 0x9a, 0x0f, 0xef, 0x4a, 0x36, 0xdd, 0x16, 0x68 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 73 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd8, 0x76, 0x44, 0x68, 0xbb, 0x10, 0x38, 0x28, 0xcf, 0x7e, 0x14, 0x73, 0xce, 0x89, 0x50, 0x73 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 74 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0x0d, 0x02, 0x89, 0x36, 0x83, 0xb9, 0xf1, 0x80, 0x45, 0x8e, 0x4a, 0xa6, 0xb7, 0x39, 0x82 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 75 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x96, 0xd9, 0xb0, 0x17, 0xd3, 0x02, 0xdf, 0x41, 0x0a, 0x93, 0x7d, 0xcd, 0xb8, 0xbb, 0x6e, 0x43 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 76 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xef, 0x16, 0x23, 0xcc, 0x44, 0x31, 0x3c, 0xff, 0x44, 0x0b, 0x15, 0x94, 0xa7, 0xe2, 0x1c, 0xc6 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 77 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x28, 0x4c, 0xa2, 0xfa, 0x35, 0x80, 0x7b, 0x8b, 0x0a, 0xe4, 0xd1, 0x9e, 0x11, 0xd7, 0xdb, 0xd7 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 78 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf2, 0xe9, 0x76, 0x87, 0x57, 0x55, 0xf9, 0x40, 0x1d, 0x54, 0xf3, 0x6e, 0x2a, 0x23, 0xa5, 0x94 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 79 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xec, 0x19, 0x8a, 0x18, 0xe1, 0x0e, 0x53, 0x24, 0x03, 0xb7, 0xe2, 0x08, 0x87, 0xc8, 0xdd, 0x80 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 80 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x54, 0x5d, 0x50, 0xeb, 0xd9, 0x19, 0xe4, 0xa6, 0x94, 0x9d, 0x96, 0xad, 0x47, 0xe4, 0x6a, 0x80 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 81 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdb, 0xdf, 0xb5, 0x27, 0x06, 0x0e, 0x0a, 0x71, 0x00, 0x9c, 0x7b, 0xb0, 0xc6, 0x8f, 0x1d, 0x44 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 82 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9c, 0xfa, 0x13, 0x22, 0xea, 0x33, 0xda, 0x21, 0x73, 0xa0, 0x24, 0xf2, 0xff, 0x0d, 0x89, 0x6d }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 83 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x87, 0x85, 0xb1, 0xa7, 0x5b, 0x0f, 0x3b, 0xd9, 0x58, 0xdc, 0xd0, 0xe2, 0x93, 0x18, 0xc5, 0x21 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 84 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x38, 0xf6, 0x7b, 0x9e, 0x98, 0xe4, 0xa9, 0x7b, 0x6d, 0xf0, 0x30, 0xa9, 0xfc, 0xdd, 0x01, 0x04 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 85 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x19, 0x2a, 0xff, 0xfb, 0x2c, 0x88, 0x0e, 0x82, 0xb0, 0x59, 0x26, 0xd0, 0xfc, 0x6c, 0x44, 0x8b }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 86 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6a, 0x79, 0x80, 0xce, 0x7b, 0x10, 0x5c, 0xf5, 0x30, 0x95, 0x2d, 0x74, 0xda, 0xaf, 0x79, 0x8c }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 87 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xea, 0x36, 0x95, 0xe1, 0x35, 0x1b, 0x9d, 0x68, 0x58, 0xbd, 0x95, 0x8c, 0xf5, 0x13, 0xef, 0x6c }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 88 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6d, 0xa0, 0x49, 0x0b, 0xa0, 0xba, 0x03, 0x43, 0xb9, 0x35, 0x68, 0x1d, 0x2c, 0xce, 0x5b, 0xa1 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 89 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf0, 0xea, 0x23, 0xaf, 0x08, 0x53, 0x40, 0x11, 0xc6, 0x00, 0x09, 0xab, 0x29, 0xad, 0xa2, 0xf1 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 90 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0x13, 0x80, 0x6c, 0xf1, 0x9c, 0xc3, 0x87, 0x21, 0x55, 0x4d, 0x7c, 0x0f, 0xcd, 0xcd, 0x4b }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 91 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x68, 0x38, 0xaf, 0x1f, 0x4f, 0x69, 0xba, 0xe9, 0xd8, 0x5d, 0xd1, 0x88, 0xdc, 0xdf, 0x06, 0x88 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 92 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x36, 0xcf, 0x44, 0xc9, 0x2d, 0x55, 0x0b, 0xfb, 0x1e, 0xd2, 0x8e, 0xf5, 0x83, 0xdd, 0xf5, 0xd7 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 93 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd0, 0x6e, 0x31, 0x95, 0xb5, 0x37, 0x6f, 0x10, 0x9d, 0x5c, 0x4e, 0xc6, 0xc5, 0xd6, 0x2c, 0xed }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 94 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc4, 0x40, 0xde, 0x01, 0x4d, 0x3d, 0x61, 0x07, 0x07, 0x27, 0x9b, 0x13, 0x24, 0x2a, 0x5c, 0x36 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 95 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf0, 0xc5, 0xc6, 0xff, 0xa5, 0xe0, 0xbd, 0x3a, 0x94, 0xc8, 0x8f, 0x6b, 0x6f, 0x7c, 0x16, 0xb9 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 96 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3e, 0x40, 0xc3, 0x90, 0x1c, 0xd7, 0xef, 0xfc, 0x22, 0xbf, 0xfc, 0x35, 0xde, 0xe0, 0xb4, 0xd9 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 97 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb6, 0x33, 0x05, 0xc7, 0x2b, 0xed, 0xfa, 0xb9, 0x73, 0x82, 0xc4, 0x06, 0xd0, 0xc4, 0x9b, 0xc6 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 98 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x36, 0xbb, 0xaa, 0xb2, 0x2a, 0x6b, 0xd4, 0x92, 0x5a, 0x99, 0xa2, 0xb4, 0x08, 0xd2, 0xdb, 0xae }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 99 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x30, 0x7c, 0x5b, 0x8f, 0xcd, 0x05, 0x33, 0xab, 0x98, 0xbc, 0x51, 0xe2, 0x7a, 0x6c, 0xe4, 0x61 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 100 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x82, 0x9c, 0x04, 0xff, 0x4c, 0x07, 0x51, 0x3c, 0x0b, 0x3e, 0xf0, 0x5c, 0x03, 0xe3, 0x37, 0xb5 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 101 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf1, 0x7a, 0xf0, 0xe8, 0x95, 0xdd, 0xa5, 0xeb, 0x98, 0xef, 0xc6, 0x80, 0x66, 0xe8, 0x4c, 0x54 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 102 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0x71, 0x67, 0xf3, 0x81, 0x2a, 0xff, 0xf1, 0xff, 0xac, 0xb4, 0xa9, 0x34, 0x37, 0x9f, 0xc3 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 103 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2c, 0xb1, 0xdc, 0x3a, 0x9c, 0x72, 0x97, 0x2e, 0x42, 0x5a, 0xe2, 0xef, 0x3e, 0xb5, 0x97, 0xcd }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 104 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x36, 0xae, 0xaa, 0x3a, 0x21, 0x3e, 0x96, 0x8d, 0x4b, 0x5b, 0x67, 0x9d, 0x3a, 0x2c, 0x97, 0xfe }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 105 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x92, 0x41, 0xda, 0xca, 0x4f, 0xdd, 0x03, 0x4a, 0x82, 0x37, 0x2d, 0xb5, 0x0e, 0x1a, 0x0f, 0x3f }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 106 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc1, 0x45, 0x74, 0xd9, 0xcd, 0x00, 0xcf, 0x2b, 0x5a, 0x7f, 0x77, 0xe5, 0x3c, 0xd5, 0x78, 0x85 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 107 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x79, 0x3d, 0xe3, 0x92, 0x36, 0x57, 0x0a, 0xba, 0x83, 0xab, 0x9b, 0x73, 0x7c, 0xb5, 0x21, 0xc9 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 108 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x16, 0x59, 0x1c, 0x0f, 0x27, 0xd6, 0x0e, 0x29, 0xb8, 0x5a, 0x96, 0xc3, 0x38, 0x61, 0xa7, 0xef }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 109 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x44, 0xfb, 0x5c, 0x4d, 0x4f, 0x5c, 0xb7, 0x9b, 0xe5, 0xc1, 0x74, 0xa3, 0xb1, 0xc9, 0x73, 0x48 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 110 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x67, 0x4d, 0x2b, 0x61, 0x63, 0x3d, 0x16, 0x2b, 0xe5, 0x9d, 0xde, 0x04, 0x22, 0x2f, 0x47, 0x40 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 111 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb4, 0x75, 0x0f, 0xf2, 0x63, 0xa6, 0x5e, 0x1f, 0x9e, 0x92, 0x4c, 0xcf, 0xd9, 0x8f, 0x3e, 0x37 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 112 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x62, 0xd0, 0x66, 0x2d, 0x6e, 0xae, 0xdd, 0xed, 0xeb, 0xae, 0x7f, 0x7e, 0xa3, 0xa4, 0xf6, 0xb6 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 113 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x70, 0xc4, 0x6b, 0xb3, 0x06, 0x92, 0xbe, 0x65, 0x7f, 0x7e, 0xaa, 0x93, 0xeb, 0xad, 0x98, 0x97 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 114 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x32, 0x39, 0x94, 0xcf, 0xb9, 0xda, 0x28, 0x5a, 0x5d, 0x96, 0x42, 0xe1, 0x75, 0x9b, 0x22, 0x4a }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 115 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1d, 0xbf, 0x57, 0x87, 0x7b, 0x7b, 0x17, 0x38, 0x5c, 0x85, 0xd0, 0xb5, 0x48, 0x51, 0xe3, 0x71 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 116 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdf, 0xa5, 0xc0, 0x97, 0xcd, 0xc1, 0x53, 0x2a, 0xc0, 0x71, 0xd5, 0x7b, 0x1d, 0x28, 0xd1, 0xbd }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 117 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0x0c, 0x53, 0xfa, 0x37, 0x31, 0x1f, 0xc1, 0x0b, 0xd2, 0xa9, 0x98, 0x1f, 0x51, 0x31, 0x74 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 118 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xba, 0x4f, 0x97, 0x0c, 0x0a, 0x25, 0xc4, 0x18, 0x14, 0xbd, 0xae, 0x2e, 0x50, 0x6b, 0xe3, 0xb4 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 119 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2d, 0xce, 0x3a, 0xcb, 0x72, 0x7c, 0xd1, 0x3c, 0xcd, 0x76, 0xd4, 0x25, 0xea, 0x56, 0xe4, 0xf6 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 120 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x51, 0x60, 0x47, 0x4d, 0x50, 0x4b, 0x9b, 0x3e, 0xef, 0xb6, 0x8d, 0x35, 0xf2, 0x45, 0xf4, 0xb3 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 121 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x41, 0xa8, 0xa9, 0x47, 0x76, 0x66, 0x35, 0xde, 0xc3, 0x75, 0x53, 0xd9, 0xa6, 0xc0, 0xcb, 0xb7 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 122 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x25, 0xd6, 0xcf, 0xe6, 0x88, 0x1f, 0x2b, 0xf4, 0x97, 0xdd, 0x14, 0xcd, 0x4d, 0xdf, 0x44, 0x5b }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 123 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x41, 0xc7, 0x8c, 0x13, 0x5e, 0xd9, 0xe9, 0x8c, 0x09, 0x66, 0x40, 0x64, 0x72, 0x65, 0xda, 0x1e }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 124 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5a, 0x4d, 0x40, 0x4d, 0x89, 0x17, 0xe3, 0x53, 0xe9, 0x2a, 0x21, 0x07, 0x2c, 0x3b, 0x23, 0x05 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 125 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x02, 0xbc, 0x96, 0x84, 0x6b, 0x3f, 0xdc, 0x71, 0x64, 0x3f, 0x38, 0x4c, 0xd3, 0xcc, 0x3e, 0xaf }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 126 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9b, 0xa4, 0xa9, 0x14, 0x3f, 0x4e, 0x5d, 0x40, 0x48, 0x52, 0x1c, 0x4f, 0x88, 0x77, 0xd8, 0x8e }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 127 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa1, 0xf6, 0x25, 0x8c, 0x87, 0x7d, 0x5f, 0xcd, 0x89, 0x64, 0x48, 0x45, 0x38, 0xbf, 0xc9, 0x2c }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 0 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0e, 0xdd, 0x33, 0xd3, 0xc6, 0x21, 0xe5, 0x46, 0x45, 0x5b, 0xd8, 0xba, 0x14, 0x18, 0xbe, 0xc8 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 1 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4b, 0xc3, 0xf8, 0x83, 0x45, 0x0c, 0x11, 0x3c, 0x64, 0xca, 0x42, 0xe1, 0x11, 0x2a, 0x9e, 0x87 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 2 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x72, 0xa1, 0xda, 0x77, 0x0f, 0x5d, 0x7a, 0xc4, 0xc9, 0xef, 0x94, 0xd8, 0x22, 0xaf, 0xfd, 0x97 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 3 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0x00, 0x14, 0xd6, 0x34, 0xe2, 0xb7, 0x65, 0x07, 0x77, 0xe8, 0xe8, 0x4d, 0x03, 0xcc, 0xd8 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 4 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf1, 0x7e, 0x79, 0xae, 0xd0, 0xdb, 0x7e, 0x27, 0x9e, 0x95, 0x5b, 0x5f, 0x49, 0x38, 0x75, 0xa7 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 5 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9e, 0xd5, 0xa7, 0x51, 0x36, 0xa9, 0x40, 0xd0, 0x96, 0x3d, 0xa3, 0x79, 0xdb, 0x4a, 0xf2, 0x6a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 6 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc4, 0x29, 0x5f, 0x83, 0x46, 0x5c, 0x77, 0x55, 0xe8, 0xfa, 0x36, 0x4b, 0xac, 0x6a, 0x7e, 0xa5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 7 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb1, 0xd7, 0x58, 0x25, 0x6b, 0x28, 0xfd, 0x85, 0x0a, 0xd4, 0x94, 0x42, 0x08, 0xcf, 0x11, 0x55 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 8 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x42, 0xff, 0xb3, 0x4c, 0x74, 0x3d, 0xe4, 0xd8, 0x8c, 0xa3, 0x80, 0x11, 0xc9, 0x90, 0x89, 0x0b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 9 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x99, 0x58, 0xf0, 0xec, 0xea, 0x8b, 0x21, 0x72, 0xc0, 0xc1, 0x99, 0x5f, 0x91, 0x82, 0xc0, 0xf3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 10 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x95, 0x6d, 0x77, 0x98, 0xfa, 0xc2, 0x0f, 0x82, 0xa8, 0x82, 0x3f, 0x98, 0x4d, 0x06, 0xf7, 0xf5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 11 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa0, 0x1b, 0xf4, 0x4f, 0x2d, 0x16, 0xbe, 0x92, 0x8c, 0xa4, 0x4a, 0xaf, 0x7b, 0x9b, 0x10, 0x6b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 12 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb5, 0xf1, 0xa3, 0x3e, 0x50, 0xd4, 0x0d, 0x10, 0x37, 0x64, 0xc7, 0x6b, 0xd4, 0xc6, 0xb6, 0xf8 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 13 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x26, 0x37, 0x05, 0x0c, 0x9f, 0xc0, 0xd4, 0x81, 0x7e, 0x2d, 0x69, 0xde, 0x87, 0x8a, 0xee, 0x8d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 14 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0x3e, 0xcb, 0xe4, 0xa4, 0x53, 0x26, 0x9a, 0x0d, 0xd2, 0x60, 0x69, 0x46, 0x7f, 0xb5, 0xb5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 15 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0xd0, 0x75, 0x4f, 0xe6, 0x8f, 0x11, 0xb9, 0xe3, 0x75, 0xd0, 0x70, 0xa6, 0x08, 0xc8, 0x84 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 16 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc6, 0xa0, 0xb3, 0xe9, 0x98, 0xd0, 0x50, 0x68, 0xa5, 0x39, 0x97, 0x78, 0x40, 0x52, 0x00, 0xb4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 17 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdf, 0x55, 0x6a, 0x33, 0x43, 0x8d, 0xb8, 0x7b, 0xc4, 0x1b, 0x17, 0x52, 0xc5, 0x5e, 0x5e, 0x49 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 18 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0xfb, 0x12, 0x8d, 0x3a, 0x1a, 0xf6, 0xe5, 0x48, 0x52, 0x1b, 0xb9, 0x62, 0xbf, 0x1f, 0x05 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 19 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x26, 0x29, 0x8e, 0x9c, 0x1d, 0xb5, 0x17, 0xc2, 0x15, 0xfa, 0xdf, 0xb7, 0xd2, 0xa8, 0xd6, 0x91 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 20 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa6, 0xcb, 0x76, 0x1d, 0x61, 0xf8, 0x29, 0x2d, 0x0d, 0xf3, 0x93, 0xa2, 0x79, 0xad, 0x03, 0x80 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 21 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x12, 0xac, 0xd8, 0x9b, 0x13, 0xcd, 0x5f, 0x87, 0x26, 0xe3, 0x4d, 0x44, 0xfd, 0x48, 0x61, 0x08 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 22 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x95, 0xb1, 0x70, 0x3f, 0xc5, 0x7b, 0xa0, 0x9f, 0xe0, 0xc3, 0x58, 0x0f, 0xeb, 0xdd, 0x7e, 0xd4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 23 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xde, 0x11, 0x72, 0x2d, 0x89, 0x3e, 0x9f, 0x91, 0x21, 0xc3, 0x81, 0xbe, 0xcc, 0x1d, 0xa5, 0x9a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 24 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6d, 0x11, 0x4c, 0xcb, 0x27, 0xbf, 0x39, 0x10, 0x12, 0xe8, 0x97, 0x4c, 0x54, 0x6d, 0x9b, 0xf2 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 25 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5c, 0xe3, 0x7e, 0x17, 0xeb, 0x46, 0x46, 0xec, 0xfa, 0xc2, 0x9b, 0x9c, 0xc3, 0x8d, 0x93, 0x40 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 26 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x18, 0xc1, 0xb6, 0xe2, 0x15, 0x71, 0x22, 0x05, 0x6d, 0x02, 0x43, 0xd8, 0xa1, 0x65, 0xcd, 0xdb }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 27 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x99, 0x69, 0x3e, 0x6a, 0x59, 0xd1, 0x36, 0x6c, 0x74, 0xd8, 0x23, 0x56, 0x2d, 0x7e, 0x14, 0x31 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 28 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6c, 0x7c, 0x64, 0xdc, 0x84, 0xa8, 0xbb, 0xa7, 0x58, 0xed, 0x17, 0xeb, 0x02, 0x5a, 0x57, 0xe3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 29 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe1, 0x7b, 0xc7, 0x9f, 0x30, 0xea, 0xab, 0x2f, 0xac, 0x2c, 0xbb, 0xe3, 0x45, 0x8d, 0x68, 0x7a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 30 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0x14, 0xbc, 0x20, 0x28, 0x00, 0x9b, 0x92, 0x3f, 0x0b, 0x01, 0x91, 0x5c, 0xe5, 0xe7, 0xc4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 31 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9c, 0x28, 0x52, 0x4a, 0x16, 0xa1, 0xe1, 0xc1, 0x45, 0x29, 0x71, 0xca, 0xa8, 0xd1, 0x34, 0x76 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 32 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xed, 0x62, 0xe1, 0x63, 0x63, 0x63, 0x83, 0x60, 0xfd, 0xd6, 0xad, 0x62, 0x11, 0x27, 0x94, 0xf0 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 33 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5a, 0x86, 0x88, 0xf0, 0xb2, 0xa2, 0xc1, 0x62, 0x24, 0xc1, 0x61, 0x65, 0x8f, 0xfd, 0x40, 0x44 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 34 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x23, 0xf7, 0x10, 0x84, 0x2b, 0x9b, 0xb9, 0xc3, 0x2f, 0x26, 0x64, 0x8c, 0x78, 0x68, 0x07, 0xca }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 35 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x44, 0xa9, 0x8b, 0xf1, 0x1e, 0x16, 0x3f, 0x63, 0x2c, 0x47, 0xec, 0x6a, 0x49, 0x68, 0x3a, 0x89 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 36 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0f, 0x18, 0xaf, 0xf9, 0x42, 0x74, 0x69, 0x6d, 0x9b, 0x61, 0x84, 0x8b, 0xd5, 0x0a, 0xc5, 0xe5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 37 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x82, 0x40, 0x85, 0x71, 0xc3, 0xe2, 0x42, 0x45, 0x40, 0x20, 0x7f, 0x83, 0x3b, 0x6d, 0xda, 0x69 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 38 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x30, 0x3f, 0xf9, 0x96, 0x94, 0x7f, 0x0c, 0x7d, 0x1f, 0x43, 0xc8, 0xf3, 0x02, 0x7b, 0x9b, 0x75 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 39 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7d, 0xf4, 0xda, 0xf4, 0xad, 0x29, 0xa3, 0x61, 0x5a, 0x9b, 0x6e, 0xce, 0x5c, 0x99, 0x51, 0x8a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 40 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc7, 0x29, 0x54, 0xa4, 0x8d, 0x07, 0x74, 0xdb, 0x0b, 0x49, 0x71, 0xc5, 0x26, 0x26, 0x04, 0x15 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 41 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1d, 0xf9, 0xb7, 0x61, 0x12, 0xdc, 0x65, 0x31, 0xe0, 0x7d, 0x2c, 0xfd, 0xa0, 0x44, 0x11, 0xf0 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 42 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8e, 0x4d, 0x8e, 0x69, 0x91, 0x19, 0xe1, 0xfc, 0x87, 0x54, 0x5a, 0x64, 0x7f, 0xb1, 0xd3, 0x4f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 43 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe6, 0xc4, 0x80, 0x7a, 0xe1, 0x1f, 0x36, 0xf0, 0x91, 0xc5, 0x7d, 0x9f, 0xb6, 0x85, 0x48, 0xd1 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 44 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8e, 0xbf, 0x73, 0xaa, 0xd4, 0x9c, 0x82, 0x00, 0x7f, 0x77, 0xa5, 0xc1, 0xcc, 0xec, 0x6a, 0xb4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 45 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4f, 0xb2, 0x88, 0xcc, 0x20, 0x40, 0x04, 0x90, 0x01, 0xd2, 0xc7, 0x58, 0x5a, 0xd1, 0x23, 0xfc }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 46 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x04, 0x49, 0x71, 0x10, 0xef, 0xb9, 0xdc, 0xeb, 0x13, 0xe2, 0xb1, 0x3f, 0xb4, 0x46, 0x55, 0x64 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 47 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x75, 0x55, 0x0e, 0x6c, 0xb5, 0xa8, 0x8e, 0x49, 0x63, 0x4c, 0x9a, 0xb6, 0x9e, 0xda, 0x04, 0x30 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 48 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb6, 0x76, 0x84, 0x73, 0xce, 0x98, 0x43, 0xea, 0x66, 0xa8, 0x14, 0x05, 0xdd, 0x50, 0xb3, 0x45 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 49 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcb, 0x2f, 0x43, 0x03, 0x83, 0xf9, 0x08, 0x4e, 0x03, 0xa6, 0x53, 0x57, 0x1e, 0x06, 0x5d, 0xe6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 50 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0x4e, 0x66, 0xc0, 0x7b, 0xae, 0x3e, 0x79, 0xfb, 0x7d, 0x21, 0x08, 0x47, 0xa3, 0xb0, 0xba }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 51 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7b, 0x90, 0x78, 0x51, 0x25, 0x50, 0x5f, 0xad, 0x59, 0xb1, 0x3c, 0x18, 0x6d, 0xd6, 0x6c, 0xe3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 52 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8b, 0x52, 0x7a, 0x6a, 0xeb, 0xda, 0xec, 0x9e, 0xae, 0xf8, 0xed, 0xa2, 0xcb, 0x77, 0x83, 0xe5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 53 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x43, 0xfd, 0xaf, 0x53, 0xeb, 0xbc, 0x98, 0x80, 0xc2, 0x28, 0x61, 0x7d, 0x6a, 0x9b, 0x54, 0x8b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 54 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x53, 0x78, 0x61, 0x04, 0xb9, 0x74, 0x4b, 0x98, 0xf0, 0x52, 0xc4, 0x6f, 0x1c, 0x85, 0x0d, 0x0b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 55 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb5, 0xab, 0x30, 0x13, 0xdd, 0x1e, 0x61, 0xdf, 0x06, 0xcb, 0xaf, 0x34, 0xca, 0x2a, 0xee, 0x78 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 56 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x74, 0x70, 0x46, 0x9b, 0xe9, 0x72, 0x30, 0x30, 0xfd, 0xcc, 0x73, 0xa8, 0xcd, 0x4f, 0xbb, 0x10 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 57 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa3, 0x5a, 0x63, 0xf5, 0x34, 0x3e, 0xbe, 0x9e, 0xf8, 0x16, 0x7b, 0xcb, 0x48, 0xad, 0x12, 0x2e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 58 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfd, 0x86, 0x87, 0xf0, 0x75, 0x7a, 0x21, 0x0e, 0x9f, 0xdf, 0x18, 0x12, 0x04, 0xc3, 0x08, 0x63 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 59 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7a, 0x18, 0x1e, 0x84, 0xbd, 0x54, 0x57, 0xd2, 0x6a, 0x88, 0xfb, 0xae, 0x96, 0x01, 0x8f, 0xb0 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 60 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x65, 0x33, 0x17, 0xb9, 0x36, 0x2b, 0x6f, 0x9b, 0x9e, 0x1a, 0x58, 0x0e, 0x68, 0xd4, 0x94, 0xb5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 61 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x99, 0x5c, 0x9d, 0xc0, 0xb6, 0x89, 0xf0, 0x3c, 0x45, 0x86, 0x7b, 0x5f, 0xaa, 0x5c, 0x18, 0xd1 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 62 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x77, 0xa4, 0xd9, 0x6d, 0x56, 0xdd, 0xa3, 0x98, 0xb9, 0xaa, 0xbe, 0xcf, 0xc7, 0x57, 0x29, 0xfd }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 63 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x84, 0xbe, 0x19, 0xe0, 0x53, 0x63, 0x5f, 0x09, 0xf2, 0x66, 0x5e, 0x7b, 0xae, 0x85, 0xb4, 0x2d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 64 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x32, 0xcd, 0x65, 0x28, 0x42, 0x92, 0x6a, 0xea, 0x4a, 0xa6, 0x13, 0x7b, 0xb2, 0xbe, 0x2b, 0x5e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 65 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x49, 0x3d, 0x4a, 0x4f, 0x38, 0xeb, 0xb3, 0x37, 0xd1, 0x0a, 0xa8, 0x4e, 0x91, 0x71, 0xa5, 0x54 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 66 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd9, 0xbf, 0xf7, 0xff, 0x45, 0x4b, 0x0e, 0xc5, 0xa4, 0xa2, 0xa6, 0x95, 0x66, 0xe2, 0xcb, 0x84 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 67 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x35, 0x35, 0xd5, 0x65, 0xac, 0xe3, 0xf3, 0x1e, 0xb2, 0x49, 0xba, 0x2c, 0xc6, 0x76, 0x5d, 0x7a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 68 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf6, 0x0e, 0x91, 0xfc, 0x32, 0x69, 0xee, 0xcf, 0x32, 0x31, 0xc6, 0xe9, 0x94, 0x56, 0x97, 0xc6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 69 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xab, 0x69, 0xcf, 0xad, 0xf5, 0x1f, 0x8e, 0x60, 0x4d, 0x9c, 0xc3, 0x71, 0x82, 0xf6, 0x63, 0x5a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 70 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x78, 0x66, 0x37, 0x3f, 0x24, 0xa0, 0xb6, 0xed, 0x56, 0xe0, 0xd9, 0x6f, 0xcd, 0xaf, 0xb8, 0x77 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 71 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1e, 0xa4, 0x48, 0xc2, 0xaa, 0xc9, 0x54, 0xf5, 0xd8, 0x12, 0xe9, 0xd7, 0x84, 0x94, 0x44, 0x6a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 72 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xac, 0xc5, 0x59, 0x9d, 0xd8, 0xac, 0x02, 0x23, 0x9a, 0x0f, 0xef, 0x4a, 0x36, 0xdd, 0x16, 0x68 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 73 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd8, 0x76, 0x44, 0x68, 0xbb, 0x10, 0x38, 0x28, 0xcf, 0x7e, 0x14, 0x73, 0xce, 0x89, 0x50, 0x73 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 74 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0x0d, 0x02, 0x89, 0x36, 0x83, 0xb9, 0xf1, 0x80, 0x45, 0x8e, 0x4a, 0xa6, 0xb7, 0x39, 0x82 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 75 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x96, 0xd9, 0xb0, 0x17, 0xd3, 0x02, 0xdf, 0x41, 0x0a, 0x93, 0x7d, 0xcd, 0xb8, 0xbb, 0x6e, 0x43 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 76 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xef, 0x16, 0x23, 0xcc, 0x44, 0x31, 0x3c, 0xff, 0x44, 0x0b, 0x15, 0x94, 0xa7, 0xe2, 0x1c, 0xc6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 77 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x28, 0x4c, 0xa2, 0xfa, 0x35, 0x80, 0x7b, 0x8b, 0x0a, 0xe4, 0xd1, 0x9e, 0x11, 0xd7, 0xdb, 0xd7 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 78 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf2, 0xe9, 0x76, 0x87, 0x57, 0x55, 0xf9, 0x40, 0x1d, 0x54, 0xf3, 0x6e, 0x2a, 0x23, 0xa5, 0x94 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 79 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xec, 0x19, 0x8a, 0x18, 0xe1, 0x0e, 0x53, 0x24, 0x03, 0xb7, 0xe2, 0x08, 0x87, 0xc8, 0xdd, 0x80 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 80 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x54, 0x5d, 0x50, 0xeb, 0xd9, 0x19, 0xe4, 0xa6, 0x94, 0x9d, 0x96, 0xad, 0x47, 0xe4, 0x6a, 0x80 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 81 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdb, 0xdf, 0xb5, 0x27, 0x06, 0x0e, 0x0a, 0x71, 0x00, 0x9c, 0x7b, 0xb0, 0xc6, 0x8f, 0x1d, 0x44 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 82 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9c, 0xfa, 0x13, 0x22, 0xea, 0x33, 0xda, 0x21, 0x73, 0xa0, 0x24, 0xf2, 0xff, 0x0d, 0x89, 0x6d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 83 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x87, 0x85, 0xb1, 0xa7, 0x5b, 0x0f, 0x3b, 0xd9, 0x58, 0xdc, 0xd0, 0xe2, 0x93, 0x18, 0xc5, 0x21 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 84 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x38, 0xf6, 0x7b, 0x9e, 0x98, 0xe4, 0xa9, 0x7b, 0x6d, 0xf0, 0x30, 0xa9, 0xfc, 0xdd, 0x01, 0x04 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 85 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x19, 0x2a, 0xff, 0xfb, 0x2c, 0x88, 0x0e, 0x82, 0xb0, 0x59, 0x26, 0xd0, 0xfc, 0x6c, 0x44, 0x8b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 86 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6a, 0x79, 0x80, 0xce, 0x7b, 0x10, 0x5c, 0xf5, 0x30, 0x95, 0x2d, 0x74, 0xda, 0xaf, 0x79, 0x8c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 87 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xea, 0x36, 0x95, 0xe1, 0x35, 0x1b, 0x9d, 0x68, 0x58, 0xbd, 0x95, 0x8c, 0xf5, 0x13, 0xef, 0x6c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 88 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6d, 0xa0, 0x49, 0x0b, 0xa0, 0xba, 0x03, 0x43, 0xb9, 0x35, 0x68, 0x1d, 0x2c, 0xce, 0x5b, 0xa1 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 89 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf0, 0xea, 0x23, 0xaf, 0x08, 0x53, 0x40, 0x11, 0xc6, 0x00, 0x09, 0xab, 0x29, 0xad, 0xa2, 0xf1 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 90 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0x13, 0x80, 0x6c, 0xf1, 0x9c, 0xc3, 0x87, 0x21, 0x55, 0x4d, 0x7c, 0x0f, 0xcd, 0xcd, 0x4b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 91 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x68, 0x38, 0xaf, 0x1f, 0x4f, 0x69, 0xba, 0xe9, 0xd8, 0x5d, 0xd1, 0x88, 0xdc, 0xdf, 0x06, 0x88 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 92 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x36, 0xcf, 0x44, 0xc9, 0x2d, 0x55, 0x0b, 0xfb, 0x1e, 0xd2, 0x8e, 0xf5, 0x83, 0xdd, 0xf5, 0xd7 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 93 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd0, 0x6e, 0x31, 0x95, 0xb5, 0x37, 0x6f, 0x10, 0x9d, 0x5c, 0x4e, 0xc6, 0xc5, 0xd6, 0x2c, 0xed }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 94 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc4, 0x40, 0xde, 0x01, 0x4d, 0x3d, 0x61, 0x07, 0x07, 0x27, 0x9b, 0x13, 0x24, 0x2a, 0x5c, 0x36 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 95 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf0, 0xc5, 0xc6, 0xff, 0xa5, 0xe0, 0xbd, 0x3a, 0x94, 0xc8, 0x8f, 0x6b, 0x6f, 0x7c, 0x16, 0xb9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 96 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3e, 0x40, 0xc3, 0x90, 0x1c, 0xd7, 0xef, 0xfc, 0x22, 0xbf, 0xfc, 0x35, 0xde, 0xe0, 0xb4, 0xd9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 97 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb6, 0x33, 0x05, 0xc7, 0x2b, 0xed, 0xfa, 0xb9, 0x73, 0x82, 0xc4, 0x06, 0xd0, 0xc4, 0x9b, 0xc6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 98 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x36, 0xbb, 0xaa, 0xb2, 0x2a, 0x6b, 0xd4, 0x92, 0x5a, 0x99, 0xa2, 0xb4, 0x08, 0xd2, 0xdb, 0xae }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 99 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x30, 0x7c, 0x5b, 0x8f, 0xcd, 0x05, 0x33, 0xab, 0x98, 0xbc, 0x51, 0xe2, 0x7a, 0x6c, 0xe4, 0x61 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 100 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x82, 0x9c, 0x04, 0xff, 0x4c, 0x07, 0x51, 0x3c, 0x0b, 0x3e, 0xf0, 0x5c, 0x03, 0xe3, 0x37, 0xb5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 101 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf1, 0x7a, 0xf0, 0xe8, 0x95, 0xdd, 0xa5, 0xeb, 0x98, 0xef, 0xc6, 0x80, 0x66, 0xe8, 0x4c, 0x54 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 102 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0x71, 0x67, 0xf3, 0x81, 0x2a, 0xff, 0xf1, 0xff, 0xac, 0xb4, 0xa9, 0x34, 0x37, 0x9f, 0xc3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 103 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2c, 0xb1, 0xdc, 0x3a, 0x9c, 0x72, 0x97, 0x2e, 0x42, 0x5a, 0xe2, 0xef, 0x3e, 0xb5, 0x97, 0xcd }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 104 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x36, 0xae, 0xaa, 0x3a, 0x21, 0x3e, 0x96, 0x8d, 0x4b, 0x5b, 0x67, 0x9d, 0x3a, 0x2c, 0x97, 0xfe }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 105 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x92, 0x41, 0xda, 0xca, 0x4f, 0xdd, 0x03, 0x4a, 0x82, 0x37, 0x2d, 0xb5, 0x0e, 0x1a, 0x0f, 0x3f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 106 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc1, 0x45, 0x74, 0xd9, 0xcd, 0x00, 0xcf, 0x2b, 0x5a, 0x7f, 0x77, 0xe5, 0x3c, 0xd5, 0x78, 0x85 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 107 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x79, 0x3d, 0xe3, 0x92, 0x36, 0x57, 0x0a, 0xba, 0x83, 0xab, 0x9b, 0x73, 0x7c, 0xb5, 0x21, 0xc9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 108 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x16, 0x59, 0x1c, 0x0f, 0x27, 0xd6, 0x0e, 0x29, 0xb8, 0x5a, 0x96, 0xc3, 0x38, 0x61, 0xa7, 0xef }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 109 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x44, 0xfb, 0x5c, 0x4d, 0x4f, 0x5c, 0xb7, 0x9b, 0xe5, 0xc1, 0x74, 0xa3, 0xb1, 0xc9, 0x73, 0x48 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 110 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x67, 0x4d, 0x2b, 0x61, 0x63, 0x3d, 0x16, 0x2b, 0xe5, 0x9d, 0xde, 0x04, 0x22, 0x2f, 0x47, 0x40 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 111 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb4, 0x75, 0x0f, 0xf2, 0x63, 0xa6, 0x5e, 0x1f, 0x9e, 0x92, 0x4c, 0xcf, 0xd9, 0x8f, 0x3e, 0x37 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 112 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x62, 0xd0, 0x66, 0x2d, 0x6e, 0xae, 0xdd, 0xed, 0xeb, 0xae, 0x7f, 0x7e, 0xa3, 0xa4, 0xf6, 0xb6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 113 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x70, 0xc4, 0x6b, 0xb3, 0x06, 0x92, 0xbe, 0x65, 0x7f, 0x7e, 0xaa, 0x93, 0xeb, 0xad, 0x98, 0x97 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 114 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x32, 0x39, 0x94, 0xcf, 0xb9, 0xda, 0x28, 0x5a, 0x5d, 0x96, 0x42, 0xe1, 0x75, 0x9b, 0x22, 0x4a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 115 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1d, 0xbf, 0x57, 0x87, 0x7b, 0x7b, 0x17, 0x38, 0x5c, 0x85, 0xd0, 0xb5, 0x48, 0x51, 0xe3, 0x71 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 116 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdf, 0xa5, 0xc0, 0x97, 0xcd, 0xc1, 0x53, 0x2a, 0xc0, 0x71, 0xd5, 0x7b, 0x1d, 0x28, 0xd1, 0xbd }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 117 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0x0c, 0x53, 0xfa, 0x37, 0x31, 0x1f, 0xc1, 0x0b, 0xd2, 0xa9, 0x98, 0x1f, 0x51, 0x31, 0x74 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 118 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xba, 0x4f, 0x97, 0x0c, 0x0a, 0x25, 0xc4, 0x18, 0x14, 0xbd, 0xae, 0x2e, 0x50, 0x6b, 0xe3, 0xb4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 119 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2d, 0xce, 0x3a, 0xcb, 0x72, 0x7c, 0xd1, 0x3c, 0xcd, 0x76, 0xd4, 0x25, 0xea, 0x56, 0xe4, 0xf6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 120 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x51, 0x60, 0x47, 0x4d, 0x50, 0x4b, 0x9b, 0x3e, 0xef, 0xb6, 0x8d, 0x35, 0xf2, 0x45, 0xf4, 0xb3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 121 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x41, 0xa8, 0xa9, 0x47, 0x76, 0x66, 0x35, 0xde, 0xc3, 0x75, 0x53, 0xd9, 0xa6, 0xc0, 0xcb, 0xb7 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 122 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x25, 0xd6, 0xcf, 0xe6, 0x88, 0x1f, 0x2b, 0xf4, 0x97, 0xdd, 0x14, 0xcd, 0x4d, 0xdf, 0x44, 0x5b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 123 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x41, 0xc7, 0x8c, 0x13, 0x5e, 0xd9, 0xe9, 0x8c, 0x09, 0x66, 0x40, 0x64, 0x72, 0x65, 0xda, 0x1e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 124 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5a, 0x4d, 0x40, 0x4d, 0x89, 0x17, 0xe3, 0x53, 0xe9, 0x2a, 0x21, 0x07, 0x2c, 0x3b, 0x23, 0x05 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 125 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x02, 0xbc, 0x96, 0x84, 0x6b, 0x3f, 0xdc, 0x71, 0x64, 0x3f, 0x38, 0x4c, 0xd3, 0xcc, 0x3e, 0xaf }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 126 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9b, 0xa4, 0xa9, 0x14, 0x3f, 0x4e, 0x5d, 0x40, 0x48, 0x52, 0x1c, 0x4f, 0x88, 0x77, 0xd8, 0x8e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey128.rsp test vector 127 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa1, 0xf6, 0x25, 0x8c, 0x87, 0x7d, 0x5f, 0xcd, 0x89, 0x64, 0x48, 0x45, 0x38, 0xbf, 0xc9, 0x2c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 0 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xde, 0x88, 0x5d, 0xc8, 0x7f, 0x5a, 0x92, 0x59, 0x40, 0x82, 0xd0, 0x2c, 0xc1, 0xe1, 0xb4, 0x2c }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 1 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x13, 0x2b, 0x07, 0x4e, 0x80, 0xf2, 0xa5, 0x97, 0xbf, 0x5f, 0xeb, 0xd8, 0xea, 0x5d, 0xa5, 0x5e }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 2 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6e, 0xcc, 0xed, 0xf8, 0xde, 0x59, 0x2c, 0x22, 0xfb, 0x81, 0x34, 0x7b, 0x79, 0xf2, 0xdb, 0x1f }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 3 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x18, 0x0b, 0x09, 0xf2, 0x67, 0xc4, 0x51, 0x45, 0xdb, 0x2f, 0x82, 0x6c, 0x25, 0x82, 0xd3, 0x5c }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 4 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xed, 0xd8, 0x07, 0xef, 0x76, 0x52, 0xd7, 0xeb, 0x0e, 0x13, 0xc8, 0xb5, 0xe1, 0x5b, 0x3b, 0xc0 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 5 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x99, 0x78, 0xbc, 0xf8, 0xdd, 0x8f, 0xd7, 0x22, 0x41, 0x22, 0x3a, 0xd2, 0x4b, 0x31, 0xb8, 0xa4 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 6 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x53, 0x10, 0xf6, 0x54, 0x34, 0x3e, 0x8f, 0x27, 0xe1, 0x2c, 0x83, 0xa4, 0x8d, 0x24, 0xff, 0x81 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 7 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x83, 0x3f, 0x71, 0x25, 0x8d, 0x53, 0x03, 0x6b, 0x02, 0x95, 0x2c, 0x76, 0xc7, 0x44, 0xf5, 0xa1 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 8 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xeb, 0xa8, 0x3f, 0xf2, 0x00, 0xcf, 0xf9, 0x31, 0x8a, 0x92, 0xf8, 0x69, 0x1a, 0x06, 0xb0, 0x9f }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 9 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0x62, 0x0c, 0xcb, 0xe9, 0xf3, 0x29, 0x2a, 0xbd, 0xf2, 0x17, 0x6b, 0x09, 0xf0, 0x4e, 0xba }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 10 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7a, 0xba, 0xbc, 0x4b, 0x3f, 0x51, 0x6c, 0x9a, 0xaf, 0xb3, 0x5f, 0x41, 0x40, 0xb5, 0x48, 0xf9 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 11 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xaa, 0x18, 0x78, 0x24, 0xd9, 0xc4, 0x58, 0x2b, 0x09, 0x16, 0x49, 0x3e, 0xcb, 0xde, 0x8c, 0x57 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 12 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1c, 0x0a, 0xd5, 0x53, 0x17, 0x7f, 0xd5, 0xea, 0x10, 0x92, 0xc9, 0xd6, 0x26, 0xa2, 0x9d, 0xc4 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 13 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa5, 0xdc, 0x46, 0xc3, 0x72, 0x61, 0x19, 0x41, 0x24, 0xec, 0xae, 0xbd, 0x68, 0x04, 0x08, 0xec }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 14 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe4, 0xf2, 0xf2, 0xae, 0x23, 0xe9, 0xb1, 0x0b, 0xac, 0xfa, 0x58, 0x60, 0x15, 0x31, 0xba, 0x54 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 15 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb7, 0xd6, 0x7c, 0xf1, 0xa1, 0xe9, 0x1e, 0x8f, 0xf3, 0xa5, 0x7a, 0x17, 0x2c, 0x7b, 0xf4, 0x12 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 16 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x26, 0x70, 0x6b, 0xe0, 0x69, 0x67, 0x88, 0x4e, 0x84, 0x7d, 0x13, 0x71, 0x28, 0xce, 0x47, 0xb3 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 17 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb2, 0xf8, 0xb4, 0x09, 0xb0, 0x58, 0x59, 0x09, 0xaa, 0xd3, 0xa7, 0xb5, 0xa2, 0x19, 0x07, 0x2a }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 18 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5e, 0x4b, 0x7b, 0xff, 0x02, 0x90, 0xc7, 0x83, 0x44, 0xc5, 0x4a, 0x23, 0xb7, 0x22, 0xcd, 0x20 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 19 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x07, 0x09, 0x36, 0x57, 0x55, 0x2d, 0x44, 0x14, 0x22, 0x7c, 0xe1, 0x61, 0xe9, 0xeb, 0xf7, 0xdd }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 20 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe1, 0xaf, 0x1e, 0x7d, 0x8b, 0xc2, 0x25, 0xed, 0x4d, 0xff, 0xb7, 0x71, 0xec, 0xbb, 0x9e, 0x67 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 21 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xef, 0x65, 0x55, 0x25, 0x36, 0x35, 0xd8, 0x43, 0x21, 0x56, 0xcf, 0xd9, 0xc1, 0x1b, 0x14, 0x5a }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 22 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfb, 0x40, 0x35, 0x07, 0x4a, 0x5d, 0x42, 0x60, 0xc9, 0x0c, 0xbd, 0x6d, 0xa6, 0xc3, 0xfc, 0xeb }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 23 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x44, 0x6e, 0xe4, 0x16, 0xf9, 0xad, 0x1c, 0x10, 0x3e, 0xb0, 0xcc, 0x96, 0x75, 0x1c, 0x88, 0xe1 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 24 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x19, 0x8a, 0xe2, 0xa4, 0x63, 0x7a, 0xc0, 0xa7, 0x89, 0x0a, 0x8f, 0xd1, 0x48, 0x54, 0x45, 0xc9 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 25 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x56, 0x20, 0x12, 0xec, 0x8f, 0xad, 0xed, 0x08, 0x25, 0xfb, 0x2f, 0xa7, 0x0a, 0xb3, 0x0c, 0xbd }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 26 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcc, 0x8a, 0x64, 0xb4, 0x6b, 0x5d, 0x88, 0xbf, 0x7f, 0x24, 0x7d, 0x4d, 0xba, 0xf3, 0x8f, 0x05 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 27 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa1, 0x68, 0x25, 0x37, 0x62, 0xe2, 0xcc, 0x81, 0xb4, 0x2d, 0x1e, 0x50, 0x01, 0x76, 0x26, 0x99 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 28 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0x41, 0xf8, 0x3b, 0x38, 0xce, 0x50, 0x32, 0xc6, 0xcd, 0x7a, 0xf9, 0x8c, 0xf6, 0x20, 0x61 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 29 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x61, 0xa8, 0x99, 0x90, 0xcd, 0x14, 0x11, 0x75, 0x0d, 0x5f, 0xb0, 0xdc, 0x98, 0x84, 0x47, 0xd4 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 30 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb5, 0xac, 0xcc, 0x8e, 0xd6, 0x29, 0xed, 0xf8, 0xc6, 0x8a, 0x53, 0x91, 0x83, 0xb1, 0xea, 0x82 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 31 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb1, 0x6f, 0xa7, 0x1f, 0x84, 0x6b, 0x81, 0xa1, 0x3f, 0x36, 0x1c, 0x43, 0xa8, 0x51, 0xf2, 0x90 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 32 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4f, 0xad, 0x6e, 0xfd, 0xff, 0x59, 0x75, 0xae, 0xe7, 0x69, 0x22, 0x34, 0xbc, 0xd5, 0x44, 0x88 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 33 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xeb, 0xfd, 0xb0, 0x5a, 0x78, 0x3d, 0x03, 0x08, 0x2d, 0xfe, 0x5f, 0xdd, 0x80, 0xa0, 0x0b, 0x17 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 34 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xeb, 0x81, 0xb5, 0x84, 0x76, 0x69, 0x97, 0xaf, 0x6b, 0xa5, 0x52, 0x9d, 0x3b, 0xdd, 0x86, 0x09 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 35 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0c, 0xf4, 0xff, 0x4f, 0x49, 0xc8, 0xa0, 0xca, 0x06, 0x0c, 0x44, 0x34, 0x99, 0xe2, 0x93, 0x13 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 36 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcc, 0x4b, 0xa8, 0xa8, 0xe0, 0x29, 0xf8, 0xb2, 0x6d, 0x8a, 0xff, 0xf9, 0xdf, 0x13, 0x3b, 0xb6 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 37 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfe, 0xfe, 0xbf, 0x64, 0x36, 0x0f, 0x38, 0xe4, 0xe6, 0x35, 0x58, 0xf0, 0xff, 0xc5, 0x50, 0xc3 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 38 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x12, 0xad, 0x98, 0xcb, 0xf7, 0x25, 0x13, 0x7d, 0x6a, 0x81, 0x08, 0xc2, 0xbe, 0xd9, 0x93, 0x22 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 39 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6a, 0xfa, 0xa9, 0x96, 0x22, 0x61, 0x98, 0xb3, 0xe2, 0x61, 0x04, 0x13, 0xce, 0x1b, 0x3f, 0x78 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 40 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2a, 0x8c, 0xe6, 0x74, 0x7a, 0x7e, 0x39, 0x36, 0x78, 0x28, 0xe2, 0x90, 0x84, 0x85, 0x02, 0xd9 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 41 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x22, 0x37, 0x36, 0xe8, 0xb8, 0xf8, 0x9c, 0xa1, 0xe3, 0x7b, 0x6d, 0xea, 0xb4, 0x0f, 0xac, 0xf1 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 42 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc0, 0xf7, 0x97, 0xe5, 0x04, 0x18, 0xb9, 0x5f, 0xa6, 0x01, 0x33, 0x33, 0x91, 0x7a, 0x94, 0x80 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 43 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa7, 0x58, 0xde, 0x37, 0xc2, 0xec, 0xe2, 0xa0, 0x2c, 0x73, 0xc0, 0x1f, 0xed, 0xc9, 0xa1, 0x32 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 44 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0x9b, 0x87, 0xae, 0x77, 0xba, 0xe7, 0x06, 0x80, 0x39, 0x66, 0xc6, 0x6c, 0x73, 0xad, 0xbd }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 45 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd3, 0x65, 0xab, 0x8d, 0xf8, 0xff, 0xd7, 0x82, 0xe3, 0x58, 0x12, 0x1a, 0x4a, 0x4f, 0xc5, 0x41 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 46 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc8, 0xdc, 0xd9, 0xe6, 0xf7, 0x5e, 0x6c, 0x36, 0xc8, 0xda, 0xee, 0x04, 0x66, 0xf0, 0xed, 0x74 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 47 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc7, 0x9a, 0x63, 0x7b, 0xeb, 0x1c, 0x03, 0x04, 0xf1, 0x40, 0x14, 0xc0, 0x37, 0xe7, 0x36, 0xdd }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 48 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x10, 0x5f, 0x0a, 0x25, 0xe8, 0x4a, 0xc9, 0x30, 0xd9, 0x96, 0x28, 0x1a, 0x5f, 0x95, 0x4d, 0xd9 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 49 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x42, 0xe4, 0x07, 0x4b, 0x29, 0x27, 0x97, 0x3e, 0x8d, 0x17, 0xff, 0xa9, 0x2f, 0x7f, 0xe6, 0x15 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 50 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4f, 0xe2, 0xa9, 0xd2, 0xc1, 0x82, 0x44, 0x49, 0xc6, 0x9e, 0x3e, 0x03, 0x98, 0xf1, 0x29, 0x63 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 51 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb7, 0xf2, 0x9c, 0x1e, 0x1f, 0x62, 0x84, 0x7a, 0x15, 0x25, 0x3b, 0x28, 0xa1, 0xe9, 0xd7, 0x12 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 52 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x36, 0xed, 0x5d, 0x29, 0xb9, 0x03, 0xf3, 0x1e, 0x89, 0x83, 0xef, 0x8b, 0x0a, 0x2b, 0xf9, 0x90 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 53 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0xb8, 0x07, 0x02, 0x70, 0x81, 0x0f, 0x9d, 0x02, 0x3f, 0x9d, 0xd7, 0xff, 0x3b, 0x4a, 0xa2 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 54 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x94, 0xd4, 0x6e, 0x15, 0x5c, 0x12, 0x28, 0xf6, 0x1d, 0x1a, 0x0d, 0xb4, 0x81, 0x5e, 0xcc, 0x4b }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 55 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xca, 0x61, 0x08, 0xd1, 0xd9, 0x80, 0x71, 0x42, 0x8e, 0xec, 0xee, 0xf1, 0x71, 0x4b, 0x96, 0xdd }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 56 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdc, 0x5b, 0x25, 0xb7, 0x1b, 0x62, 0x96, 0xcf, 0x73, 0xdd, 0x2c, 0xdc, 0xac, 0x2f, 0x70, 0xb1 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 57 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x44, 0xab, 0xa9, 0x5e, 0x8a, 0x06, 0xa2, 0xd9, 0xd3, 0x53, 0x0d, 0x26, 0x77, 0x87, 0x8c, 0x80 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 58 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa5, 0x70, 0xd2, 0x0e, 0x89, 0xb4, 0x67, 0xe8, 0xf5, 0x17, 0x60, 0x61, 0xb8, 0x1d, 0xd3, 0x96 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 59 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x75, 0x8f, 0x44, 0x67, 0xa5, 0xd8, 0xf1, 0xe7, 0x30, 0x7d, 0xc3, 0x0b, 0x34, 0xe4, 0x04, 0xf4 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 60 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbc, 0xea, 0x28, 0xe9, 0x07, 0x1b, 0x5a, 0x23, 0x02, 0x97, 0x0f, 0xf3, 0x52, 0x45, 0x1b, 0xc5 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 61 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x75, 0x23, 0xc0, 0x0b, 0xc1, 0x77, 0xd3, 0x31, 0xad, 0x31, 0x2e, 0x09, 0xc9, 0x01, 0x5c, 0x1c }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 62 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcc, 0xac, 0x61, 0xe3, 0x18, 0x37, 0x47, 0xb3, 0xf5, 0x83, 0x6d, 0xa2, 0x1a, 0x1b, 0xc4, 0xf4 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 63 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x70, 0x7b, 0x07, 0x57, 0x91, 0x87, 0x88, 0x80, 0xb4, 0x41, 0x89, 0xd3, 0x52, 0x2b, 0x8c, 0x30 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 64 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x71, 0x32, 0xd0, 0xc0, 0xe4, 0xa0, 0x75, 0x93, 0xcf, 0x12, 0xeb, 0xb1, 0x2b, 0xe7, 0x68, 0x8c }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 65 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xef, 0xfb, 0xac, 0x16, 0x44, 0xde, 0xb0, 0xc7, 0x84, 0x27, 0x5f, 0xe5, 0x6e, 0x19, 0xea, 0xd3 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 66 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa0, 0x05, 0x06, 0x3f, 0x30, 0xf4, 0x22, 0x8b, 0x37, 0x4e, 0x24, 0x59, 0x73, 0x8f, 0x26, 0xbb }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 67 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x29, 0x97, 0x5b, 0x5f, 0x48, 0xbb, 0x68, 0xfc, 0xbb, 0xc7, 0xce, 0xa9, 0x3b, 0x45, 0x2e, 0xd7 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 68 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcf, 0x3f, 0x25, 0x76, 0xe2, 0xaf, 0xed, 0xc7, 0x4b, 0xb1, 0xca, 0x7e, 0xee, 0xc1, 0xc0, 0xe7 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 69 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x07, 0xc4, 0x03, 0xf5, 0xf9, 0x66, 0xe0, 0xe3, 0xd9, 0xf2, 0x96, 0xd6, 0x22, 0x6d, 0xca, 0x28 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 70 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc8, 0xc2, 0x09, 0x08, 0x24, 0x9a, 0xb4, 0xa3, 0x4d, 0x6d, 0xd0, 0xa3, 0x13, 0x27, 0xff, 0x1a }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 71 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc0, 0x54, 0x13, 0x29, 0xec, 0xb6, 0x15, 0x9a, 0xb2, 0x3b, 0x7f, 0xc5, 0xe6, 0xa2, 0x1b, 0xca }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 72 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7a, 0xa1, 0xac, 0xf1, 0xa2, 0xed, 0x9b, 0xa7, 0x2b, 0xc6, 0xde, 0xb3, 0x1d, 0x88, 0xb8, 0x63 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 73 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x80, 0x8b, 0xd8, 0xed, 0xda, 0xbb, 0x6f, 0x3b, 0xf0, 0xd5, 0xa8, 0xa2, 0x7b, 0xe1, 0xfe, 0x8a }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 74 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0x3c, 0x7d, 0x76, 0x85, 0xe1, 0x4e, 0xc6, 0x6b, 0xbb, 0x96, 0xb8, 0xf0, 0x5b, 0x6d, 0xdd }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 75 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x32, 0x75, 0x2e, 0xef, 0xc8, 0xc2, 0xa9, 0x3f, 0x91, 0xb6, 0xe7, 0x3e, 0xb0, 0x7c, 0xca, 0x6e }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 76 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd8, 0x93, 0xe7, 0xd6, 0x2f, 0x6c, 0xe5, 0x02, 0xc6, 0x4f, 0x75, 0xe2, 0x81, 0xf9, 0xc0, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 77 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8d, 0xfd, 0x99, 0x9b, 0xe5, 0xd0, 0xcf, 0xa3, 0x57, 0x32, 0xc0, 0xdd, 0xc8, 0x8f, 0xf5, 0xa5 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 78 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x02, 0x64, 0x7c, 0x76, 0xa3, 0x00, 0xc3, 0x17, 0x3b, 0x84, 0x14, 0x87, 0xeb, 0x2b, 0xae, 0x9f }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 79 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x17, 0x2d, 0xf8, 0xb0, 0x2f, 0x04, 0xb5, 0x3a, 0xda, 0xb0, 0x28, 0xb4, 0xe0, 0x1a, 0xcd, 0x87 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 80 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x05, 0x4b, 0x3b, 0xf4, 0x99, 0x8a, 0xeb, 0x05, 0xaf, 0xd8, 0x7e, 0xc5, 0x36, 0x53, 0x3a, 0x36 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 81 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x37, 0x83, 0xf7, 0xbf, 0x44, 0xc9, 0x7f, 0x06, 0x52, 0x58, 0xa6, 0x66, 0xca, 0xe0, 0x30, 0x20 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 82 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xaa, 0xd4, 0xc8, 0xa6, 0x3f, 0x80, 0x95, 0x41, 0x04, 0xde, 0x7b, 0x92, 0xce, 0xde, 0x1b, 0xe1 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 83 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcb, 0xfe, 0x61, 0x81, 0x0f, 0xd5, 0x46, 0x7c, 0xcd, 0xac, 0xb7, 0x58, 0x00, 0xf3, 0xac, 0x07 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 84 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x83, 0x0d, 0x8a, 0x25, 0x90, 0xf7, 0xd8, 0xe1, 0xb5, 0x5a, 0x73, 0x7f, 0x4a, 0xf4, 0x5f, 0x34 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 85 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xfc, 0xd4, 0x68, 0x3f, 0x85, 0x80, 0x58, 0xe7, 0x43, 0x14, 0x67, 0x1d, 0x43, 0xfa, 0x2c }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 86 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x52, 0x3d, 0x0b, 0xab, 0xbb, 0x82, 0xf4, 0x6e, 0xbc, 0x9e, 0x70, 0xb1, 0xcd, 0x41, 0xdd, 0xd0 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 87 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x34, 0x4a, 0xab, 0x37, 0x08, 0x0d, 0x74, 0x86, 0xf7, 0xd5, 0x42, 0xa3, 0x09, 0xe5, 0x3e, 0xed }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 88 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x56, 0xc5, 0x60, 0x9d, 0x09, 0x06, 0xb2, 0x3a, 0xb9, 0xca, 0xca, 0x81, 0x6f, 0x5d, 0xbe, 0xbd }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 89 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x70, 0x26, 0x02, 0x6e, 0xed, 0xd9, 0x1a, 0xdc, 0x6d, 0x83, 0x1c, 0xdf, 0x98, 0x94, 0xbd, 0xc6 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 90 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x88, 0x33, 0x0b, 0xaa, 0x4f, 0x2b, 0x61, 0x8f, 0xc9, 0xd9, 0xb0, 0x21, 0xbf, 0x50, 0x3d, 0x5a }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 91 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfc, 0x9e, 0x0e, 0xa2, 0x24, 0x80, 0xb0, 0xba, 0xc9, 0x35, 0xc8, 0xa8, 0xeb, 0xef, 0xcd, 0xcf }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 92 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x29, 0xca, 0x77, 0x9f, 0x39, 0x8f, 0xb0, 0x4f, 0x86, 0x7d, 0xa7, 0xe8, 0xa4, 0x47, 0x56, 0xcb }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 93 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x51, 0xf8, 0x9c, 0x42, 0x98, 0x57, 0x86, 0xbf, 0xc4, 0x3c, 0x6d, 0xf8, 0xad, 0xa3, 0x68, 0x32 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 94 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6a, 0xc1, 0xde, 0x5f, 0xb8, 0xf2, 0x1d, 0x87, 0x4e, 0x91, 0xc5, 0x3b, 0x56, 0x0c, 0x50, 0xe3 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 95 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x03, 0xaa, 0x90, 0x58, 0x49, 0x0e, 0xda, 0x30, 0x60, 0x01, 0xa8, 0xa9, 0xf4, 0x8d, 0x0c, 0xa7 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 96 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe3, 0x4e, 0xc7, 0x1d, 0x61, 0x28, 0xd4, 0x87, 0x18, 0x65, 0xd6, 0x17, 0xc3, 0x0b, 0x37, 0xe3 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 97 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x14, 0xbe, 0x1c, 0x53, 0x5b, 0x17, 0xca, 0xbd, 0x0c, 0x4d, 0x93, 0x52, 0x9d, 0x69, 0xbf, 0x47 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 98 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc9, 0xef, 0x67, 0x75, 0x65, 0x07, 0xbe, 0xec, 0x9d, 0xd3, 0x86, 0x28, 0x83, 0x47, 0x80, 0x44 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 99 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x40, 0xe2, 0x31, 0xfa, 0x5a, 0x59, 0x48, 0xce, 0x21, 0x34, 0xe9, 0x2f, 0xc0, 0x66, 0x4d, 0x4b }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 100 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x03, 0x19, 0x4b, 0x8e, 0x5d, 0xda, 0x55, 0x30, 0xd0, 0xc6, 0x78, 0xc0, 0xb4, 0x8f, 0x5d, 0x92 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 101 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0xbd, 0x08, 0x6f, 0x23, 0x7c, 0xc4, 0xfd, 0x99, 0xf4, 0xd7, 0x6b, 0xde, 0x6b, 0x48, 0x26 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 102 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x19, 0x25, 0x97, 0x61, 0xca, 0x17, 0x13, 0x0d, 0x6e, 0xd8, 0x6d, 0x57, 0xcd, 0x79, 0x51, 0xee }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 103 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd7, 0xcb, 0xb3, 0xf3, 0x4b, 0x9b, 0x45, 0x0f, 0x24, 0xb0, 0xe8, 0x51, 0x8e, 0x54, 0xda, 0x6d }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 104 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x72, 0x5b, 0x9c, 0xae, 0xbe, 0x9f, 0x7f, 0x41, 0x7f, 0x40, 0x68, 0xd0, 0xd2, 0xee, 0x20, 0xb3 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 105 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9d, 0x92, 0x4b, 0x93, 0x4a, 0x90, 0xce, 0x1f, 0xd3, 0x9b, 0x8a, 0x97, 0x94, 0xf8, 0x26, 0x72 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 106 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc5, 0x05, 0x62, 0xbf, 0x09, 0x45, 0x26, 0xa9, 0x1c, 0x5b, 0xc6, 0x3c, 0x0c, 0x22, 0x49, 0x95 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 107 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0xf1, 0x18, 0x05, 0x04, 0x67, 0x43, 0xbd, 0x74, 0xf5, 0x71, 0x88, 0xd9, 0x18, 0x8d, 0xf7 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 108 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8d, 0xd2, 0x74, 0xbd, 0x0f, 0x1b, 0x58, 0xae, 0x34, 0x5d, 0x9e, 0x72, 0x33, 0xf9, 0xb8, 0xf3 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 109 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9d, 0x6b, 0xdc, 0x8f, 0x4c, 0xe5, 0xfe, 0xb0, 0xf3, 0xbe, 0xd2, 0xe4, 0xb9, 0xa9, 0xbb, 0x0b }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 110 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfd, 0x55, 0x48, 0xbc, 0xf3, 0xf4, 0x25, 0x65, 0xf7, 0xef, 0xa9, 0x45, 0x62, 0x52, 0x8d, 0x46 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 111 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0xcc, 0xae, 0xbd, 0x3a, 0x4c, 0x3e, 0x80, 0xb0, 0x63, 0x74, 0x81, 0x31, 0xba, 0x4a, 0x71 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 112 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe0, 0x3c, 0xb2, 0x3d, 0x9e, 0x11, 0xc9, 0xd9, 0x3f, 0x11, 0x7e, 0x9c, 0x0a, 0x91, 0xb5, 0x76 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 113 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x78, 0xf9, 0x33, 0xa2, 0x08, 0x1a, 0xc1, 0xdb, 0x84, 0xf6, 0x9d, 0x10, 0xf4, 0x52, 0x3f, 0xe0 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 114 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x40, 0x61, 0xf7, 0x41, 0x2e, 0xd3, 0x20, 0xde, 0x0e, 0xdc, 0x88, 0x51, 0xc2, 0xe2, 0x43, 0x6f }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 115 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0x64, 0xba, 0x1c, 0xd0, 0x4c, 0xe6, 0xba, 0xb9, 0x84, 0x74, 0x33, 0x08, 0x14, 0xb4, 0xd4 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 116 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x48, 0x39, 0x1b, 0xff, 0xb9, 0xcf, 0xff, 0x80, 0xac, 0x23, 0x8c, 0x88, 0x6e, 0xf0, 0xa4, 0x61 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 117 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb8, 0xd2, 0xa6, 0x7d, 0xf5, 0xa9, 0x99, 0xfd, 0xbf, 0x93, 0xed, 0xd0, 0x34, 0x32, 0x96, 0xc9 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 118 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xaa, 0xca, 0x73, 0x67, 0x39, 0x6b, 0x69, 0xa2, 0x21, 0xbd, 0x63, 0x2b, 0xea, 0x38, 0x6e, 0xec }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 119 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa8, 0x0f, 0xd5, 0x02, 0x0d, 0xfe, 0x65, 0xf5, 0xf1, 0x62, 0x93, 0xec, 0x92, 0xc6, 0xfd, 0x89 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 120 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x21, 0x62, 0x99, 0x5b, 0x82, 0x17, 0xa6, 0x7f, 0x1a, 0xbc, 0x34, 0x2e, 0x14, 0x64, 0x06, 0xf8 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 121 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc6, 0xa6, 0x16, 0x4b, 0x7a, 0x60, 0xba, 0xe4, 0xe9, 0x86, 0xff, 0xac, 0x28, 0xdf, 0xad, 0xd9 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 122 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x64, 0xe0, 0xd7, 0xf9, 0x00, 0xe3, 0xd9, 0xc8, 0x3e, 0x4b, 0x8f, 0x96, 0x71, 0x7b, 0x21, 0x46 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 123 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1a, 0xd2, 0x56, 0x1d, 0xe8, 0xc1, 0x23, 0x2f, 0x5d, 0x8d, 0xba, 0xb4, 0x73, 0x9b, 0x6c, 0xbb }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 124 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0x96, 0x89, 0xe9, 0xa5, 0x57, 0xf5, 0x8b, 0x1c, 0x3b, 0xf4, 0x0c, 0x97, 0xa9, 0x09, 0x64 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 125 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc4, 0x63, 0x7e, 0x4a, 0x5e, 0x63, 0x77, 0xf9, 0xcc, 0x5a, 0x86, 0x38, 0x04, 0x5d, 0xe0, 0x29 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 126 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x49, 0x2e, 0x60, 0x7e, 0x5a, 0xea, 0x46, 0x88, 0x59, 0x4b, 0x45, 0xf3, 0xae, 0xe3, 0xdf, 0x90 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 127 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe8, 0xc4, 0xe4, 0x38, 0x1f, 0xee, 0xc7, 0x40, 0x54, 0x95, 0x4c, 0x05, 0xb7, 0x77, 0xa0, 0x0a }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 128 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x91, 0x54, 0x95, 0x14, 0x60, 0x5f, 0x38, 0x24, 0x6c, 0x9b, 0x72, 0x4a, 0xd8, 0x39, 0xf0, 0x1d }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 129 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x74, 0xb2, 0x4e, 0x3b, 0x6f, 0xef, 0xe4, 0x0a, 0x4f, 0x9e, 0xf7, 0xac, 0x6e, 0x44, 0xd7, 0x6a }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 130 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x24, 0x37, 0xa6, 0x83, 0xdc, 0x5d, 0x4b, 0x52, 0xab, 0xb4, 0xa1, 0x23, 0xa8, 0xdf, 0x86, 0xc6 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 131 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbb, 0x28, 0x52, 0xc8, 0x91, 0xc5, 0x94, 0x7d, 0x2e, 0xd4, 0x40, 0x32, 0xc4, 0x21, 0xb8, 0x5f }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 132 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0x9f, 0x5f, 0xbd, 0x5e, 0x8a, 0x42, 0x64, 0xc0, 0xa8, 0x5b, 0x80, 0x40, 0x9a, 0xfa, 0x5e }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 133 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x30, 0xda, 0xb8, 0x09, 0xf8, 0x5a, 0x91, 0x7f, 0xe9, 0x24, 0x73, 0x3f, 0x42, 0x4a, 0xc5, 0x89 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 134 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xea, 0xef, 0x5c, 0x1f, 0x8d, 0x60, 0x51, 0x92, 0x64, 0x66, 0x95, 0xce, 0xad, 0xc6, 0x5f, 0x32 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 135 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb8, 0xaa, 0x90, 0x04, 0x0b, 0x4c, 0x15, 0xa1, 0x23, 0x16, 0xb7, 0x8e, 0x0f, 0x95, 0x86, 0xfc }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 136 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0xfa, 0xc8, 0x29, 0x7c, 0xea, 0xab, 0xc8, 0x7d, 0x45, 0x43, 0x50, 0x60, 0x1e, 0x06, 0x73 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 137 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9b, 0x47, 0xef, 0x56, 0x7a, 0xc2, 0x8d, 0xfe, 0x48, 0x84, 0x92, 0xf1, 0x57, 0xe2, 0xb2, 0xe0 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 138 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0x84, 0x26, 0x02, 0x7d, 0xdb, 0x96, 0x2b, 0x5c, 0x5b, 0xa7, 0xeb, 0x8b, 0xc9, 0xab, 0x63 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 139 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe9, 0x17, 0xfc, 0x77, 0xe7, 0x19, 0x92, 0xa1, 0x2d, 0xbe, 0x4c, 0x18, 0x06, 0x8b, 0xec, 0x82 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 140 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdc, 0xee, 0xbb, 0xc9, 0x88, 0x40, 0xf8, 0xae, 0x6d, 0xaf, 0x76, 0x57, 0x3b, 0x7e, 0x56, 0xf4 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 141 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4e, 0x11, 0xa9, 0xf7, 0x42, 0x05, 0x12, 0x5b, 0x61, 0xe0, 0xae, 0xe0, 0x47, 0xec, 0xa2, 0x0d }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 142 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf6, 0x04, 0x67, 0xf5, 0x5a, 0x1f, 0x17, 0xea, 0xb8, 0x8e, 0x80, 0x01, 0x20, 0xcb, 0xc2, 0x84 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 143 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd4, 0x36, 0x64, 0x9f, 0x60, 0x0b, 0x44, 0x9e, 0xe2, 0x76, 0x53, 0x0f, 0x0c, 0xd8, 0x3c, 0x11 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 144 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3b, 0xc0, 0xe3, 0x65, 0x6a, 0x9e, 0x3a, 0xc7, 0xcd, 0x37, 0x8a, 0x73, 0x7f, 0x53, 0xb6, 0x37 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 145 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6b, 0xac, 0xae, 0x63, 0xd3, 0x3b, 0x92, 0x8a, 0xa8, 0x38, 0x0f, 0x8d, 0x54, 0xd8, 0x8c, 0x17 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 146 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x89, 0x35, 0xff, 0xbc, 0x75, 0xae, 0x62, 0x51, 0xbf, 0x8e, 0x85, 0x9f, 0x08, 0x5a, 0xdc, 0xb9 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 147 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x93, 0xdc, 0x49, 0x70, 0xfe, 0x35, 0xf6, 0x77, 0x47, 0xcb, 0x05, 0x62, 0xc0, 0x6d, 0x87, 0x5a }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 148 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x14, 0xf9, 0xdf, 0x85, 0x89, 0x75, 0x85, 0x17, 0x97, 0xba, 0x60, 0x4f, 0xb0, 0xd1, 0x6c, 0xc7 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 149 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x02, 0xea, 0x0c, 0x98, 0xdc, 0xa1, 0x0b, 0x38, 0xc2, 0x1b, 0x3b, 0x14, 0xe8, 0xd1, 0xb7, 0x1f }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 150 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8f, 0x09, 0x1b, 0x1b, 0x5b, 0x07, 0x49, 0xb2, 0xad, 0xc8, 0x03, 0xe6, 0x3d, 0xda, 0x9b, 0x72 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 151 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x05, 0xb3, 0x89, 0xe3, 0x32, 0x2c, 0x6d, 0xa0, 0x83, 0x84, 0x34, 0x5a, 0x41, 0x37, 0xfd, 0x08 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 152 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x38, 0x13, 0x08, 0xc4, 0x38, 0xf3, 0x5b, 0x39, 0x9f, 0x10, 0xad, 0x71, 0xb0, 0x50, 0x27, 0xd8 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 153 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x68, 0xc2, 0x30, 0xfc, 0xfa, 0x92, 0x79, 0xc3, 0x40, 0x9f, 0xc4, 0x23, 0xe2, 0xac, 0xbe, 0x04 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 154 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1c, 0x84, 0xa4, 0x75, 0xac, 0xb0, 0x11, 0xf3, 0xf5, 0x9f, 0x4f, 0x46, 0xb7, 0x62, 0x74, 0xc0 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 155 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x45, 0x11, 0x9b, 0x68, 0xcb, 0x3f, 0x83, 0x99, 0xee, 0x60, 0x06, 0x6b, 0x56, 0x11, 0xa4, 0xd7 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 156 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x94, 0x23, 0x76, 0x2f, 0x52, 0x7a, 0x40, 0x60, 0xff, 0xca, 0x31, 0x2d, 0xcc, 0xa2, 0x2a, 0x16 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 157 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf3, 0x61, 0xa2, 0x74, 0x5a, 0x33, 0xf0, 0x56, 0xa5, 0xac, 0x6a, 0xce, 0x2f, 0x08, 0xe3, 0x44 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 158 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5e, 0xf1, 0x45, 0x76, 0x6e, 0xca, 0x84, 0x9f, 0x5d, 0x01, 0x15, 0x36, 0xa6, 0x55, 0x7f, 0xdb }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 159 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc9, 0xaf, 0x27, 0xb2, 0xc8, 0x9c, 0x9b, 0x4c, 0xf4, 0xa0, 0xc4, 0x10, 0x6a, 0xc8, 0x03, 0x18 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 160 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfb, 0x9c, 0x4f, 0x16, 0xc6, 0x21, 0xf4, 0xea, 0xb7, 0xe9, 0xac, 0x1d, 0x75, 0x51, 0xdd, 0x57 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 161 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x13, 0x8e, 0x06, 0xfb, 0xa4, 0x66, 0xfa, 0x70, 0x85, 0x4d, 0x8c, 0x2e, 0x52, 0x4c, 0xff, 0xb2 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 162 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfb, 0x4b, 0xc7, 0x8b, 0x22, 0x50, 0x70, 0x77, 0x3f, 0x04, 0xc4, 0x04, 0x66, 0xd4, 0xe9, 0x0c }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 163 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8b, 0x2c, 0xbf, 0xf1, 0xed, 0x01, 0x50, 0xfe, 0xda, 0x8a, 0x47, 0x99, 0xbe, 0x94, 0x55, 0x1f }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 164 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x08, 0xb3, 0x0d, 0x7b, 0x3f, 0x27, 0x96, 0x27, 0x09, 0xa3, 0x6b, 0xca, 0xdf, 0xb9, 0x74, 0xbd }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 165 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfd, 0xf6, 0xd3, 0x2e, 0x04, 0x4d, 0x77, 0xad, 0xcf, 0x37, 0xfb, 0x97, 0xac, 0x21, 0x33, 0x26 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 166 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x93, 0xcb, 0x28, 0x4e, 0xcd, 0xcf, 0xd7, 0x81, 0xa8, 0xaf, 0xe3, 0x20, 0x77, 0x94, 0x9e, 0x88 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 167 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7b, 0x01, 0x7b, 0xb0, 0x2e, 0xc8, 0x7b, 0x2b, 0x94, 0xc9, 0x6e, 0x40, 0xa2, 0x6f, 0xc7, 0x1a }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 168 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc5, 0xc0, 0x38, 0xb6, 0x99, 0x06, 0x64, 0xab, 0x08, 0xa3, 0xaa, 0xa5, 0xdf, 0x9f, 0x32, 0x66 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 169 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4b, 0x70, 0x20, 0xbe, 0x37, 0xfa, 0xb6, 0x25, 0x9b, 0x2a, 0x27, 0xf4, 0xec, 0x55, 0x15, 0x76 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 170 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x60, 0x13, 0x67, 0x03, 0x37, 0x4f, 0x64, 0xe8, 0x60, 0xb4, 0x8c, 0xe3, 0x1f, 0x93, 0x07, 0x16 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 171 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8d, 0x63, 0xa2, 0x69, 0xb1, 0x4d, 0x50, 0x6c, 0xcc, 0x40, 0x1a, 0xb8, 0xa9, 0xf1, 0xb5, 0x91 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 172 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd3, 0x17, 0xf8, 0x1d, 0xc6, 0xaa, 0x45, 0x4a, 0xee, 0x4b, 0xd4, 0xa5, 0xa5, 0xcf, 0xf4, 0xbd }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 173 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdd, 0xde, 0xce, 0xcd, 0x53, 0x54, 0xf0, 0x4d, 0x53, 0x0d, 0x76, 0xed, 0x88, 0x42, 0x46, 0xeb }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 174 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x41, 0xc5, 0x20, 0x5c, 0xc8, 0xfd, 0x8e, 0xda, 0x9a, 0x3c, 0xff, 0xd2, 0x51, 0x8f, 0x36, 0x5a }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 175 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcf, 0x42, 0xfb, 0x47, 0x42, 0x93, 0xd9, 0x6e, 0xca, 0x9d, 0xb1, 0xb3, 0x7b, 0x1b, 0xa6, 0x76 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 176 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa2, 0x31, 0x69, 0x26, 0x07, 0x16, 0x9b, 0x4e, 0xcd, 0xea, 0xd5, 0xcd, 0x3b, 0x10, 0xdb, 0x3e }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 177 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xac, 0xe4, 0xb9, 0x1c, 0x9c, 0x66, 0x9e, 0x77, 0xe7, 0xac, 0xac, 0xd1, 0x98, 0x59, 0xed, 0x49 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 178 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x75, 0xdb, 0x7c, 0xfd, 0x4a, 0x7b, 0x2b, 0x62, 0xab, 0x78, 0xa4, 0x8f, 0x3d, 0xda, 0xf4, 0xaf }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 179 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc1, 0xfa, 0xba, 0x2d, 0x46, 0xe2, 0x59, 0xcf, 0x48, 0x0d, 0x7c, 0x38, 0xe4, 0x57, 0x2a, 0x58 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 180 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x24, 0x1c, 0x45, 0xbc, 0x6a, 0xe1, 0x6d, 0xee, 0x6e, 0xb7, 0xbe, 0xa1, 0x28, 0x70, 0x15, 0x82 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 181 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8f, 0xd0, 0x30, 0x57, 0xcf, 0x13, 0x64, 0x42, 0x0c, 0x2b, 0x78, 0x06, 0x9a, 0x3e, 0x25, 0x02 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 182 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdd, 0xb5, 0x05, 0xe6, 0xcc, 0x13, 0x84, 0xcb, 0xae, 0xc1, 0xdf, 0x90, 0xb8, 0x0b, 0xeb, 0x20 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 183 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x56, 0x74, 0xa3, 0xbe, 0xd2, 0x7b, 0xf4, 0xbd, 0x36, 0x22, 0xf9, 0xf5, 0xfe, 0x20, 0x83, 0x06 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 184 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb6, 0x87, 0xf2, 0x6a, 0x89, 0xcf, 0xbf, 0xbb, 0x8e, 0x5e, 0xea, 0xc5, 0x40, 0x55, 0x31, 0x5e }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 185 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x05, 0x47, 0xdd, 0x32, 0xd3, 0xb2, 0x9a, 0xb6, 0xa4, 0xca, 0xeb, 0x60, 0x6c, 0x5b, 0x6f, 0x78 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 186 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x18, 0x68, 0x61, 0xf8, 0xbc, 0x53, 0x86, 0xd3, 0x1f, 0xb7, 0x7f, 0x72, 0x0c, 0x32, 0x26, 0xe6 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 187 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xea, 0xcf, 0x1e, 0x6c, 0x42, 0x24, 0xef, 0xb3, 0x89, 0x00, 0xb1, 0x85, 0xab, 0x1d, 0xfd, 0x42 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 188 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0x41, 0xaa, 0xb0, 0x5a, 0x42, 0xd3, 0x19, 0xde, 0x81, 0xd8, 0x74, 0xf5, 0xc7, 0xb9, 0x0d }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 189 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5e, 0xb9, 0xbc, 0x75, 0x9e, 0x2a, 0xd8, 0xd2, 0x14, 0x0a, 0x6c, 0x76, 0x2a, 0xe9, 0xe1, 0xab }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 190 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x01, 0x85, 0x96, 0xe1, 0x5e, 0x78, 0xe2, 0xc0, 0x64, 0x15, 0x9d, 0xef, 0xce, 0x5f, 0x30, 0x85 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 191 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdd, 0x8a, 0x49, 0x35, 0x14, 0x23, 0x1c, 0xbf, 0x56, 0xec, 0xce, 0xe4, 0xc4, 0x08, 0x89, 0xfb }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 0 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xde, 0x88, 0x5d, 0xc8, 0x7f, 0x5a, 0x92, 0x59, 0x40, 0x82, 0xd0, 0x2c, 0xc1, 0xe1, 0xb4, 0x2c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 1 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x13, 0x2b, 0x07, 0x4e, 0x80, 0xf2, 0xa5, 0x97, 0xbf, 0x5f, 0xeb, 0xd8, 0xea, 0x5d, 0xa5, 0x5e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 2 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6e, 0xcc, 0xed, 0xf8, 0xde, 0x59, 0x2c, 0x22, 0xfb, 0x81, 0x34, 0x7b, 0x79, 0xf2, 0xdb, 0x1f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 3 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x18, 0x0b, 0x09, 0xf2, 0x67, 0xc4, 0x51, 0x45, 0xdb, 0x2f, 0x82, 0x6c, 0x25, 0x82, 0xd3, 0x5c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 4 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xed, 0xd8, 0x07, 0xef, 0x76, 0x52, 0xd7, 0xeb, 0x0e, 0x13, 0xc8, 0xb5, 0xe1, 0x5b, 0x3b, 0xc0 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 5 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x99, 0x78, 0xbc, 0xf8, 0xdd, 0x8f, 0xd7, 0x22, 0x41, 0x22, 0x3a, 0xd2, 0x4b, 0x31, 0xb8, 0xa4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 6 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x53, 0x10, 0xf6, 0x54, 0x34, 0x3e, 0x8f, 0x27, 0xe1, 0x2c, 0x83, 0xa4, 0x8d, 0x24, 0xff, 0x81 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 7 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x83, 0x3f, 0x71, 0x25, 0x8d, 0x53, 0x03, 0x6b, 0x02, 0x95, 0x2c, 0x76, 0xc7, 0x44, 0xf5, 0xa1 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 8 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xeb, 0xa8, 0x3f, 0xf2, 0x00, 0xcf, 0xf9, 0x31, 0x8a, 0x92, 0xf8, 0x69, 0x1a, 0x06, 0xb0, 0x9f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 9 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0x62, 0x0c, 0xcb, 0xe9, 0xf3, 0x29, 0x2a, 0xbd, 0xf2, 0x17, 0x6b, 0x09, 0xf0, 0x4e, 0xba }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 10 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7a, 0xba, 0xbc, 0x4b, 0x3f, 0x51, 0x6c, 0x9a, 0xaf, 0xb3, 0x5f, 0x41, 0x40, 0xb5, 0x48, 0xf9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 11 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xaa, 0x18, 0x78, 0x24, 0xd9, 0xc4, 0x58, 0x2b, 0x09, 0x16, 0x49, 0x3e, 0xcb, 0xde, 0x8c, 0x57 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 12 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1c, 0x0a, 0xd5, 0x53, 0x17, 0x7f, 0xd5, 0xea, 0x10, 0x92, 0xc9, 0xd6, 0x26, 0xa2, 0x9d, 0xc4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 13 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa5, 0xdc, 0x46, 0xc3, 0x72, 0x61, 0x19, 0x41, 0x24, 0xec, 0xae, 0xbd, 0x68, 0x04, 0x08, 0xec }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 14 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe4, 0xf2, 0xf2, 0xae, 0x23, 0xe9, 0xb1, 0x0b, 0xac, 0xfa, 0x58, 0x60, 0x15, 0x31, 0xba, 0x54 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 15 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb7, 0xd6, 0x7c, 0xf1, 0xa1, 0xe9, 0x1e, 0x8f, 0xf3, 0xa5, 0x7a, 0x17, 0x2c, 0x7b, 0xf4, 0x12 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 16 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x26, 0x70, 0x6b, 0xe0, 0x69, 0x67, 0x88, 0x4e, 0x84, 0x7d, 0x13, 0x71, 0x28, 0xce, 0x47, 0xb3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 17 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb2, 0xf8, 0xb4, 0x09, 0xb0, 0x58, 0x59, 0x09, 0xaa, 0xd3, 0xa7, 0xb5, 0xa2, 0x19, 0x07, 0x2a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 18 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5e, 0x4b, 0x7b, 0xff, 0x02, 0x90, 0xc7, 0x83, 0x44, 0xc5, 0x4a, 0x23, 0xb7, 0x22, 0xcd, 0x20 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 19 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x07, 0x09, 0x36, 0x57, 0x55, 0x2d, 0x44, 0x14, 0x22, 0x7c, 0xe1, 0x61, 0xe9, 0xeb, 0xf7, 0xdd }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 20 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe1, 0xaf, 0x1e, 0x7d, 0x8b, 0xc2, 0x25, 0xed, 0x4d, 0xff, 0xb7, 0x71, 0xec, 0xbb, 0x9e, 0x67 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 21 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xef, 0x65, 0x55, 0x25, 0x36, 0x35, 0xd8, 0x43, 0x21, 0x56, 0xcf, 0xd9, 0xc1, 0x1b, 0x14, 0x5a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 22 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfb, 0x40, 0x35, 0x07, 0x4a, 0x5d, 0x42, 0x60, 0xc9, 0x0c, 0xbd, 0x6d, 0xa6, 0xc3, 0xfc, 0xeb }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 23 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x44, 0x6e, 0xe4, 0x16, 0xf9, 0xad, 0x1c, 0x10, 0x3e, 0xb0, 0xcc, 0x96, 0x75, 0x1c, 0x88, 0xe1 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 24 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x19, 0x8a, 0xe2, 0xa4, 0x63, 0x7a, 0xc0, 0xa7, 0x89, 0x0a, 0x8f, 0xd1, 0x48, 0x54, 0x45, 0xc9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 25 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x56, 0x20, 0x12, 0xec, 0x8f, 0xad, 0xed, 0x08, 0x25, 0xfb, 0x2f, 0xa7, 0x0a, 0xb3, 0x0c, 0xbd }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 26 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcc, 0x8a, 0x64, 0xb4, 0x6b, 0x5d, 0x88, 0xbf, 0x7f, 0x24, 0x7d, 0x4d, 0xba, 0xf3, 0x8f, 0x05 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 27 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa1, 0x68, 0x25, 0x37, 0x62, 0xe2, 0xcc, 0x81, 0xb4, 0x2d, 0x1e, 0x50, 0x01, 0x76, 0x26, 0x99 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 28 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0x41, 0xf8, 0x3b, 0x38, 0xce, 0x50, 0x32, 0xc6, 0xcd, 0x7a, 0xf9, 0x8c, 0xf6, 0x20, 0x61 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 29 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x61, 0xa8, 0x99, 0x90, 0xcd, 0x14, 0x11, 0x75, 0x0d, 0x5f, 0xb0, 0xdc, 0x98, 0x84, 0x47, 0xd4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 30 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb5, 0xac, 0xcc, 0x8e, 0xd6, 0x29, 0xed, 0xf8, 0xc6, 0x8a, 0x53, 0x91, 0x83, 0xb1, 0xea, 0x82 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 31 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb1, 0x6f, 0xa7, 0x1f, 0x84, 0x6b, 0x81, 0xa1, 0x3f, 0x36, 0x1c, 0x43, 0xa8, 0x51, 0xf2, 0x90 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 32 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4f, 0xad, 0x6e, 0xfd, 0xff, 0x59, 0x75, 0xae, 0xe7, 0x69, 0x22, 0x34, 0xbc, 0xd5, 0x44, 0x88 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 33 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xeb, 0xfd, 0xb0, 0x5a, 0x78, 0x3d, 0x03, 0x08, 0x2d, 0xfe, 0x5f, 0xdd, 0x80, 0xa0, 0x0b, 0x17 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 34 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xeb, 0x81, 0xb5, 0x84, 0x76, 0x69, 0x97, 0xaf, 0x6b, 0xa5, 0x52, 0x9d, 0x3b, 0xdd, 0x86, 0x09 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 35 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0c, 0xf4, 0xff, 0x4f, 0x49, 0xc8, 0xa0, 0xca, 0x06, 0x0c, 0x44, 0x34, 0x99, 0xe2, 0x93, 0x13 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 36 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcc, 0x4b, 0xa8, 0xa8, 0xe0, 0x29, 0xf8, 0xb2, 0x6d, 0x8a, 0xff, 0xf9, 0xdf, 0x13, 0x3b, 0xb6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 37 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfe, 0xfe, 0xbf, 0x64, 0x36, 0x0f, 0x38, 0xe4, 0xe6, 0x35, 0x58, 0xf0, 0xff, 0xc5, 0x50, 0xc3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 38 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x12, 0xad, 0x98, 0xcb, 0xf7, 0x25, 0x13, 0x7d, 0x6a, 0x81, 0x08, 0xc2, 0xbe, 0xd9, 0x93, 0x22 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 39 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6a, 0xfa, 0xa9, 0x96, 0x22, 0x61, 0x98, 0xb3, 0xe2, 0x61, 0x04, 0x13, 0xce, 0x1b, 0x3f, 0x78 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 40 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2a, 0x8c, 0xe6, 0x74, 0x7a, 0x7e, 0x39, 0x36, 0x78, 0x28, 0xe2, 0x90, 0x84, 0x85, 0x02, 0xd9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 41 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x22, 0x37, 0x36, 0xe8, 0xb8, 0xf8, 0x9c, 0xa1, 0xe3, 0x7b, 0x6d, 0xea, 0xb4, 0x0f, 0xac, 0xf1 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 42 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc0, 0xf7, 0x97, 0xe5, 0x04, 0x18, 0xb9, 0x5f, 0xa6, 0x01, 0x33, 0x33, 0x91, 0x7a, 0x94, 0x80 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 43 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa7, 0x58, 0xde, 0x37, 0xc2, 0xec, 0xe2, 0xa0, 0x2c, 0x73, 0xc0, 0x1f, 0xed, 0xc9, 0xa1, 0x32 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 44 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0x9b, 0x87, 0xae, 0x77, 0xba, 0xe7, 0x06, 0x80, 0x39, 0x66, 0xc6, 0x6c, 0x73, 0xad, 0xbd }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 45 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd3, 0x65, 0xab, 0x8d, 0xf8, 0xff, 0xd7, 0x82, 0xe3, 0x58, 0x12, 0x1a, 0x4a, 0x4f, 0xc5, 0x41 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 46 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc8, 0xdc, 0xd9, 0xe6, 0xf7, 0x5e, 0x6c, 0x36, 0xc8, 0xda, 0xee, 0x04, 0x66, 0xf0, 0xed, 0x74 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 47 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc7, 0x9a, 0x63, 0x7b, 0xeb, 0x1c, 0x03, 0x04, 0xf1, 0x40, 0x14, 0xc0, 0x37, 0xe7, 0x36, 0xdd }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 48 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x10, 0x5f, 0x0a, 0x25, 0xe8, 0x4a, 0xc9, 0x30, 0xd9, 0x96, 0x28, 0x1a, 0x5f, 0x95, 0x4d, 0xd9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 49 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x42, 0xe4, 0x07, 0x4b, 0x29, 0x27, 0x97, 0x3e, 0x8d, 0x17, 0xff, 0xa9, 0x2f, 0x7f, 0xe6, 0x15 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 50 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4f, 0xe2, 0xa9, 0xd2, 0xc1, 0x82, 0x44, 0x49, 0xc6, 0x9e, 0x3e, 0x03, 0x98, 0xf1, 0x29, 0x63 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 51 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb7, 0xf2, 0x9c, 0x1e, 0x1f, 0x62, 0x84, 0x7a, 0x15, 0x25, 0x3b, 0x28, 0xa1, 0xe9, 0xd7, 0x12 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 52 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x36, 0xed, 0x5d, 0x29, 0xb9, 0x03, 0xf3, 0x1e, 0x89, 0x83, 0xef, 0x8b, 0x0a, 0x2b, 0xf9, 0x90 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 53 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0xb8, 0x07, 0x02, 0x70, 0x81, 0x0f, 0x9d, 0x02, 0x3f, 0x9d, 0xd7, 0xff, 0x3b, 0x4a, 0xa2 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 54 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x94, 0xd4, 0x6e, 0x15, 0x5c, 0x12, 0x28, 0xf6, 0x1d, 0x1a, 0x0d, 0xb4, 0x81, 0x5e, 0xcc, 0x4b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 55 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xca, 0x61, 0x08, 0xd1, 0xd9, 0x80, 0x71, 0x42, 0x8e, 0xec, 0xee, 0xf1, 0x71, 0x4b, 0x96, 0xdd }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 56 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdc, 0x5b, 0x25, 0xb7, 0x1b, 0x62, 0x96, 0xcf, 0x73, 0xdd, 0x2c, 0xdc, 0xac, 0x2f, 0x70, 0xb1 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 57 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x44, 0xab, 0xa9, 0x5e, 0x8a, 0x06, 0xa2, 0xd9, 0xd3, 0x53, 0x0d, 0x26, 0x77, 0x87, 0x8c, 0x80 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 58 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa5, 0x70, 0xd2, 0x0e, 0x89, 0xb4, 0x67, 0xe8, 0xf5, 0x17, 0x60, 0x61, 0xb8, 0x1d, 0xd3, 0x96 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 59 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x75, 0x8f, 0x44, 0x67, 0xa5, 0xd8, 0xf1, 0xe7, 0x30, 0x7d, 0xc3, 0x0b, 0x34, 0xe4, 0x04, 0xf4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 60 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbc, 0xea, 0x28, 0xe9, 0x07, 0x1b, 0x5a, 0x23, 0x02, 0x97, 0x0f, 0xf3, 0x52, 0x45, 0x1b, 0xc5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 61 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x75, 0x23, 0xc0, 0x0b, 0xc1, 0x77, 0xd3, 0x31, 0xad, 0x31, 0x2e, 0x09, 0xc9, 0x01, 0x5c, 0x1c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 62 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcc, 0xac, 0x61, 0xe3, 0x18, 0x37, 0x47, 0xb3, 0xf5, 0x83, 0x6d, 0xa2, 0x1a, 0x1b, 0xc4, 0xf4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 63 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x70, 0x7b, 0x07, 0x57, 0x91, 0x87, 0x88, 0x80, 0xb4, 0x41, 0x89, 0xd3, 0x52, 0x2b, 0x8c, 0x30 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 64 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x71, 0x32, 0xd0, 0xc0, 0xe4, 0xa0, 0x75, 0x93, 0xcf, 0x12, 0xeb, 0xb1, 0x2b, 0xe7, 0x68, 0x8c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 65 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xef, 0xfb, 0xac, 0x16, 0x44, 0xde, 0xb0, 0xc7, 0x84, 0x27, 0x5f, 0xe5, 0x6e, 0x19, 0xea, 0xd3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 66 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa0, 0x05, 0x06, 0x3f, 0x30, 0xf4, 0x22, 0x8b, 0x37, 0x4e, 0x24, 0x59, 0x73, 0x8f, 0x26, 0xbb }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 67 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x29, 0x97, 0x5b, 0x5f, 0x48, 0xbb, 0x68, 0xfc, 0xbb, 0xc7, 0xce, 0xa9, 0x3b, 0x45, 0x2e, 0xd7 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 68 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcf, 0x3f, 0x25, 0x76, 0xe2, 0xaf, 0xed, 0xc7, 0x4b, 0xb1, 0xca, 0x7e, 0xee, 0xc1, 0xc0, 0xe7 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 69 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x07, 0xc4, 0x03, 0xf5, 0xf9, 0x66, 0xe0, 0xe3, 0xd9, 0xf2, 0x96, 0xd6, 0x22, 0x6d, 0xca, 0x28 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 70 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc8, 0xc2, 0x09, 0x08, 0x24, 0x9a, 0xb4, 0xa3, 0x4d, 0x6d, 0xd0, 0xa3, 0x13, 0x27, 0xff, 0x1a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 71 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc0, 0x54, 0x13, 0x29, 0xec, 0xb6, 0x15, 0x9a, 0xb2, 0x3b, 0x7f, 0xc5, 0xe6, 0xa2, 0x1b, 0xca }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 72 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7a, 0xa1, 0xac, 0xf1, 0xa2, 0xed, 0x9b, 0xa7, 0x2b, 0xc6, 0xde, 0xb3, 0x1d, 0x88, 0xb8, 0x63 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 73 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x80, 0x8b, 0xd8, 0xed, 0xda, 0xbb, 0x6f, 0x3b, 0xf0, 0xd5, 0xa8, 0xa2, 0x7b, 0xe1, 0xfe, 0x8a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 74 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0x3c, 0x7d, 0x76, 0x85, 0xe1, 0x4e, 0xc6, 0x6b, 0xbb, 0x96, 0xb8, 0xf0, 0x5b, 0x6d, 0xdd }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 75 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x32, 0x75, 0x2e, 0xef, 0xc8, 0xc2, 0xa9, 0x3f, 0x91, 0xb6, 0xe7, 0x3e, 0xb0, 0x7c, 0xca, 0x6e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 76 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd8, 0x93, 0xe7, 0xd6, 0x2f, 0x6c, 0xe5, 0x02, 0xc6, 0x4f, 0x75, 0xe2, 0x81, 0xf9, 0xc0, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 77 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8d, 0xfd, 0x99, 0x9b, 0xe5, 0xd0, 0xcf, 0xa3, 0x57, 0x32, 0xc0, 0xdd, 0xc8, 0x8f, 0xf5, 0xa5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 78 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x02, 0x64, 0x7c, 0x76, 0xa3, 0x00, 0xc3, 0x17, 0x3b, 0x84, 0x14, 0x87, 0xeb, 0x2b, 0xae, 0x9f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 79 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x17, 0x2d, 0xf8, 0xb0, 0x2f, 0x04, 0xb5, 0x3a, 0xda, 0xb0, 0x28, 0xb4, 0xe0, 0x1a, 0xcd, 0x87 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 80 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x05, 0x4b, 0x3b, 0xf4, 0x99, 0x8a, 0xeb, 0x05, 0xaf, 0xd8, 0x7e, 0xc5, 0x36, 0x53, 0x3a, 0x36 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 81 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x37, 0x83, 0xf7, 0xbf, 0x44, 0xc9, 0x7f, 0x06, 0x52, 0x58, 0xa6, 0x66, 0xca, 0xe0, 0x30, 0x20 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 82 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xaa, 0xd4, 0xc8, 0xa6, 0x3f, 0x80, 0x95, 0x41, 0x04, 0xde, 0x7b, 0x92, 0xce, 0xde, 0x1b, 0xe1 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 83 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcb, 0xfe, 0x61, 0x81, 0x0f, 0xd5, 0x46, 0x7c, 0xcd, 0xac, 0xb7, 0x58, 0x00, 0xf3, 0xac, 0x07 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 84 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x83, 0x0d, 0x8a, 0x25, 0x90, 0xf7, 0xd8, 0xe1, 0xb5, 0x5a, 0x73, 0x7f, 0x4a, 0xf4, 0x5f, 0x34 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 85 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xfc, 0xd4, 0x68, 0x3f, 0x85, 0x80, 0x58, 0xe7, 0x43, 0x14, 0x67, 0x1d, 0x43, 0xfa, 0x2c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 86 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x52, 0x3d, 0x0b, 0xab, 0xbb, 0x82, 0xf4, 0x6e, 0xbc, 0x9e, 0x70, 0xb1, 0xcd, 0x41, 0xdd, 0xd0 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 87 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x34, 0x4a, 0xab, 0x37, 0x08, 0x0d, 0x74, 0x86, 0xf7, 0xd5, 0x42, 0xa3, 0x09, 0xe5, 0x3e, 0xed }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 88 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x56, 0xc5, 0x60, 0x9d, 0x09, 0x06, 0xb2, 0x3a, 0xb9, 0xca, 0xca, 0x81, 0x6f, 0x5d, 0xbe, 0xbd }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 89 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x70, 0x26, 0x02, 0x6e, 0xed, 0xd9, 0x1a, 0xdc, 0x6d, 0x83, 0x1c, 0xdf, 0x98, 0x94, 0xbd, 0xc6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 90 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x88, 0x33, 0x0b, 0xaa, 0x4f, 0x2b, 0x61, 0x8f, 0xc9, 0xd9, 0xb0, 0x21, 0xbf, 0x50, 0x3d, 0x5a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 91 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfc, 0x9e, 0x0e, 0xa2, 0x24, 0x80, 0xb0, 0xba, 0xc9, 0x35, 0xc8, 0xa8, 0xeb, 0xef, 0xcd, 0xcf }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 92 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x29, 0xca, 0x77, 0x9f, 0x39, 0x8f, 0xb0, 0x4f, 0x86, 0x7d, 0xa7, 0xe8, 0xa4, 0x47, 0x56, 0xcb }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 93 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x51, 0xf8, 0x9c, 0x42, 0x98, 0x57, 0x86, 0xbf, 0xc4, 0x3c, 0x6d, 0xf8, 0xad, 0xa3, 0x68, 0x32 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 94 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6a, 0xc1, 0xde, 0x5f, 0xb8, 0xf2, 0x1d, 0x87, 0x4e, 0x91, 0xc5, 0x3b, 0x56, 0x0c, 0x50, 0xe3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 95 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x03, 0xaa, 0x90, 0x58, 0x49, 0x0e, 0xda, 0x30, 0x60, 0x01, 0xa8, 0xa9, 0xf4, 0x8d, 0x0c, 0xa7 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 96 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe3, 0x4e, 0xc7, 0x1d, 0x61, 0x28, 0xd4, 0x87, 0x18, 0x65, 0xd6, 0x17, 0xc3, 0x0b, 0x37, 0xe3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 97 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x14, 0xbe, 0x1c, 0x53, 0x5b, 0x17, 0xca, 0xbd, 0x0c, 0x4d, 0x93, 0x52, 0x9d, 0x69, 0xbf, 0x47 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 98 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc9, 0xef, 0x67, 0x75, 0x65, 0x07, 0xbe, 0xec, 0x9d, 0xd3, 0x86, 0x28, 0x83, 0x47, 0x80, 0x44 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 99 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x40, 0xe2, 0x31, 0xfa, 0x5a, 0x59, 0x48, 0xce, 0x21, 0x34, 0xe9, 0x2f, 0xc0, 0x66, 0x4d, 0x4b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 100 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x03, 0x19, 0x4b, 0x8e, 0x5d, 0xda, 0x55, 0x30, 0xd0, 0xc6, 0x78, 0xc0, 0xb4, 0x8f, 0x5d, 0x92 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 101 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0xbd, 0x08, 0x6f, 0x23, 0x7c, 0xc4, 0xfd, 0x99, 0xf4, 0xd7, 0x6b, 0xde, 0x6b, 0x48, 0x26 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 102 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x19, 0x25, 0x97, 0x61, 0xca, 0x17, 0x13, 0x0d, 0x6e, 0xd8, 0x6d, 0x57, 0xcd, 0x79, 0x51, 0xee }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 103 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd7, 0xcb, 0xb3, 0xf3, 0x4b, 0x9b, 0x45, 0x0f, 0x24, 0xb0, 0xe8, 0x51, 0x8e, 0x54, 0xda, 0x6d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 104 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x72, 0x5b, 0x9c, 0xae, 0xbe, 0x9f, 0x7f, 0x41, 0x7f, 0x40, 0x68, 0xd0, 0xd2, 0xee, 0x20, 0xb3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 105 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9d, 0x92, 0x4b, 0x93, 0x4a, 0x90, 0xce, 0x1f, 0xd3, 0x9b, 0x8a, 0x97, 0x94, 0xf8, 0x26, 0x72 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 106 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc5, 0x05, 0x62, 0xbf, 0x09, 0x45, 0x26, 0xa9, 0x1c, 0x5b, 0xc6, 0x3c, 0x0c, 0x22, 0x49, 0x95 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 107 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0xf1, 0x18, 0x05, 0x04, 0x67, 0x43, 0xbd, 0x74, 0xf5, 0x71, 0x88, 0xd9, 0x18, 0x8d, 0xf7 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 108 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8d, 0xd2, 0x74, 0xbd, 0x0f, 0x1b, 0x58, 0xae, 0x34, 0x5d, 0x9e, 0x72, 0x33, 0xf9, 0xb8, 0xf3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 109 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9d, 0x6b, 0xdc, 0x8f, 0x4c, 0xe5, 0xfe, 0xb0, 0xf3, 0xbe, 0xd2, 0xe4, 0xb9, 0xa9, 0xbb, 0x0b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 110 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfd, 0x55, 0x48, 0xbc, 0xf3, 0xf4, 0x25, 0x65, 0xf7, 0xef, 0xa9, 0x45, 0x62, 0x52, 0x8d, 0x46 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 111 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0xcc, 0xae, 0xbd, 0x3a, 0x4c, 0x3e, 0x80, 0xb0, 0x63, 0x74, 0x81, 0x31, 0xba, 0x4a, 0x71 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 112 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe0, 0x3c, 0xb2, 0x3d, 0x9e, 0x11, 0xc9, 0xd9, 0x3f, 0x11, 0x7e, 0x9c, 0x0a, 0x91, 0xb5, 0x76 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 113 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x78, 0xf9, 0x33, 0xa2, 0x08, 0x1a, 0xc1, 0xdb, 0x84, 0xf6, 0x9d, 0x10, 0xf4, 0x52, 0x3f, 0xe0 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 114 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x40, 0x61, 0xf7, 0x41, 0x2e, 0xd3, 0x20, 0xde, 0x0e, 0xdc, 0x88, 0x51, 0xc2, 0xe2, 0x43, 0x6f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 115 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0x64, 0xba, 0x1c, 0xd0, 0x4c, 0xe6, 0xba, 0xb9, 0x84, 0x74, 0x33, 0x08, 0x14, 0xb4, 0xd4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 116 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x48, 0x39, 0x1b, 0xff, 0xb9, 0xcf, 0xff, 0x80, 0xac, 0x23, 0x8c, 0x88, 0x6e, 0xf0, 0xa4, 0x61 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 117 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb8, 0xd2, 0xa6, 0x7d, 0xf5, 0xa9, 0x99, 0xfd, 0xbf, 0x93, 0xed, 0xd0, 0x34, 0x32, 0x96, 0xc9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 118 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xaa, 0xca, 0x73, 0x67, 0x39, 0x6b, 0x69, 0xa2, 0x21, 0xbd, 0x63, 0x2b, 0xea, 0x38, 0x6e, 0xec }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 119 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa8, 0x0f, 0xd5, 0x02, 0x0d, 0xfe, 0x65, 0xf5, 0xf1, 0x62, 0x93, 0xec, 0x92, 0xc6, 0xfd, 0x89 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 120 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x21, 0x62, 0x99, 0x5b, 0x82, 0x17, 0xa6, 0x7f, 0x1a, 0xbc, 0x34, 0x2e, 0x14, 0x64, 0x06, 0xf8 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 121 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc6, 0xa6, 0x16, 0x4b, 0x7a, 0x60, 0xba, 0xe4, 0xe9, 0x86, 0xff, 0xac, 0x28, 0xdf, 0xad, 0xd9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 122 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x64, 0xe0, 0xd7, 0xf9, 0x00, 0xe3, 0xd9, 0xc8, 0x3e, 0x4b, 0x8f, 0x96, 0x71, 0x7b, 0x21, 0x46 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 123 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1a, 0xd2, 0x56, 0x1d, 0xe8, 0xc1, 0x23, 0x2f, 0x5d, 0x8d, 0xba, 0xb4, 0x73, 0x9b, 0x6c, 0xbb }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 124 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0x96, 0x89, 0xe9, 0xa5, 0x57, 0xf5, 0x8b, 0x1c, 0x3b, 0xf4, 0x0c, 0x97, 0xa9, 0x09, 0x64 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 125 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc4, 0x63, 0x7e, 0x4a, 0x5e, 0x63, 0x77, 0xf9, 0xcc, 0x5a, 0x86, 0x38, 0x04, 0x5d, 0xe0, 0x29 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 126 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x49, 0x2e, 0x60, 0x7e, 0x5a, 0xea, 0x46, 0x88, 0x59, 0x4b, 0x45, 0xf3, 0xae, 0xe3, 0xdf, 0x90 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 127 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe8, 0xc4, 0xe4, 0x38, 0x1f, 0xee, 0xc7, 0x40, 0x54, 0x95, 0x4c, 0x05, 0xb7, 0x77, 0xa0, 0x0a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 128 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x91, 0x54, 0x95, 0x14, 0x60, 0x5f, 0x38, 0x24, 0x6c, 0x9b, 0x72, 0x4a, 0xd8, 0x39, 0xf0, 0x1d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 129 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x74, 0xb2, 0x4e, 0x3b, 0x6f, 0xef, 0xe4, 0x0a, 0x4f, 0x9e, 0xf7, 0xac, 0x6e, 0x44, 0xd7, 0x6a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 130 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x24, 0x37, 0xa6, 0x83, 0xdc, 0x5d, 0x4b, 0x52, 0xab, 0xb4, 0xa1, 0x23, 0xa8, 0xdf, 0x86, 0xc6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 131 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbb, 0x28, 0x52, 0xc8, 0x91, 0xc5, 0x94, 0x7d, 0x2e, 0xd4, 0x40, 0x32, 0xc4, 0x21, 0xb8, 0x5f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 132 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0x9f, 0x5f, 0xbd, 0x5e, 0x8a, 0x42, 0x64, 0xc0, 0xa8, 0x5b, 0x80, 0x40, 0x9a, 0xfa, 0x5e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 133 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x30, 0xda, 0xb8, 0x09, 0xf8, 0x5a, 0x91, 0x7f, 0xe9, 0x24, 0x73, 0x3f, 0x42, 0x4a, 0xc5, 0x89 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 134 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xea, 0xef, 0x5c, 0x1f, 0x8d, 0x60, 0x51, 0x92, 0x64, 0x66, 0x95, 0xce, 0xad, 0xc6, 0x5f, 0x32 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 135 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb8, 0xaa, 0x90, 0x04, 0x0b, 0x4c, 0x15, 0xa1, 0x23, 0x16, 0xb7, 0x8e, 0x0f, 0x95, 0x86, 0xfc }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 136 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0xfa, 0xc8, 0x29, 0x7c, 0xea, 0xab, 0xc8, 0x7d, 0x45, 0x43, 0x50, 0x60, 0x1e, 0x06, 0x73 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 137 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9b, 0x47, 0xef, 0x56, 0x7a, 0xc2, 0x8d, 0xfe, 0x48, 0x84, 0x92, 0xf1, 0x57, 0xe2, 0xb2, 0xe0 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 138 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0x84, 0x26, 0x02, 0x7d, 0xdb, 0x96, 0x2b, 0x5c, 0x5b, 0xa7, 0xeb, 0x8b, 0xc9, 0xab, 0x63 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 139 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe9, 0x17, 0xfc, 0x77, 0xe7, 0x19, 0x92, 0xa1, 0x2d, 0xbe, 0x4c, 0x18, 0x06, 0x8b, 0xec, 0x82 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 140 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdc, 0xee, 0xbb, 0xc9, 0x88, 0x40, 0xf8, 0xae, 0x6d, 0xaf, 0x76, 0x57, 0x3b, 0x7e, 0x56, 0xf4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 141 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4e, 0x11, 0xa9, 0xf7, 0x42, 0x05, 0x12, 0x5b, 0x61, 0xe0, 0xae, 0xe0, 0x47, 0xec, 0xa2, 0x0d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 142 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf6, 0x04, 0x67, 0xf5, 0x5a, 0x1f, 0x17, 0xea, 0xb8, 0x8e, 0x80, 0x01, 0x20, 0xcb, 0xc2, 0x84 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 143 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd4, 0x36, 0x64, 0x9f, 0x60, 0x0b, 0x44, 0x9e, 0xe2, 0x76, 0x53, 0x0f, 0x0c, 0xd8, 0x3c, 0x11 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 144 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3b, 0xc0, 0xe3, 0x65, 0x6a, 0x9e, 0x3a, 0xc7, 0xcd, 0x37, 0x8a, 0x73, 0x7f, 0x53, 0xb6, 0x37 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 145 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6b, 0xac, 0xae, 0x63, 0xd3, 0x3b, 0x92, 0x8a, 0xa8, 0x38, 0x0f, 0x8d, 0x54, 0xd8, 0x8c, 0x17 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 146 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x89, 0x35, 0xff, 0xbc, 0x75, 0xae, 0x62, 0x51, 0xbf, 0x8e, 0x85, 0x9f, 0x08, 0x5a, 0xdc, 0xb9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 147 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x93, 0xdc, 0x49, 0x70, 0xfe, 0x35, 0xf6, 0x77, 0x47, 0xcb, 0x05, 0x62, 0xc0, 0x6d, 0x87, 0x5a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 148 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x14, 0xf9, 0xdf, 0x85, 0x89, 0x75, 0x85, 0x17, 0x97, 0xba, 0x60, 0x4f, 0xb0, 0xd1, 0x6c, 0xc7 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 149 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x02, 0xea, 0x0c, 0x98, 0xdc, 0xa1, 0x0b, 0x38, 0xc2, 0x1b, 0x3b, 0x14, 0xe8, 0xd1, 0xb7, 0x1f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 150 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8f, 0x09, 0x1b, 0x1b, 0x5b, 0x07, 0x49, 0xb2, 0xad, 0xc8, 0x03, 0xe6, 0x3d, 0xda, 0x9b, 0x72 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 151 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x05, 0xb3, 0x89, 0xe3, 0x32, 0x2c, 0x6d, 0xa0, 0x83, 0x84, 0x34, 0x5a, 0x41, 0x37, 0xfd, 0x08 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 152 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x38, 0x13, 0x08, 0xc4, 0x38, 0xf3, 0x5b, 0x39, 0x9f, 0x10, 0xad, 0x71, 0xb0, 0x50, 0x27, 0xd8 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 153 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x68, 0xc2, 0x30, 0xfc, 0xfa, 0x92, 0x79, 0xc3, 0x40, 0x9f, 0xc4, 0x23, 0xe2, 0xac, 0xbe, 0x04 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 154 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1c, 0x84, 0xa4, 0x75, 0xac, 0xb0, 0x11, 0xf3, 0xf5, 0x9f, 0x4f, 0x46, 0xb7, 0x62, 0x74, 0xc0 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 155 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x45, 0x11, 0x9b, 0x68, 0xcb, 0x3f, 0x83, 0x99, 0xee, 0x60, 0x06, 0x6b, 0x56, 0x11, 0xa4, 0xd7 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 156 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x94, 0x23, 0x76, 0x2f, 0x52, 0x7a, 0x40, 0x60, 0xff, 0xca, 0x31, 0x2d, 0xcc, 0xa2, 0x2a, 0x16 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 157 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf3, 0x61, 0xa2, 0x74, 0x5a, 0x33, 0xf0, 0x56, 0xa5, 0xac, 0x6a, 0xce, 0x2f, 0x08, 0xe3, 0x44 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 158 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5e, 0xf1, 0x45, 0x76, 0x6e, 0xca, 0x84, 0x9f, 0x5d, 0x01, 0x15, 0x36, 0xa6, 0x55, 0x7f, 0xdb }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 159 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc9, 0xaf, 0x27, 0xb2, 0xc8, 0x9c, 0x9b, 0x4c, 0xf4, 0xa0, 0xc4, 0x10, 0x6a, 0xc8, 0x03, 0x18 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 160 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfb, 0x9c, 0x4f, 0x16, 0xc6, 0x21, 0xf4, 0xea, 0xb7, 0xe9, 0xac, 0x1d, 0x75, 0x51, 0xdd, 0x57 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 161 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x13, 0x8e, 0x06, 0xfb, 0xa4, 0x66, 0xfa, 0x70, 0x85, 0x4d, 0x8c, 0x2e, 0x52, 0x4c, 0xff, 0xb2 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 162 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfb, 0x4b, 0xc7, 0x8b, 0x22, 0x50, 0x70, 0x77, 0x3f, 0x04, 0xc4, 0x04, 0x66, 0xd4, 0xe9, 0x0c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 163 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8b, 0x2c, 0xbf, 0xf1, 0xed, 0x01, 0x50, 0xfe, 0xda, 0x8a, 0x47, 0x99, 0xbe, 0x94, 0x55, 0x1f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 164 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x08, 0xb3, 0x0d, 0x7b, 0x3f, 0x27, 0x96, 0x27, 0x09, 0xa3, 0x6b, 0xca, 0xdf, 0xb9, 0x74, 0xbd }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 165 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfd, 0xf6, 0xd3, 0x2e, 0x04, 0x4d, 0x77, 0xad, 0xcf, 0x37, 0xfb, 0x97, 0xac, 0x21, 0x33, 0x26 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 166 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x93, 0xcb, 0x28, 0x4e, 0xcd, 0xcf, 0xd7, 0x81, 0xa8, 0xaf, 0xe3, 0x20, 0x77, 0x94, 0x9e, 0x88 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 167 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7b, 0x01, 0x7b, 0xb0, 0x2e, 0xc8, 0x7b, 0x2b, 0x94, 0xc9, 0x6e, 0x40, 0xa2, 0x6f, 0xc7, 0x1a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 168 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc5, 0xc0, 0x38, 0xb6, 0x99, 0x06, 0x64, 0xab, 0x08, 0xa3, 0xaa, 0xa5, 0xdf, 0x9f, 0x32, 0x66 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 169 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4b, 0x70, 0x20, 0xbe, 0x37, 0xfa, 0xb6, 0x25, 0x9b, 0x2a, 0x27, 0xf4, 0xec, 0x55, 0x15, 0x76 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 170 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x60, 0x13, 0x67, 0x03, 0x37, 0x4f, 0x64, 0xe8, 0x60, 0xb4, 0x8c, 0xe3, 0x1f, 0x93, 0x07, 0x16 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 171 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8d, 0x63, 0xa2, 0x69, 0xb1, 0x4d, 0x50, 0x6c, 0xcc, 0x40, 0x1a, 0xb8, 0xa9, 0xf1, 0xb5, 0x91 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 172 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd3, 0x17, 0xf8, 0x1d, 0xc6, 0xaa, 0x45, 0x4a, 0xee, 0x4b, 0xd4, 0xa5, 0xa5, 0xcf, 0xf4, 0xbd }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 173 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdd, 0xde, 0xce, 0xcd, 0x53, 0x54, 0xf0, 0x4d, 0x53, 0x0d, 0x76, 0xed, 0x88, 0x42, 0x46, 0xeb }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 174 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x41, 0xc5, 0x20, 0x5c, 0xc8, 0xfd, 0x8e, 0xda, 0x9a, 0x3c, 0xff, 0xd2, 0x51, 0x8f, 0x36, 0x5a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 175 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcf, 0x42, 0xfb, 0x47, 0x42, 0x93, 0xd9, 0x6e, 0xca, 0x9d, 0xb1, 0xb3, 0x7b, 0x1b, 0xa6, 0x76 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 176 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa2, 0x31, 0x69, 0x26, 0x07, 0x16, 0x9b, 0x4e, 0xcd, 0xea, 0xd5, 0xcd, 0x3b, 0x10, 0xdb, 0x3e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 177 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xac, 0xe4, 0xb9, 0x1c, 0x9c, 0x66, 0x9e, 0x77, 0xe7, 0xac, 0xac, 0xd1, 0x98, 0x59, 0xed, 0x49 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 178 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x75, 0xdb, 0x7c, 0xfd, 0x4a, 0x7b, 0x2b, 0x62, 0xab, 0x78, 0xa4, 0x8f, 0x3d, 0xda, 0xf4, 0xaf }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 179 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc1, 0xfa, 0xba, 0x2d, 0x46, 0xe2, 0x59, 0xcf, 0x48, 0x0d, 0x7c, 0x38, 0xe4, 0x57, 0x2a, 0x58 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 180 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x24, 0x1c, 0x45, 0xbc, 0x6a, 0xe1, 0x6d, 0xee, 0x6e, 0xb7, 0xbe, 0xa1, 0x28, 0x70, 0x15, 0x82 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 181 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8f, 0xd0, 0x30, 0x57, 0xcf, 0x13, 0x64, 0x42, 0x0c, 0x2b, 0x78, 0x06, 0x9a, 0x3e, 0x25, 0x02 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 182 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdd, 0xb5, 0x05, 0xe6, 0xcc, 0x13, 0x84, 0xcb, 0xae, 0xc1, 0xdf, 0x90, 0xb8, 0x0b, 0xeb, 0x20 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 183 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x56, 0x74, 0xa3, 0xbe, 0xd2, 0x7b, 0xf4, 0xbd, 0x36, 0x22, 0xf9, 0xf5, 0xfe, 0x20, 0x83, 0x06 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 184 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb6, 0x87, 0xf2, 0x6a, 0x89, 0xcf, 0xbf, 0xbb, 0x8e, 0x5e, 0xea, 0xc5, 0x40, 0x55, 0x31, 0x5e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 185 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x05, 0x47, 0xdd, 0x32, 0xd3, 0xb2, 0x9a, 0xb6, 0xa4, 0xca, 0xeb, 0x60, 0x6c, 0x5b, 0x6f, 0x78 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 186 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x18, 0x68, 0x61, 0xf8, 0xbc, 0x53, 0x86, 0xd3, 0x1f, 0xb7, 0x7f, 0x72, 0x0c, 0x32, 0x26, 0xe6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 187 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xea, 0xcf, 0x1e, 0x6c, 0x42, 0x24, 0xef, 0xb3, 0x89, 0x00, 0xb1, 0x85, 0xab, 0x1d, 0xfd, 0x42 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 188 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0x41, 0xaa, 0xb0, 0x5a, 0x42, 0xd3, 0x19, 0xde, 0x81, 0xd8, 0x74, 0xf5, 0xc7, 0xb9, 0x0d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 189 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5e, 0xb9, 0xbc, 0x75, 0x9e, 0x2a, 0xd8, 0xd2, 0x14, 0x0a, 0x6c, 0x76, 0x2a, 0xe9, 0xe1, 0xab }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 190 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x01, 0x85, 0x96, 0xe1, 0x5e, 0x78, 0xe2, 0xc0, 0x64, 0x15, 0x9d, 0xef, 0xce, 0x5f, 0x30, 0x85 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey192.rsp test vector 191 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdd, 0x8a, 0x49, 0x35, 0x14, 0x23, 0x1c, 0xbf, 0x56, 0xec, 0xce, 0xe4, 0xc4, 0x08, 0x89, 0xfb }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 0 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe3, 0x5a, 0x6d, 0xcb, 0x19, 0xb2, 0x01, 0xa0, 0x1e, 0xbc, 0xfa, 0x8a, 0xa2, 0x2b, 0x57, 0x59 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 1 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb2, 0x91, 0x69, 0xcd, 0xcf, 0x2d, 0x83, 0xe8, 0x38, 0x12, 0x5a, 0x12, 0xee, 0x6a, 0xa4, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 2 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd8, 0xf3, 0xa7, 0x2f, 0xc3, 0xcd, 0xf7, 0x4d, 0xfa, 0xf6, 0xc3, 0xe6, 0xb9, 0x7b, 0x2f, 0xa6 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 3 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1c, 0x77, 0x76, 0x79, 0xd5, 0x00, 0x37, 0xc7, 0x94, 0x91, 0xa9, 0x4d, 0xa7, 0x6a, 0x9a, 0x35 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 4 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9c, 0xf4, 0x89, 0x3e, 0xca, 0xfa, 0x0a, 0x02, 0x47, 0xa8, 0x98, 0xe0, 0x40, 0x69, 0x15, 0x59 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 5 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8f, 0xbb, 0x41, 0x37, 0x03, 0x73, 0x53, 0x26, 0x31, 0x0a, 0x26, 0x9b, 0xd3, 0xaa, 0x94, 0xb2 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 6 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x60, 0xe3, 0x22, 0x46, 0xbe, 0xd2, 0xb0, 0xe8, 0x59, 0xe5, 0x5c, 0x1c, 0xc6, 0xb2, 0x65, 0x02 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 7 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xec, 0x52, 0xa2, 0x12, 0xf8, 0x0a, 0x09, 0xdf, 0x63, 0x17, 0x02, 0x1b, 0xc2, 0xa9, 0x81, 0x9e }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 8 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf2, 0x3e, 0x5b, 0x60, 0x0e, 0xb7, 0x0d, 0xbc, 0xcf, 0x6c, 0x0b, 0x1d, 0x9a, 0x68, 0x18, 0x2c }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 9 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa3, 0xf5, 0x99, 0xd6, 0x3a, 0x82, 0xa9, 0x68, 0xc3, 0x3f, 0xe2, 0x65, 0x90, 0x74, 0x59, 0x70 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 10 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd1, 0xcc, 0xb9, 0xb1, 0x33, 0x70, 0x02, 0xcb, 0xac, 0x42, 0xc5, 0x20, 0xb5, 0xd6, 0x77, 0x22 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 11 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcc, 0x11, 0x1f, 0x6c, 0x37, 0xcf, 0x40, 0xa1, 0x15, 0x9d, 0x00, 0xfb, 0x59, 0xfb, 0x04, 0x88 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 12 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdc, 0x43, 0xb5, 0x1a, 0xb6, 0x09, 0x05, 0x23, 0x72, 0x98, 0x9a, 0x26, 0xe9, 0xcd, 0xd7, 0x14 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 13 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4d, 0xce, 0xde, 0x8d, 0xa9, 0xe2, 0x57, 0x8f, 0x39, 0x70, 0x3d, 0x44, 0x33, 0xdc, 0x64, 0x59 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 14 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1a, 0x4c, 0x1c, 0x26, 0x3b, 0xbc, 0xcf, 0xaf, 0xc1, 0x17, 0x82, 0x89, 0x46, 0x85, 0xe3, 0xa8 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 15 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x93, 0x7a, 0xd8, 0x48, 0x80, 0xdb, 0x50, 0x61, 0x34, 0x23, 0xd6, 0xd5, 0x27, 0xa2, 0x82, 0x3d }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 16 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x61, 0x0b, 0x71, 0xdf, 0xc6, 0x88, 0xe1, 0x50, 0xd8, 0x15, 0x2c, 0x5b, 0x35, 0xeb, 0xc1, 0x4d }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 17 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0xef, 0x24, 0x95, 0xda, 0xbf, 0x32, 0x38, 0x85, 0xaa, 0xb3, 0x9c, 0x80, 0xf1, 0x8d, 0x8b }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 18 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x63, 0x3c, 0xaf, 0xea, 0x39, 0x5b, 0xc0, 0x3a, 0xda, 0xe3, 0xa1, 0xe2, 0x06, 0x8e, 0x4b, 0x4e }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 19 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6e, 0x1b, 0x48, 0x2b, 0x53, 0x76, 0x1c, 0xf6, 0x31, 0x81, 0x9b, 0x74, 0x9a, 0x6f, 0x37, 0x24 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 20 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0x6e, 0x6f, 0x85, 0x1a, 0xb5, 0x2c, 0x77, 0x19, 0x98, 0xdb, 0xb2, 0xd7, 0x1c, 0x75, 0xa9 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 21 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x85, 0xf2, 0xba, 0x84, 0xf8, 0xc3, 0x07, 0xcf, 0x52, 0x5e, 0x12, 0x4c, 0x3e, 0x22, 0xe6, 0xcc }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 22 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6b, 0xcc, 0xa9, 0x8b, 0xf6, 0xa8, 0x35, 0xfa, 0x64, 0x95, 0x5f, 0x72, 0xde, 0x41, 0x15, 0xfe }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 23 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2c, 0x75, 0xe2, 0xd3, 0x6e, 0xeb, 0xd6, 0x54, 0x11, 0xf1, 0x4f, 0xd0, 0xeb, 0x1d, 0x2a, 0x06 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 24 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbd, 0x49, 0x29, 0x50, 0x06, 0x25, 0x0f, 0xfc, 0xa5, 0x10, 0x0b, 0x60, 0x07, 0xa0, 0xea, 0xde }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 25 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa1, 0x90, 0x52, 0x7d, 0x0e, 0xf7, 0xc7, 0x0f, 0x45, 0x9c, 0xd3, 0x94, 0x0d, 0xf3, 0x16, 0xec }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 26 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbb, 0xd1, 0x09, 0x7a, 0x62, 0x43, 0x3f, 0x79, 0x44, 0x9f, 0xa9, 0x7d, 0x4e, 0xe8, 0x0d, 0xbf }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 27 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x07, 0x05, 0x8e, 0x40, 0x8f, 0x5b, 0x99, 0xb0, 0xe0, 0xf0, 0x61, 0xa1, 0x76, 0x1b, 0x5b, 0x3b }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 28 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5f, 0xd1, 0xf1, 0x3f, 0xa0, 0xf3, 0x1e, 0x37, 0xfa, 0xbd, 0xe3, 0x28, 0xf8, 0x94, 0xea, 0xc2 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 29 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfc, 0x4a, 0xf7, 0xc9, 0x48, 0xdf, 0x26, 0xe2, 0xef, 0x3e, 0x01, 0xc1, 0xee, 0x5b, 0x8f, 0x6f }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 30 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x82, 0x9f, 0xd7, 0x20, 0x8f, 0xb9, 0x2d, 0x44, 0xa0, 0x74, 0xa6, 0x77, 0xee, 0x98, 0x61, 0xac }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 31 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xad, 0x9f, 0xc6, 0x13, 0xa7, 0x03, 0x25, 0x1b, 0x54, 0xc6, 0x4a, 0x0e, 0x76, 0x43, 0x17, 0x11 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 32 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x33, 0xac, 0x9e, 0xcc, 0xc4, 0xcc, 0x75, 0xe2, 0x71, 0x16, 0x18, 0xf8, 0x0b, 0x15, 0x48, 0xe8 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 33 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x20, 0x25, 0xc7, 0x4b, 0x8a, 0xd8, 0xf4, 0xcd, 0xa1, 0x7e, 0xe2, 0x04, 0x9c, 0x4c, 0x90, 0x2d }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 34 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf8, 0x5c, 0xa0, 0x5f, 0xe5, 0x28, 0xf1, 0xce, 0x9b, 0x79, 0x01, 0x66, 0xe8, 0xd5, 0x51, 0xe7 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 35 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6f, 0x62, 0x38, 0xd8, 0x96, 0x60, 0x48, 0xd4, 0x96, 0x71, 0x54, 0xe0, 0xda, 0xd5, 0xa6, 0xc9 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 36 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf2, 0xb2, 0x1b, 0x4e, 0x76, 0x40, 0xa9, 0xb3, 0x34, 0x6d, 0xe8, 0xb8, 0x2f, 0xb4, 0x1e, 0x49 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 37 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf8, 0x36, 0xf2, 0x51, 0xad, 0x1d, 0x11, 0xd4, 0x9d, 0xc3, 0x44, 0x62, 0x8b, 0x18, 0x84, 0xe1 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 38 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x07, 0x7e, 0x94, 0x70, 0xae, 0x7a, 0xbe, 0xa5, 0xa9, 0x76, 0x9d, 0x49, 0x18, 0x26, 0x28, 0xc3 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 39 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe0, 0xdc, 0xc2, 0xd2, 0x7f, 0xc9, 0x86, 0x56, 0x33, 0xf8, 0x52, 0x23, 0xcf, 0x0d, 0x61, 0x1f }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 40 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbe, 0x66, 0xcf, 0xea, 0x2f, 0xec, 0xd6, 0xbf, 0x0e, 0xc7, 0xb4, 0x35, 0x2c, 0x99, 0xbc, 0xaa }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 41 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdf, 0x31, 0x14, 0x4f, 0x87, 0xa2, 0xef, 0x52, 0x3f, 0xac, 0xdc, 0xf2, 0x1a, 0x42, 0x78, 0x04 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 42 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb5, 0xbb, 0x0f, 0x56, 0x29, 0xfb, 0x6a, 0xae, 0x5e, 0x18, 0x39, 0xa3, 0xc3, 0x62, 0x5d, 0x63 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 43 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3c, 0x9d, 0xb3, 0x33, 0x53, 0x06, 0xfe, 0x1e, 0xc6, 0x12, 0xbd, 0xbf, 0xae, 0x6b, 0x60, 0x28 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 44 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3d, 0xd5, 0xc3, 0x46, 0x34, 0xa7, 0x9d, 0x3c, 0xfc, 0xc8, 0x33, 0x97, 0x60, 0xe6, 0xf5, 0xf4 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 45 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x82, 0xbd, 0xa1, 0x18, 0xa3, 0xed, 0x7a, 0xf3, 0x14, 0xfa, 0x2c, 0xcc, 0x5c, 0x07, 0xb7, 0x61 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 46 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x29, 0x37, 0xa6, 0x4f, 0x7d, 0x4f, 0x46, 0xfe, 0x6f, 0xea, 0x3b, 0x34, 0x9e, 0xc7, 0x8e, 0x38 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 47 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x22, 0x5f, 0x06, 0x8c, 0x28, 0x47, 0x66, 0x05, 0x73, 0x5a, 0xd6, 0x71, 0xbb, 0x8f, 0x39, 0xf3 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 48 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xae, 0x68, 0x2c, 0x5e, 0xcd, 0x71, 0x89, 0x8e, 0x08, 0x94, 0x2a, 0xc9, 0xaa, 0x89, 0x87, 0x5c }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 49 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5e, 0x03, 0x1c, 0xb9, 0xd6, 0x76, 0xc3, 0x02, 0x2d, 0x7f, 0x26, 0x22, 0x7e, 0x85, 0xc3, 0x8f }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 50 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa7, 0x84, 0x63, 0xfb, 0x06, 0x4d, 0xb5, 0xd5, 0x2b, 0xb6, 0x4b, 0xfe, 0xf6, 0x4f, 0x2d, 0xda }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 51 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8a, 0xa9, 0xb7, 0x5e, 0x78, 0x45, 0x93, 0x87, 0x6c, 0x53, 0xa0, 0x0e, 0xae, 0x5a, 0xf5, 0x2b }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 52 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3f, 0x84, 0x56, 0x6d, 0xf2, 0x3d, 0xa4, 0x8a, 0xf6, 0x92, 0x72, 0x2f, 0xe9, 0x80, 0x57, 0x3a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 53 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x31, 0x69, 0x0b, 0x5e, 0xd4, 0x1c, 0x7e, 0xb4, 0x2a, 0x1e, 0x83, 0x27, 0x0a, 0x7f, 0xf0, 0xe6 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 54 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x77, 0xdd, 0x77, 0x02, 0x64, 0x6d, 0x55, 0xf0, 0x83, 0x65, 0xe4, 0x77, 0xd3, 0x59, 0x0e, 0xda }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 55 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4c, 0x02, 0x2a, 0xc6, 0x2b, 0x3c, 0xb7, 0x8d, 0x73, 0x9c, 0xc6, 0x7b, 0x3e, 0x20, 0xbb, 0x7e }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 56 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x09, 0x2f, 0xa1, 0x37, 0xce, 0x18, 0xb5, 0xdf, 0xe7, 0x90, 0x6f, 0x55, 0x0b, 0xb1, 0x33, 0x70 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 57 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3e, 0x0c, 0xda, 0xdf, 0x2e, 0x68, 0x35, 0x3c, 0x00, 0x27, 0x67, 0x2c, 0x97, 0x14, 0x4d, 0xd3 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 58 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd8, 0xc4, 0xb2, 0x00, 0xb3, 0x83, 0xfc, 0x1f, 0x2b, 0x2e, 0xa6, 0x77, 0x61, 0x8a, 0x1d, 0x27 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 59 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0x82, 0x5f, 0x99, 0xb0, 0xe9, 0xbb, 0x34, 0x77, 0xc1, 0xc0, 0x71, 0x3b, 0x01, 0x5a, 0xac }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 60 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf8, 0xb9, 0xff, 0xfb, 0x5c, 0x18, 0x7f, 0x7d, 0xdc, 0x7a, 0xb1, 0x0f, 0x4f, 0xb7, 0x75, 0x76 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 61 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xb4, 0xe8, 0x7a, 0x32, 0xb3, 0x7d, 0x6f, 0x2c, 0x83, 0x28, 0xd3, 0xb5, 0x37, 0x78, 0x02 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 62 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0x76, 0xc1, 0x3a, 0x5d, 0x22, 0x0f, 0x4d, 0xa9, 0x22, 0x4e, 0x74, 0x89, 0x63, 0x91, 0xce }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 63 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x94, 0xef, 0xe7, 0xa0, 0xe2, 0xe0, 0x31, 0xe2, 0x53, 0x6d, 0xa0, 0x1d, 0xf7, 0x99, 0xc9, 0x27 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 64 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8f, 0x8f, 0xd8, 0x22, 0x68, 0x0a, 0x85, 0x97, 0x4e, 0x53, 0xa5, 0xa8, 0xeb, 0x9d, 0x38, 0xde }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 65 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe0, 0xf0, 0xa9, 0x1b, 0x2e, 0x45, 0xf8, 0xcc, 0x37, 0xb7, 0x80, 0x5a, 0x30, 0x42, 0x58, 0x8d }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 66 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x59, 0x7a, 0x62, 0x52, 0x25, 0x5e, 0x46, 0xd6, 0x36, 0x4d, 0xbe, 0xed, 0xa3, 0x1e, 0x27, 0x9c }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 67 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf5, 0x1a, 0x0f, 0x69, 0x44, 0x42, 0xb8, 0xf0, 0x55, 0x71, 0x79, 0x7f, 0xec, 0x7e, 0xe8, 0xbf }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 68 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9f, 0xf0, 0x71, 0xb1, 0x65, 0xb5, 0x19, 0x8a, 0x93, 0xdd, 0xde, 0xeb, 0xc5, 0x4d, 0x09, 0xb5 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 69 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc2, 0x0a, 0x19, 0xfd, 0x57, 0x58, 0xb0, 0xc4, 0xbc, 0x1a, 0x5d, 0xf8, 0x9c, 0xf7, 0x38, 0x77 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 70 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0x12, 0x01, 0x66, 0x30, 0x71, 0x19, 0xca, 0x22, 0x80, 0xe9, 0x31, 0x56, 0x68, 0xe9, 0x6f }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 71 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4b, 0x3b, 0x9f, 0x1e, 0x09, 0x9c, 0x2a, 0x09, 0xdc, 0x09, 0x1e, 0x90, 0xe4, 0xf1, 0x8f, 0x0a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 72 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xeb, 0x04, 0x0b, 0x89, 0x1d, 0x4b, 0x37, 0xf6, 0x85, 0x1f, 0x7e, 0xc2, 0x19, 0xcd, 0x3f, 0x6d }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 73 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9f, 0x0f, 0xde, 0xc0, 0x8b, 0x7f, 0xd7, 0x9a, 0xa3, 0x95, 0x35, 0xbe, 0xa4, 0x2d, 0xb9, 0x2a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 74 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2e, 0x70, 0xf1, 0x68, 0xfc, 0x74, 0xbf, 0x91, 0x1d, 0xf2, 0x40, 0xbc, 0xd2, 0xce, 0xf2, 0x36 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 75 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x46, 0x2c, 0xcd, 0x7f, 0x5f, 0xd1, 0x10, 0x8d, 0xbc, 0x15, 0x2f, 0x3c, 0xac, 0xad, 0x32, 0x8b }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 76 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa4, 0xaf, 0x53, 0x4a, 0x7d, 0x0b, 0x64, 0x3a, 0x01, 0x86, 0x87, 0x85, 0xd8, 0x6d, 0xfb, 0x95 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 77 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xab, 0x98, 0x02, 0x96, 0x19, 0x7e, 0x1a, 0x50, 0x22, 0x32, 0x6c, 0x31, 0xda, 0x4b, 0xf6, 0xf3 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 78 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf9, 0x7d, 0x57, 0xb3, 0x33, 0x3b, 0x62, 0x81, 0xb0, 0x7d, 0x48, 0x6d, 0xb2, 0xd4, 0xe2, 0x0c }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 79 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf3, 0x3f, 0xa3, 0x67, 0x20, 0x23, 0x1a, 0xfe, 0x4c, 0x75, 0x9a, 0xde, 0x6b, 0xd6, 0x2e, 0xb6 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 80 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfd, 0xcf, 0xac, 0x0c, 0x02, 0xca, 0x53, 0x83, 0x43, 0xc6, 0x81, 0x17, 0xe0, 0xa1, 0x59, 0x38 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 81 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xad, 0x49, 0x16, 0xf5, 0xee, 0x57, 0x72, 0xbe, 0x76, 0x4f, 0xc0, 0x27, 0xb8, 0xa6, 0xe5, 0x39 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 82 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2e, 0x16, 0x87, 0x3e, 0x16, 0x78, 0x61, 0x0d, 0x7e, 0x14, 0xc0, 0x2d, 0x00, 0x2e, 0xa8, 0x45 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 83 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4e, 0x6e, 0x62, 0x7c, 0x1a, 0xcc, 0x51, 0x34, 0x00, 0x53, 0xa8, 0x23, 0x6d, 0x57, 0x95, 0x76 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 84 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xab, 0x0c, 0x84, 0x10, 0xae, 0xee, 0xad, 0x92, 0xfe, 0xec, 0x1e, 0xb4, 0x30, 0xd6, 0x52, 0xcb }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 85 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe8, 0x6f, 0x7e, 0x23, 0xe8, 0x35, 0xe1, 0x14, 0x97, 0x7f, 0x60, 0xe1, 0xa5, 0x92, 0x20, 0x2e }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 86 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe6, 0x8a, 0xd5, 0x05, 0x5a, 0x36, 0x70, 0x41, 0xfa, 0xde, 0x09, 0xd9, 0xa7, 0x0a, 0x79, 0x4b }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 87 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x07, 0x91, 0x82, 0x3a, 0x3c, 0x66, 0x6b, 0xb6, 0x16, 0x28, 0x25, 0xe7, 0x86, 0x06, 0xa7, 0xfe }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 88 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdc, 0xca, 0x36, 0x6a, 0x9b, 0xf4, 0x7b, 0x7b, 0x86, 0x8b, 0x77, 0xe2, 0x5c, 0x18, 0xa3, 0x64 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 89 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x68, 0x4c, 0x9e, 0xfc, 0x23, 0x7e, 0x4a, 0x44, 0x29, 0x65, 0xf8, 0x4b, 0xce, 0x20, 0x24, 0x7a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 90 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa8, 0x58, 0x41, 0x1f, 0xfb, 0xe6, 0x3f, 0xdb, 0x9c, 0x8a, 0xa1, 0xbf, 0xae, 0xd6, 0x7b, 0x52 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 91 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x04, 0xbc, 0x3d, 0xa2, 0x17, 0x9c, 0x30, 0x15, 0x49, 0x8b, 0x0e, 0x03, 0x91, 0x0d, 0xb5, 0xb8 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 92 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x40, 0x07, 0x1e, 0xea, 0xb3, 0xf9, 0x35, 0xdb, 0xc2, 0x5d, 0x00, 0x84, 0x14, 0x60, 0x26, 0x0f }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 93 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0e, 0xbd, 0x7c, 0x30, 0xed, 0x20, 0x16, 0xe0, 0x8b, 0xa8, 0x06, 0xdd, 0xb0, 0x08, 0xbc, 0xc8 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 94 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x15, 0xc6, 0xbe, 0xcf, 0x0f, 0x4c, 0xec, 0x71, 0x29, 0xcb, 0xd2, 0x2d, 0x1a, 0x79, 0xb1, 0xb8 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 95 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0a, 0xee, 0xde, 0x5b, 0x91, 0xf7, 0x21, 0x70, 0x0e, 0x9e, 0x62, 0xed, 0xbf, 0x60, 0xb7, 0x81 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 96 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x26, 0x65, 0x81, 0xaf, 0x0d, 0xcf, 0xbe, 0xd1, 0x58, 0x5e, 0x0a, 0x24, 0x2c, 0x64, 0xb8, 0xdf }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 97 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x66, 0x93, 0xdc, 0x91, 0x16, 0x62, 0xae, 0x47, 0x32, 0x16, 0xba, 0x22, 0x18, 0x9a, 0x51, 0x1a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 98 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x76, 0x06, 0xfa, 0x36, 0xd8, 0x64, 0x73, 0xe6, 0xfb, 0x3a, 0x1b, 0xb0, 0xe2, 0xc0, 0xad, 0xf5 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 99 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0x20, 0x78, 0xe9, 0xe1, 0x1f, 0xbb, 0x78, 0xe2, 0x6f, 0xfb, 0x88, 0x99, 0xe9, 0x6b, 0x9a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 100 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x40, 0xb2, 0x64, 0xe9, 0x21, 0xe9, 0xe4, 0xa8, 0x26, 0x94, 0x58, 0x9e, 0xf3, 0x79, 0x82, 0x62 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 101 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8d, 0x45, 0x95, 0xcb, 0x4f, 0xa7, 0x02, 0x67, 0x15, 0xf5, 0x5b, 0xd6, 0x8e, 0x28, 0x82, 0xf9 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 102 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb5, 0x88, 0xa3, 0x02, 0xbd, 0xbc, 0x09, 0x19, 0x7d, 0xf1, 0xed, 0xae, 0x68, 0x92, 0x6e, 0xd9 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 103 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x33, 0xf7, 0x50, 0x23, 0x90, 0xb8, 0xa4, 0xa2, 0x21, 0xcf, 0xec, 0xd0, 0x66, 0x66, 0x24, 0xba }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 104 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3d, 0x20, 0x25, 0x3a, 0xdb, 0xce, 0x3b, 0xe2, 0x37, 0x37, 0x67, 0xc4, 0xd8, 0x22, 0xc5, 0x66 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 105 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa4, 0x27, 0x34, 0xa3, 0x92, 0x9b, 0xf8, 0x4c, 0xf0, 0x11, 0x6c, 0x98, 0x56, 0xa3, 0xc1, 0x8c }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 106 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe3, 0xab, 0xc4, 0x93, 0x94, 0x57, 0x42, 0x2b, 0xb9, 0x57, 0xda, 0x3c, 0x56, 0x93, 0x8c, 0x6d }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 107 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0x2b, 0xdd, 0x2e, 0x7c, 0x52, 0x51, 0x30, 0xfa, 0xdc, 0x8f, 0x76, 0xfc, 0x6f, 0x4b, 0x3f }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 108 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x84, 0xa8, 0x3d, 0x7b, 0x94, 0xc6, 0x99, 0xcb, 0xcb, 0x8a, 0x7d, 0x9b, 0x61, 0xf6, 0x40, 0x93 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 109 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xce, 0x61, 0xd6, 0x35, 0x14, 0xad, 0xed, 0x03, 0xd4, 0x3e, 0x6e, 0xbf, 0xc3, 0xa9, 0x00, 0x1f }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 110 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6c, 0x83, 0x9d, 0xd5, 0x8e, 0xea, 0xe6, 0xb8, 0xa3, 0x6a, 0xf4, 0x8e, 0xd6, 0x3d, 0x2d, 0xc9 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 111 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcd, 0x5e, 0xce, 0x55, 0xb8, 0xda, 0x3b, 0xf6, 0x22, 0xc4, 0x10, 0x0d, 0xf5, 0xde, 0x46, 0xf9 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 112 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3b, 0x6f, 0x46, 0xf4, 0x0e, 0x0a, 0xc5, 0xfc, 0x0a, 0x9c, 0x11, 0x05, 0xf8, 0x00, 0xf4, 0x8d }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 113 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xba, 0x26, 0xd4, 0x7d, 0xa3, 0xae, 0xb0, 0x28, 0xde, 0x4f, 0xb5, 0xb3, 0xa8, 0x54, 0xa2, 0x4b }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 114 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x87, 0xf5, 0x3b, 0xf6, 0x20, 0xd3, 0x67, 0x72, 0x68, 0x44, 0x52, 0x12, 0x90, 0x43, 0x89, 0xd5 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 115 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x10, 0x61, 0x7d, 0x28, 0xb5, 0xe0, 0xf4, 0x60, 0x54, 0x92, 0xb1, 0x82, 0xa5, 0xd7, 0xf9, 0xf6 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 116 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9a, 0xae, 0xc4, 0xfa, 0xbb, 0xf6, 0xfa, 0xe2, 0xa7, 0x1f, 0xef, 0xf0, 0x2e, 0x37, 0x2b, 0x39 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 117 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0x90, 0xc6, 0x2d, 0x88, 0xb5, 0xc4, 0x28, 0x09, 0xab, 0xf7, 0x82, 0x48, 0x8e, 0xd1, 0x30 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 118 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf1, 0xf1, 0xc5, 0xa4, 0x08, 0x99, 0xe1, 0x57, 0x72, 0x85, 0x7c, 0xcb, 0x65, 0xc7, 0xa0, 0x9a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 119 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x19, 0x08, 0x43, 0xd2, 0x9b, 0x25, 0xa3, 0x89, 0x7c, 0x69, 0x2c, 0xe1, 0xdd, 0x81, 0xee, 0x52 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 120 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa8, 0x66, 0xbc, 0x65, 0xb6, 0x94, 0x1d, 0x86, 0xe8, 0x42, 0x0a, 0x7f, 0xfb, 0x09, 0x64, 0xdb }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 121 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x81, 0x93, 0xc6, 0xff, 0x85, 0x22, 0x5c, 0xed, 0x42, 0x55, 0xe9, 0x2f, 0x6e, 0x07, 0x8a, 0x14 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 122 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x96, 0x61, 0xcb, 0x24, 0x24, 0xd7, 0xd4, 0xa3, 0x80, 0xd5, 0x47, 0xf9, 0xe7, 0xec, 0x1c, 0xb9 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 123 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x86, 0xf9, 0x3d, 0x9e, 0xc0, 0x84, 0x53, 0xa0, 0x71, 0xe2, 0xe2, 0x87, 0x78, 0x77, 0xa9, 0xc8 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 124 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0xee, 0xfa, 0x80, 0xce, 0x6a, 0x4a, 0x9d, 0x59, 0x8e, 0x3f, 0xec, 0x36, 0x54, 0x34, 0xd2 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 125 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd6, 0x20, 0x68, 0x44, 0x45, 0x78, 0xe3, 0xab, 0x39, 0xce, 0x7e, 0xc9, 0x5d, 0xd0, 0x45, 0xdc }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 126 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb5, 0xf7, 0x1d, 0x4d, 0xd9, 0xa7, 0x1f, 0xe5, 0xd8, 0xbc, 0x8b, 0xa7, 0xe6, 0xea, 0x30, 0x48 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 127 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x68, 0x25, 0xa3, 0x47, 0xac, 0x47, 0x9d, 0x4f, 0x9d, 0x95, 0xc5, 0xcb, 0x8d, 0x3f, 0xd7, 0xe9 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 128 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe3, 0x71, 0x4e, 0x94, 0xa5, 0x77, 0x89, 0x55, 0xcc, 0x03, 0x46, 0x35, 0x8e, 0x94, 0x78, 0x3a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 129 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd8, 0x36, 0xb4, 0x4b, 0xb2, 0x9e, 0x0c, 0x7d, 0x89, 0xfa, 0x4b, 0x2d, 0x4b, 0x67, 0x7d, 0x2a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 130 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5d, 0x45, 0x4b, 0x75, 0x02, 0x1d, 0x76, 0xd4, 0xb8, 0x4f, 0x87, 0x3a, 0x8f, 0x87, 0x7b, 0x92 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 131 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc3, 0x49, 0x8f, 0x7e, 0xce, 0xd2, 0x09, 0x53, 0x14, 0xfc, 0x28, 0x11, 0x58, 0x85, 0xb3, 0x3f }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 132 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6e, 0x66, 0x88, 0x56, 0x53, 0x9a, 0xd8, 0xe4, 0x05, 0xbd, 0x12, 0x3f, 0xe6, 0xc8, 0x85, 0x30 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 133 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x86, 0x80, 0xdb, 0x7f, 0x3a, 0x87, 0xb8, 0x60, 0x55, 0x43, 0xcf, 0xdb, 0xe6, 0x75, 0x40, 0x76 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 134 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6c, 0x5d, 0x03, 0xb1, 0x30, 0x69, 0xc3, 0x65, 0x8b, 0x31, 0x79, 0xbe, 0x91, 0xb0, 0x80, 0x0c }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 135 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xef, 0x1b, 0x38, 0x4a, 0xc4, 0xd9, 0x3e, 0xda, 0x00, 0xc9, 0x2a, 0xdd, 0x09, 0x95, 0xea, 0x5f }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 136 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbf, 0x81, 0x15, 0x80, 0x54, 0x71, 0x74, 0x1b, 0xd5, 0xad, 0x20, 0xa0, 0x39, 0x44, 0x79, 0x0f }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 137 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc6, 0x4c, 0x24, 0xb6, 0x89, 0x4b, 0x03, 0x8b, 0x3c, 0x0d, 0x09, 0xb1, 0xdf, 0x06, 0x8b, 0x0b }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 138 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x39, 0x67, 0xa1, 0x0c, 0xff, 0xe2, 0x7d, 0x01, 0x78, 0x54, 0x5f, 0xbf, 0x6a, 0x40, 0x54, 0x4b }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 139 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7c, 0x85, 0xe9, 0xc9, 0x5d, 0xe1, 0xa9, 0xec, 0x5a, 0x53, 0x63, 0xa8, 0xa0, 0x53, 0x47, 0x2d }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 140 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa9, 0xee, 0xc0, 0x3c, 0x8a, 0xbe, 0xc7, 0xba, 0x68, 0x31, 0x5c, 0x2c, 0x8c, 0x23, 0x16, 0xe0 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 141 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xca, 0xc8, 0xe4, 0x14, 0xc2, 0xf3, 0x88, 0x22, 0x7a, 0xe1, 0x49, 0x86, 0xfc, 0x98, 0x35, 0x24 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 142 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5d, 0x94, 0x2b, 0x7f, 0x46, 0x22, 0xce, 0x05, 0x6c, 0x3c, 0xe3, 0xce, 0x5f, 0x1d, 0xd9, 0xd6 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 143 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0x40, 0xd6, 0x48, 0xce, 0x21, 0xa3, 0x02, 0x02, 0x82, 0xc3, 0xf1, 0xb5, 0x28, 0xa0, 0xb6 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 144 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x45, 0xd0, 0x89, 0xc3, 0x6d, 0x5c, 0x5a, 0x4e, 0xfc, 0x68, 0x9e, 0x3b, 0x0d, 0xe1, 0x0d, 0xd5 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 145 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb4, 0xda, 0x5d, 0xf4, 0xbe, 0xcb, 0x54, 0x62, 0xe0, 0x3a, 0x0e, 0xd0, 0x0d, 0x29, 0x56, 0x29 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 146 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdc, 0xf4, 0xe1, 0x29, 0x13, 0x6c, 0x1a, 0x4b, 0x7a, 0x0f, 0x38, 0x93, 0x5c, 0xc3, 0x4b, 0x2b }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 147 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd9, 0xa4, 0xc7, 0x61, 0x8b, 0x0c, 0xe4, 0x8a, 0x3d, 0x5a, 0xee, 0x1a, 0x1c, 0x01, 0x14, 0xc4 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 148 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xca, 0x35, 0x2d, 0xf0, 0x25, 0xc6, 0x5c, 0x7b, 0x0b, 0xf3, 0x06, 0xfb, 0xee, 0x0f, 0x36, 0xba }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 149 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x23, 0x8a, 0xca, 0x23, 0xfd, 0x34, 0x09, 0xf3, 0x8a, 0xf6, 0x33, 0x78, 0xed, 0x2f, 0x54, 0x73 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 150 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x59, 0x83, 0x6a, 0x0e, 0x06, 0xa7, 0x96, 0x91, 0xb3, 0x66, 0x67, 0xd5, 0x38, 0x0d, 0x81, 0x88 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 151 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x33, 0x90, 0x50, 0x80, 0xf7, 0xac, 0xf1, 0xcd, 0xae, 0x0a, 0x91, 0xfc, 0x3e, 0x85, 0xae, 0xe4 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 152 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x72, 0xc9, 0xe4, 0x64, 0x6d, 0xbc, 0x3d, 0x63, 0x20, 0xfc, 0x66, 0x89, 0xd9, 0x3e, 0x88, 0x33 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 153 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xba, 0x77, 0x41, 0x3d, 0xea, 0x59, 0x25, 0xb7, 0xf5, 0x41, 0x7e, 0xa4, 0x7f, 0xf1, 0x9f, 0x59 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 154 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6c, 0xae, 0x81, 0x29, 0xf8, 0x43, 0xd8, 0x6d, 0xc7, 0x86, 0xa0, 0xfb, 0x1a, 0x18, 0x49, 0x70 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 155 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfc, 0xfe, 0xfb, 0x53, 0x41, 0x00, 0x79, 0x6e, 0xeb, 0xbd, 0x99, 0x02, 0x06, 0x75, 0x4e, 0x19 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 156 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8c, 0x79, 0x1d, 0x5f, 0xdd, 0xdf, 0x47, 0x0d, 0xa0, 0x4f, 0x3e, 0x6d, 0xc4, 0xa5, 0xb5, 0xb5 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 157 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc9, 0x3b, 0xbd, 0xc0, 0x7a, 0x46, 0x11, 0xae, 0x4b, 0xb2, 0x66, 0xea, 0x50, 0x34, 0xa3, 0x87 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 158 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc1, 0x02, 0xe3, 0x8e, 0x48, 0x9a, 0xa7, 0x47, 0x62, 0xf3, 0xef, 0xc5, 0xbb, 0x23, 0x20, 0x5a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 159 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x93, 0x20, 0x14, 0x81, 0x66, 0x5c, 0xba, 0xfc, 0x1f, 0xcc, 0x22, 0x0b, 0xc5, 0x45, 0xfb, 0x3d }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 160 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x49, 0x60, 0x75, 0x7e, 0xc6, 0xce, 0x68, 0xcf, 0x19, 0x5e, 0x45, 0x4c, 0xfd, 0x0f, 0x32, 0xca }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 161 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfe, 0xec, 0x7c, 0xe6, 0xa6, 0xcb, 0xd0, 0x7c, 0x04, 0x34, 0x16, 0x73, 0x7f, 0x1b, 0xbb, 0x33 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 162 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0xc5, 0x41, 0x39, 0x04, 0x48, 0x7a, 0x80, 0x5d, 0x70, 0xa8, 0xed, 0xd9, 0xc3, 0x55, 0x27 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 163 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x34, 0x78, 0x46, 0xb2, 0xb2, 0xe3, 0x6f, 0x1f, 0x03, 0x24, 0xc8, 0x6f, 0x7f, 0x1b, 0x98, 0xe2 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 164 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x33, 0x2e, 0xee, 0x1a, 0x0c, 0xbd, 0x19, 0xca, 0x2d, 0x69, 0xb4, 0x26, 0x89, 0x40, 0x44, 0xf0 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 165 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x86, 0x6b, 0x5b, 0x39, 0x77, 0xba, 0x6e, 0xfa, 0x51, 0x28, 0xef, 0xbd, 0xa9, 0xff, 0x03, 0xcd }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 166 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcc, 0x14, 0x45, 0xee, 0x94, 0xc0, 0xf0, 0x8c, 0xde, 0xe5, 0xc3, 0x44, 0xec, 0xd1, 0xe2, 0x33 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 167 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbe, 0x28, 0x83, 0x19, 0x02, 0x93, 0x63, 0xc2, 0x62, 0x2f, 0xeb, 0xa4, 0xb0, 0x5d, 0xfd, 0xfe }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 168 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcf, 0xd1, 0x87, 0x55, 0x23, 0xf3, 0xcd, 0x21, 0xc3, 0x95, 0x65, 0x1e, 0x6e, 0xe1, 0x5e, 0x56 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 169 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcb, 0x5a, 0x40, 0x86, 0x57, 0x83, 0x7c, 0x53, 0xbf, 0x16, 0xf9, 0xd8, 0x46, 0x5d, 0xce, 0x19 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 170 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xca, 0x0b, 0xf4, 0x2c, 0xb1, 0x07, 0xf5, 0x5c, 0xcf, 0xf2, 0xfc, 0x09, 0xee, 0x08, 0xca, 0x15 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 171 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfd, 0xd9, 0xbb, 0xb4, 0xa7, 0xdc, 0x2e, 0x4a, 0x23, 0x53, 0x6a, 0x58, 0x80, 0xa2, 0xdb, 0x67 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 172 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xed, 0xe4, 0x47, 0xb3, 0x62, 0xc4, 0x84, 0x99, 0x3d, 0xec, 0x94, 0x42, 0xa3, 0xb4, 0x6a, 0xef }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 173 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x10, 0xdf, 0xfb, 0x05, 0x90, 0x4b, 0xff, 0x7c, 0x47, 0x81, 0xdf, 0x78, 0x0a, 0xd2, 0x68, 0x37 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 174 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc3, 0x3b, 0xc1, 0x3e, 0x8d, 0xe8, 0x8a, 0xc2, 0x52, 0x32, 0xaa, 0x74, 0x96, 0x39, 0x87, 0x83 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 175 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xca, 0x35, 0x9c, 0x70, 0x80, 0x3a, 0x3b, 0x2a, 0x3d, 0x54, 0x2e, 0x87, 0x81, 0xde, 0xa9, 0x75 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 176 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbc, 0xc6, 0x5b, 0x52, 0x6f, 0x88, 0xd0, 0x5b, 0x89, 0xce, 0x8a, 0x52, 0x02, 0x1f, 0xdb, 0x06 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 177 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdb, 0x91, 0xa3, 0x88, 0x55, 0xc8, 0xc4, 0x64, 0x38, 0x51, 0xfb, 0xfb, 0x35, 0x8b, 0x01, 0x09 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 178 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xca, 0x6e, 0x88, 0x93, 0xa1, 0x14, 0xae, 0x8e, 0x27, 0xd5, 0xab, 0x03, 0xa5, 0x49, 0x96, 0x10 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 179 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x66, 0x29, 0xd2, 0xb8, 0xdf, 0x97, 0xda, 0x72, 0x8c, 0xdd, 0x8b, 0x1e, 0x7f, 0x94, 0x50, 0x77 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 180 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x45, 0x70, 0xa5, 0xa1, 0x8c, 0xfc, 0x0d, 0xd5, 0x82, 0xf1, 0xd8, 0x8d, 0x5c, 0x9a, 0x17, 0x20 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 181 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x72, 0xbc, 0x65, 0xaa, 0x8e, 0x89, 0x56, 0x2e, 0x3f, 0x27, 0x4d, 0x45, 0xaf, 0x1c, 0xd1, 0x0b }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 182 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x98, 0x55, 0x1d, 0xa1, 0xa6, 0x50, 0x32, 0x76, 0xae, 0x1c, 0x77, 0x62, 0x5f, 0x9e, 0xa6, 0x15 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 183 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0d, 0xdf, 0xe5, 0x1c, 0xed, 0x7e, 0x3f, 0x4a, 0xe9, 0x27, 0xda, 0xa3, 0xfe, 0x45, 0x2c, 0xee }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 184 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdb, 0x82, 0x62, 0x51, 0xe4, 0xce, 0x38, 0x4b, 0x80, 0x21, 0x8b, 0x0e, 0x1d, 0xa1, 0xdd, 0x4c }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 185 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2c, 0xac, 0xf7, 0x28, 0xb8, 0x8a, 0xbb, 0xad, 0x70, 0x11, 0xed, 0x0e, 0x64, 0xa1, 0x68, 0x0c }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 186 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x33, 0x0d, 0x8e, 0xe7, 0xc5, 0x67, 0x7e, 0x09, 0x9a, 0xc7, 0x4c, 0x99, 0x94, 0xee, 0x4c, 0xfb }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 187 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xed, 0xf6, 0x1a, 0xe3, 0x62, 0xe8, 0x82, 0xdd, 0xc0, 0x16, 0x74, 0x74, 0xa7, 0xa7, 0x7f, 0x3a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 188 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x61, 0x68, 0xb0, 0x0b, 0xa7, 0x85, 0x9e, 0x09, 0x70, 0xec, 0xfd, 0x75, 0x7e, 0xfe, 0xcf, 0x7c }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 189 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd1, 0x41, 0x54, 0x47, 0x86, 0x62, 0x30, 0xd2, 0x8b, 0xb1, 0xea, 0x18, 0xa4, 0xcd, 0xfd, 0x02 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 190 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x51, 0x61, 0x83, 0x39, 0x2f, 0x7a, 0x87, 0x63, 0xaf, 0xec, 0x68, 0xa0, 0x60, 0x26, 0x41, 0x41 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 191 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x77, 0x56, 0x5c, 0x8d, 0x73, 0xcf, 0xd4, 0x13, 0x0b, 0x4a, 0xa1, 0x4d, 0x89, 0x11, 0x71, 0x0f }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 192 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x37, 0x23, 0x2a, 0x4e, 0xd2, 0x1c, 0xcc, 0x27, 0xc1, 0x9c, 0x96, 0x10, 0x07, 0x8c, 0xab, 0xac }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 193 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x80, 0x4f, 0x32, 0xea, 0x71, 0x82, 0x8c, 0x7d, 0x32, 0x90, 0x77, 0xe7, 0x12, 0x23, 0x16, 0x66 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 194 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd6, 0x44, 0x24, 0xf2, 0x3c, 0xb9, 0x72, 0x15, 0xe9, 0xc2, 0xc6, 0xf2, 0x8d, 0x29, 0xea, 0xb7 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 195 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x02, 0x3e, 0x82, 0xb5, 0x33, 0xf6, 0x8c, 0x75, 0xc2, 0x38, 0xce, 0xbd, 0xb2, 0xee, 0x89, 0xa2 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 196 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x19, 0x3a, 0x3d, 0x24, 0x15, 0x7a, 0x51, 0xf1, 0xee, 0x08, 0x93, 0xf6, 0x77, 0x74, 0x17, 0xe7 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 197 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x84, 0xec, 0xac, 0xfc, 0xd4, 0x00, 0x08, 0x4d, 0x07, 0x86, 0x12, 0xb1, 0x94, 0x5f, 0x2e, 0xf5 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 198 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1d, 0xcd, 0x8b, 0xb1, 0x73, 0x25, 0x9e, 0xb3, 0x3a, 0x52, 0x42, 0xb0, 0xde, 0x31, 0xa4, 0x55 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 199 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x35, 0xe9, 0xed, 0xdb, 0xc3, 0x75, 0xe7, 0x92, 0xc1, 0x99, 0x92, 0xc1, 0x91, 0x65, 0x01, 0x2b }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 200 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8a, 0x77, 0x22, 0x31, 0xc0, 0x1d, 0xfd, 0xd7, 0xc9, 0x8e, 0x4c, 0xfd, 0xdc, 0xc0, 0x80, 0x7a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 201 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6e, 0xda, 0x7f, 0xf6, 0xb8, 0x31, 0x91, 0x80, 0xff, 0x0d, 0x6e, 0x65, 0x62, 0x9d, 0x01, 0xc3 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 202 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc2, 0x67, 0xef, 0x0e, 0x2d, 0x01, 0xa9, 0x93, 0x94, 0x4d, 0xd3, 0x97, 0x10, 0x14, 0x13, 0xcb }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 203 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe9, 0xf8, 0x0e, 0x9d, 0x84, 0x5b, 0xcc, 0x0f, 0x62, 0x92, 0x6a, 0xf7, 0x2e, 0xab, 0xca, 0x39 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 204 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x67, 0x02, 0x99, 0x07, 0x27, 0xaa, 0x08, 0x78, 0x63, 0x7b, 0x45, 0xdc, 0xd3, 0xa3, 0xb0, 0x74 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 205 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2e, 0x2e, 0x64, 0x7d, 0x53, 0x60, 0xe0, 0x92, 0x30, 0xa5, 0xd7, 0x38, 0xca, 0x33, 0x47, 0x1e }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 206 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1f, 0x56, 0x41, 0x3c, 0x7a, 0xdd, 0x6f, 0x43, 0xd1, 0xd5, 0x6e, 0x4f, 0x02, 0x19, 0x03, 0x30 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 207 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x69, 0xcd, 0x06, 0x06, 0xe1, 0x5a, 0xf7, 0x29, 0xd6, 0xbc, 0xa1, 0x43, 0x01, 0x6d, 0x98, 0x42 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 208 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa0, 0x85, 0xd7, 0xc1, 0xa5, 0x00, 0x87, 0x3a, 0x20, 0x09, 0x9c, 0x4c, 0xaa, 0x3c, 0x3f, 0x5b }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 209 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4f, 0xc0, 0xd2, 0x30, 0xf8, 0x89, 0x14, 0x15, 0xb8, 0x7b, 0x83, 0xf9, 0x5f, 0x2e, 0x09, 0xd1 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 210 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x43, 0x27, 0xd0, 0x8c, 0x52, 0x3d, 0x8e, 0xba, 0x69, 0x7a, 0x43, 0x36, 0x50, 0x7d, 0x1f, 0x42 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 211 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7a, 0x15, 0xaa, 0xb8, 0x27, 0x01, 0xef, 0xa5, 0xae, 0x36, 0xab, 0x1d, 0x6b, 0x76, 0x29, 0x0f }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 212 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5b, 0xf0, 0x05, 0x18, 0x93, 0xa1, 0x8b, 0xb3, 0x0e, 0x13, 0x9a, 0x58, 0xfe, 0xd0, 0xfa, 0x54 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 213 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0xe8, 0xad, 0xf6, 0x56, 0x38, 0xfd, 0x9c, 0xdf, 0x3b, 0xc2, 0x2c, 0x17, 0xfe, 0x4d, 0xbd }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 214 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1e, 0xe6, 0xee, 0x32, 0x65, 0x83, 0xa0, 0x58, 0x64, 0x91, 0xc9, 0x64, 0x18, 0xd1, 0xa3, 0x5d }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 215 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x26, 0xb5, 0x49, 0xc2, 0xec, 0x75, 0x6f, 0x82, 0xec, 0xc4, 0x80, 0x08, 0xe5, 0x29, 0x95, 0x6b }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 216 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x70, 0x37, 0x7b, 0x6d, 0xa6, 0x69, 0xb0, 0x72, 0x12, 0x9e, 0x05, 0x7c, 0xc2, 0x8e, 0x9c, 0xa5 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 217 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9c, 0x94, 0xb8, 0xb0, 0xcb, 0x8b, 0xcc, 0x91, 0x90, 0x72, 0x26, 0x2b, 0x3f, 0xa0, 0x5a, 0xd9 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 218 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2f, 0xbb, 0x83, 0xdf, 0xd0, 0xd7, 0xab, 0xcb, 0x05, 0xcd, 0x28, 0xca, 0xd2, 0xdf, 0xb5, 0x23 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 219 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x96, 0x87, 0x78, 0x03, 0xde, 0x77, 0x74, 0x4b, 0xb9, 0x70, 0xd0, 0xa9, 0x1f, 0x4d, 0xeb, 0xae }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 220 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x73, 0x79, 0xf3, 0x37, 0x0c, 0xf6, 0xe5, 0xce, 0x12, 0xae, 0x59, 0x69, 0xc8, 0xee, 0xa3, 0x12 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 221 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x02, 0xdc, 0x99, 0xfa, 0x3d, 0x4f, 0x98, 0xce, 0x80, 0x98, 0x5e, 0x72, 0x33, 0x88, 0x93, 0x13 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 222 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1e, 0x38, 0xe7, 0x59, 0x07, 0x5b, 0xa5, 0xca, 0xb6, 0x45, 0x7d, 0xa5, 0x18, 0x44, 0x29, 0x5a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 223 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x70, 0xbe, 0xd8, 0xdb, 0xf6, 0x15, 0x86, 0x8a, 0x1f, 0x9d, 0x9b, 0x05, 0xd3, 0xe7, 0xa2, 0x67 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 224 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x23, 0x4b, 0x14, 0x8b, 0x8c, 0xb1, 0xd8, 0xc3, 0x2b, 0x28, 0x7e, 0x89, 0x69, 0x03, 0xd1, 0x50 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 225 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x29, 0x4b, 0x03, 0x3d, 0xf4, 0xda, 0x85, 0x3f, 0x4b, 0xe3, 0xe2, 0x43, 0xf7, 0xe5, 0x13, 0xf4 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 226 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3f, 0x58, 0xc9, 0x50, 0xf0, 0x36, 0x71, 0x60, 0xad, 0xec, 0x45, 0xf2, 0x44, 0x1e, 0x74, 0x11 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 227 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x37, 0xf6, 0x55, 0x53, 0x6a, 0x70, 0x4e, 0x5a, 0xce, 0x18, 0x2d, 0x74, 0x2a, 0x82, 0x0c, 0xf4 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 228 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xea, 0x7b, 0xd6, 0xbb, 0x63, 0x41, 0x87, 0x31, 0xae, 0xac, 0x79, 0x0f, 0xe4, 0x2d, 0x61, 0xe8 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 229 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe7, 0x4a, 0x4c, 0x99, 0x9b, 0x4c, 0x06, 0x4e, 0x48, 0xbb, 0x1e, 0x41, 0x3f, 0x51, 0xe5, 0xea }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 230 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xba, 0x9e, 0xbe, 0xfd, 0xb4, 0xcc, 0xf3, 0x0f, 0x29, 0x6c, 0xec, 0xb3, 0xbc, 0x19, 0x43, 0xe8 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 231 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x31, 0x94, 0x36, 0x7a, 0x48, 0x98, 0xc5, 0x02, 0xc1, 0x3b, 0xb7, 0x47, 0x86, 0x40, 0xa7, 0x2d }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 232 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xda, 0x79, 0x77, 0x13, 0x26, 0x3d, 0x6f, 0x33, 0xa5, 0x47, 0x8a, 0x65, 0xef, 0x60, 0xd4, 0x12 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 233 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd1, 0xac, 0x39, 0xbb, 0x1e, 0xf8, 0x6b, 0x9c, 0x13, 0x44, 0xf2, 0x14, 0x67, 0x9a, 0xa3, 0x76 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 234 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2f, 0xde, 0xa9, 0xe6, 0x50, 0x53, 0x2b, 0xe5, 0xbc, 0x0e, 0x73, 0x25, 0x33, 0x7f, 0xd3, 0x63 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 235 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd3, 0xa2, 0x04, 0xdb, 0xd9, 0xc2, 0xaf, 0x15, 0x8b, 0x6c, 0xa6, 0x7a, 0x51, 0x56, 0xce, 0x4a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 236 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0x0a, 0x0e, 0x75, 0xa8, 0xda, 0x36, 0x73, 0x5a, 0xee, 0x66, 0x84, 0xd9, 0x65, 0xa7, 0x78 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 237 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x52, 0xfc, 0x3e, 0x62, 0x04, 0x92, 0xea, 0x99, 0x64, 0x1e, 0xa1, 0x68, 0xda, 0x5b, 0x6d, 0x52 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 238 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0xe0, 0xc7, 0xf1, 0x5b, 0x47, 0x72, 0x46, 0x7d, 0x2c, 0xfc, 0x87, 0x30, 0x00, 0xb2, 0xca }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 239 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x56, 0x35, 0x31, 0x13, 0x5e, 0x0c, 0x4d, 0x70, 0xa3, 0x8f, 0x8b, 0xdb, 0x19, 0x0b, 0xa0, 0x4e }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 240 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa8, 0xa3, 0x9a, 0x0f, 0x56, 0x63, 0xf4, 0xc0, 0xfe, 0x5f, 0x2d, 0x3c, 0xaf, 0xff, 0x42, 0x1a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 241 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd9, 0x4b, 0x5e, 0x90, 0xdb, 0x35, 0x4c, 0x1e, 0x42, 0xf6, 0x1f, 0xab, 0xe1, 0x67, 0xb2, 0xc0 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 242 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x50, 0xe6, 0xd3, 0xc9, 0xb6, 0x69, 0x8a, 0x7c, 0xd2, 0x76, 0xf9, 0x6b, 0x14, 0x73, 0xf3, 0x5a }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 243 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x93, 0x38, 0xf0, 0x8e, 0x0e, 0xbe, 0xe9, 0x69, 0x05, 0xd8, 0xf2, 0xe8, 0x25, 0x20, 0x8f, 0x43 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 244 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8b, 0x37, 0x8c, 0x86, 0x67, 0x2a, 0xa5, 0x4a, 0x3a, 0x26, 0x6b, 0xa1, 0x9d, 0x25, 0x80, 0xca }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 245 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcc, 0xa7, 0xc3, 0x08, 0x6f, 0x5f, 0x95, 0x11, 0xb3, 0x12, 0x33, 0xda, 0x7c, 0xab, 0x91, 0x60 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 246 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5b, 0x40, 0xff, 0x4e, 0xc9, 0xbe, 0x53, 0x6b, 0xa2, 0x30, 0x35, 0xfa, 0x4f, 0x06, 0x06, 0x4c }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 247 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x60, 0xeb, 0x5a, 0xf8, 0x41, 0x6b, 0x25, 0x71, 0x49, 0x37, 0x21, 0x94, 0xe8, 0xb8, 0x87, 0x49 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 248 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2f, 0x00, 0x5a, 0x8a, 0xed, 0x8a, 0x36, 0x1c, 0x92, 0xe4, 0x40, 0xc1, 0x55, 0x20, 0xcb, 0xd1 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 249 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7b, 0x03, 0x62, 0x76, 0x11, 0x67, 0x8a, 0x99, 0x77, 0x17, 0x57, 0x88, 0x07, 0xa8, 0x00, 0xe2 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 250 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcf, 0x78, 0x61, 0x8f, 0x74, 0xf6, 0xf3, 0x69, 0x6e, 0x0a, 0x47, 0x79, 0xb9, 0x0b, 0x5a, 0x77 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 251 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x03, 0x72, 0x03, 0x71, 0xa0, 0x49, 0x62, 0xea, 0xea, 0x0a, 0x85, 0x2e, 0x69, 0x97, 0x28, 0x58 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 252 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1f, 0x8a, 0x81, 0x33, 0xaa, 0x8c, 0xcf, 0x70, 0xe2, 0xbd, 0x32, 0x85, 0x83, 0x1c, 0xa6, 0xb7 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 253 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0x93, 0x6b, 0xd2, 0x7f, 0xb1, 0x46, 0x8f, 0xc8, 0xb4, 0x8b, 0xc4, 0x83, 0x32, 0x17, 0x25 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 254 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb0, 0x7d, 0x4f, 0x3e, 0x2c, 0xd2, 0xef, 0x2e, 0xb5, 0x45, 0x98, 0x07, 0x54, 0xdf, 0xea, 0x0f }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 255 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4b, 0xf8, 0x5f, 0x1b, 0x5d, 0x54, 0xad, 0xbc, 0x30, 0x7b, 0x0a, 0x04, 0x83, 0x89, 0xad, 0xcb }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 0 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe3, 0x5a, 0x6d, 0xcb, 0x19, 0xb2, 0x01, 0xa0, 0x1e, 0xbc, 0xfa, 0x8a, 0xa2, 0x2b, 0x57, 0x59 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 1 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb2, 0x91, 0x69, 0xcd, 0xcf, 0x2d, 0x83, 0xe8, 0x38, 0x12, 0x5a, 0x12, 0xee, 0x6a, 0xa4, 0x00 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 2 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd8, 0xf3, 0xa7, 0x2f, 0xc3, 0xcd, 0xf7, 0x4d, 0xfa, 0xf6, 0xc3, 0xe6, 0xb9, 0x7b, 0x2f, 0xa6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 3 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1c, 0x77, 0x76, 0x79, 0xd5, 0x00, 0x37, 0xc7, 0x94, 0x91, 0xa9, 0x4d, 0xa7, 0x6a, 0x9a, 0x35 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 4 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9c, 0xf4, 0x89, 0x3e, 0xca, 0xfa, 0x0a, 0x02, 0x47, 0xa8, 0x98, 0xe0, 0x40, 0x69, 0x15, 0x59 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 5 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8f, 0xbb, 0x41, 0x37, 0x03, 0x73, 0x53, 0x26, 0x31, 0x0a, 0x26, 0x9b, 0xd3, 0xaa, 0x94, 0xb2 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 6 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x60, 0xe3, 0x22, 0x46, 0xbe, 0xd2, 0xb0, 0xe8, 0x59, 0xe5, 0x5c, 0x1c, 0xc6, 0xb2, 0x65, 0x02 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 7 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xec, 0x52, 0xa2, 0x12, 0xf8, 0x0a, 0x09, 0xdf, 0x63, 0x17, 0x02, 0x1b, 0xc2, 0xa9, 0x81, 0x9e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 8 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf2, 0x3e, 0x5b, 0x60, 0x0e, 0xb7, 0x0d, 0xbc, 0xcf, 0x6c, 0x0b, 0x1d, 0x9a, 0x68, 0x18, 0x2c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 9 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa3, 0xf5, 0x99, 0xd6, 0x3a, 0x82, 0xa9, 0x68, 0xc3, 0x3f, 0xe2, 0x65, 0x90, 0x74, 0x59, 0x70 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 10 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd1, 0xcc, 0xb9, 0xb1, 0x33, 0x70, 0x02, 0xcb, 0xac, 0x42, 0xc5, 0x20, 0xb5, 0xd6, 0x77, 0x22 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 11 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcc, 0x11, 0x1f, 0x6c, 0x37, 0xcf, 0x40, 0xa1, 0x15, 0x9d, 0x00, 0xfb, 0x59, 0xfb, 0x04, 0x88 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 12 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdc, 0x43, 0xb5, 0x1a, 0xb6, 0x09, 0x05, 0x23, 0x72, 0x98, 0x9a, 0x26, 0xe9, 0xcd, 0xd7, 0x14 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 13 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4d, 0xce, 0xde, 0x8d, 0xa9, 0xe2, 0x57, 0x8f, 0x39, 0x70, 0x3d, 0x44, 0x33, 0xdc, 0x64, 0x59 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 14 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1a, 0x4c, 0x1c, 0x26, 0x3b, 0xbc, 0xcf, 0xaf, 0xc1, 0x17, 0x82, 0x89, 0x46, 0x85, 0xe3, 0xa8 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 15 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x93, 0x7a, 0xd8, 0x48, 0x80, 0xdb, 0x50, 0x61, 0x34, 0x23, 0xd6, 0xd5, 0x27, 0xa2, 0x82, 0x3d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 16 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x61, 0x0b, 0x71, 0xdf, 0xc6, 0x88, 0xe1, 0x50, 0xd8, 0x15, 0x2c, 0x5b, 0x35, 0xeb, 0xc1, 0x4d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 17 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0xef, 0x24, 0x95, 0xda, 0xbf, 0x32, 0x38, 0x85, 0xaa, 0xb3, 0x9c, 0x80, 0xf1, 0x8d, 0x8b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 18 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x63, 0x3c, 0xaf, 0xea, 0x39, 0x5b, 0xc0, 0x3a, 0xda, 0xe3, 0xa1, 0xe2, 0x06, 0x8e, 0x4b, 0x4e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 19 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6e, 0x1b, 0x48, 0x2b, 0x53, 0x76, 0x1c, 0xf6, 0x31, 0x81, 0x9b, 0x74, 0x9a, 0x6f, 0x37, 0x24 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 20 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0x6e, 0x6f, 0x85, 0x1a, 0xb5, 0x2c, 0x77, 0x19, 0x98, 0xdb, 0xb2, 0xd7, 0x1c, 0x75, 0xa9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 21 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x85, 0xf2, 0xba, 0x84, 0xf8, 0xc3, 0x07, 0xcf, 0x52, 0x5e, 0x12, 0x4c, 0x3e, 0x22, 0xe6, 0xcc }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 22 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6b, 0xcc, 0xa9, 0x8b, 0xf6, 0xa8, 0x35, 0xfa, 0x64, 0x95, 0x5f, 0x72, 0xde, 0x41, 0x15, 0xfe }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 23 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2c, 0x75, 0xe2, 0xd3, 0x6e, 0xeb, 0xd6, 0x54, 0x11, 0xf1, 0x4f, 0xd0, 0xeb, 0x1d, 0x2a, 0x06 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 24 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbd, 0x49, 0x29, 0x50, 0x06, 0x25, 0x0f, 0xfc, 0xa5, 0x10, 0x0b, 0x60, 0x07, 0xa0, 0xea, 0xde }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 25 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa1, 0x90, 0x52, 0x7d, 0x0e, 0xf7, 0xc7, 0x0f, 0x45, 0x9c, 0xd3, 0x94, 0x0d, 0xf3, 0x16, 0xec }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 26 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbb, 0xd1, 0x09, 0x7a, 0x62, 0x43, 0x3f, 0x79, 0x44, 0x9f, 0xa9, 0x7d, 0x4e, 0xe8, 0x0d, 0xbf }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 27 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x07, 0x05, 0x8e, 0x40, 0x8f, 0x5b, 0x99, 0xb0, 0xe0, 0xf0, 0x61, 0xa1, 0x76, 0x1b, 0x5b, 0x3b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 28 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5f, 0xd1, 0xf1, 0x3f, 0xa0, 0xf3, 0x1e, 0x37, 0xfa, 0xbd, 0xe3, 0x28, 0xf8, 0x94, 0xea, 0xc2 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 29 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfc, 0x4a, 0xf7, 0xc9, 0x48, 0xdf, 0x26, 0xe2, 0xef, 0x3e, 0x01, 0xc1, 0xee, 0x5b, 0x8f, 0x6f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 30 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x82, 0x9f, 0xd7, 0x20, 0x8f, 0xb9, 0x2d, 0x44, 0xa0, 0x74, 0xa6, 0x77, 0xee, 0x98, 0x61, 0xac }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 31 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xad, 0x9f, 0xc6, 0x13, 0xa7, 0x03, 0x25, 0x1b, 0x54, 0xc6, 0x4a, 0x0e, 0x76, 0x43, 0x17, 0x11 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 32 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x33, 0xac, 0x9e, 0xcc, 0xc4, 0xcc, 0x75, 0xe2, 0x71, 0x16, 0x18, 0xf8, 0x0b, 0x15, 0x48, 0xe8 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 33 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x20, 0x25, 0xc7, 0x4b, 0x8a, 0xd8, 0xf4, 0xcd, 0xa1, 0x7e, 0xe2, 0x04, 0x9c, 0x4c, 0x90, 0x2d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 34 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf8, 0x5c, 0xa0, 0x5f, 0xe5, 0x28, 0xf1, 0xce, 0x9b, 0x79, 0x01, 0x66, 0xe8, 0xd5, 0x51, 0xe7 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 35 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6f, 0x62, 0x38, 0xd8, 0x96, 0x60, 0x48, 0xd4, 0x96, 0x71, 0x54, 0xe0, 0xda, 0xd5, 0xa6, 0xc9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 36 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf2, 0xb2, 0x1b, 0x4e, 0x76, 0x40, 0xa9, 0xb3, 0x34, 0x6d, 0xe8, 0xb8, 0x2f, 0xb4, 0x1e, 0x49 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 37 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf8, 0x36, 0xf2, 0x51, 0xad, 0x1d, 0x11, 0xd4, 0x9d, 0xc3, 0x44, 0x62, 0x8b, 0x18, 0x84, 0xe1 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 38 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x07, 0x7e, 0x94, 0x70, 0xae, 0x7a, 0xbe, 0xa5, 0xa9, 0x76, 0x9d, 0x49, 0x18, 0x26, 0x28, 0xc3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 39 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe0, 0xdc, 0xc2, 0xd2, 0x7f, 0xc9, 0x86, 0x56, 0x33, 0xf8, 0x52, 0x23, 0xcf, 0x0d, 0x61, 0x1f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 40 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbe, 0x66, 0xcf, 0xea, 0x2f, 0xec, 0xd6, 0xbf, 0x0e, 0xc7, 0xb4, 0x35, 0x2c, 0x99, 0xbc, 0xaa }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 41 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdf, 0x31, 0x14, 0x4f, 0x87, 0xa2, 0xef, 0x52, 0x3f, 0xac, 0xdc, 0xf2, 0x1a, 0x42, 0x78, 0x04 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 42 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb5, 0xbb, 0x0f, 0x56, 0x29, 0xfb, 0x6a, 0xae, 0x5e, 0x18, 0x39, 0xa3, 0xc3, 0x62, 0x5d, 0x63 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 43 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3c, 0x9d, 0xb3, 0x33, 0x53, 0x06, 0xfe, 0x1e, 0xc6, 0x12, 0xbd, 0xbf, 0xae, 0x6b, 0x60, 0x28 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 44 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3d, 0xd5, 0xc3, 0x46, 0x34, 0xa7, 0x9d, 0x3c, 0xfc, 0xc8, 0x33, 0x97, 0x60, 0xe6, 0xf5, 0xf4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 45 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x82, 0xbd, 0xa1, 0x18, 0xa3, 0xed, 0x7a, 0xf3, 0x14, 0xfa, 0x2c, 0xcc, 0x5c, 0x07, 0xb7, 0x61 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 46 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x29, 0x37, 0xa6, 0x4f, 0x7d, 0x4f, 0x46, 0xfe, 0x6f, 0xea, 0x3b, 0x34, 0x9e, 0xc7, 0x8e, 0x38 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 47 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x22, 0x5f, 0x06, 0x8c, 0x28, 0x47, 0x66, 0x05, 0x73, 0x5a, 0xd6, 0x71, 0xbb, 0x8f, 0x39, 0xf3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 48 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xae, 0x68, 0x2c, 0x5e, 0xcd, 0x71, 0x89, 0x8e, 0x08, 0x94, 0x2a, 0xc9, 0xaa, 0x89, 0x87, 0x5c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 49 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5e, 0x03, 0x1c, 0xb9, 0xd6, 0x76, 0xc3, 0x02, 0x2d, 0x7f, 0x26, 0x22, 0x7e, 0x85, 0xc3, 0x8f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 50 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa7, 0x84, 0x63, 0xfb, 0x06, 0x4d, 0xb5, 0xd5, 0x2b, 0xb6, 0x4b, 0xfe, 0xf6, 0x4f, 0x2d, 0xda }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 51 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8a, 0xa9, 0xb7, 0x5e, 0x78, 0x45, 0x93, 0x87, 0x6c, 0x53, 0xa0, 0x0e, 0xae, 0x5a, 0xf5, 0x2b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 52 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3f, 0x84, 0x56, 0x6d, 0xf2, 0x3d, 0xa4, 0x8a, 0xf6, 0x92, 0x72, 0x2f, 0xe9, 0x80, 0x57, 0x3a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 53 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x31, 0x69, 0x0b, 0x5e, 0xd4, 0x1c, 0x7e, 0xb4, 0x2a, 0x1e, 0x83, 0x27, 0x0a, 0x7f, 0xf0, 0xe6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 54 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x77, 0xdd, 0x77, 0x02, 0x64, 0x6d, 0x55, 0xf0, 0x83, 0x65, 0xe4, 0x77, 0xd3, 0x59, 0x0e, 0xda }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 55 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4c, 0x02, 0x2a, 0xc6, 0x2b, 0x3c, 0xb7, 0x8d, 0x73, 0x9c, 0xc6, 0x7b, 0x3e, 0x20, 0xbb, 0x7e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 56 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x09, 0x2f, 0xa1, 0x37, 0xce, 0x18, 0xb5, 0xdf, 0xe7, 0x90, 0x6f, 0x55, 0x0b, 0xb1, 0x33, 0x70 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 57 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3e, 0x0c, 0xda, 0xdf, 0x2e, 0x68, 0x35, 0x3c, 0x00, 0x27, 0x67, 0x2c, 0x97, 0x14, 0x4d, 0xd3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 58 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd8, 0xc4, 0xb2, 0x00, 0xb3, 0x83, 0xfc, 0x1f, 0x2b, 0x2e, 0xa6, 0x77, 0x61, 0x8a, 0x1d, 0x27 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 59 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0x82, 0x5f, 0x99, 0xb0, 0xe9, 0xbb, 0x34, 0x77, 0xc1, 0xc0, 0x71, 0x3b, 0x01, 0x5a, 0xac }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 60 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf8, 0xb9, 0xff, 0xfb, 0x5c, 0x18, 0x7f, 0x7d, 0xdc, 0x7a, 0xb1, 0x0f, 0x4f, 0xb7, 0x75, 0x76 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 61 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xb4, 0xe8, 0x7a, 0x32, 0xb3, 0x7d, 0x6f, 0x2c, 0x83, 0x28, 0xd3, 0xb5, 0x37, 0x78, 0x02 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 62 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0x76, 0xc1, 0x3a, 0x5d, 0x22, 0x0f, 0x4d, 0xa9, 0x22, 0x4e, 0x74, 0x89, 0x63, 0x91, 0xce }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 63 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x94, 0xef, 0xe7, 0xa0, 0xe2, 0xe0, 0x31, 0xe2, 0x53, 0x6d, 0xa0, 0x1d, 0xf7, 0x99, 0xc9, 0x27 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 64 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8f, 0x8f, 0xd8, 0x22, 0x68, 0x0a, 0x85, 0x97, 0x4e, 0x53, 0xa5, 0xa8, 0xeb, 0x9d, 0x38, 0xde }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 65 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe0, 0xf0, 0xa9, 0x1b, 0x2e, 0x45, 0xf8, 0xcc, 0x37, 0xb7, 0x80, 0x5a, 0x30, 0x42, 0x58, 0x8d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 66 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x59, 0x7a, 0x62, 0x52, 0x25, 0x5e, 0x46, 0xd6, 0x36, 0x4d, 0xbe, 0xed, 0xa3, 0x1e, 0x27, 0x9c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 67 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf5, 0x1a, 0x0f, 0x69, 0x44, 0x42, 0xb8, 0xf0, 0x55, 0x71, 0x79, 0x7f, 0xec, 0x7e, 0xe8, 0xbf }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 68 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9f, 0xf0, 0x71, 0xb1, 0x65, 0xb5, 0x19, 0x8a, 0x93, 0xdd, 0xde, 0xeb, 0xc5, 0x4d, 0x09, 0xb5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 69 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc2, 0x0a, 0x19, 0xfd, 0x57, 0x58, 0xb0, 0xc4, 0xbc, 0x1a, 0x5d, 0xf8, 0x9c, 0xf7, 0x38, 0x77 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 70 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0x12, 0x01, 0x66, 0x30, 0x71, 0x19, 0xca, 0x22, 0x80, 0xe9, 0x31, 0x56, 0x68, 0xe9, 0x6f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 71 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4b, 0x3b, 0x9f, 0x1e, 0x09, 0x9c, 0x2a, 0x09, 0xdc, 0x09, 0x1e, 0x90, 0xe4, 0xf1, 0x8f, 0x0a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 72 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xeb, 0x04, 0x0b, 0x89, 0x1d, 0x4b, 0x37, 0xf6, 0x85, 0x1f, 0x7e, 0xc2, 0x19, 0xcd, 0x3f, 0x6d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 73 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9f, 0x0f, 0xde, 0xc0, 0x8b, 0x7f, 0xd7, 0x9a, 0xa3, 0x95, 0x35, 0xbe, 0xa4, 0x2d, 0xb9, 0x2a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 74 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2e, 0x70, 0xf1, 0x68, 0xfc, 0x74, 0xbf, 0x91, 0x1d, 0xf2, 0x40, 0xbc, 0xd2, 0xce, 0xf2, 0x36 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 75 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x46, 0x2c, 0xcd, 0x7f, 0x5f, 0xd1, 0x10, 0x8d, 0xbc, 0x15, 0x2f, 0x3c, 0xac, 0xad, 0x32, 0x8b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 76 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa4, 0xaf, 0x53, 0x4a, 0x7d, 0x0b, 0x64, 0x3a, 0x01, 0x86, 0x87, 0x85, 0xd8, 0x6d, 0xfb, 0x95 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 77 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xab, 0x98, 0x02, 0x96, 0x19, 0x7e, 0x1a, 0x50, 0x22, 0x32, 0x6c, 0x31, 0xda, 0x4b, 0xf6, 0xf3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 78 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf9, 0x7d, 0x57, 0xb3, 0x33, 0x3b, 0x62, 0x81, 0xb0, 0x7d, 0x48, 0x6d, 0xb2, 0xd4, 0xe2, 0x0c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 79 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf3, 0x3f, 0xa3, 0x67, 0x20, 0x23, 0x1a, 0xfe, 0x4c, 0x75, 0x9a, 0xde, 0x6b, 0xd6, 0x2e, 0xb6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 80 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfd, 0xcf, 0xac, 0x0c, 0x02, 0xca, 0x53, 0x83, 0x43, 0xc6, 0x81, 0x17, 0xe0, 0xa1, 0x59, 0x38 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 81 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xad, 0x49, 0x16, 0xf5, 0xee, 0x57, 0x72, 0xbe, 0x76, 0x4f, 0xc0, 0x27, 0xb8, 0xa6, 0xe5, 0x39 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 82 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2e, 0x16, 0x87, 0x3e, 0x16, 0x78, 0x61, 0x0d, 0x7e, 0x14, 0xc0, 0x2d, 0x00, 0x2e, 0xa8, 0x45 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 83 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4e, 0x6e, 0x62, 0x7c, 0x1a, 0xcc, 0x51, 0x34, 0x00, 0x53, 0xa8, 0x23, 0x6d, 0x57, 0x95, 0x76 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 84 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xab, 0x0c, 0x84, 0x10, 0xae, 0xee, 0xad, 0x92, 0xfe, 0xec, 0x1e, 0xb4, 0x30, 0xd6, 0x52, 0xcb }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 85 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe8, 0x6f, 0x7e, 0x23, 0xe8, 0x35, 0xe1, 0x14, 0x97, 0x7f, 0x60, 0xe1, 0xa5, 0x92, 0x20, 0x2e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 86 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe6, 0x8a, 0xd5, 0x05, 0x5a, 0x36, 0x70, 0x41, 0xfa, 0xde, 0x09, 0xd9, 0xa7, 0x0a, 0x79, 0x4b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 87 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x07, 0x91, 0x82, 0x3a, 0x3c, 0x66, 0x6b, 0xb6, 0x16, 0x28, 0x25, 0xe7, 0x86, 0x06, 0xa7, 0xfe }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 88 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdc, 0xca, 0x36, 0x6a, 0x9b, 0xf4, 0x7b, 0x7b, 0x86, 0x8b, 0x77, 0xe2, 0x5c, 0x18, 0xa3, 0x64 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 89 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x68, 0x4c, 0x9e, 0xfc, 0x23, 0x7e, 0x4a, 0x44, 0x29, 0x65, 0xf8, 0x4b, 0xce, 0x20, 0x24, 0x7a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 90 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa8, 0x58, 0x41, 0x1f, 0xfb, 0xe6, 0x3f, 0xdb, 0x9c, 0x8a, 0xa1, 0xbf, 0xae, 0xd6, 0x7b, 0x52 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 91 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x04, 0xbc, 0x3d, 0xa2, 0x17, 0x9c, 0x30, 0x15, 0x49, 0x8b, 0x0e, 0x03, 0x91, 0x0d, 0xb5, 0xb8 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 92 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x40, 0x07, 0x1e, 0xea, 0xb3, 0xf9, 0x35, 0xdb, 0xc2, 0x5d, 0x00, 0x84, 0x14, 0x60, 0x26, 0x0f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 93 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0e, 0xbd, 0x7c, 0x30, 0xed, 0x20, 0x16, 0xe0, 0x8b, 0xa8, 0x06, 0xdd, 0xb0, 0x08, 0xbc, 0xc8 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 94 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x15, 0xc6, 0xbe, 0xcf, 0x0f, 0x4c, 0xec, 0x71, 0x29, 0xcb, 0xd2, 0x2d, 0x1a, 0x79, 0xb1, 0xb8 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 95 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0a, 0xee, 0xde, 0x5b, 0x91, 0xf7, 0x21, 0x70, 0x0e, 0x9e, 0x62, 0xed, 0xbf, 0x60, 0xb7, 0x81 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 96 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x26, 0x65, 0x81, 0xaf, 0x0d, 0xcf, 0xbe, 0xd1, 0x58, 0x5e, 0x0a, 0x24, 0x2c, 0x64, 0xb8, 0xdf }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 97 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x66, 0x93, 0xdc, 0x91, 0x16, 0x62, 0xae, 0x47, 0x32, 0x16, 0xba, 0x22, 0x18, 0x9a, 0x51, 0x1a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 98 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x76, 0x06, 0xfa, 0x36, 0xd8, 0x64, 0x73, 0xe6, 0xfb, 0x3a, 0x1b, 0xb0, 0xe2, 0xc0, 0xad, 0xf5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 99 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0x20, 0x78, 0xe9, 0xe1, 0x1f, 0xbb, 0x78, 0xe2, 0x6f, 0xfb, 0x88, 0x99, 0xe9, 0x6b, 0x9a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 100 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x40, 0xb2, 0x64, 0xe9, 0x21, 0xe9, 0xe4, 0xa8, 0x26, 0x94, 0x58, 0x9e, 0xf3, 0x79, 0x82, 0x62 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 101 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8d, 0x45, 0x95, 0xcb, 0x4f, 0xa7, 0x02, 0x67, 0x15, 0xf5, 0x5b, 0xd6, 0x8e, 0x28, 0x82, 0xf9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 102 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb5, 0x88, 0xa3, 0x02, 0xbd, 0xbc, 0x09, 0x19, 0x7d, 0xf1, 0xed, 0xae, 0x68, 0x92, 0x6e, 0xd9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 103 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x33, 0xf7, 0x50, 0x23, 0x90, 0xb8, 0xa4, 0xa2, 0x21, 0xcf, 0xec, 0xd0, 0x66, 0x66, 0x24, 0xba }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 104 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3d, 0x20, 0x25, 0x3a, 0xdb, 0xce, 0x3b, 0xe2, 0x37, 0x37, 0x67, 0xc4, 0xd8, 0x22, 0xc5, 0x66 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 105 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa4, 0x27, 0x34, 0xa3, 0x92, 0x9b, 0xf8, 0x4c, 0xf0, 0x11, 0x6c, 0x98, 0x56, 0xa3, 0xc1, 0x8c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 106 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe3, 0xab, 0xc4, 0x93, 0x94, 0x57, 0x42, 0x2b, 0xb9, 0x57, 0xda, 0x3c, 0x56, 0x93, 0x8c, 0x6d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 107 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0x2b, 0xdd, 0x2e, 0x7c, 0x52, 0x51, 0x30, 0xfa, 0xdc, 0x8f, 0x76, 0xfc, 0x6f, 0x4b, 0x3f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 108 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x84, 0xa8, 0x3d, 0x7b, 0x94, 0xc6, 0x99, 0xcb, 0xcb, 0x8a, 0x7d, 0x9b, 0x61, 0xf6, 0x40, 0x93 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 109 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xce, 0x61, 0xd6, 0x35, 0x14, 0xad, 0xed, 0x03, 0xd4, 0x3e, 0x6e, 0xbf, 0xc3, 0xa9, 0x00, 0x1f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 110 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6c, 0x83, 0x9d, 0xd5, 0x8e, 0xea, 0xe6, 0xb8, 0xa3, 0x6a, 0xf4, 0x8e, 0xd6, 0x3d, 0x2d, 0xc9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 111 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcd, 0x5e, 0xce, 0x55, 0xb8, 0xda, 0x3b, 0xf6, 0x22, 0xc4, 0x10, 0x0d, 0xf5, 0xde, 0x46, 0xf9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 112 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3b, 0x6f, 0x46, 0xf4, 0x0e, 0x0a, 0xc5, 0xfc, 0x0a, 0x9c, 0x11, 0x05, 0xf8, 0x00, 0xf4, 0x8d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 113 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xba, 0x26, 0xd4, 0x7d, 0xa3, 0xae, 0xb0, 0x28, 0xde, 0x4f, 0xb5, 0xb3, 0xa8, 0x54, 0xa2, 0x4b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 114 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x87, 0xf5, 0x3b, 0xf6, 0x20, 0xd3, 0x67, 0x72, 0x68, 0x44, 0x52, 0x12, 0x90, 0x43, 0x89, 0xd5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 115 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x10, 0x61, 0x7d, 0x28, 0xb5, 0xe0, 0xf4, 0x60, 0x54, 0x92, 0xb1, 0x82, 0xa5, 0xd7, 0xf9, 0xf6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 116 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9a, 0xae, 0xc4, 0xfa, 0xbb, 0xf6, 0xfa, 0xe2, 0xa7, 0x1f, 0xef, 0xf0, 0x2e, 0x37, 0x2b, 0x39 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 117 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0x90, 0xc6, 0x2d, 0x88, 0xb5, 0xc4, 0x28, 0x09, 0xab, 0xf7, 0x82, 0x48, 0x8e, 0xd1, 0x30 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 118 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf1, 0xf1, 0xc5, 0xa4, 0x08, 0x99, 0xe1, 0x57, 0x72, 0x85, 0x7c, 0xcb, 0x65, 0xc7, 0xa0, 0x9a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 119 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x19, 0x08, 0x43, 0xd2, 0x9b, 0x25, 0xa3, 0x89, 0x7c, 0x69, 0x2c, 0xe1, 0xdd, 0x81, 0xee, 0x52 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 120 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa8, 0x66, 0xbc, 0x65, 0xb6, 0x94, 0x1d, 0x86, 0xe8, 0x42, 0x0a, 0x7f, 0xfb, 0x09, 0x64, 0xdb }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 121 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x81, 0x93, 0xc6, 0xff, 0x85, 0x22, 0x5c, 0xed, 0x42, 0x55, 0xe9, 0x2f, 0x6e, 0x07, 0x8a, 0x14 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 122 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x96, 0x61, 0xcb, 0x24, 0x24, 0xd7, 0xd4, 0xa3, 0x80, 0xd5, 0x47, 0xf9, 0xe7, 0xec, 0x1c, 0xb9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 123 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x86, 0xf9, 0x3d, 0x9e, 0xc0, 0x84, 0x53, 0xa0, 0x71, 0xe2, 0xe2, 0x87, 0x78, 0x77, 0xa9, 0xc8 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 124 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0xee, 0xfa, 0x80, 0xce, 0x6a, 0x4a, 0x9d, 0x59, 0x8e, 0x3f, 0xec, 0x36, 0x54, 0x34, 0xd2 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 125 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd6, 0x20, 0x68, 0x44, 0x45, 0x78, 0xe3, 0xab, 0x39, 0xce, 0x7e, 0xc9, 0x5d, 0xd0, 0x45, 0xdc }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 126 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb5, 0xf7, 0x1d, 0x4d, 0xd9, 0xa7, 0x1f, 0xe5, 0xd8, 0xbc, 0x8b, 0xa7, 0xe6, 0xea, 0x30, 0x48 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 127 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x68, 0x25, 0xa3, 0x47, 0xac, 0x47, 0x9d, 0x4f, 0x9d, 0x95, 0xc5, 0xcb, 0x8d, 0x3f, 0xd7, 0xe9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 128 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe3, 0x71, 0x4e, 0x94, 0xa5, 0x77, 0x89, 0x55, 0xcc, 0x03, 0x46, 0x35, 0x8e, 0x94, 0x78, 0x3a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 129 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd8, 0x36, 0xb4, 0x4b, 0xb2, 0x9e, 0x0c, 0x7d, 0x89, 0xfa, 0x4b, 0x2d, 0x4b, 0x67, 0x7d, 0x2a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 130 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5d, 0x45, 0x4b, 0x75, 0x02, 0x1d, 0x76, 0xd4, 0xb8, 0x4f, 0x87, 0x3a, 0x8f, 0x87, 0x7b, 0x92 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 131 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc3, 0x49, 0x8f, 0x7e, 0xce, 0xd2, 0x09, 0x53, 0x14, 0xfc, 0x28, 0x11, 0x58, 0x85, 0xb3, 0x3f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 132 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6e, 0x66, 0x88, 0x56, 0x53, 0x9a, 0xd8, 0xe4, 0x05, 0xbd, 0x12, 0x3f, 0xe6, 0xc8, 0x85, 0x30 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 133 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x86, 0x80, 0xdb, 0x7f, 0x3a, 0x87, 0xb8, 0x60, 0x55, 0x43, 0xcf, 0xdb, 0xe6, 0x75, 0x40, 0x76 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 134 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6c, 0x5d, 0x03, 0xb1, 0x30, 0x69, 0xc3, 0x65, 0x8b, 0x31, 0x79, 0xbe, 0x91, 0xb0, 0x80, 0x0c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 135 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xef, 0x1b, 0x38, 0x4a, 0xc4, 0xd9, 0x3e, 0xda, 0x00, 0xc9, 0x2a, 0xdd, 0x09, 0x95, 0xea, 0x5f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 136 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbf, 0x81, 0x15, 0x80, 0x54, 0x71, 0x74, 0x1b, 0xd5, 0xad, 0x20, 0xa0, 0x39, 0x44, 0x79, 0x0f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 137 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc6, 0x4c, 0x24, 0xb6, 0x89, 0x4b, 0x03, 0x8b, 0x3c, 0x0d, 0x09, 0xb1, 0xdf, 0x06, 0x8b, 0x0b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 138 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x39, 0x67, 0xa1, 0x0c, 0xff, 0xe2, 0x7d, 0x01, 0x78, 0x54, 0x5f, 0xbf, 0x6a, 0x40, 0x54, 0x4b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 139 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7c, 0x85, 0xe9, 0xc9, 0x5d, 0xe1, 0xa9, 0xec, 0x5a, 0x53, 0x63, 0xa8, 0xa0, 0x53, 0x47, 0x2d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 140 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa9, 0xee, 0xc0, 0x3c, 0x8a, 0xbe, 0xc7, 0xba, 0x68, 0x31, 0x5c, 0x2c, 0x8c, 0x23, 0x16, 0xe0 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 141 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xca, 0xc8, 0xe4, 0x14, 0xc2, 0xf3, 0x88, 0x22, 0x7a, 0xe1, 0x49, 0x86, 0xfc, 0x98, 0x35, 0x24 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 142 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5d, 0x94, 0x2b, 0x7f, 0x46, 0x22, 0xce, 0x05, 0x6c, 0x3c, 0xe3, 0xce, 0x5f, 0x1d, 0xd9, 0xd6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 143 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0x40, 0xd6, 0x48, 0xce, 0x21, 0xa3, 0x02, 0x02, 0x82, 0xc3, 0xf1, 0xb5, 0x28, 0xa0, 0xb6 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 144 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x45, 0xd0, 0x89, 0xc3, 0x6d, 0x5c, 0x5a, 0x4e, 0xfc, 0x68, 0x9e, 0x3b, 0x0d, 0xe1, 0x0d, 0xd5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 145 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb4, 0xda, 0x5d, 0xf4, 0xbe, 0xcb, 0x54, 0x62, 0xe0, 0x3a, 0x0e, 0xd0, 0x0d, 0x29, 0x56, 0x29 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 146 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdc, 0xf4, 0xe1, 0x29, 0x13, 0x6c, 0x1a, 0x4b, 0x7a, 0x0f, 0x38, 0x93, 0x5c, 0xc3, 0x4b, 0x2b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 147 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd9, 0xa4, 0xc7, 0x61, 0x8b, 0x0c, 0xe4, 0x8a, 0x3d, 0x5a, 0xee, 0x1a, 0x1c, 0x01, 0x14, 0xc4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 148 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xca, 0x35, 0x2d, 0xf0, 0x25, 0xc6, 0x5c, 0x7b, 0x0b, 0xf3, 0x06, 0xfb, 0xee, 0x0f, 0x36, 0xba }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 149 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x23, 0x8a, 0xca, 0x23, 0xfd, 0x34, 0x09, 0xf3, 0x8a, 0xf6, 0x33, 0x78, 0xed, 0x2f, 0x54, 0x73 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 150 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x59, 0x83, 0x6a, 0x0e, 0x06, 0xa7, 0x96, 0x91, 0xb3, 0x66, 0x67, 0xd5, 0x38, 0x0d, 0x81, 0x88 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 151 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x33, 0x90, 0x50, 0x80, 0xf7, 0xac, 0xf1, 0xcd, 0xae, 0x0a, 0x91, 0xfc, 0x3e, 0x85, 0xae, 0xe4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 152 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x72, 0xc9, 0xe4, 0x64, 0x6d, 0xbc, 0x3d, 0x63, 0x20, 0xfc, 0x66, 0x89, 0xd9, 0x3e, 0x88, 0x33 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 153 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xba, 0x77, 0x41, 0x3d, 0xea, 0x59, 0x25, 0xb7, 0xf5, 0x41, 0x7e, 0xa4, 0x7f, 0xf1, 0x9f, 0x59 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 154 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6c, 0xae, 0x81, 0x29, 0xf8, 0x43, 0xd8, 0x6d, 0xc7, 0x86, 0xa0, 0xfb, 0x1a, 0x18, 0x49, 0x70 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 155 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfc, 0xfe, 0xfb, 0x53, 0x41, 0x00, 0x79, 0x6e, 0xeb, 0xbd, 0x99, 0x02, 0x06, 0x75, 0x4e, 0x19 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 156 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8c, 0x79, 0x1d, 0x5f, 0xdd, 0xdf, 0x47, 0x0d, 0xa0, 0x4f, 0x3e, 0x6d, 0xc4, 0xa5, 0xb5, 0xb5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 157 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc9, 0x3b, 0xbd, 0xc0, 0x7a, 0x46, 0x11, 0xae, 0x4b, 0xb2, 0x66, 0xea, 0x50, 0x34, 0xa3, 0x87 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 158 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc1, 0x02, 0xe3, 0x8e, 0x48, 0x9a, 0xa7, 0x47, 0x62, 0xf3, 0xef, 0xc5, 0xbb, 0x23, 0x20, 0x5a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 159 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x93, 0x20, 0x14, 0x81, 0x66, 0x5c, 0xba, 0xfc, 0x1f, 0xcc, 0x22, 0x0b, 0xc5, 0x45, 0xfb, 0x3d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 160 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x49, 0x60, 0x75, 0x7e, 0xc6, 0xce, 0x68, 0xcf, 0x19, 0x5e, 0x45, 0x4c, 0xfd, 0x0f, 0x32, 0xca }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 161 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfe, 0xec, 0x7c, 0xe6, 0xa6, 0xcb, 0xd0, 0x7c, 0x04, 0x34, 0x16, 0x73, 0x7f, 0x1b, 0xbb, 0x33 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 162 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0xc5, 0x41, 0x39, 0x04, 0x48, 0x7a, 0x80, 0x5d, 0x70, 0xa8, 0xed, 0xd9, 0xc3, 0x55, 0x27 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 163 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x34, 0x78, 0x46, 0xb2, 0xb2, 0xe3, 0x6f, 0x1f, 0x03, 0x24, 0xc8, 0x6f, 0x7f, 0x1b, 0x98, 0xe2 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 164 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x33, 0x2e, 0xee, 0x1a, 0x0c, 0xbd, 0x19, 0xca, 0x2d, 0x69, 0xb4, 0x26, 0x89, 0x40, 0x44, 0xf0 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 165 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x86, 0x6b, 0x5b, 0x39, 0x77, 0xba, 0x6e, 0xfa, 0x51, 0x28, 0xef, 0xbd, 0xa9, 0xff, 0x03, 0xcd }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 166 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcc, 0x14, 0x45, 0xee, 0x94, 0xc0, 0xf0, 0x8c, 0xde, 0xe5, 0xc3, 0x44, 0xec, 0xd1, 0xe2, 0x33 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 167 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbe, 0x28, 0x83, 0x19, 0x02, 0x93, 0x63, 0xc2, 0x62, 0x2f, 0xeb, 0xa4, 0xb0, 0x5d, 0xfd, 0xfe }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 168 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcf, 0xd1, 0x87, 0x55, 0x23, 0xf3, 0xcd, 0x21, 0xc3, 0x95, 0x65, 0x1e, 0x6e, 0xe1, 0x5e, 0x56 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 169 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcb, 0x5a, 0x40, 0x86, 0x57, 0x83, 0x7c, 0x53, 0xbf, 0x16, 0xf9, 0xd8, 0x46, 0x5d, 0xce, 0x19 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 170 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xca, 0x0b, 0xf4, 0x2c, 0xb1, 0x07, 0xf5, 0x5c, 0xcf, 0xf2, 0xfc, 0x09, 0xee, 0x08, 0xca, 0x15 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 171 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfd, 0xd9, 0xbb, 0xb4, 0xa7, 0xdc, 0x2e, 0x4a, 0x23, 0x53, 0x6a, 0x58, 0x80, 0xa2, 0xdb, 0x67 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 172 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xed, 0xe4, 0x47, 0xb3, 0x62, 0xc4, 0x84, 0x99, 0x3d, 0xec, 0x94, 0x42, 0xa3, 0xb4, 0x6a, 0xef }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 173 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x10, 0xdf, 0xfb, 0x05, 0x90, 0x4b, 0xff, 0x7c, 0x47, 0x81, 0xdf, 0x78, 0x0a, 0xd2, 0x68, 0x37 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 174 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc3, 0x3b, 0xc1, 0x3e, 0x8d, 0xe8, 0x8a, 0xc2, 0x52, 0x32, 0xaa, 0x74, 0x96, 0x39, 0x87, 0x83 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 175 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xca, 0x35, 0x9c, 0x70, 0x80, 0x3a, 0x3b, 0x2a, 0x3d, 0x54, 0x2e, 0x87, 0x81, 0xde, 0xa9, 0x75 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 176 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbc, 0xc6, 0x5b, 0x52, 0x6f, 0x88, 0xd0, 0x5b, 0x89, 0xce, 0x8a, 0x52, 0x02, 0x1f, 0xdb, 0x06 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 177 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdb, 0x91, 0xa3, 0x88, 0x55, 0xc8, 0xc4, 0x64, 0x38, 0x51, 0xfb, 0xfb, 0x35, 0x8b, 0x01, 0x09 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 178 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xca, 0x6e, 0x88, 0x93, 0xa1, 0x14, 0xae, 0x8e, 0x27, 0xd5, 0xab, 0x03, 0xa5, 0x49, 0x96, 0x10 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 179 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x66, 0x29, 0xd2, 0xb8, 0xdf, 0x97, 0xda, 0x72, 0x8c, 0xdd, 0x8b, 0x1e, 0x7f, 0x94, 0x50, 0x77 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 180 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x45, 0x70, 0xa5, 0xa1, 0x8c, 0xfc, 0x0d, 0xd5, 0x82, 0xf1, 0xd8, 0x8d, 0x5c, 0x9a, 0x17, 0x20 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 181 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x72, 0xbc, 0x65, 0xaa, 0x8e, 0x89, 0x56, 0x2e, 0x3f, 0x27, 0x4d, 0x45, 0xaf, 0x1c, 0xd1, 0x0b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 182 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x98, 0x55, 0x1d, 0xa1, 0xa6, 0x50, 0x32, 0x76, 0xae, 0x1c, 0x77, 0x62, 0x5f, 0x9e, 0xa6, 0x15 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 183 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0d, 0xdf, 0xe5, 0x1c, 0xed, 0x7e, 0x3f, 0x4a, 0xe9, 0x27, 0xda, 0xa3, 0xfe, 0x45, 0x2c, 0xee }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 184 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdb, 0x82, 0x62, 0x51, 0xe4, 0xce, 0x38, 0x4b, 0x80, 0x21, 0x8b, 0x0e, 0x1d, 0xa1, 0xdd, 0x4c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 185 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2c, 0xac, 0xf7, 0x28, 0xb8, 0x8a, 0xbb, 0xad, 0x70, 0x11, 0xed, 0x0e, 0x64, 0xa1, 0x68, 0x0c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 186 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x33, 0x0d, 0x8e, 0xe7, 0xc5, 0x67, 0x7e, 0x09, 0x9a, 0xc7, 0x4c, 0x99, 0x94, 0xee, 0x4c, 0xfb }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 187 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xed, 0xf6, 0x1a, 0xe3, 0x62, 0xe8, 0x82, 0xdd, 0xc0, 0x16, 0x74, 0x74, 0xa7, 0xa7, 0x7f, 0x3a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 188 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x61, 0x68, 0xb0, 0x0b, 0xa7, 0x85, 0x9e, 0x09, 0x70, 0xec, 0xfd, 0x75, 0x7e, 0xfe, 0xcf, 0x7c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 189 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd1, 0x41, 0x54, 0x47, 0x86, 0x62, 0x30, 0xd2, 0x8b, 0xb1, 0xea, 0x18, 0xa4, 0xcd, 0xfd, 0x02 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 190 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x51, 0x61, 0x83, 0x39, 0x2f, 0x7a, 0x87, 0x63, 0xaf, 0xec, 0x68, 0xa0, 0x60, 0x26, 0x41, 0x41 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 191 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x77, 0x56, 0x5c, 0x8d, 0x73, 0xcf, 0xd4, 0x13, 0x0b, 0x4a, 0xa1, 0x4d, 0x89, 0x11, 0x71, 0x0f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 192 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x37, 0x23, 0x2a, 0x4e, 0xd2, 0x1c, 0xcc, 0x27, 0xc1, 0x9c, 0x96, 0x10, 0x07, 0x8c, 0xab, 0xac }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 193 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x80, 0x4f, 0x32, 0xea, 0x71, 0x82, 0x8c, 0x7d, 0x32, 0x90, 0x77, 0xe7, 0x12, 0x23, 0x16, 0x66 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 194 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd6, 0x44, 0x24, 0xf2, 0x3c, 0xb9, 0x72, 0x15, 0xe9, 0xc2, 0xc6, 0xf2, 0x8d, 0x29, 0xea, 0xb7 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 195 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x02, 0x3e, 0x82, 0xb5, 0x33, 0xf6, 0x8c, 0x75, 0xc2, 0x38, 0xce, 0xbd, 0xb2, 0xee, 0x89, 0xa2 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 196 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x19, 0x3a, 0x3d, 0x24, 0x15, 0x7a, 0x51, 0xf1, 0xee, 0x08, 0x93, 0xf6, 0x77, 0x74, 0x17, 0xe7 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 197 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x84, 0xec, 0xac, 0xfc, 0xd4, 0x00, 0x08, 0x4d, 0x07, 0x86, 0x12, 0xb1, 0x94, 0x5f, 0x2e, 0xf5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 198 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1d, 0xcd, 0x8b, 0xb1, 0x73, 0x25, 0x9e, 0xb3, 0x3a, 0x52, 0x42, 0xb0, 0xde, 0x31, 0xa4, 0x55 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 199 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x35, 0xe9, 0xed, 0xdb, 0xc3, 0x75, 0xe7, 0x92, 0xc1, 0x99, 0x92, 0xc1, 0x91, 0x65, 0x01, 0x2b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 200 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8a, 0x77, 0x22, 0x31, 0xc0, 0x1d, 0xfd, 0xd7, 0xc9, 0x8e, 0x4c, 0xfd, 0xdc, 0xc0, 0x80, 0x7a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 201 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6e, 0xda, 0x7f, 0xf6, 0xb8, 0x31, 0x91, 0x80, 0xff, 0x0d, 0x6e, 0x65, 0x62, 0x9d, 0x01, 0xc3 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 202 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc2, 0x67, 0xef, 0x0e, 0x2d, 0x01, 0xa9, 0x93, 0x94, 0x4d, 0xd3, 0x97, 0x10, 0x14, 0x13, 0xcb }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 203 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe9, 0xf8, 0x0e, 0x9d, 0x84, 0x5b, 0xcc, 0x0f, 0x62, 0x92, 0x6a, 0xf7, 0x2e, 0xab, 0xca, 0x39 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 204 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x67, 0x02, 0x99, 0x07, 0x27, 0xaa, 0x08, 0x78, 0x63, 0x7b, 0x45, 0xdc, 0xd3, 0xa3, 0xb0, 0x74 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 205 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2e, 0x2e, 0x64, 0x7d, 0x53, 0x60, 0xe0, 0x92, 0x30, 0xa5, 0xd7, 0x38, 0xca, 0x33, 0x47, 0x1e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 206 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1f, 0x56, 0x41, 0x3c, 0x7a, 0xdd, 0x6f, 0x43, 0xd1, 0xd5, 0x6e, 0x4f, 0x02, 0x19, 0x03, 0x30 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 207 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x69, 0xcd, 0x06, 0x06, 0xe1, 0x5a, 0xf7, 0x29, 0xd6, 0xbc, 0xa1, 0x43, 0x01, 0x6d, 0x98, 0x42 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 208 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa0, 0x85, 0xd7, 0xc1, 0xa5, 0x00, 0x87, 0x3a, 0x20, 0x09, 0x9c, 0x4c, 0xaa, 0x3c, 0x3f, 0x5b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 209 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4f, 0xc0, 0xd2, 0x30, 0xf8, 0x89, 0x14, 0x15, 0xb8, 0x7b, 0x83, 0xf9, 0x5f, 0x2e, 0x09, 0xd1 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 210 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x43, 0x27, 0xd0, 0x8c, 0x52, 0x3d, 0x8e, 0xba, 0x69, 0x7a, 0x43, 0x36, 0x50, 0x7d, 0x1f, 0x42 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 211 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7a, 0x15, 0xaa, 0xb8, 0x27, 0x01, 0xef, 0xa5, 0xae, 0x36, 0xab, 0x1d, 0x6b, 0x76, 0x29, 0x0f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 212 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5b, 0xf0, 0x05, 0x18, 0x93, 0xa1, 0x8b, 0xb3, 0x0e, 0x13, 0x9a, 0x58, 0xfe, 0xd0, 0xfa, 0x54 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 213 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x97, 0xe8, 0xad, 0xf6, 0x56, 0x38, 0xfd, 0x9c, 0xdf, 0x3b, 0xc2, 0x2c, 0x17, 0xfe, 0x4d, 0xbd }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 214 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1e, 0xe6, 0xee, 0x32, 0x65, 0x83, 0xa0, 0x58, 0x64, 0x91, 0xc9, 0x64, 0x18, 0xd1, 0xa3, 0x5d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 215 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x26, 0xb5, 0x49, 0xc2, 0xec, 0x75, 0x6f, 0x82, 0xec, 0xc4, 0x80, 0x08, 0xe5, 0x29, 0x95, 0x6b }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 216 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x70, 0x37, 0x7b, 0x6d, 0xa6, 0x69, 0xb0, 0x72, 0x12, 0x9e, 0x05, 0x7c, 0xc2, 0x8e, 0x9c, 0xa5 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 217 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9c, 0x94, 0xb8, 0xb0, 0xcb, 0x8b, 0xcc, 0x91, 0x90, 0x72, 0x26, 0x2b, 0x3f, 0xa0, 0x5a, 0xd9 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 218 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2f, 0xbb, 0x83, 0xdf, 0xd0, 0xd7, 0xab, 0xcb, 0x05, 0xcd, 0x28, 0xca, 0xd2, 0xdf, 0xb5, 0x23 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 219 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x96, 0x87, 0x78, 0x03, 0xde, 0x77, 0x74, 0x4b, 0xb9, 0x70, 0xd0, 0xa9, 0x1f, 0x4d, 0xeb, 0xae }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 220 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x73, 0x79, 0xf3, 0x37, 0x0c, 0xf6, 0xe5, 0xce, 0x12, 0xae, 0x59, 0x69, 0xc8, 0xee, 0xa3, 0x12 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 221 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x02, 0xdc, 0x99, 0xfa, 0x3d, 0x4f, 0x98, 0xce, 0x80, 0x98, 0x5e, 0x72, 0x33, 0x88, 0x93, 0x13 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 222 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1e, 0x38, 0xe7, 0x59, 0x07, 0x5b, 0xa5, 0xca, 0xb6, 0x45, 0x7d, 0xa5, 0x18, 0x44, 0x29, 0x5a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 223 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x70, 0xbe, 0xd8, 0xdb, 0xf6, 0x15, 0x86, 0x8a, 0x1f, 0x9d, 0x9b, 0x05, 0xd3, 0xe7, 0xa2, 0x67 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 224 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x23, 0x4b, 0x14, 0x8b, 0x8c, 0xb1, 0xd8, 0xc3, 0x2b, 0x28, 0x7e, 0x89, 0x69, 0x03, 0xd1, 0x50 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 225 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x29, 0x4b, 0x03, 0x3d, 0xf4, 0xda, 0x85, 0x3f, 0x4b, 0xe3, 0xe2, 0x43, 0xf7, 0xe5, 0x13, 0xf4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 226 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3f, 0x58, 0xc9, 0x50, 0xf0, 0x36, 0x71, 0x60, 0xad, 0xec, 0x45, 0xf2, 0x44, 0x1e, 0x74, 0x11 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 227 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x37, 0xf6, 0x55, 0x53, 0x6a, 0x70, 0x4e, 0x5a, 0xce, 0x18, 0x2d, 0x74, 0x2a, 0x82, 0x0c, 0xf4 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 228 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xea, 0x7b, 0xd6, 0xbb, 0x63, 0x41, 0x87, 0x31, 0xae, 0xac, 0x79, 0x0f, 0xe4, 0x2d, 0x61, 0xe8 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 229 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe7, 0x4a, 0x4c, 0x99, 0x9b, 0x4c, 0x06, 0x4e, 0x48, 0xbb, 0x1e, 0x41, 0x3f, 0x51, 0xe5, 0xea }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 230 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xba, 0x9e, 0xbe, 0xfd, 0xb4, 0xcc, 0xf3, 0x0f, 0x29, 0x6c, 0xec, 0xb3, 0xbc, 0x19, 0x43, 0xe8 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 231 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x31, 0x94, 0x36, 0x7a, 0x48, 0x98, 0xc5, 0x02, 0xc1, 0x3b, 0xb7, 0x47, 0x86, 0x40, 0xa7, 0x2d }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 232 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xda, 0x79, 0x77, 0x13, 0x26, 0x3d, 0x6f, 0x33, 0xa5, 0x47, 0x8a, 0x65, 0xef, 0x60, 0xd4, 0x12 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 233 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd1, 0xac, 0x39, 0xbb, 0x1e, 0xf8, 0x6b, 0x9c, 0x13, 0x44, 0xf2, 0x14, 0x67, 0x9a, 0xa3, 0x76 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 234 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2f, 0xde, 0xa9, 0xe6, 0x50, 0x53, 0x2b, 0xe5, 0xbc, 0x0e, 0x73, 0x25, 0x33, 0x7f, 0xd3, 0x63 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 235 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd3, 0xa2, 0x04, 0xdb, 0xd9, 0xc2, 0xaf, 0x15, 0x8b, 0x6c, 0xa6, 0x7a, 0x51, 0x56, 0xce, 0x4a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 236 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0x0a, 0x0e, 0x75, 0xa8, 0xda, 0x36, 0x73, 0x5a, 0xee, 0x66, 0x84, 0xd9, 0x65, 0xa7, 0x78 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 237 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x52, 0xfc, 0x3e, 0x62, 0x04, 0x92, 0xea, 0x99, 0x64, 0x1e, 0xa1, 0x68, 0xda, 0x5b, 0x6d, 0x52 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 238 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0xe0, 0xc7, 0xf1, 0x5b, 0x47, 0x72, 0x46, 0x7d, 0x2c, 0xfc, 0x87, 0x30, 0x00, 0xb2, 0xca }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 239 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x56, 0x35, 0x31, 0x13, 0x5e, 0x0c, 0x4d, 0x70, 0xa3, 0x8f, 0x8b, 0xdb, 0x19, 0x0b, 0xa0, 0x4e }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 240 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa8, 0xa3, 0x9a, 0x0f, 0x56, 0x63, 0xf4, 0xc0, 0xfe, 0x5f, 0x2d, 0x3c, 0xaf, 0xff, 0x42, 0x1a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 241 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd9, 0x4b, 0x5e, 0x90, 0xdb, 0x35, 0x4c, 0x1e, 0x42, 0xf6, 0x1f, 0xab, 0xe1, 0x67, 0xb2, 0xc0 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 242 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x50, 0xe6, 0xd3, 0xc9, 0xb6, 0x69, 0x8a, 0x7c, 0xd2, 0x76, 0xf9, 0x6b, 0x14, 0x73, 0xf3, 0x5a }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 243 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x93, 0x38, 0xf0, 0x8e, 0x0e, 0xbe, 0xe9, 0x69, 0x05, 0xd8, 0xf2, 0xe8, 0x25, 0x20, 0x8f, 0x43 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 244 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8b, 0x37, 0x8c, 0x86, 0x67, 0x2a, 0xa5, 0x4a, 0x3a, 0x26, 0x6b, 0xa1, 0x9d, 0x25, 0x80, 0xca }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 245 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcc, 0xa7, 0xc3, 0x08, 0x6f, 0x5f, 0x95, 0x11, 0xb3, 0x12, 0x33, 0xda, 0x7c, 0xab, 0x91, 0x60 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 246 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5b, 0x40, 0xff, 0x4e, 0xc9, 0xbe, 0x53, 0x6b, 0xa2, 0x30, 0x35, 0xfa, 0x4f, 0x06, 0x06, 0x4c }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 247 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x60, 0xeb, 0x5a, 0xf8, 0x41, 0x6b, 0x25, 0x71, 0x49, 0x37, 0x21, 0x94, 0xe8, 0xb8, 0x87, 0x49 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 248 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2f, 0x00, 0x5a, 0x8a, 0xed, 0x8a, 0x36, 0x1c, 0x92, 0xe4, 0x40, 0xc1, 0x55, 0x20, 0xcb, 0xd1 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 249 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7b, 0x03, 0x62, 0x76, 0x11, 0x67, 0x8a, 0x99, 0x77, 0x17, 0x57, 0x88, 0x07, 0xa8, 0x00, 0xe2 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 250 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcf, 0x78, 0x61, 0x8f, 0x74, 0xf6, 0xf3, 0x69, 0x6e, 0x0a, 0x47, 0x79, 0xb9, 0x0b, 0x5a, 0x77 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 251 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x03, 0x72, 0x03, 0x71, 0xa0, 0x49, 0x62, 0xea, 0xea, 0x0a, 0x85, 0x2e, 0x69, 0x97, 0x28, 0x58 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 252 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1f, 0x8a, 0x81, 0x33, 0xaa, 0x8c, 0xcf, 0x70, 0xe2, 0xbd, 0x32, 0x85, 0x83, 0x1c, 0xa6, 0xb7 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 253 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0x93, 0x6b, 0xd2, 0x7f, 0xb1, 0x46, 0x8f, 0xc8, 0xb4, 0x8b, 0xc4, 0x83, 0x32, 0x17, 0x25 }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 254 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb0, 0x7d, 0x4f, 0x3e, 0x2c, 0xd2, 0xef, 0x2e, 0xb5, 0x45, 0x98, 0x07, 0x54, 0xdf, 0xea, 0x0f }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarKey256.rsp test vector 255 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4b, 0xf8, 0x5f, 0x1b, 0x5d, 0x54, 0xad, 0xbc, 0x30, 0x7b, 0x0a, 0x04, 0x83, 0x89, 0xad, 0xcb }, 16, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 0 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0xd7, 0x8e, 0x72, 0x6c, 0x1e, 0xc0, 0x2b, 0x7e, 0xbf, 0xe9, 0x2b, 0x23, 0xd9, 0xec, 0x34 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 1 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xaa, 0xe5, 0x93, 0x9c, 0x8e, 0xfd, 0xf2, 0xf0, 0x4e, 0x60, 0xb9, 0xfe, 0x71, 0x17, 0xb2, 0xc2 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 2 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf0, 0x31, 0xd4, 0xd7, 0x4f, 0x5d, 0xcb, 0xf3, 0x9d, 0xaa, 0xf8, 0xca, 0x3a, 0xf6, 0xe5, 0x27 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 3 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x96, 0xd9, 0xfd, 0x5c, 0xc4, 0xf0, 0x74, 0x41, 0x72, 0x7d, 0xf0, 0xf3, 0x3e, 0x40, 0x1a, 0x36 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 4 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x30, 0xcc, 0xdb, 0x04, 0x46, 0x46, 0xd7, 0xe1, 0xf3, 0xcc, 0xea, 0x3d, 0xca, 0x08, 0xb8, 0xc0 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 5 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x16, 0xae, 0x4c, 0xe5, 0x04, 0x2a, 0x67, 0xee, 0x8e, 0x17, 0x7b, 0x7c, 0x58, 0x7e, 0xcc, 0x82 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 6 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb6, 0xda, 0x0b, 0xb1, 0x1a, 0x23, 0x85, 0x5d, 0x9c, 0x5c, 0xb1, 0xb4, 0xc6, 0x41, 0x2e, 0x0a }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 7 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdb, 0x4f, 0x1a, 0xa5, 0x30, 0x96, 0x7d, 0x67, 0x32, 0xce, 0x47, 0x15, 0xeb, 0x0e, 0xe2, 0x4b }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 8 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa8, 0x17, 0x38, 0x25, 0x26, 0x21, 0xdd, 0x18, 0x0a, 0x34, 0xf3, 0x45, 0x5b, 0x4b, 0xaa, 0x2f }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 9 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x77, 0xe2, 0xb5, 0x08, 0xdb, 0x7f, 0xd8, 0x92, 0x34, 0xca, 0xf7, 0x93, 0x9e, 0xe5, 0x62, 0x1a }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 10 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb8, 0x49, 0x9c, 0x25, 0x1f, 0x84, 0x42, 0xee, 0x13, 0xf0, 0x93, 0x3b, 0x68, 0x8f, 0xcd, 0x19 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 11 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x96, 0x51, 0x35, 0xf8, 0xa8, 0x1f, 0x25, 0xc9, 0xd6, 0x30, 0xb1, 0x75, 0x02, 0xf6, 0x8e, 0x53 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 12 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8b, 0x87, 0x14, 0x5a, 0x01, 0xad, 0x1c, 0x6c, 0xed, 0xe9, 0x95, 0xea, 0x36, 0x70, 0x45, 0x4f }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 13 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8e, 0xae, 0x3b, 0x10, 0xa0, 0xc8, 0xca, 0x6d, 0x1d, 0x3b, 0x0f, 0xa6, 0x1e, 0x56, 0xb0, 0xb2 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 14 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x64, 0xb4, 0xd6, 0x29, 0x81, 0x0f, 0xda, 0x6b, 0xaf, 0xdf, 0x08, 0xf3, 0xb0, 0xd8, 0xd2, 0xc5 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 15 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd7, 0xe5, 0xdb, 0xd3, 0x32, 0x45, 0x95, 0xf8, 0xfd, 0xc7, 0xd7, 0xc5, 0x71, 0xda, 0x6c, 0x2a }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 16 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf3, 0xf7, 0x23, 0x75, 0x26, 0x4e, 0x16, 0x7f, 0xca, 0x9d, 0xe2, 0xc1, 0x52, 0x7d, 0x96, 0x06 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 17 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8e, 0xe7, 0x9d, 0xd4, 0xf4, 0x01, 0xff, 0x9b, 0x7e, 0xa9, 0x45, 0xd8, 0x66, 0x66, 0xc1, 0x3b }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 18 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdd, 0x35, 0xce, 0xa2, 0x79, 0x99, 0x40, 0xb4, 0x0d, 0xb3, 0xf8, 0x19, 0xcb, 0x94, 0xc0, 0x8b }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 19 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x69, 0x41, 0xcb, 0x6b, 0x3e, 0x08, 0xc2, 0xb7, 0xaf, 0xa5, 0x81, 0xeb, 0xdd, 0x60, 0x7b, 0x87 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 20 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2c, 0x20, 0xf4, 0x39, 0xf6, 0xbb, 0x09, 0x7b, 0x29, 0xb8, 0xbd, 0x6d, 0x99, 0xaa, 0xd7, 0x99 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 21 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x62, 0x5d, 0x01, 0xf0, 0x58, 0xe5, 0x65, 0xf7, 0x7a, 0xe8, 0x63, 0x78, 0xbd, 0x2c, 0x49, 0xb3 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 22 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc0, 0xb5, 0xfd, 0x98, 0x19, 0x0e, 0xf4, 0x5f, 0xbb, 0x43, 0x01, 0x43, 0x8d, 0x09, 0x59, 0x50 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 23 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x13, 0x00, 0x1f, 0xf5, 0xd9, 0x98, 0x06, 0xef, 0xd2, 0x5d, 0xa3, 0x4f, 0x56, 0xbe, 0x85, 0x4b }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 24 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3b, 0x59, 0x4c, 0x60, 0xf5, 0xc8, 0x27, 0x7a, 0x51, 0x13, 0x67, 0x7f, 0x94, 0x20, 0x8d, 0x82 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 25 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe9, 0xc0, 0xfc, 0x18, 0x18, 0xe4, 0xaa, 0x46, 0xbd, 0x2e, 0x39, 0xd6, 0x38, 0xf8, 0x9e, 0x05 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 26 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf8, 0x02, 0x3e, 0xe9, 0xc3, 0xfd, 0xc4, 0x5a, 0x01, 0x9b, 0x4e, 0x98, 0x5c, 0x7e, 0x1a, 0x54 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 27 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x35, 0xf4, 0x01, 0x82, 0xab, 0x46, 0x62, 0xf3, 0x02, 0x3b, 0xae, 0xc1, 0xee, 0x79, 0x6b, 0x57 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 28 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0xeb, 0xba, 0xd7, 0x30, 0x36, 0x49, 0xb4, 0x19, 0x4a, 0x69, 0x45, 0xc6, 0xcc, 0x36, 0x94 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 29 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa2, 0x12, 0x4b, 0xea, 0x53, 0xec, 0x28, 0x34, 0x27, 0x9b, 0xed, 0x7f, 0x7e, 0xb0, 0xf9, 0x38 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 30 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb9, 0xfb, 0x43, 0x99, 0xfa, 0x4f, 0xac, 0xc7, 0x30, 0x9e, 0x14, 0xec, 0x98, 0x36, 0x0b, 0x0a }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 31 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc2, 0x62, 0x77, 0x43, 0x74, 0x20, 0xc5, 0xd6, 0x34, 0xf7, 0x15, 0xae, 0xa8, 0x1a, 0x91, 0x32 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 32 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x17, 0x1a, 0x0e, 0x1b, 0x2d, 0xd4, 0x24, 0xf0, 0xe0, 0x89, 0xaf, 0x2c, 0x4c, 0x10, 0xf3, 0x2f }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 33 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7c, 0xad, 0xbe, 0x40, 0x2d, 0x1b, 0x20, 0x8f, 0xe7, 0x35, 0xed, 0xce, 0x00, 0xae, 0xe7, 0xce }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 34 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x43, 0xb0, 0x2f, 0xf9, 0x29, 0xa1, 0x48, 0x5a, 0xf6, 0xf5, 0xc6, 0xd6, 0x55, 0x8b, 0xaa, 0x0f }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 35 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x09, 0x2f, 0xaa, 0xcc, 0x9b, 0xf4, 0x35, 0x08, 0xbf, 0x8f, 0xa8, 0x61, 0x3c, 0xa7, 0x5d, 0xea }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 36 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcb, 0x2b, 0xf8, 0x28, 0x0f, 0x3f, 0x97, 0x42, 0xc7, 0xed, 0x51, 0x3f, 0xe8, 0x02, 0x62, 0x9c }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 37 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x21, 0x5a, 0x41, 0xee, 0x44, 0x2f, 0xa9, 0x92, 0xa6, 0xe3, 0x23, 0x98, 0x6d, 0xed, 0x3f, 0x68 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 38 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf2, 0x1e, 0x99, 0xcf, 0x4f, 0x0f, 0x77, 0xce, 0xa8, 0x36, 0xe1, 0x1a, 0x2f, 0xe7, 0x5f, 0xb1 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 39 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x95, 0xe3, 0xa0, 0xca, 0x90, 0x79, 0xe6, 0x46, 0x33, 0x1d, 0xf8, 0xb4, 0xe7, 0x0d, 0x2c, 0xd6 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 40 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4a, 0xfe, 0x7f, 0x12, 0x0c, 0xe7, 0x61, 0x3f, 0x74, 0xfc, 0x12, 0xa0, 0x1a, 0x82, 0x80, 0x73 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 41 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x82, 0x7f, 0x00, 0x0e, 0x75, 0xe2, 0xc8, 0xb9, 0xd4, 0x79, 0xbe, 0xed, 0x91, 0x3f, 0xe6, 0x78 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 42 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x35, 0x83, 0x0c, 0x8e, 0x7a, 0xae, 0xfe, 0x2d, 0x30, 0x31, 0x0e, 0xf3, 0x81, 0xcb, 0xf6, 0x91 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 43 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x19, 0x1a, 0xa0, 0xf2, 0xc8, 0x57, 0x01, 0x44, 0xf3, 0x86, 0x57, 0xea, 0x40, 0x85, 0xeb, 0xe5 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 44 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x85, 0x06, 0x2c, 0x2c, 0x90, 0x9f, 0x15, 0xd9, 0x26, 0x9b, 0x6c, 0x18, 0xce, 0x99, 0xc4, 0xf0 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 45 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x67, 0x80, 0x34, 0xdc, 0x9e, 0x41, 0xb5, 0xa5, 0x60, 0xed, 0x23, 0x9e, 0xea, 0xb1, 0xbc, 0x78 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 46 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc2, 0xf9, 0x3a, 0x4c, 0xe5, 0xab, 0x6d, 0x5d, 0x56, 0xf1, 0xb9, 0x3c, 0xf1, 0x99, 0x11, 0xc1 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 47 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1c, 0x31, 0x12, 0xbc, 0xb0, 0xc1, 0xdc, 0xc7, 0x49, 0xd7, 0x99, 0x74, 0x36, 0x91, 0xbf, 0x82 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 48 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0xc5, 0x5b, 0xd7, 0x5c, 0x7f, 0x9c, 0x88, 0x19, 0x89, 0xd3, 0xec, 0x19, 0x11, 0xc0, 0xd4 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 49 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xea, 0x2e, 0x6b, 0x5e, 0xf1, 0x82, 0xb7, 0xdf, 0xf3, 0x62, 0x9a, 0xbd, 0x6a, 0x12, 0x04, 0x5f }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 50 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x22, 0x32, 0x23, 0x27, 0xe0, 0x17, 0x80, 0xb1, 0x73, 0x97, 0xf2, 0x40, 0x87, 0xf8, 0xcc, 0x6f }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 51 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc9, 0xca, 0xcb, 0x5c, 0xd1, 0x16, 0x92, 0xc3, 0x73, 0xb2, 0x41, 0x17, 0x68, 0x14, 0x9e, 0xe7 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 52 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa1, 0x8e, 0x3d, 0xbb, 0xca, 0x57, 0x78, 0x60, 0xda, 0xb6, 0xb8, 0x0d, 0xa3, 0x13, 0x92, 0x56 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 53 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x79, 0xb6, 0x1c, 0x37, 0xbf, 0x32, 0x8e, 0xcc, 0xa8, 0xd7, 0x43, 0x26, 0x5a, 0x3d, 0x42, 0x5c }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 54 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0xd9, 0x9c, 0x6b, 0xcc, 0x1f, 0x06, 0xfd, 0xa8, 0xe2, 0x7e, 0x8a, 0xe3, 0xf1, 0xcc, 0xc7 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 55 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0xfd, 0x4b, 0x91, 0xc7, 0x01, 0xfd, 0x6b, 0x61, 0xb7, 0xf9, 0x97, 0x82, 0x9d, 0x66, 0x3b }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 56 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0x00, 0x5d, 0x52, 0xf2, 0x5f, 0x16, 0xbd, 0xc9, 0x54, 0x5a, 0x87, 0x6a, 0x63, 0x49, 0x0a }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 57 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0x4d, 0x35, 0x4f, 0x02, 0xbb, 0x5a, 0x5e, 0x47, 0xd3, 0x96, 0x66, 0x86, 0x7f, 0x24, 0x6a }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 58 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd4, 0x51, 0xb8, 0xd6, 0xe1, 0xe1, 0xa0, 0xeb, 0xb1, 0x55, 0xfb, 0xbf, 0x6e, 0x7b, 0x7d, 0xc3 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 59 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x68, 0x98, 0xd4, 0xf4, 0x2f, 0xa7, 0xba, 0x6a, 0x10, 0xac, 0x05, 0xe8, 0x7b, 0x9f, 0x20, 0x80 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 60 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb6, 0x11, 0x29, 0x5e, 0x73, 0x9c, 0xa7, 0xd9, 0xb5, 0x0f, 0x8e, 0x4c, 0x0e, 0x75, 0x4a, 0x3f }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 61 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7d, 0x33, 0xfc, 0x7d, 0x8a, 0xbe, 0x3c, 0xa1, 0x93, 0x67, 0x59, 0xf8, 0xf5, 0xde, 0xaf, 0x20 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 62 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3b, 0x5e, 0x0f, 0x56, 0x6d, 0xc9, 0x6c, 0x29, 0x8f, 0x0c, 0x12, 0x63, 0x75, 0x39, 0xb2, 0x5c }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 63 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf8, 0x07, 0xc3, 0xe7, 0x98, 0x5f, 0xe0, 0xf5, 0xa5, 0x0e, 0x2c, 0xdb, 0x25, 0xc5, 0x10, 0x9e }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 64 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x41, 0xf9, 0x92, 0xa8, 0x56, 0xfb, 0x27, 0x8b, 0x38, 0x9a, 0x62, 0xf5, 0xd2, 0x74, 0xd7, 0xe9 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 65 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x10, 0xd3, 0xed, 0x7a, 0x6f, 0xe1, 0x5a, 0xb4, 0xd9, 0x1a, 0xcb, 0xc7, 0xd0, 0x76, 0x7a, 0xb1 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 66 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x21, 0xfe, 0xec, 0xd4, 0x5b, 0x2e, 0x67, 0x59, 0x73, 0xac, 0x33, 0xbf, 0x0c, 0x54, 0x24, 0xfc }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 67 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x14, 0x80, 0xcb, 0x39, 0x55, 0xba, 0x62, 0xd0, 0x9e, 0xea, 0x66, 0x8f, 0x7c, 0x70, 0x88, 0x17 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 68 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x66, 0x40, 0x40, 0x33, 0xd6, 0xb7, 0x2b, 0x60, 0x93, 0x54, 0xd5, 0x49, 0x6e, 0x7e, 0xb5, 0x11 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 69 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1c, 0x31, 0x7a, 0x22, 0x0a, 0x7d, 0x70, 0x0d, 0xa2, 0xb1, 0xe0, 0x75, 0xb0, 0x02, 0x66, 0xe1 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 70 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xab, 0x3b, 0x89, 0x54, 0x22, 0x33, 0xf1, 0x27, 0x1b, 0xf8, 0xfd, 0x0c, 0x0f, 0x40, 0x35, 0x45 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 71 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd9, 0x3e, 0xae, 0x96, 0x6f, 0xac, 0x46, 0xdc, 0xa9, 0x27, 0xd6, 0xb1, 0x14, 0xfa, 0x3f, 0x9e }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 72 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0xde, 0xc5, 0x21, 0x31, 0x65, 0x03, 0xd9, 0xd5, 0xee, 0x65, 0xdf, 0x3e, 0xa9, 0x4d, 0xdf }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 73 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xee, 0xf4, 0x56, 0x43, 0x1d, 0xea, 0x8b, 0x4a, 0xcf, 0x83, 0xbd, 0xae, 0x37, 0x17, 0xf7, 0x5f }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 74 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x06, 0xf2, 0x51, 0x9a, 0x2f, 0xaf, 0xaa, 0x59, 0x6b, 0xfe, 0xf5, 0xcf, 0xa1, 0x5c, 0x21, 0xb9 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 75 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x25, 0x1a, 0x7e, 0xac, 0x7e, 0x2f, 0xe8, 0x09, 0xe4, 0xaa, 0x8d, 0x0d, 0x70, 0x12, 0x53, 0x1a }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 76 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3b, 0xff, 0xc1, 0x6e, 0x4c, 0x49, 0xb2, 0x68, 0xa2, 0x0f, 0x8d, 0x96, 0xa6, 0x0b, 0x40, 0x58 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 77 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe8, 0x86, 0xf9, 0x28, 0x19, 0x99, 0xc5, 0xbb, 0x3b, 0x3e, 0x88, 0x62, 0xe2, 0xf7, 0xc9, 0x88 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 78 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x56, 0x3b, 0xf9, 0x0d, 0x61, 0xbe, 0xef, 0x39, 0xf4, 0x8d, 0xd6, 0x25, 0xfc, 0xef, 0x13, 0x61 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 79 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4d, 0x37, 0xc8, 0x50, 0x64, 0x45, 0x63, 0xc6, 0x9f, 0xd0, 0xac, 0xd9, 0xa0, 0x49, 0x32, 0x5b }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 80 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb8, 0x7c, 0x92, 0x1b, 0x91, 0x82, 0x9e, 0xf3, 0xb1, 0x3c, 0xa5, 0x41, 0xee, 0x11, 0x30, 0xa6 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 81 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2e, 0x65, 0xeb, 0x6b, 0x6e, 0xa3, 0x83, 0xe1, 0x09, 0xac, 0xcc, 0xe8, 0x32, 0x6b, 0x03, 0x93 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 82 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9c, 0xa5, 0x47, 0xf7, 0x43, 0x9e, 0xdc, 0x3e, 0x25, 0x5c, 0x0f, 0x4d, 0x49, 0xaa, 0x89, 0x90 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 83 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa5, 0xe6, 0x52, 0x61, 0x4c, 0x93, 0x00, 0xf3, 0x78, 0x16, 0xb1, 0xf9, 0xfd, 0x0c, 0x87, 0xf9 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 84 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x14, 0x95, 0x4f, 0x0b, 0x46, 0x97, 0x77, 0x6f, 0x44, 0x49, 0x4f, 0xe4, 0x58, 0xd8, 0x14, 0xed }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 85 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7c, 0x8d, 0x9a, 0xb6, 0xc2, 0x76, 0x17, 0x23, 0xfe, 0x42, 0xf8, 0xbb, 0x50, 0x6c, 0xbc, 0xf7 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 86 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdb, 0x7e, 0x19, 0x32, 0x67, 0x9f, 0xdd, 0x99, 0x74, 0x2a, 0xab, 0x04, 0xaa, 0x0d, 0x5a, 0x80 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 87 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4c, 0x6a, 0x1c, 0x83, 0xe5, 0x68, 0xcd, 0x10, 0xf2, 0x7c, 0x2d, 0x73, 0xde, 0xd1, 0x9c, 0x28 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 88 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0xec, 0xbe, 0x61, 0x77, 0xe6, 0x74, 0xc9, 0x8d, 0xe4, 0x12, 0x41, 0x3f, 0x7a, 0xc9, 0x15 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 89 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0x68, 0x4a, 0x2a, 0xc5, 0x5f, 0xe1, 0xec, 0x2b, 0x8e, 0xbd, 0x56, 0x22, 0x52, 0x0b, 0x73 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 90 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x74, 0x72, 0xf9, 0xa7, 0x98, 0x86, 0x07, 0xca, 0x79, 0x70, 0x77, 0x95, 0x99, 0x10, 0x35, 0xe6 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 91 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x56, 0xaf, 0xf0, 0x89, 0x87, 0x8b, 0xf3, 0x35, 0x2f, 0x8d, 0xf1, 0x72, 0xa3, 0xae, 0x47, 0xd8 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 92 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x65, 0xc0, 0x52, 0x6c, 0xbe, 0x40, 0x16, 0x1b, 0x80, 0x19, 0xa2, 0xa3, 0x17, 0x1a, 0xbd, 0x23 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 93 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x37, 0x7b, 0xe0, 0xbe, 0x33, 0xb4, 0xe3, 0xe3, 0x10, 0xb4, 0xaa, 0xbd, 0xa1, 0x73, 0xf8, 0x4f }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 94 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x94, 0x02, 0xe9, 0xaa, 0x6f, 0x69, 0xde, 0x65, 0x04, 0xda, 0x8d, 0x20, 0xc4, 0xfc, 0xaa, 0x2f }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 95 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x12, 0x3c, 0x1f, 0x4a, 0xf3, 0x13, 0xad, 0x8c, 0x2c, 0xe6, 0x48, 0xb2, 0xe7, 0x1f, 0xb6, 0xe1 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 96 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 }, 16, { 0x1f, 0xfc, 0x62, 0x6d, 0x30, 0x20, 0x3d, 0xcd, 0xb0, 0x01, 0x9f, 0xb8, 0x0f, 0x72, 0x6c, 0xf4 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 97 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 }, 16, { 0x76, 0xda, 0x1f, 0xbe, 0x3a, 0x50, 0x72, 0x8c, 0x50, 0xfd, 0x2e, 0x62, 0x1b, 0x5a, 0xd8, 0x85 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 98 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 }, 16, { 0x08, 0x2e, 0xb8, 0xbe, 0x35, 0xf4, 0x42, 0xfb, 0x52, 0x66, 0x8e, 0x16, 0xa5, 0x91, 0xd1, 0xd6 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 99 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 }, 16, { 0xe6, 0x56, 0xf9, 0xec, 0xf5, 0xfe, 0x27, 0xec, 0x3e, 0x4a, 0x73, 0xd0, 0x0c, 0x28, 0x2f, 0xb3 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 100 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 }, 16, { 0x2c, 0xa8, 0x20, 0x9d, 0x63, 0x27, 0x4c, 0xd9, 0xa2, 0x9b, 0xb7, 0x4b, 0xcd, 0x77, 0x68, 0x3a }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 101 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 }, 16, { 0x79, 0xbf, 0x5d, 0xce, 0x14, 0xbb, 0x7d, 0xd7, 0x3a, 0x8e, 0x36, 0x11, 0xde, 0x7c, 0xe0, 0x26 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 102 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 }, 16, { 0x3c, 0x84, 0x99, 0x39, 0xa5, 0xd2, 0x93, 0x99, 0xf3, 0x44, 0xc4, 0xa0, 0xec, 0xa8, 0xa5, 0x76 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 103 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }, 16, { 0xed, 0x3c, 0x0a, 0x94, 0xd5, 0x9b, 0xec, 0xe9, 0x88, 0x35, 0xda, 0x7a, 0xa4, 0xf0, 0x7c, 0xa2 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 104 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 }, 16, { 0x63, 0x91, 0x9e, 0xd4, 0xce, 0x10, 0x19, 0x64, 0x38, 0xb6, 0xad, 0x09, 0xd9, 0x9c, 0xd7, 0x95 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 105 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 }, 16, { 0x76, 0x78, 0xf3, 0xa8, 0x33, 0xf1, 0x9f, 0xea, 0x95, 0xf3, 0xc6, 0x02, 0x9e, 0x2b, 0xc6, 0x10 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 106 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 }, 16, { 0x3a, 0xa4, 0x26, 0x83, 0x10, 0x67, 0xd3, 0x6b, 0x92, 0xbe, 0x7c, 0x5f, 0x81, 0xc1, 0x3c, 0x56 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 107 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 }, 16, { 0x92, 0x72, 0xe2, 0xd2, 0xcd, 0xd1, 0x10, 0x50, 0x99, 0x8c, 0x84, 0x50, 0x77, 0xa3, 0x0e, 0xa0 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 108 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 }, 16, { 0x08, 0x8c, 0x4b, 0x53, 0xf5, 0xec, 0x0f, 0xf8, 0x14, 0xc1, 0x9a, 0xda, 0xe7, 0xf6, 0x24, 0x6c }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 109 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 }, 16, { 0x40, 0x10, 0xa5, 0xe4, 0x01, 0xfd, 0xf0, 0xa0, 0x35, 0x4d, 0xdb, 0xcc, 0x0d, 0x01, 0x2b, 0x17 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 110 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 }, 16, { 0xa8, 0x7a, 0x38, 0x57, 0x36, 0xc0, 0xa6, 0x18, 0x9b, 0xd6, 0x58, 0x9b, 0xd8, 0x44, 0x5a, 0x93 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 111 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 }, 16, { 0x54, 0x5f, 0x2b, 0x83, 0xd9, 0x61, 0x6d, 0xcc, 0xf6, 0x0f, 0xa9, 0x83, 0x0e, 0x9c, 0xd2, 0x87 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 112 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 }, 16, { 0x4b, 0x70, 0x6f, 0x7f, 0x92, 0x40, 0x63, 0x52, 0x39, 0x40, 0x37, 0xa6, 0xd4, 0xf4, 0x68, 0x8d }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 113 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 }, 16, { 0xb7, 0x97, 0x2b, 0x39, 0x41, 0xc4, 0x4b, 0x90, 0xaf, 0xa7, 0xb2, 0x64, 0xbf, 0xba, 0x73, 0x87 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 114 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 }, 16, { 0x6f, 0x45, 0x73, 0x2c, 0xf1, 0x08, 0x81, 0x54, 0x6f, 0x0f, 0xd2, 0x38, 0x96, 0xd2, 0xbb, 0x60 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 115 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 }, 16, { 0x2e, 0x35, 0x79, 0xca, 0x15, 0xaf, 0x27, 0xf6, 0x4b, 0x3c, 0x95, 0x5a, 0x5b, 0xfc, 0x30, 0xba }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 116 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 }, 16, { 0x34, 0xa2, 0xc5, 0xa9, 0x1a, 0xe2, 0xae, 0xc9, 0x9b, 0x7d, 0x1b, 0x5f, 0xa6, 0x78, 0x04, 0x47 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 117 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 }, 16, { 0xa4, 0xd6, 0x61, 0x6b, 0xd0, 0x4f, 0x87, 0x33, 0x5b, 0x0e, 0x53, 0x35, 0x12, 0x27, 0xa9, 0xee }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 118 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 }, 16, { 0x7f, 0x69, 0x2b, 0x03, 0x94, 0x58, 0x67, 0xd1, 0x61, 0x79, 0xa8, 0xce, 0xfc, 0x83, 0xea, 0x3f }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 119 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 }, 16, { 0x3b, 0xd1, 0x41, 0xee, 0x84, 0xa0, 0xe6, 0x41, 0x4a, 0x26, 0xe7, 0xa4, 0xf2, 0x81, 0xf8, 0xa2 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 120 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 }, 16, { 0xd1, 0x78, 0x8f, 0x57, 0x2d, 0x98, 0xb2, 0xb1, 0x6e, 0xc5, 0xd5, 0xf3, 0x92, 0x2b, 0x99, 0xbc }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 121 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 }, 16, { 0x08, 0x33, 0xff, 0x6f, 0x61, 0xd9, 0x8a, 0x57, 0xb2, 0x88, 0xe8, 0xc3, 0x58, 0x6b, 0x85, 0xa6 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 122 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 }, 16, { 0x85, 0x68, 0x26, 0x17, 0x97, 0xde, 0x17, 0x6b, 0xf0, 0xb4, 0x3b, 0xec, 0xc6, 0x28, 0x5a, 0xfb }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 123 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 }, 16, { 0xf9, 0xb0, 0xfd, 0xa0, 0xc4, 0xa8, 0x98, 0xf5, 0xb9, 0xe6, 0xf6, 0x61, 0xc4, 0xce, 0x4d, 0x07 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 124 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 }, 16, { 0x8a, 0xde, 0x89, 0x59, 0x13, 0x68, 0x5c, 0x67, 0xc5, 0x26, 0x9f, 0x8a, 0xae, 0x42, 0x98, 0x3e }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 125 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc }, 16, { 0x39, 0xbd, 0xe6, 0x7d, 0x5c, 0x8e, 0xd8, 0xa8, 0xb1, 0xc3, 0x7e, 0xb8, 0xfa, 0x9f, 0x5a, 0xc0 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 126 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe }, 16, { 0x5c, 0x00, 0x5e, 0x72, 0xc1, 0x41, 0x8c, 0x44, 0xf5, 0x69, 0xf2, 0xea, 0x33, 0xba, 0x54, 0xf3 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 127 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }, 16, { 0x3f, 0x5b, 0x8c, 0xc9, 0xea, 0x85, 0x5a, 0x0a, 0xfa, 0x73, 0x47, 0xd2, 0x3e, 0x8d, 0x66, 0x4e }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 0 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0xd7, 0x8e, 0x72, 0x6c, 0x1e, 0xc0, 0x2b, 0x7e, 0xbf, 0xe9, 0x2b, 0x23, 0xd9, 0xec, 0x34 }, 16, { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 1 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xaa, 0xe5, 0x93, 0x9c, 0x8e, 0xfd, 0xf2, 0xf0, 0x4e, 0x60, 0xb9, 0xfe, 0x71, 0x17, 0xb2, 0xc2 }, 16, { 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 2 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf0, 0x31, 0xd4, 0xd7, 0x4f, 0x5d, 0xcb, 0xf3, 0x9d, 0xaa, 0xf8, 0xca, 0x3a, 0xf6, 0xe5, 0x27 }, 16, { 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 3 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x96, 0xd9, 0xfd, 0x5c, 0xc4, 0xf0, 0x74, 0x41, 0x72, 0x7d, 0xf0, 0xf3, 0x3e, 0x40, 0x1a, 0x36 }, 16, { 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 4 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x30, 0xcc, 0xdb, 0x04, 0x46, 0x46, 0xd7, 0xe1, 0xf3, 0xcc, 0xea, 0x3d, 0xca, 0x08, 0xb8, 0xc0 }, 16, { 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 5 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x16, 0xae, 0x4c, 0xe5, 0x04, 0x2a, 0x67, 0xee, 0x8e, 0x17, 0x7b, 0x7c, 0x58, 0x7e, 0xcc, 0x82 }, 16, { 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 6 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb6, 0xda, 0x0b, 0xb1, 0x1a, 0x23, 0x85, 0x5d, 0x9c, 0x5c, 0xb1, 0xb4, 0xc6, 0x41, 0x2e, 0x0a }, 16, { 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 7 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdb, 0x4f, 0x1a, 0xa5, 0x30, 0x96, 0x7d, 0x67, 0x32, 0xce, 0x47, 0x15, 0xeb, 0x0e, 0xe2, 0x4b }, 16, { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 8 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa8, 0x17, 0x38, 0x25, 0x26, 0x21, 0xdd, 0x18, 0x0a, 0x34, 0xf3, 0x45, 0x5b, 0x4b, 0xaa, 0x2f }, 16, { 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 9 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x77, 0xe2, 0xb5, 0x08, 0xdb, 0x7f, 0xd8, 0x92, 0x34, 0xca, 0xf7, 0x93, 0x9e, 0xe5, 0x62, 0x1a }, 16, { 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 10 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb8, 0x49, 0x9c, 0x25, 0x1f, 0x84, 0x42, 0xee, 0x13, 0xf0, 0x93, 0x3b, 0x68, 0x8f, 0xcd, 0x19 }, 16, { 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 11 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x96, 0x51, 0x35, 0xf8, 0xa8, 0x1f, 0x25, 0xc9, 0xd6, 0x30, 0xb1, 0x75, 0x02, 0xf6, 0x8e, 0x53 }, 16, { 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 12 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8b, 0x87, 0x14, 0x5a, 0x01, 0xad, 0x1c, 0x6c, 0xed, 0xe9, 0x95, 0xea, 0x36, 0x70, 0x45, 0x4f }, 16, { 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 13 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8e, 0xae, 0x3b, 0x10, 0xa0, 0xc8, 0xca, 0x6d, 0x1d, 0x3b, 0x0f, 0xa6, 0x1e, 0x56, 0xb0, 0xb2 }, 16, { 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 14 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x64, 0xb4, 0xd6, 0x29, 0x81, 0x0f, 0xda, 0x6b, 0xaf, 0xdf, 0x08, 0xf3, 0xb0, 0xd8, 0xd2, 0xc5 }, 16, { 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 15 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd7, 0xe5, 0xdb, 0xd3, 0x32, 0x45, 0x95, 0xf8, 0xfd, 0xc7, 0xd7, 0xc5, 0x71, 0xda, 0x6c, 0x2a }, 16, { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 16 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf3, 0xf7, 0x23, 0x75, 0x26, 0x4e, 0x16, 0x7f, 0xca, 0x9d, 0xe2, 0xc1, 0x52, 0x7d, 0x96, 0x06 }, 16, { 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 17 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8e, 0xe7, 0x9d, 0xd4, 0xf4, 0x01, 0xff, 0x9b, 0x7e, 0xa9, 0x45, 0xd8, 0x66, 0x66, 0xc1, 0x3b }, 16, { 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 18 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdd, 0x35, 0xce, 0xa2, 0x79, 0x99, 0x40, 0xb4, 0x0d, 0xb3, 0xf8, 0x19, 0xcb, 0x94, 0xc0, 0x8b }, 16, { 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 19 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x69, 0x41, 0xcb, 0x6b, 0x3e, 0x08, 0xc2, 0xb7, 0xaf, 0xa5, 0x81, 0xeb, 0xdd, 0x60, 0x7b, 0x87 }, 16, { 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 20 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2c, 0x20, 0xf4, 0x39, 0xf6, 0xbb, 0x09, 0x7b, 0x29, 0xb8, 0xbd, 0x6d, 0x99, 0xaa, 0xd7, 0x99 }, 16, { 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 21 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x62, 0x5d, 0x01, 0xf0, 0x58, 0xe5, 0x65, 0xf7, 0x7a, 0xe8, 0x63, 0x78, 0xbd, 0x2c, 0x49, 0xb3 }, 16, { 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 22 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc0, 0xb5, 0xfd, 0x98, 0x19, 0x0e, 0xf4, 0x5f, 0xbb, 0x43, 0x01, 0x43, 0x8d, 0x09, 0x59, 0x50 }, 16, { 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 23 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x13, 0x00, 0x1f, 0xf5, 0xd9, 0x98, 0x06, 0xef, 0xd2, 0x5d, 0xa3, 0x4f, 0x56, 0xbe, 0x85, 0x4b }, 16, { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 24 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3b, 0x59, 0x4c, 0x60, 0xf5, 0xc8, 0x27, 0x7a, 0x51, 0x13, 0x67, 0x7f, 0x94, 0x20, 0x8d, 0x82 }, 16, { 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 25 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe9, 0xc0, 0xfc, 0x18, 0x18, 0xe4, 0xaa, 0x46, 0xbd, 0x2e, 0x39, 0xd6, 0x38, 0xf8, 0x9e, 0x05 }, 16, { 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 26 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf8, 0x02, 0x3e, 0xe9, 0xc3, 0xfd, 0xc4, 0x5a, 0x01, 0x9b, 0x4e, 0x98, 0x5c, 0x7e, 0x1a, 0x54 }, 16, { 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 27 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x35, 0xf4, 0x01, 0x82, 0xab, 0x46, 0x62, 0xf3, 0x02, 0x3b, 0xae, 0xc1, 0xee, 0x79, 0x6b, 0x57 }, 16, { 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 28 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0xeb, 0xba, 0xd7, 0x30, 0x36, 0x49, 0xb4, 0x19, 0x4a, 0x69, 0x45, 0xc6, 0xcc, 0x36, 0x94 }, 16, { 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 29 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa2, 0x12, 0x4b, 0xea, 0x53, 0xec, 0x28, 0x34, 0x27, 0x9b, 0xed, 0x7f, 0x7e, 0xb0, 0xf9, 0x38 }, 16, { 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 30 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb9, 0xfb, 0x43, 0x99, 0xfa, 0x4f, 0xac, 0xc7, 0x30, 0x9e, 0x14, 0xec, 0x98, 0x36, 0x0b, 0x0a }, 16, { 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 31 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc2, 0x62, 0x77, 0x43, 0x74, 0x20, 0xc5, 0xd6, 0x34, 0xf7, 0x15, 0xae, 0xa8, 0x1a, 0x91, 0x32 }, 16, { 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 32 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x17, 0x1a, 0x0e, 0x1b, 0x2d, 0xd4, 0x24, 0xf0, 0xe0, 0x89, 0xaf, 0x2c, 0x4c, 0x10, 0xf3, 0x2f }, 16, { 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 33 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7c, 0xad, 0xbe, 0x40, 0x2d, 0x1b, 0x20, 0x8f, 0xe7, 0x35, 0xed, 0xce, 0x00, 0xae, 0xe7, 0xce }, 16, { 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 34 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x43, 0xb0, 0x2f, 0xf9, 0x29, 0xa1, 0x48, 0x5a, 0xf6, 0xf5, 0xc6, 0xd6, 0x55, 0x8b, 0xaa, 0x0f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 35 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x09, 0x2f, 0xaa, 0xcc, 0x9b, 0xf4, 0x35, 0x08, 0xbf, 0x8f, 0xa8, 0x61, 0x3c, 0xa7, 0x5d, 0xea }, 16, { 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 36 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcb, 0x2b, 0xf8, 0x28, 0x0f, 0x3f, 0x97, 0x42, 0xc7, 0xed, 0x51, 0x3f, 0xe8, 0x02, 0x62, 0x9c }, 16, { 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 37 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x21, 0x5a, 0x41, 0xee, 0x44, 0x2f, 0xa9, 0x92, 0xa6, 0xe3, 0x23, 0x98, 0x6d, 0xed, 0x3f, 0x68 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 38 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf2, 0x1e, 0x99, 0xcf, 0x4f, 0x0f, 0x77, 0xce, 0xa8, 0x36, 0xe1, 0x1a, 0x2f, 0xe7, 0x5f, 0xb1 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 39 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x95, 0xe3, 0xa0, 0xca, 0x90, 0x79, 0xe6, 0x46, 0x33, 0x1d, 0xf8, 0xb4, 0xe7, 0x0d, 0x2c, 0xd6 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 40 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4a, 0xfe, 0x7f, 0x12, 0x0c, 0xe7, 0x61, 0x3f, 0x74, 0xfc, 0x12, 0xa0, 0x1a, 0x82, 0x80, 0x73 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 41 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x82, 0x7f, 0x00, 0x0e, 0x75, 0xe2, 0xc8, 0xb9, 0xd4, 0x79, 0xbe, 0xed, 0x91, 0x3f, 0xe6, 0x78 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 42 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x35, 0x83, 0x0c, 0x8e, 0x7a, 0xae, 0xfe, 0x2d, 0x30, 0x31, 0x0e, 0xf3, 0x81, 0xcb, 0xf6, 0x91 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 43 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x19, 0x1a, 0xa0, 0xf2, 0xc8, 0x57, 0x01, 0x44, 0xf3, 0x86, 0x57, 0xea, 0x40, 0x85, 0xeb, 0xe5 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 44 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x85, 0x06, 0x2c, 0x2c, 0x90, 0x9f, 0x15, 0xd9, 0x26, 0x9b, 0x6c, 0x18, 0xce, 0x99, 0xc4, 0xf0 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 45 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x67, 0x80, 0x34, 0xdc, 0x9e, 0x41, 0xb5, 0xa5, 0x60, 0xed, 0x23, 0x9e, 0xea, 0xb1, 0xbc, 0x78 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 46 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc2, 0xf9, 0x3a, 0x4c, 0xe5, 0xab, 0x6d, 0x5d, 0x56, 0xf1, 0xb9, 0x3c, 0xf1, 0x99, 0x11, 0xc1 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 47 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1c, 0x31, 0x12, 0xbc, 0xb0, 0xc1, 0xdc, 0xc7, 0x49, 0xd7, 0x99, 0x74, 0x36, 0x91, 0xbf, 0x82 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 48 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0xc5, 0x5b, 0xd7, 0x5c, 0x7f, 0x9c, 0x88, 0x19, 0x89, 0xd3, 0xec, 0x19, 0x11, 0xc0, 0xd4 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 49 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xea, 0x2e, 0x6b, 0x5e, 0xf1, 0x82, 0xb7, 0xdf, 0xf3, 0x62, 0x9a, 0xbd, 0x6a, 0x12, 0x04, 0x5f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 50 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x22, 0x32, 0x23, 0x27, 0xe0, 0x17, 0x80, 0xb1, 0x73, 0x97, 0xf2, 0x40, 0x87, 0xf8, 0xcc, 0x6f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 51 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc9, 0xca, 0xcb, 0x5c, 0xd1, 0x16, 0x92, 0xc3, 0x73, 0xb2, 0x41, 0x17, 0x68, 0x14, 0x9e, 0xe7 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 52 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa1, 0x8e, 0x3d, 0xbb, 0xca, 0x57, 0x78, 0x60, 0xda, 0xb6, 0xb8, 0x0d, 0xa3, 0x13, 0x92, 0x56 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 53 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x79, 0xb6, 0x1c, 0x37, 0xbf, 0x32, 0x8e, 0xcc, 0xa8, 0xd7, 0x43, 0x26, 0x5a, 0x3d, 0x42, 0x5c }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 54 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0xd9, 0x9c, 0x6b, 0xcc, 0x1f, 0x06, 0xfd, 0xa8, 0xe2, 0x7e, 0x8a, 0xe3, 0xf1, 0xcc, 0xc7 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 55 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0xfd, 0x4b, 0x91, 0xc7, 0x01, 0xfd, 0x6b, 0x61, 0xb7, 0xf9, 0x97, 0x82, 0x9d, 0x66, 0x3b }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 56 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0x00, 0x5d, 0x52, 0xf2, 0x5f, 0x16, 0xbd, 0xc9, 0x54, 0x5a, 0x87, 0x6a, 0x63, 0x49, 0x0a }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 57 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0x4d, 0x35, 0x4f, 0x02, 0xbb, 0x5a, 0x5e, 0x47, 0xd3, 0x96, 0x66, 0x86, 0x7f, 0x24, 0x6a }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 58 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd4, 0x51, 0xb8, 0xd6, 0xe1, 0xe1, 0xa0, 0xeb, 0xb1, 0x55, 0xfb, 0xbf, 0x6e, 0x7b, 0x7d, 0xc3 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 59 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x68, 0x98, 0xd4, 0xf4, 0x2f, 0xa7, 0xba, 0x6a, 0x10, 0xac, 0x05, 0xe8, 0x7b, 0x9f, 0x20, 0x80 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 60 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb6, 0x11, 0x29, 0x5e, 0x73, 0x9c, 0xa7, 0xd9, 0xb5, 0x0f, 0x8e, 0x4c, 0x0e, 0x75, 0x4a, 0x3f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 61 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7d, 0x33, 0xfc, 0x7d, 0x8a, 0xbe, 0x3c, 0xa1, 0x93, 0x67, 0x59, 0xf8, 0xf5, 0xde, 0xaf, 0x20 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 62 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3b, 0x5e, 0x0f, 0x56, 0x6d, 0xc9, 0x6c, 0x29, 0x8f, 0x0c, 0x12, 0x63, 0x75, 0x39, 0xb2, 0x5c }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 63 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf8, 0x07, 0xc3, 0xe7, 0x98, 0x5f, 0xe0, 0xf5, 0xa5, 0x0e, 0x2c, 0xdb, 0x25, 0xc5, 0x10, 0x9e }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 64 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x41, 0xf9, 0x92, 0xa8, 0x56, 0xfb, 0x27, 0x8b, 0x38, 0x9a, 0x62, 0xf5, 0xd2, 0x74, 0xd7, 0xe9 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 65 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x10, 0xd3, 0xed, 0x7a, 0x6f, 0xe1, 0x5a, 0xb4, 0xd9, 0x1a, 0xcb, 0xc7, 0xd0, 0x76, 0x7a, 0xb1 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 66 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x21, 0xfe, 0xec, 0xd4, 0x5b, 0x2e, 0x67, 0x59, 0x73, 0xac, 0x33, 0xbf, 0x0c, 0x54, 0x24, 0xfc }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 67 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x14, 0x80, 0xcb, 0x39, 0x55, 0xba, 0x62, 0xd0, 0x9e, 0xea, 0x66, 0x8f, 0x7c, 0x70, 0x88, 0x17 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 68 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x66, 0x40, 0x40, 0x33, 0xd6, 0xb7, 0x2b, 0x60, 0x93, 0x54, 0xd5, 0x49, 0x6e, 0x7e, 0xb5, 0x11 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 69 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1c, 0x31, 0x7a, 0x22, 0x0a, 0x7d, 0x70, 0x0d, 0xa2, 0xb1, 0xe0, 0x75, 0xb0, 0x02, 0x66, 0xe1 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 70 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xab, 0x3b, 0x89, 0x54, 0x22, 0x33, 0xf1, 0x27, 0x1b, 0xf8, 0xfd, 0x0c, 0x0f, 0x40, 0x35, 0x45 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 71 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd9, 0x3e, 0xae, 0x96, 0x6f, 0xac, 0x46, 0xdc, 0xa9, 0x27, 0xd6, 0xb1, 0x14, 0xfa, 0x3f, 0x9e }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 72 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0xde, 0xc5, 0x21, 0x31, 0x65, 0x03, 0xd9, 0xd5, 0xee, 0x65, 0xdf, 0x3e, 0xa9, 0x4d, 0xdf }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 73 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xee, 0xf4, 0x56, 0x43, 0x1d, 0xea, 0x8b, 0x4a, 0xcf, 0x83, 0xbd, 0xae, 0x37, 0x17, 0xf7, 0x5f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 74 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x06, 0xf2, 0x51, 0x9a, 0x2f, 0xaf, 0xaa, 0x59, 0x6b, 0xfe, 0xf5, 0xcf, 0xa1, 0x5c, 0x21, 0xb9 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 75 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x25, 0x1a, 0x7e, 0xac, 0x7e, 0x2f, 0xe8, 0x09, 0xe4, 0xaa, 0x8d, 0x0d, 0x70, 0x12, 0x53, 0x1a }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 76 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3b, 0xff, 0xc1, 0x6e, 0x4c, 0x49, 0xb2, 0x68, 0xa2, 0x0f, 0x8d, 0x96, 0xa6, 0x0b, 0x40, 0x58 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 77 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe8, 0x86, 0xf9, 0x28, 0x19, 0x99, 0xc5, 0xbb, 0x3b, 0x3e, 0x88, 0x62, 0xe2, 0xf7, 0xc9, 0x88 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 78 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x56, 0x3b, 0xf9, 0x0d, 0x61, 0xbe, 0xef, 0x39, 0xf4, 0x8d, 0xd6, 0x25, 0xfc, 0xef, 0x13, 0x61 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 79 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4d, 0x37, 0xc8, 0x50, 0x64, 0x45, 0x63, 0xc6, 0x9f, 0xd0, 0xac, 0xd9, 0xa0, 0x49, 0x32, 0x5b }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 80 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb8, 0x7c, 0x92, 0x1b, 0x91, 0x82, 0x9e, 0xf3, 0xb1, 0x3c, 0xa5, 0x41, 0xee, 0x11, 0x30, 0xa6 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 81 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2e, 0x65, 0xeb, 0x6b, 0x6e, 0xa3, 0x83, 0xe1, 0x09, 0xac, 0xcc, 0xe8, 0x32, 0x6b, 0x03, 0x93 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 82 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9c, 0xa5, 0x47, 0xf7, 0x43, 0x9e, 0xdc, 0x3e, 0x25, 0x5c, 0x0f, 0x4d, 0x49, 0xaa, 0x89, 0x90 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 83 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa5, 0xe6, 0x52, 0x61, 0x4c, 0x93, 0x00, 0xf3, 0x78, 0x16, 0xb1, 0xf9, 0xfd, 0x0c, 0x87, 0xf9 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 84 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x14, 0x95, 0x4f, 0x0b, 0x46, 0x97, 0x77, 0x6f, 0x44, 0x49, 0x4f, 0xe4, 0x58, 0xd8, 0x14, 0xed }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 85 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7c, 0x8d, 0x9a, 0xb6, 0xc2, 0x76, 0x17, 0x23, 0xfe, 0x42, 0xf8, 0xbb, 0x50, 0x6c, 0xbc, 0xf7 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 86 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdb, 0x7e, 0x19, 0x32, 0x67, 0x9f, 0xdd, 0x99, 0x74, 0x2a, 0xab, 0x04, 0xaa, 0x0d, 0x5a, 0x80 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 87 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4c, 0x6a, 0x1c, 0x83, 0xe5, 0x68, 0xcd, 0x10, 0xf2, 0x7c, 0x2d, 0x73, 0xde, 0xd1, 0x9c, 0x28 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 88 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0xec, 0xbe, 0x61, 0x77, 0xe6, 0x74, 0xc9, 0x8d, 0xe4, 0x12, 0x41, 0x3f, 0x7a, 0xc9, 0x15 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 89 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0x68, 0x4a, 0x2a, 0xc5, 0x5f, 0xe1, 0xec, 0x2b, 0x8e, 0xbd, 0x56, 0x22, 0x52, 0x0b, 0x73 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 90 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x74, 0x72, 0xf9, 0xa7, 0x98, 0x86, 0x07, 0xca, 0x79, 0x70, 0x77, 0x95, 0x99, 0x10, 0x35, 0xe6 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 91 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x56, 0xaf, 0xf0, 0x89, 0x87, 0x8b, 0xf3, 0x35, 0x2f, 0x8d, 0xf1, 0x72, 0xa3, 0xae, 0x47, 0xd8 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 92 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x65, 0xc0, 0x52, 0x6c, 0xbe, 0x40, 0x16, 0x1b, 0x80, 0x19, 0xa2, 0xa3, 0x17, 0x1a, 0xbd, 0x23 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 93 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x37, 0x7b, 0xe0, 0xbe, 0x33, 0xb4, 0xe3, 0xe3, 0x10, 0xb4, 0xaa, 0xbd, 0xa1, 0x73, 0xf8, 0x4f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 94 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x94, 0x02, 0xe9, 0xaa, 0x6f, 0x69, 0xde, 0x65, 0x04, 0xda, 0x8d, 0x20, 0xc4, 0xfc, 0xaa, 0x2f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 95 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x12, 0x3c, 0x1f, 0x4a, 0xf3, 0x13, 0xad, 0x8c, 0x2c, 0xe6, 0x48, 0xb2, 0xe7, 0x1f, 0xb6, 0xe1 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 96 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1f, 0xfc, 0x62, 0x6d, 0x30, 0x20, 0x3d, 0xcd, 0xb0, 0x01, 0x9f, 0xb8, 0x0f, 0x72, 0x6c, 0xf4 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 97 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x76, 0xda, 0x1f, 0xbe, 0x3a, 0x50, 0x72, 0x8c, 0x50, 0xfd, 0x2e, 0x62, 0x1b, 0x5a, 0xd8, 0x85 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 98 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x08, 0x2e, 0xb8, 0xbe, 0x35, 0xf4, 0x42, 0xfb, 0x52, 0x66, 0x8e, 0x16, 0xa5, 0x91, 0xd1, 0xd6 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 99 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe6, 0x56, 0xf9, 0xec, 0xf5, 0xfe, 0x27, 0xec, 0x3e, 0x4a, 0x73, 0xd0, 0x0c, 0x28, 0x2f, 0xb3 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 100 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2c, 0xa8, 0x20, 0x9d, 0x63, 0x27, 0x4c, 0xd9, 0xa2, 0x9b, 0xb7, 0x4b, 0xcd, 0x77, 0x68, 0x3a }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 101 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x79, 0xbf, 0x5d, 0xce, 0x14, 0xbb, 0x7d, 0xd7, 0x3a, 0x8e, 0x36, 0x11, 0xde, 0x7c, 0xe0, 0x26 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 102 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3c, 0x84, 0x99, 0x39, 0xa5, 0xd2, 0x93, 0x99, 0xf3, 0x44, 0xc4, 0xa0, 0xec, 0xa8, 0xa5, 0x76 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 103 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xed, 0x3c, 0x0a, 0x94, 0xd5, 0x9b, 0xec, 0xe9, 0x88, 0x35, 0xda, 0x7a, 0xa4, 0xf0, 0x7c, 0xa2 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 104 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x63, 0x91, 0x9e, 0xd4, 0xce, 0x10, 0x19, 0x64, 0x38, 0xb6, 0xad, 0x09, 0xd9, 0x9c, 0xd7, 0x95 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 105 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x76, 0x78, 0xf3, 0xa8, 0x33, 0xf1, 0x9f, 0xea, 0x95, 0xf3, 0xc6, 0x02, 0x9e, 0x2b, 0xc6, 0x10 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 106 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0xa4, 0x26, 0x83, 0x10, 0x67, 0xd3, 0x6b, 0x92, 0xbe, 0x7c, 0x5f, 0x81, 0xc1, 0x3c, 0x56 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 107 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x92, 0x72, 0xe2, 0xd2, 0xcd, 0xd1, 0x10, 0x50, 0x99, 0x8c, 0x84, 0x50, 0x77, 0xa3, 0x0e, 0xa0 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 108 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x08, 0x8c, 0x4b, 0x53, 0xf5, 0xec, 0x0f, 0xf8, 0x14, 0xc1, 0x9a, 0xda, 0xe7, 0xf6, 0x24, 0x6c }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 109 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x40, 0x10, 0xa5, 0xe4, 0x01, 0xfd, 0xf0, 0xa0, 0x35, 0x4d, 0xdb, 0xcc, 0x0d, 0x01, 0x2b, 0x17 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 110 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa8, 0x7a, 0x38, 0x57, 0x36, 0xc0, 0xa6, 0x18, 0x9b, 0xd6, 0x58, 0x9b, 0xd8, 0x44, 0x5a, 0x93 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 111 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x54, 0x5f, 0x2b, 0x83, 0xd9, 0x61, 0x6d, 0xcc, 0xf6, 0x0f, 0xa9, 0x83, 0x0e, 0x9c, 0xd2, 0x87 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 112 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4b, 0x70, 0x6f, 0x7f, 0x92, 0x40, 0x63, 0x52, 0x39, 0x40, 0x37, 0xa6, 0xd4, 0xf4, 0x68, 0x8d }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 113 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb7, 0x97, 0x2b, 0x39, 0x41, 0xc4, 0x4b, 0x90, 0xaf, 0xa7, 0xb2, 0x64, 0xbf, 0xba, 0x73, 0x87 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 114 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6f, 0x45, 0x73, 0x2c, 0xf1, 0x08, 0x81, 0x54, 0x6f, 0x0f, 0xd2, 0x38, 0x96, 0xd2, 0xbb, 0x60 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 115 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2e, 0x35, 0x79, 0xca, 0x15, 0xaf, 0x27, 0xf6, 0x4b, 0x3c, 0x95, 0x5a, 0x5b, 0xfc, 0x30, 0xba }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 116 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x34, 0xa2, 0xc5, 0xa9, 0x1a, 0xe2, 0xae, 0xc9, 0x9b, 0x7d, 0x1b, 0x5f, 0xa6, 0x78, 0x04, 0x47 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 117 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa4, 0xd6, 0x61, 0x6b, 0xd0, 0x4f, 0x87, 0x33, 0x5b, 0x0e, 0x53, 0x35, 0x12, 0x27, 0xa9, 0xee }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 118 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7f, 0x69, 0x2b, 0x03, 0x94, 0x58, 0x67, 0xd1, 0x61, 0x79, 0xa8, 0xce, 0xfc, 0x83, 0xea, 0x3f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 119 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3b, 0xd1, 0x41, 0xee, 0x84, 0xa0, 0xe6, 0x41, 0x4a, 0x26, 0xe7, 0xa4, 0xf2, 0x81, 0xf8, 0xa2 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 120 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd1, 0x78, 0x8f, 0x57, 0x2d, 0x98, 0xb2, 0xb1, 0x6e, 0xc5, 0xd5, 0xf3, 0x92, 0x2b, 0x99, 0xbc }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 121 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x08, 0x33, 0xff, 0x6f, 0x61, 0xd9, 0x8a, 0x57, 0xb2, 0x88, 0xe8, 0xc3, 0x58, 0x6b, 0x85, 0xa6 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 122 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x85, 0x68, 0x26, 0x17, 0x97, 0xde, 0x17, 0x6b, 0xf0, 0xb4, 0x3b, 0xec, 0xc6, 0x28, 0x5a, 0xfb }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 123 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf9, 0xb0, 0xfd, 0xa0, 0xc4, 0xa8, 0x98, 0xf5, 0xb9, 0xe6, 0xf6, 0x61, 0xc4, 0xce, 0x4d, 0x07 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 124 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8a, 0xde, 0x89, 0x59, 0x13, 0x68, 0x5c, 0x67, 0xc5, 0x26, 0x9f, 0x8a, 0xae, 0x42, 0x98, 0x3e }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 125 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x39, 0xbd, 0xe6, 0x7d, 0x5c, 0x8e, 0xd8, 0xa8, 0xb1, 0xc3, 0x7e, 0xb8, 0xfa, 0x9f, 0x5a, 0xc0 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 126 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5c, 0x00, 0x5e, 0x72, 0xc1, 0x41, 0x8c, 0x44, 0xf5, 0x69, 0xf2, 0xea, 0x33, 0xba, 0x54, 0xf3 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe }, 16 }, { "NIST KAT-AES ECBVarTxt128.rsp test vector 127 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 128, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3f, 0x5b, 0x8c, 0xc9, 0xea, 0x85, 0x5a, 0x0a, 0xfa, 0x73, 0x47, 0xd2, 0x3e, 0x8d, 0x66, 0x4e }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 0 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6c, 0xd0, 0x25, 0x13, 0xe8, 0xd4, 0xdc, 0x98, 0x6b, 0x4a, 0xfe, 0x08, 0x7a, 0x60, 0xbd, 0x0c }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 1 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2c, 0xe1, 0xf8, 0xb7, 0xe3, 0x06, 0x27, 0xc1, 0xc4, 0x51, 0x9e, 0xad, 0xa4, 0x4b, 0xc4, 0x36 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 2 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x99, 0x46, 0xb5, 0xf8, 0x7a, 0xf4, 0x46, 0xf5, 0x79, 0x6c, 0x1f, 0xee, 0x63, 0xa2, 0xda, 0x24 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 3 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2a, 0x56, 0x03, 0x64, 0xce, 0x52, 0x9e, 0xfc, 0x21, 0x78, 0x87, 0x79, 0x56, 0x8d, 0x55, 0x55 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 4 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x35, 0xc1, 0x47, 0x18, 0x37, 0xaf, 0x44, 0x61, 0x53, 0xbc, 0xe5, 0x5d, 0x5b, 0xa7, 0x2a, 0x0a }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 5 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xce, 0x60, 0xbc, 0x52, 0x38, 0x62, 0x34, 0xf1, 0x58, 0xf8, 0x43, 0x41, 0xe5, 0x34, 0xcd, 0x9e }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 6 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8c, 0x7c, 0x27, 0xff, 0x32, 0xbc, 0xf8, 0xdc, 0x2d, 0xc5, 0x7c, 0x90, 0xc2, 0x90, 0x39, 0x61 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 7 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x32, 0xbb, 0x6a, 0x7e, 0xc8, 0x44, 0x99, 0xe1, 0x66, 0xf9, 0x36, 0x00, 0x3d, 0x55, 0xa5, 0xbb }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 8 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa5, 0xc7, 0x72, 0xe5, 0xc6, 0x26, 0x31, 0xef, 0x66, 0x0e, 0xe1, 0xd5, 0x87, 0x7f, 0x6d, 0x1b }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 9 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x03, 0x0d, 0x7e, 0x5b, 0x64, 0xf3, 0x80, 0xa7, 0xe4, 0xea, 0x53, 0x87, 0xb5, 0xcd, 0x7f, 0x49 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 10 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0d, 0xc9, 0xa2, 0x61, 0x00, 0x37, 0x00, 0x9b, 0x69, 0x8f, 0x11, 0xbb, 0x7e, 0x86, 0xc8, 0x3e }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 11 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x46, 0x61, 0x2c, 0x76, 0x6d, 0x18, 0x40, 0xc2, 0x26, 0x36, 0x4f, 0x1f, 0xa7, 0xed, 0x72 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 12 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x48, 0x80, 0xc7, 0xe0, 0x8f, 0x27, 0xbe, 0xfe, 0x78, 0x59, 0x07, 0x43, 0xc0, 0x5e, 0x69, 0x8b }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 13 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x25, 0x20, 0xce, 0x82, 0x9a, 0x26, 0x57, 0x7f, 0x0f, 0x48, 0x22, 0xc4, 0xec, 0xc8, 0x74, 0x01 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 14 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x87, 0x65, 0xe8, 0xac, 0xc1, 0x69, 0x75, 0x83, 0x19, 0xcb, 0x46, 0xdc, 0x7b, 0xcf, 0x3d, 0xca }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 15 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe9, 0x8f, 0x4b, 0xa4, 0xf0, 0x73, 0xdf, 0x4b, 0xaa, 0x11, 0x6d, 0x01, 0x1d, 0xc2, 0x4a, 0x28 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 16 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf3, 0x78, 0xf6, 0x8c, 0x5d, 0xbf, 0x59, 0xe2, 0x11, 0xb3, 0xa6, 0x59, 0xa7, 0x31, 0x7d, 0x94 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 17 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x28, 0x3d, 0x3b, 0x06, 0x9d, 0x8e, 0xb9, 0xfb, 0x43, 0x2d, 0x74, 0xb9, 0x6c, 0xa7, 0x62, 0xb4 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 18 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa7, 0xe1, 0x84, 0x2e, 0x8a, 0x87, 0x86, 0x1c, 0x22, 0x1a, 0x50, 0x08, 0x83, 0x24, 0x5c, 0x51 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 19 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x77, 0xaa, 0x27, 0x04, 0x71, 0x88, 0x1b, 0xe0, 0x70, 0xfb, 0x52, 0xc7, 0x06, 0x7c, 0xe7, 0x32 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 20 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x01, 0xb0, 0xf4, 0x76, 0xd4, 0x84, 0xf4, 0x3f, 0x1a, 0xeb, 0x6e, 0xfa, 0x93, 0x61, 0xa8, 0xac }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 21 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1c, 0x3a, 0x94, 0xf1, 0xc0, 0x52, 0xc5, 0x5c, 0x2d, 0x83, 0x59, 0xaf, 0xf2, 0x16, 0x3b, 0x4f }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 22 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe8, 0xa0, 0x67, 0xb6, 0x04, 0xd5, 0x37, 0x3d, 0x8b, 0x0f, 0x2e, 0x05, 0xa0, 0x3b, 0x34, 0x1b }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 23 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa7, 0x87, 0x6e, 0xc8, 0x7f, 0x5a, 0x09, 0xbf, 0xea, 0x42, 0xc7, 0x7d, 0xa3, 0x0f, 0xd5, 0x0e }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 24 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0c, 0xf3, 0xe9, 0xd3, 0xa4, 0x2b, 0xe5, 0xb8, 0x54, 0xca, 0x65, 0xb1, 0x3f, 0x35, 0xf4, 0x8d }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 25 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6c, 0x62, 0xf6, 0xbb, 0xca, 0xb7, 0xc3, 0xe8, 0x21, 0xc9, 0x29, 0x0f, 0x08, 0x89, 0x2d, 0xda }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 26 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7f, 0x5e, 0x05, 0xbd, 0x20, 0x68, 0x73, 0x81, 0x96, 0xfe, 0xe7, 0x9a, 0xce, 0x7e, 0x3a, 0xec }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 27 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x44, 0x0e, 0x0d, 0x73, 0x32, 0x55, 0xcd, 0xa9, 0x2f, 0xb4, 0x6e, 0x84, 0x2f, 0xe5, 0x80, 0x54 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 28 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xaa, 0x5d, 0x5b, 0x1c, 0x4e, 0xa1, 0xb7, 0xa2, 0x2e, 0x55, 0x83, 0xac, 0x2e, 0x9e, 0xd8, 0xa7 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 29 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x77, 0xe5, 0x37, 0xe8, 0x9e, 0x84, 0x91, 0xe8, 0x66, 0x2a, 0xae, 0x3b, 0xc8, 0x09, 0x42, 0x1d }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 30 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x99, 0x7d, 0xd3, 0xe9, 0xf1, 0x59, 0x8b, 0xfa, 0x73, 0xf7, 0x59, 0x73, 0xf7, 0xe9, 0x3b, 0x76 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 31 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0x38, 0xd4, 0xf7, 0x45, 0x2a, 0xfe, 0xfc, 0xb7, 0xfc, 0x72, 0x12, 0x44, 0xe4, 0xb7, 0x2e }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 32 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0b, 0xe2, 0xb1, 0x82, 0x52, 0xe7, 0x74, 0xdd, 0xa3, 0x0c, 0xdd, 0xa0, 0x2c, 0x69, 0x06, 0xe3 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 33 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0x69, 0x5e, 0x59, 0xc2, 0x03, 0x61, 0xd8, 0x26, 0x52, 0xd7, 0xd5, 0x8b, 0x6f, 0x11, 0xb2 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 34 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0x2d, 0x88, 0xd1, 0x3e, 0xae, 0x52, 0x08, 0x9a, 0xbd, 0x61, 0x43, 0xcf, 0xe3, 0x94, 0xe9 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 35 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd4, 0x9b, 0xce, 0xb3, 0xb8, 0x23, 0xfe, 0xdd, 0x60, 0x2c, 0x30, 0x53, 0x45, 0x73, 0x4b, 0xd2 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 36 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x70, 0x7b, 0x1d, 0xbb, 0x0f, 0xfa, 0x40, 0xef, 0x7d, 0x95, 0xde, 0xf4, 0x21, 0x23, 0x3f, 0xae }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 37 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7c, 0xa0, 0xc1, 0xd9, 0x33, 0x56, 0xd9, 0xeb, 0x8a, 0xa9, 0x52, 0x08, 0x4d, 0x75, 0xf9, 0x13 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 38 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf2, 0xcb, 0xf9, 0xcb, 0x18, 0x6e, 0x27, 0x0d, 0xd7, 0xbd, 0xb0, 0xc2, 0x8f, 0xeb, 0xc5, 0x7d }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 39 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc9, 0x43, 0x37, 0xc3, 0x7c, 0x4e, 0x79, 0x0a, 0xb4, 0x57, 0x80, 0xbd, 0x9c, 0x36, 0x74, 0xa0 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 40 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8e, 0x35, 0x58, 0xc1, 0x35, 0x25, 0x2f, 0xb9, 0xc9, 0xf3, 0x67, 0xed, 0x60, 0x94, 0x67, 0xa1 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 41 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0x72, 0xee, 0xae, 0xe4, 0x89, 0x9b, 0x44, 0x39, 0x14, 0xe5, 0xb3, 0xa5, 0x7f, 0xba, 0x92 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 42 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x01, 0x18, 0x65, 0xf9, 0x1b, 0xc5, 0x68, 0x68, 0xd0, 0x51, 0xe5, 0x2c, 0x9e, 0xfd, 0x59, 0xb7 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 43 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe4, 0x77, 0x13, 0x18, 0xad, 0x7a, 0x63, 0xdd, 0x68, 0x0f, 0x6e, 0x58, 0x3b, 0x77, 0x47, 0xea }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 44 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x61, 0xe3, 0xd1, 0x94, 0x08, 0x8d, 0xc8, 0xd9, 0x7e, 0x9e, 0x6d, 0xb3, 0x74, 0x57, 0xea, 0xc5 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 45 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x36, 0xff, 0x1e, 0xc9, 0xcc, 0xfb, 0xc3, 0x49, 0xe5, 0xd3, 0x56, 0xd0, 0x63, 0x69, 0x3a, 0xd6 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 46 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3c, 0xc9, 0xe9, 0xa9, 0xbe, 0x8c, 0xc3, 0xf6, 0xfb, 0x2e, 0xa2, 0x40, 0x88, 0xe9, 0xbb, 0x19 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 47 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1e, 0xe5, 0xab, 0x00, 0x3d, 0xc8, 0x72, 0x2e, 0x74, 0x90, 0x5d, 0x9a, 0x8f, 0xe3, 0xd3, 0x50 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 48 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x24, 0x53, 0x39, 0x31, 0x95, 0x84, 0xb0, 0xa4, 0x12, 0x41, 0x28, 0x69, 0xd6, 0xc2, 0xea, 0xda }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 49 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7b, 0xd4, 0x96, 0x91, 0x81, 0x15, 0xd1, 0x4e, 0xd5, 0x38, 0x08, 0x52, 0x71, 0x6c, 0x88, 0x14 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 50 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0x3a, 0xb2, 0xf2, 0xb4, 0xa3, 0x66, 0xa5, 0x7d, 0x58, 0x2a, 0x33, 0x93, 0x13, 0xc8, 0xb1 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 51 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0x33, 0x65, 0xa9, 0xff, 0xbe, 0x3b, 0x0c, 0xa6, 0x1e, 0x98, 0x50, 0x75, 0x54, 0x16, 0x8b }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 52 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xaf, 0xa9, 0x9c, 0x99, 0x7a, 0xc4, 0x78, 0xa0, 0xde, 0xa4, 0x11, 0x9c, 0x9e, 0x45, 0xf8, 0xb1 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 53 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x92, 0x16, 0x30, 0x9a, 0x78, 0x42, 0x43, 0x0b, 0x83, 0xff, 0xb9, 0x86, 0x38, 0x01, 0x15, 0x12 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 54 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x62, 0xab, 0xc7, 0x92, 0x28, 0x82, 0x58, 0x49, 0x2a, 0x7c, 0xb4, 0x51, 0x45, 0xf4, 0xb7, 0x59 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 55 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x53, 0x49, 0x23, 0xc1, 0x69, 0xd5, 0x04, 0xd7, 0x51, 0x9c, 0x15, 0xd3, 0x0e, 0x75, 0x6c, 0x50 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 56 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfa, 0x75, 0xe0, 0x5b, 0xcd, 0xc7, 0xe0, 0x0c, 0x27, 0x3f, 0xa3, 0x3f, 0x6e, 0xe4, 0x41, 0xd2 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 57 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7d, 0x35, 0x0f, 0xa6, 0x05, 0x70, 0x80, 0xf1, 0x08, 0x6a, 0x56, 0xb1, 0x7e, 0xc2, 0x40, 0xdb }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 58 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf3, 0x4e, 0x4a, 0x63, 0x24, 0xea, 0x4a, 0x5c, 0x39, 0xa6, 0x61, 0xc8, 0xfe, 0x5a, 0xda, 0x8f }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 59 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x08, 0x82, 0xa1, 0x6f, 0x44, 0x08, 0x8d, 0x42, 0x44, 0x7a, 0x29, 0xac, 0x09, 0x0e, 0xc1, 0x7e }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 60 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0x3c, 0x15, 0xbf, 0xc1, 0x1a, 0x95, 0x37, 0xc1, 0x30, 0x68, 0x70, 0x04, 0xe1, 0x36, 0xee }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 61 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x22, 0xc0, 0xa7, 0x67, 0x8d, 0xc6, 0xd8, 0xcf, 0x5c, 0x8a, 0x6d, 0x5a, 0x99, 0x60, 0x76, 0x7c }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 62 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb4, 0x6b, 0x09, 0x80, 0x9d, 0x68, 0xb9, 0xa4, 0x56, 0x43, 0x2a, 0x79, 0xbd, 0xc2, 0xe3, 0x8c }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 63 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x93, 0xba, 0xaf, 0xfb, 0x35, 0xfb, 0xe7, 0x39, 0xc1, 0x7c, 0x6a, 0xc2, 0x2e, 0xec, 0xf1, 0x8f }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 64 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc8, 0xaa, 0x80, 0xa7, 0x85, 0x06, 0x75, 0xbc, 0x00, 0x7c, 0x46, 0xdf, 0x06, 0xb4, 0x98, 0x68 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 65 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x12, 0xc6, 0xf3, 0x87, 0x7a, 0xf4, 0x21, 0xa9, 0x18, 0xa8, 0x4b, 0x77, 0x58, 0x58, 0x02, 0x1d }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 66 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x33, 0xf1, 0x23, 0x28, 0x2c, 0x5d, 0x63, 0x39, 0x24, 0xf7, 0xd5, 0xba, 0x3f, 0x3c, 0xab, 0x11 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 67 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa8, 0xf1, 0x61, 0x00, 0x27, 0x33, 0xe9, 0x3c, 0xa4, 0x52, 0x7d, 0x22, 0xc1, 0xa0, 0xc5, 0xbb }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 68 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb7, 0x2f, 0x70, 0xeb, 0xf3, 0xe3, 0xfd, 0xa2, 0x3f, 0x50, 0x8e, 0xec, 0x76, 0xb4, 0x2c, 0x02 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 69 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6a, 0x9d, 0x96, 0x5e, 0x62, 0x74, 0x14, 0x3f, 0x25, 0xaf, 0xdc, 0xfc, 0x88, 0xff, 0xd7, 0x7c }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 70 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa0, 0xc7, 0x4f, 0xd0, 0xb9, 0x36, 0x17, 0x64, 0xce, 0x91, 0xc5, 0x20, 0x0b, 0x09, 0x53, 0x57 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 71 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x09, 0x1d, 0x1f, 0xdc, 0x2b, 0xd2, 0xc3, 0x46, 0xcd, 0x50, 0x46, 0xa8, 0xc6, 0x20, 0x91, 0x46 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 72 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe2, 0xa3, 0x75, 0x80, 0x11, 0x6c, 0xfb, 0x71, 0x85, 0x62, 0x54, 0x49, 0x6a, 0xb0, 0xac, 0xa8 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 73 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe0, 0xb3, 0xa0, 0x07, 0x85, 0x91, 0x7c, 0x7e, 0xfc, 0x9a, 0xdb, 0xa3, 0x22, 0x81, 0x35, 0x71 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 74 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x73, 0x3d, 0x41, 0xf4, 0x72, 0x7b, 0x5e, 0xf0, 0xdf, 0x4a, 0xf4, 0xcf, 0x3c, 0xff, 0xa0, 0xcb }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 75 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa9, 0x9e, 0xbb, 0x03, 0x02, 0x60, 0x82, 0x6f, 0x98, 0x1a, 0xd3, 0xe6, 0x44, 0x90, 0xaa, 0x4f }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 76 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x73, 0xf3, 0x4c, 0x7d, 0x3e, 0xae, 0x5e, 0x80, 0x08, 0x2c, 0x16, 0x47, 0x52, 0x43, 0x08, 0xee }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 77 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x40, 0xeb, 0xd5, 0xad, 0x08, 0x23, 0x45, 0xb7, 0xa2, 0x09, 0x7c, 0xcd, 0x34, 0x64, 0xda, 0x02 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 78 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7c, 0xc4, 0xae, 0x9a, 0x42, 0x4b, 0x2c, 0xec, 0x90, 0xc9, 0x71, 0x53, 0xc2, 0x45, 0x7e, 0xc5 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 79 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x54, 0xd6, 0x32, 0xd0, 0x3a, 0xba, 0x0b, 0xd0, 0xf9, 0x18, 0x77, 0xeb, 0xdd, 0x4d, 0x09, 0xcb }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 80 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd3, 0x42, 0x7b, 0xe7, 0xe4, 0xd2, 0x7c, 0xd5, 0x4f, 0x5f, 0xe3, 0x7b, 0x03, 0xcf, 0x08, 0x97 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 81 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb2, 0x09, 0x97, 0x95, 0xe8, 0x8c, 0xc1, 0x58, 0xfd, 0x75, 0xea, 0x13, 0x3d, 0x7e, 0x7f, 0xbe }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 82 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa6, 0xca, 0xe4, 0x6f, 0xb6, 0xfa, 0xdf, 0xe7, 0xa2, 0xc3, 0x02, 0xa3, 0x42, 0x42, 0x81, 0x7b }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 83 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x02, 0x6a, 0x70, 0x24, 0xd6, 0xa9, 0x02, 0xe0, 0xb3, 0xff, 0xcc, 0xba, 0xa9, 0x10, 0xcc, 0x3f }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 84 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x15, 0x6f, 0x07, 0x76, 0x7a, 0x85, 0xa4, 0x31, 0x23, 0x21, 0xf6, 0x39, 0x68, 0x33, 0x8a, 0x01 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 85 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x15, 0xee, 0xc9, 0xeb, 0xf4, 0x2b, 0x9c, 0xa7, 0x68, 0x97, 0xd2, 0xcd, 0x6c, 0x5a, 0x12, 0xe2 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 86 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdb, 0x0d, 0x3a, 0x6f, 0xdc, 0xc1, 0x3f, 0x91, 0x5e, 0x2b, 0x30, 0x2c, 0xee, 0xb7, 0x0f, 0xd8 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 87 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x71, 0xdb, 0xf3, 0x7e, 0x87, 0xa2, 0xe3, 0x4d, 0x15, 0xb2, 0x0e, 0x8f, 0x10, 0xe4, 0x89, 0x24 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 88 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc7, 0x45, 0xc4, 0x51, 0xe9, 0x6f, 0xf3, 0xc0, 0x45, 0xe4, 0x36, 0x7c, 0x83, 0x3e, 0x3b, 0x54 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 89 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x34, 0x0d, 0xa0, 0x9c, 0x2d, 0xd1, 0x1c, 0x3b, 0x67, 0x9d, 0x08, 0xcc, 0xd2, 0x7d, 0xd5, 0x95 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 90 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x82, 0x79, 0xf7, 0xc0, 0xc2, 0xa0, 0x3e, 0xe6, 0x60, 0xc6, 0xd3, 0x92, 0xdb, 0x02, 0x5d, 0x18 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 91 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa4, 0xb2, 0xc7, 0xd8, 0xeb, 0xa5, 0x31, 0xff, 0x47, 0xc5, 0x04, 0x1a, 0x55, 0xfb, 0xd1, 0xec }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 92 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x74, 0x56, 0x9a, 0x2c, 0xa5, 0xa7, 0xbd, 0x51, 0x31, 0xce, 0x8d, 0xc7, 0xcb, 0xfb, 0xf7, 0x2f }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 93 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x37, 0x13, 0xda, 0x0c, 0x02, 0x19, 0xb6, 0x34, 0x54, 0x03, 0x56, 0x13, 0xb5, 0xa4, 0x03, 0xdd }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 94 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x88, 0x27, 0x55, 0x1d, 0xdc, 0xc9, 0xdf, 0x23, 0xfa, 0x72, 0xa3, 0xde, 0x4e, 0x9f, 0x0b, 0x07 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 95 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2e, 0x3f, 0xeb, 0xfd, 0x62, 0x5b, 0xfc, 0xd0, 0xa2, 0xc0, 0x6e, 0xb4, 0x60, 0xda, 0x17, 0x32 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 96 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 }, 16, { 0xee, 0x82, 0xe6, 0xba, 0x48, 0x81, 0x56, 0xf7, 0x64, 0x96, 0x31, 0x1d, 0xa6, 0x94, 0x1d, 0xeb }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 97 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 }, 16, { 0x47, 0x70, 0x44, 0x6f, 0x01, 0xd1, 0xf3, 0x91, 0x25, 0x6e, 0x85, 0xa1, 0xb3, 0x0d, 0x89, 0xd3 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 98 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 }, 16, { 0xaf, 0x04, 0xb6, 0x8f, 0x10, 0x4f, 0x21, 0xef, 0x2a, 0xfb, 0x47, 0x67, 0xcf, 0x74, 0x14, 0x3c }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 99 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 }, 16, { 0xcf, 0x35, 0x79, 0xa9, 0xba, 0x38, 0xc8, 0xe4, 0x36, 0x53, 0x17, 0x3e, 0x14, 0xf3, 0xa4, 0xc6 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 100 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 }, 16, { 0xb3, 0xbb, 0xa9, 0x04, 0xf4, 0x95, 0x3e, 0x09, 0xb5, 0x48, 0x00, 0xaf, 0x2f, 0x62, 0xe7, 0xd4 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 101 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 }, 16, { 0xfc, 0x42, 0x49, 0x65, 0x6e, 0x14, 0xb2, 0x9e, 0xb9, 0xc4, 0x48, 0x29, 0xb4, 0xc5, 0x9a, 0x46 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 102 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 }, 16, { 0x9b, 0x31, 0x56, 0x8f, 0xeb, 0xe8, 0x1c, 0xfc, 0x2e, 0x65, 0xaf, 0x1c, 0x86, 0xd1, 0xa3, 0x08 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 103 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }, 16, { 0x9c, 0xa0, 0x9c, 0x25, 0xf2, 0x73, 0xa7, 0x66, 0xdb, 0x98, 0xa4, 0x80, 0xce, 0x8d, 0xfe, 0xdc }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 104 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 }, 16, { 0xb9, 0x09, 0x92, 0x57, 0x86, 0xf3, 0x4c, 0x3c, 0x92, 0xd9, 0x71, 0x88, 0x3c, 0x9f, 0xbe, 0xdf }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 105 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 }, 16, { 0x82, 0x64, 0x7f, 0x13, 0x32, 0xfe, 0x57, 0x0a, 0x9d, 0x4d, 0x92, 0xb2, 0xee, 0x77, 0x1d, 0x3b }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 106 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 }, 16, { 0x36, 0x04, 0xa7, 0xe8, 0x08, 0x32, 0xb3, 0xa9, 0x99, 0x54, 0xbc, 0xa6, 0xf5, 0xb9, 0xf5, 0x01 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 107 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 }, 16, { 0x88, 0x46, 0x07, 0xb1, 0x28, 0xc5, 0xde, 0x3a, 0xb3, 0x9a, 0x52, 0x9a, 0x1e, 0xf5, 0x1b, 0xef }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 108 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 }, 16, { 0x67, 0x0c, 0xfa, 0x09, 0x3d, 0x1d, 0xbd, 0xb2, 0x31, 0x70, 0x41, 0x40, 0x41, 0x02, 0x43, 0x5e }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 109 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 }, 16, { 0x7a, 0x86, 0x71, 0x95, 0xf3, 0xce, 0x87, 0x69, 0xcb, 0xd3, 0x36, 0x50, 0x2f, 0xbb, 0x51, 0x30 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 110 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 }, 16, { 0x52, 0xef, 0xcf, 0x64, 0xc7, 0x2b, 0x2f, 0x7c, 0xa5, 0xb3, 0xc8, 0x36, 0xb1, 0x07, 0x8c, 0x15 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 111 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 }, 16, { 0x40, 0x19, 0x25, 0x0f, 0x6e, 0xef, 0xb2, 0xac, 0x5c, 0xcb, 0xca, 0xe0, 0x44, 0xe7, 0x5c, 0x7e }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 112 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 }, 16, { 0x02, 0x2c, 0x4f, 0x6f, 0x5a, 0x01, 0x7d, 0x29, 0x27, 0x85, 0x62, 0x76, 0x67, 0xdd, 0xef, 0x24 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 113 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 }, 16, { 0xe9, 0xc2, 0x10, 0x78, 0xa2, 0xeb, 0x7e, 0x03, 0x25, 0x0f, 0x71, 0x00, 0x0f, 0xa9, 0xe3, 0xed }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 114 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 }, 16, { 0xa1, 0x3e, 0xae, 0xeb, 0x9c, 0xd3, 0x91, 0xda, 0x4e, 0x2b, 0x09, 0x49, 0x0b, 0x3e, 0x7f, 0xad }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 115 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 }, 16, { 0xc9, 0x58, 0xa1, 0x71, 0xdc, 0xa1, 0xd4, 0xed, 0x53, 0xe1, 0xaf, 0x1d, 0x38, 0x08, 0x03, 0xa9 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 116 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 }, 16, { 0x21, 0x44, 0x2e, 0x07, 0xa1, 0x10, 0x66, 0x7f, 0x25, 0x83, 0xea, 0xee, 0xee, 0x44, 0xdc, 0x8c }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 117 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 }, 16, { 0x59, 0xbb, 0xb3, 0x53, 0xcf, 0x1d, 0xd8, 0x67, 0xa6, 0xe3, 0x37, 0x37, 0xaf, 0x65, 0x5e, 0x99 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 118 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 }, 16, { 0x43, 0xcd, 0x3b, 0x25, 0x37, 0x5d, 0x0c, 0xe4, 0x10, 0x87, 0xff, 0x9f, 0xe2, 0x82, 0x96, 0x39 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 119 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 }, 16, { 0x6b, 0x98, 0xb1, 0x7e, 0x80, 0xd1, 0x11, 0x8e, 0x35, 0x16, 0xbd, 0x76, 0x8b, 0x28, 0x5a, 0x84 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 120 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 }, 16, { 0xae, 0x47, 0xed, 0x36, 0x76, 0xca, 0x0c, 0x08, 0xde, 0xea, 0x02, 0xd9, 0x5b, 0x81, 0xdb, 0x58 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 121 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 }, 16, { 0x34, 0xec, 0x40, 0xdc, 0x20, 0x41, 0x37, 0x95, 0xed, 0x53, 0x62, 0x8e, 0xa7, 0x48, 0x72, 0x0b }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 122 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 }, 16, { 0x4d, 0xc6, 0x81, 0x63, 0xf8, 0xe9, 0x83, 0x54, 0x73, 0x25, 0x35, 0x42, 0xc8, 0xa6, 0x5d, 0x46 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 123 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 }, 16, { 0x2a, 0xab, 0xb9, 0x99, 0xf4, 0x36, 0x93, 0x17, 0x5a, 0xf6, 0x5c, 0x6c, 0x61, 0x2c, 0x46, 0xfb }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 124 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 }, 16, { 0xe0, 0x1f, 0x94, 0x49, 0x9d, 0xac, 0x35, 0x47, 0x51, 0x5c, 0x5b, 0x1d, 0x75, 0x6f, 0x0f, 0x58 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 125 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc }, 16, { 0x9d, 0x12, 0x43, 0x5a, 0x46, 0x48, 0x0c, 0xe0, 0x0e, 0xa3, 0x49, 0xf7, 0x17, 0x99, 0xdf, 0x9a }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 126 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe }, 16, { 0xce, 0xf4, 0x1d, 0x16, 0xd2, 0x66, 0xbd, 0xfe, 0x46, 0x93, 0x8a, 0xd7, 0x88, 0x4c, 0xc0, 0xcf }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 127 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }, 16, { 0xb1, 0x3d, 0xb4, 0xda, 0x1f, 0x71, 0x8b, 0xc6, 0x90, 0x47, 0x97, 0xc8, 0x2b, 0xcf, 0x2d, 0x32 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 0 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6c, 0xd0, 0x25, 0x13, 0xe8, 0xd4, 0xdc, 0x98, 0x6b, 0x4a, 0xfe, 0x08, 0x7a, 0x60, 0xbd, 0x0c }, 16, { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 1 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2c, 0xe1, 0xf8, 0xb7, 0xe3, 0x06, 0x27, 0xc1, 0xc4, 0x51, 0x9e, 0xad, 0xa4, 0x4b, 0xc4, 0x36 }, 16, { 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 2 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x99, 0x46, 0xb5, 0xf8, 0x7a, 0xf4, 0x46, 0xf5, 0x79, 0x6c, 0x1f, 0xee, 0x63, 0xa2, 0xda, 0x24 }, 16, { 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 3 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2a, 0x56, 0x03, 0x64, 0xce, 0x52, 0x9e, 0xfc, 0x21, 0x78, 0x87, 0x79, 0x56, 0x8d, 0x55, 0x55 }, 16, { 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 4 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x35, 0xc1, 0x47, 0x18, 0x37, 0xaf, 0x44, 0x61, 0x53, 0xbc, 0xe5, 0x5d, 0x5b, 0xa7, 0x2a, 0x0a }, 16, { 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 5 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xce, 0x60, 0xbc, 0x52, 0x38, 0x62, 0x34, 0xf1, 0x58, 0xf8, 0x43, 0x41, 0xe5, 0x34, 0xcd, 0x9e }, 16, { 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 6 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8c, 0x7c, 0x27, 0xff, 0x32, 0xbc, 0xf8, 0xdc, 0x2d, 0xc5, 0x7c, 0x90, 0xc2, 0x90, 0x39, 0x61 }, 16, { 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 7 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x32, 0xbb, 0x6a, 0x7e, 0xc8, 0x44, 0x99, 0xe1, 0x66, 0xf9, 0x36, 0x00, 0x3d, 0x55, 0xa5, 0xbb }, 16, { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 8 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa5, 0xc7, 0x72, 0xe5, 0xc6, 0x26, 0x31, 0xef, 0x66, 0x0e, 0xe1, 0xd5, 0x87, 0x7f, 0x6d, 0x1b }, 16, { 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 9 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x03, 0x0d, 0x7e, 0x5b, 0x64, 0xf3, 0x80, 0xa7, 0xe4, 0xea, 0x53, 0x87, 0xb5, 0xcd, 0x7f, 0x49 }, 16, { 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 10 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0d, 0xc9, 0xa2, 0x61, 0x00, 0x37, 0x00, 0x9b, 0x69, 0x8f, 0x11, 0xbb, 0x7e, 0x86, 0xc8, 0x3e }, 16, { 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 11 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x46, 0x61, 0x2c, 0x76, 0x6d, 0x18, 0x40, 0xc2, 0x26, 0x36, 0x4f, 0x1f, 0xa7, 0xed, 0x72 }, 16, { 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 12 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x48, 0x80, 0xc7, 0xe0, 0x8f, 0x27, 0xbe, 0xfe, 0x78, 0x59, 0x07, 0x43, 0xc0, 0x5e, 0x69, 0x8b }, 16, { 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 13 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x25, 0x20, 0xce, 0x82, 0x9a, 0x26, 0x57, 0x7f, 0x0f, 0x48, 0x22, 0xc4, 0xec, 0xc8, 0x74, 0x01 }, 16, { 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 14 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x87, 0x65, 0xe8, 0xac, 0xc1, 0x69, 0x75, 0x83, 0x19, 0xcb, 0x46, 0xdc, 0x7b, 0xcf, 0x3d, 0xca }, 16, { 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 15 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe9, 0x8f, 0x4b, 0xa4, 0xf0, 0x73, 0xdf, 0x4b, 0xaa, 0x11, 0x6d, 0x01, 0x1d, 0xc2, 0x4a, 0x28 }, 16, { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 16 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf3, 0x78, 0xf6, 0x8c, 0x5d, 0xbf, 0x59, 0xe2, 0x11, 0xb3, 0xa6, 0x59, 0xa7, 0x31, 0x7d, 0x94 }, 16, { 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 17 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x28, 0x3d, 0x3b, 0x06, 0x9d, 0x8e, 0xb9, 0xfb, 0x43, 0x2d, 0x74, 0xb9, 0x6c, 0xa7, 0x62, 0xb4 }, 16, { 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 18 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa7, 0xe1, 0x84, 0x2e, 0x8a, 0x87, 0x86, 0x1c, 0x22, 0x1a, 0x50, 0x08, 0x83, 0x24, 0x5c, 0x51 }, 16, { 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 19 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x77, 0xaa, 0x27, 0x04, 0x71, 0x88, 0x1b, 0xe0, 0x70, 0xfb, 0x52, 0xc7, 0x06, 0x7c, 0xe7, 0x32 }, 16, { 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 20 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x01, 0xb0, 0xf4, 0x76, 0xd4, 0x84, 0xf4, 0x3f, 0x1a, 0xeb, 0x6e, 0xfa, 0x93, 0x61, 0xa8, 0xac }, 16, { 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 21 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1c, 0x3a, 0x94, 0xf1, 0xc0, 0x52, 0xc5, 0x5c, 0x2d, 0x83, 0x59, 0xaf, 0xf2, 0x16, 0x3b, 0x4f }, 16, { 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 22 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe8, 0xa0, 0x67, 0xb6, 0x04, 0xd5, 0x37, 0x3d, 0x8b, 0x0f, 0x2e, 0x05, 0xa0, 0x3b, 0x34, 0x1b }, 16, { 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 23 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa7, 0x87, 0x6e, 0xc8, 0x7f, 0x5a, 0x09, 0xbf, 0xea, 0x42, 0xc7, 0x7d, 0xa3, 0x0f, 0xd5, 0x0e }, 16, { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 24 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0c, 0xf3, 0xe9, 0xd3, 0xa4, 0x2b, 0xe5, 0xb8, 0x54, 0xca, 0x65, 0xb1, 0x3f, 0x35, 0xf4, 0x8d }, 16, { 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 25 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6c, 0x62, 0xf6, 0xbb, 0xca, 0xb7, 0xc3, 0xe8, 0x21, 0xc9, 0x29, 0x0f, 0x08, 0x89, 0x2d, 0xda }, 16, { 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 26 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7f, 0x5e, 0x05, 0xbd, 0x20, 0x68, 0x73, 0x81, 0x96, 0xfe, 0xe7, 0x9a, 0xce, 0x7e, 0x3a, 0xec }, 16, { 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 27 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x44, 0x0e, 0x0d, 0x73, 0x32, 0x55, 0xcd, 0xa9, 0x2f, 0xb4, 0x6e, 0x84, 0x2f, 0xe5, 0x80, 0x54 }, 16, { 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 28 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xaa, 0x5d, 0x5b, 0x1c, 0x4e, 0xa1, 0xb7, 0xa2, 0x2e, 0x55, 0x83, 0xac, 0x2e, 0x9e, 0xd8, 0xa7 }, 16, { 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 29 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x77, 0xe5, 0x37, 0xe8, 0x9e, 0x84, 0x91, 0xe8, 0x66, 0x2a, 0xae, 0x3b, 0xc8, 0x09, 0x42, 0x1d }, 16, { 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 30 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x99, 0x7d, 0xd3, 0xe9, 0xf1, 0x59, 0x8b, 0xfa, 0x73, 0xf7, 0x59, 0x73, 0xf7, 0xe9, 0x3b, 0x76 }, 16, { 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 31 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0x38, 0xd4, 0xf7, 0x45, 0x2a, 0xfe, 0xfc, 0xb7, 0xfc, 0x72, 0x12, 0x44, 0xe4, 0xb7, 0x2e }, 16, { 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 32 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0b, 0xe2, 0xb1, 0x82, 0x52, 0xe7, 0x74, 0xdd, 0xa3, 0x0c, 0xdd, 0xa0, 0x2c, 0x69, 0x06, 0xe3 }, 16, { 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 33 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd2, 0x69, 0x5e, 0x59, 0xc2, 0x03, 0x61, 0xd8, 0x26, 0x52, 0xd7, 0xd5, 0x8b, 0x6f, 0x11, 0xb2 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 34 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0x2d, 0x88, 0xd1, 0x3e, 0xae, 0x52, 0x08, 0x9a, 0xbd, 0x61, 0x43, 0xcf, 0xe3, 0x94, 0xe9 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 35 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd4, 0x9b, 0xce, 0xb3, 0xb8, 0x23, 0xfe, 0xdd, 0x60, 0x2c, 0x30, 0x53, 0x45, 0x73, 0x4b, 0xd2 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 36 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x70, 0x7b, 0x1d, 0xbb, 0x0f, 0xfa, 0x40, 0xef, 0x7d, 0x95, 0xde, 0xf4, 0x21, 0x23, 0x3f, 0xae }, 16, { 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 37 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7c, 0xa0, 0xc1, 0xd9, 0x33, 0x56, 0xd9, 0xeb, 0x8a, 0xa9, 0x52, 0x08, 0x4d, 0x75, 0xf9, 0x13 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 38 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf2, 0xcb, 0xf9, 0xcb, 0x18, 0x6e, 0x27, 0x0d, 0xd7, 0xbd, 0xb0, 0xc2, 0x8f, 0xeb, 0xc5, 0x7d }, 16, { 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 39 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc9, 0x43, 0x37, 0xc3, 0x7c, 0x4e, 0x79, 0x0a, 0xb4, 0x57, 0x80, 0xbd, 0x9c, 0x36, 0x74, 0xa0 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 40 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8e, 0x35, 0x58, 0xc1, 0x35, 0x25, 0x2f, 0xb9, 0xc9, 0xf3, 0x67, 0xed, 0x60, 0x94, 0x67, 0xa1 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 41 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1b, 0x72, 0xee, 0xae, 0xe4, 0x89, 0x9b, 0x44, 0x39, 0x14, 0xe5, 0xb3, 0xa5, 0x7f, 0xba, 0x92 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 42 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x01, 0x18, 0x65, 0xf9, 0x1b, 0xc5, 0x68, 0x68, 0xd0, 0x51, 0xe5, 0x2c, 0x9e, 0xfd, 0x59, 0xb7 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 43 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe4, 0x77, 0x13, 0x18, 0xad, 0x7a, 0x63, 0xdd, 0x68, 0x0f, 0x6e, 0x58, 0x3b, 0x77, 0x47, 0xea }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 44 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x61, 0xe3, 0xd1, 0x94, 0x08, 0x8d, 0xc8, 0xd9, 0x7e, 0x9e, 0x6d, 0xb3, 0x74, 0x57, 0xea, 0xc5 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 45 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x36, 0xff, 0x1e, 0xc9, 0xcc, 0xfb, 0xc3, 0x49, 0xe5, 0xd3, 0x56, 0xd0, 0x63, 0x69, 0x3a, 0xd6 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 46 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3c, 0xc9, 0xe9, 0xa9, 0xbe, 0x8c, 0xc3, 0xf6, 0xfb, 0x2e, 0xa2, 0x40, 0x88, 0xe9, 0xbb, 0x19 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 47 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1e, 0xe5, 0xab, 0x00, 0x3d, 0xc8, 0x72, 0x2e, 0x74, 0x90, 0x5d, 0x9a, 0x8f, 0xe3, 0xd3, 0x50 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 48 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x24, 0x53, 0x39, 0x31, 0x95, 0x84, 0xb0, 0xa4, 0x12, 0x41, 0x28, 0x69, 0xd6, 0xc2, 0xea, 0xda }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 49 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7b, 0xd4, 0x96, 0x91, 0x81, 0x15, 0xd1, 0x4e, 0xd5, 0x38, 0x08, 0x52, 0x71, 0x6c, 0x88, 0x14 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 50 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0x3a, 0xb2, 0xf2, 0xb4, 0xa3, 0x66, 0xa5, 0x7d, 0x58, 0x2a, 0x33, 0x93, 0x13, 0xc8, 0xb1 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 51 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0x33, 0x65, 0xa9, 0xff, 0xbe, 0x3b, 0x0c, 0xa6, 0x1e, 0x98, 0x50, 0x75, 0x54, 0x16, 0x8b }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 52 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xaf, 0xa9, 0x9c, 0x99, 0x7a, 0xc4, 0x78, 0xa0, 0xde, 0xa4, 0x11, 0x9c, 0x9e, 0x45, 0xf8, 0xb1 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 53 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x92, 0x16, 0x30, 0x9a, 0x78, 0x42, 0x43, 0x0b, 0x83, 0xff, 0xb9, 0x86, 0x38, 0x01, 0x15, 0x12 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 54 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x62, 0xab, 0xc7, 0x92, 0x28, 0x82, 0x58, 0x49, 0x2a, 0x7c, 0xb4, 0x51, 0x45, 0xf4, 0xb7, 0x59 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 55 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x53, 0x49, 0x23, 0xc1, 0x69, 0xd5, 0x04, 0xd7, 0x51, 0x9c, 0x15, 0xd3, 0x0e, 0x75, 0x6c, 0x50 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 56 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfa, 0x75, 0xe0, 0x5b, 0xcd, 0xc7, 0xe0, 0x0c, 0x27, 0x3f, 0xa3, 0x3f, 0x6e, 0xe4, 0x41, 0xd2 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 57 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7d, 0x35, 0x0f, 0xa6, 0x05, 0x70, 0x80, 0xf1, 0x08, 0x6a, 0x56, 0xb1, 0x7e, 0xc2, 0x40, 0xdb }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 58 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf3, 0x4e, 0x4a, 0x63, 0x24, 0xea, 0x4a, 0x5c, 0x39, 0xa6, 0x61, 0xc8, 0xfe, 0x5a, 0xda, 0x8f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 59 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x08, 0x82, 0xa1, 0x6f, 0x44, 0x08, 0x8d, 0x42, 0x44, 0x7a, 0x29, 0xac, 0x09, 0x0e, 0xc1, 0x7e }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 60 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3a, 0x3c, 0x15, 0xbf, 0xc1, 0x1a, 0x95, 0x37, 0xc1, 0x30, 0x68, 0x70, 0x04, 0xe1, 0x36, 0xee }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 61 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x22, 0xc0, 0xa7, 0x67, 0x8d, 0xc6, 0xd8, 0xcf, 0x5c, 0x8a, 0x6d, 0x5a, 0x99, 0x60, 0x76, 0x7c }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 62 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb4, 0x6b, 0x09, 0x80, 0x9d, 0x68, 0xb9, 0xa4, 0x56, 0x43, 0x2a, 0x79, 0xbd, 0xc2, 0xe3, 0x8c }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 63 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x93, 0xba, 0xaf, 0xfb, 0x35, 0xfb, 0xe7, 0x39, 0xc1, 0x7c, 0x6a, 0xc2, 0x2e, 0xec, 0xf1, 0x8f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 64 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc8, 0xaa, 0x80, 0xa7, 0x85, 0x06, 0x75, 0xbc, 0x00, 0x7c, 0x46, 0xdf, 0x06, 0xb4, 0x98, 0x68 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 65 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x12, 0xc6, 0xf3, 0x87, 0x7a, 0xf4, 0x21, 0xa9, 0x18, 0xa8, 0x4b, 0x77, 0x58, 0x58, 0x02, 0x1d }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 66 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x33, 0xf1, 0x23, 0x28, 0x2c, 0x5d, 0x63, 0x39, 0x24, 0xf7, 0xd5, 0xba, 0x3f, 0x3c, 0xab, 0x11 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 67 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa8, 0xf1, 0x61, 0x00, 0x27, 0x33, 0xe9, 0x3c, 0xa4, 0x52, 0x7d, 0x22, 0xc1, 0xa0, 0xc5, 0xbb }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 68 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb7, 0x2f, 0x70, 0xeb, 0xf3, 0xe3, 0xfd, 0xa2, 0x3f, 0x50, 0x8e, 0xec, 0x76, 0xb4, 0x2c, 0x02 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 69 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6a, 0x9d, 0x96, 0x5e, 0x62, 0x74, 0x14, 0x3f, 0x25, 0xaf, 0xdc, 0xfc, 0x88, 0xff, 0xd7, 0x7c }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 70 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa0, 0xc7, 0x4f, 0xd0, 0xb9, 0x36, 0x17, 0x64, 0xce, 0x91, 0xc5, 0x20, 0x0b, 0x09, 0x53, 0x57 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 71 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x09, 0x1d, 0x1f, 0xdc, 0x2b, 0xd2, 0xc3, 0x46, 0xcd, 0x50, 0x46, 0xa8, 0xc6, 0x20, 0x91, 0x46 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 72 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe2, 0xa3, 0x75, 0x80, 0x11, 0x6c, 0xfb, 0x71, 0x85, 0x62, 0x54, 0x49, 0x6a, 0xb0, 0xac, 0xa8 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 73 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe0, 0xb3, 0xa0, 0x07, 0x85, 0x91, 0x7c, 0x7e, 0xfc, 0x9a, 0xdb, 0xa3, 0x22, 0x81, 0x35, 0x71 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 74 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x73, 0x3d, 0x41, 0xf4, 0x72, 0x7b, 0x5e, 0xf0, 0xdf, 0x4a, 0xf4, 0xcf, 0x3c, 0xff, 0xa0, 0xcb }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 75 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa9, 0x9e, 0xbb, 0x03, 0x02, 0x60, 0x82, 0x6f, 0x98, 0x1a, 0xd3, 0xe6, 0x44, 0x90, 0xaa, 0x4f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 76 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x73, 0xf3, 0x4c, 0x7d, 0x3e, 0xae, 0x5e, 0x80, 0x08, 0x2c, 0x16, 0x47, 0x52, 0x43, 0x08, 0xee }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 77 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x40, 0xeb, 0xd5, 0xad, 0x08, 0x23, 0x45, 0xb7, 0xa2, 0x09, 0x7c, 0xcd, 0x34, 0x64, 0xda, 0x02 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 78 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7c, 0xc4, 0xae, 0x9a, 0x42, 0x4b, 0x2c, 0xec, 0x90, 0xc9, 0x71, 0x53, 0xc2, 0x45, 0x7e, 0xc5 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 79 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x54, 0xd6, 0x32, 0xd0, 0x3a, 0xba, 0x0b, 0xd0, 0xf9, 0x18, 0x77, 0xeb, 0xdd, 0x4d, 0x09, 0xcb }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 80 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd3, 0x42, 0x7b, 0xe7, 0xe4, 0xd2, 0x7c, 0xd5, 0x4f, 0x5f, 0xe3, 0x7b, 0x03, 0xcf, 0x08, 0x97 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 81 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb2, 0x09, 0x97, 0x95, 0xe8, 0x8c, 0xc1, 0x58, 0xfd, 0x75, 0xea, 0x13, 0x3d, 0x7e, 0x7f, 0xbe }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 82 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa6, 0xca, 0xe4, 0x6f, 0xb6, 0xfa, 0xdf, 0xe7, 0xa2, 0xc3, 0x02, 0xa3, 0x42, 0x42, 0x81, 0x7b }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 83 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x02, 0x6a, 0x70, 0x24, 0xd6, 0xa9, 0x02, 0xe0, 0xb3, 0xff, 0xcc, 0xba, 0xa9, 0x10, 0xcc, 0x3f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 84 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x15, 0x6f, 0x07, 0x76, 0x7a, 0x85, 0xa4, 0x31, 0x23, 0x21, 0xf6, 0x39, 0x68, 0x33, 0x8a, 0x01 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 85 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x15, 0xee, 0xc9, 0xeb, 0xf4, 0x2b, 0x9c, 0xa7, 0x68, 0x97, 0xd2, 0xcd, 0x6c, 0x5a, 0x12, 0xe2 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 86 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdb, 0x0d, 0x3a, 0x6f, 0xdc, 0xc1, 0x3f, 0x91, 0x5e, 0x2b, 0x30, 0x2c, 0xee, 0xb7, 0x0f, 0xd8 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 87 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x71, 0xdb, 0xf3, 0x7e, 0x87, 0xa2, 0xe3, 0x4d, 0x15, 0xb2, 0x0e, 0x8f, 0x10, 0xe4, 0x89, 0x24 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 88 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc7, 0x45, 0xc4, 0x51, 0xe9, 0x6f, 0xf3, 0xc0, 0x45, 0xe4, 0x36, 0x7c, 0x83, 0x3e, 0x3b, 0x54 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 89 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x34, 0x0d, 0xa0, 0x9c, 0x2d, 0xd1, 0x1c, 0x3b, 0x67, 0x9d, 0x08, 0xcc, 0xd2, 0x7d, 0xd5, 0x95 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 90 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x82, 0x79, 0xf7, 0xc0, 0xc2, 0xa0, 0x3e, 0xe6, 0x60, 0xc6, 0xd3, 0x92, 0xdb, 0x02, 0x5d, 0x18 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 91 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa4, 0xb2, 0xc7, 0xd8, 0xeb, 0xa5, 0x31, 0xff, 0x47, 0xc5, 0x04, 0x1a, 0x55, 0xfb, 0xd1, 0xec }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 92 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x74, 0x56, 0x9a, 0x2c, 0xa5, 0xa7, 0xbd, 0x51, 0x31, 0xce, 0x8d, 0xc7, 0xcb, 0xfb, 0xf7, 0x2f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 93 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x37, 0x13, 0xda, 0x0c, 0x02, 0x19, 0xb6, 0x34, 0x54, 0x03, 0x56, 0x13, 0xb5, 0xa4, 0x03, 0xdd }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 94 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x88, 0x27, 0x55, 0x1d, 0xdc, 0xc9, 0xdf, 0x23, 0xfa, 0x72, 0xa3, 0xde, 0x4e, 0x9f, 0x0b, 0x07 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 95 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2e, 0x3f, 0xeb, 0xfd, 0x62, 0x5b, 0xfc, 0xd0, 0xa2, 0xc0, 0x6e, 0xb4, 0x60, 0xda, 0x17, 0x32 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 96 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xee, 0x82, 0xe6, 0xba, 0x48, 0x81, 0x56, 0xf7, 0x64, 0x96, 0x31, 0x1d, 0xa6, 0x94, 0x1d, 0xeb }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 97 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x47, 0x70, 0x44, 0x6f, 0x01, 0xd1, 0xf3, 0x91, 0x25, 0x6e, 0x85, 0xa1, 0xb3, 0x0d, 0x89, 0xd3 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 98 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xaf, 0x04, 0xb6, 0x8f, 0x10, 0x4f, 0x21, 0xef, 0x2a, 0xfb, 0x47, 0x67, 0xcf, 0x74, 0x14, 0x3c }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 99 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcf, 0x35, 0x79, 0xa9, 0xba, 0x38, 0xc8, 0xe4, 0x36, 0x53, 0x17, 0x3e, 0x14, 0xf3, 0xa4, 0xc6 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 100 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb3, 0xbb, 0xa9, 0x04, 0xf4, 0x95, 0x3e, 0x09, 0xb5, 0x48, 0x00, 0xaf, 0x2f, 0x62, 0xe7, 0xd4 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 101 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfc, 0x42, 0x49, 0x65, 0x6e, 0x14, 0xb2, 0x9e, 0xb9, 0xc4, 0x48, 0x29, 0xb4, 0xc5, 0x9a, 0x46 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 102 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9b, 0x31, 0x56, 0x8f, 0xeb, 0xe8, 0x1c, 0xfc, 0x2e, 0x65, 0xaf, 0x1c, 0x86, 0xd1, 0xa3, 0x08 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 103 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9c, 0xa0, 0x9c, 0x25, 0xf2, 0x73, 0xa7, 0x66, 0xdb, 0x98, 0xa4, 0x80, 0xce, 0x8d, 0xfe, 0xdc }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 104 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb9, 0x09, 0x92, 0x57, 0x86, 0xf3, 0x4c, 0x3c, 0x92, 0xd9, 0x71, 0x88, 0x3c, 0x9f, 0xbe, 0xdf }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 105 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x82, 0x64, 0x7f, 0x13, 0x32, 0xfe, 0x57, 0x0a, 0x9d, 0x4d, 0x92, 0xb2, 0xee, 0x77, 0x1d, 0x3b }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 106 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x36, 0x04, 0xa7, 0xe8, 0x08, 0x32, 0xb3, 0xa9, 0x99, 0x54, 0xbc, 0xa6, 0xf5, 0xb9, 0xf5, 0x01 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 107 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x88, 0x46, 0x07, 0xb1, 0x28, 0xc5, 0xde, 0x3a, 0xb3, 0x9a, 0x52, 0x9a, 0x1e, 0xf5, 0x1b, 0xef }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 108 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x67, 0x0c, 0xfa, 0x09, 0x3d, 0x1d, 0xbd, 0xb2, 0x31, 0x70, 0x41, 0x40, 0x41, 0x02, 0x43, 0x5e }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 109 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7a, 0x86, 0x71, 0x95, 0xf3, 0xce, 0x87, 0x69, 0xcb, 0xd3, 0x36, 0x50, 0x2f, 0xbb, 0x51, 0x30 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 110 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x52, 0xef, 0xcf, 0x64, 0xc7, 0x2b, 0x2f, 0x7c, 0xa5, 0xb3, 0xc8, 0x36, 0xb1, 0x07, 0x8c, 0x15 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 111 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x40, 0x19, 0x25, 0x0f, 0x6e, 0xef, 0xb2, 0xac, 0x5c, 0xcb, 0xca, 0xe0, 0x44, 0xe7, 0x5c, 0x7e }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 112 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x02, 0x2c, 0x4f, 0x6f, 0x5a, 0x01, 0x7d, 0x29, 0x27, 0x85, 0x62, 0x76, 0x67, 0xdd, 0xef, 0x24 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 113 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe9, 0xc2, 0x10, 0x78, 0xa2, 0xeb, 0x7e, 0x03, 0x25, 0x0f, 0x71, 0x00, 0x0f, 0xa9, 0xe3, 0xed }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 114 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa1, 0x3e, 0xae, 0xeb, 0x9c, 0xd3, 0x91, 0xda, 0x4e, 0x2b, 0x09, 0x49, 0x0b, 0x3e, 0x7f, 0xad }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 115 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc9, 0x58, 0xa1, 0x71, 0xdc, 0xa1, 0xd4, 0xed, 0x53, 0xe1, 0xaf, 0x1d, 0x38, 0x08, 0x03, 0xa9 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 116 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x21, 0x44, 0x2e, 0x07, 0xa1, 0x10, 0x66, 0x7f, 0x25, 0x83, 0xea, 0xee, 0xee, 0x44, 0xdc, 0x8c }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 117 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x59, 0xbb, 0xb3, 0x53, 0xcf, 0x1d, 0xd8, 0x67, 0xa6, 0xe3, 0x37, 0x37, 0xaf, 0x65, 0x5e, 0x99 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 118 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x43, 0xcd, 0x3b, 0x25, 0x37, 0x5d, 0x0c, 0xe4, 0x10, 0x87, 0xff, 0x9f, 0xe2, 0x82, 0x96, 0x39 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 119 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6b, 0x98, 0xb1, 0x7e, 0x80, 0xd1, 0x11, 0x8e, 0x35, 0x16, 0xbd, 0x76, 0x8b, 0x28, 0x5a, 0x84 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 120 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xae, 0x47, 0xed, 0x36, 0x76, 0xca, 0x0c, 0x08, 0xde, 0xea, 0x02, 0xd9, 0x5b, 0x81, 0xdb, 0x58 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 121 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x34, 0xec, 0x40, 0xdc, 0x20, 0x41, 0x37, 0x95, 0xed, 0x53, 0x62, 0x8e, 0xa7, 0x48, 0x72, 0x0b }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 122 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4d, 0xc6, 0x81, 0x63, 0xf8, 0xe9, 0x83, 0x54, 0x73, 0x25, 0x35, 0x42, 0xc8, 0xa6, 0x5d, 0x46 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 123 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2a, 0xab, 0xb9, 0x99, 0xf4, 0x36, 0x93, 0x17, 0x5a, 0xf6, 0x5c, 0x6c, 0x61, 0x2c, 0x46, 0xfb }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 124 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe0, 0x1f, 0x94, 0x49, 0x9d, 0xac, 0x35, 0x47, 0x51, 0x5c, 0x5b, 0x1d, 0x75, 0x6f, 0x0f, 0x58 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 125 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9d, 0x12, 0x43, 0x5a, 0x46, 0x48, 0x0c, 0xe0, 0x0e, 0xa3, 0x49, 0xf7, 0x17, 0x99, 0xdf, 0x9a }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 126 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xce, 0xf4, 0x1d, 0x16, 0xd2, 0x66, 0xbd, 0xfe, 0x46, 0x93, 0x8a, 0xd7, 0x88, 0x4c, 0xc0, 0xcf }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe }, 16 }, { "NIST KAT-AES ECBVarTxt192.rsp test vector 127 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 192, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb1, 0x3d, 0xb4, 0xda, 0x1f, 0x71, 0x8b, 0xc6, 0x90, 0x47, 0x97, 0xc8, 0x2b, 0xcf, 0x2d, 0x32 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 0 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdd, 0xc6, 0xbf, 0x79, 0x0c, 0x15, 0x76, 0x0d, 0x8d, 0x9a, 0xeb, 0x6f, 0x9a, 0x75, 0xfd, 0x4e }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 1 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0a, 0x6b, 0xdc, 0x6d, 0x4c, 0x1e, 0x62, 0x80, 0x30, 0x1f, 0xd8, 0xe9, 0x7d, 0xdb, 0xe6, 0x01 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 2 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9b, 0x80, 0xee, 0xfb, 0x7e, 0xbe, 0x2d, 0x2b, 0x16, 0x24, 0x7a, 0xa0, 0xef, 0xc7, 0x2f, 0x5d }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 3 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7f, 0x2c, 0x5e, 0xce, 0x07, 0xa9, 0x8d, 0x8b, 0xee, 0x13, 0xc5, 0x11, 0x77, 0x39, 0x5f, 0xf7 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 4 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x78, 0x18, 0xd8, 0x00, 0xdc, 0xf6, 0xf4, 0xbe, 0x1e, 0x0e, 0x94, 0xf4, 0x03, 0xd1, 0xe4, 0xc2 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 5 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe7, 0x4c, 0xd1, 0xc9, 0x2f, 0x09, 0x19, 0xc3, 0x5a, 0x03, 0x24, 0x12, 0x3d, 0x61, 0x77, 0xd3 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 6 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x80, 0x92, 0xa4, 0xdc, 0xf2, 0xda, 0x7e, 0x77, 0xe9, 0x3b, 0xdd, 0x37, 0x1d, 0xfe, 0xd8, 0x2e }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 7 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x49, 0xaf, 0x6b, 0x37, 0x21, 0x35, 0xac, 0xef, 0x10, 0x13, 0x2e, 0x54, 0x8f, 0x21, 0x7b, 0x17 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 8 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8b, 0xcd, 0x40, 0xf9, 0x4e, 0xbb, 0x63, 0xb9, 0xf7, 0x90, 0x96, 0x76, 0xe6, 0x67, 0xf1, 0xe7 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 9 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfe, 0x1c, 0xff, 0xb8, 0x3f, 0x45, 0xdc, 0xfb, 0x38, 0xb2, 0x9b, 0xe4, 0x38, 0xdb, 0xd3, 0xab }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 10 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0d, 0xc5, 0x8a, 0x8d, 0x88, 0x66, 0x23, 0x70, 0x5a, 0xec, 0x15, 0xcb, 0x1e, 0x70, 0xdc, 0x0e }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 11 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc2, 0x18, 0xfa, 0xa1, 0x60, 0x56, 0xbd, 0x07, 0x74, 0xc3, 0xe8, 0xd7, 0x9c, 0x35, 0xa5, 0xe4 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 12 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x04, 0x7b, 0xba, 0x83, 0xf7, 0xaa, 0x84, 0x17, 0x31, 0x50, 0x4e, 0x01, 0x22, 0x08, 0xfc, 0x9e }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 13 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdc, 0x8f, 0x0e, 0x49, 0x15, 0xfd, 0x81, 0xba, 0x70, 0xa3, 0x31, 0x31, 0x08, 0x82, 0xf6, 0xda }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 14 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x15, 0x69, 0x85, 0x9e, 0xa6, 0xb7, 0x20, 0x6c, 0x30, 0xbf, 0x4f, 0xd0, 0xcb, 0xfa, 0xc3, 0x3c }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 15 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x30, 0x0a, 0xde, 0x92, 0xf8, 0x8f, 0x48, 0xfa, 0x2d, 0xf7, 0x30, 0xec, 0x16, 0xef, 0x44, 0xcd }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 16 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1f, 0xe6, 0xcc, 0x3c, 0x05, 0x96, 0x5d, 0xc0, 0x8e, 0xb0, 0x59, 0x0c, 0x95, 0xac, 0x71, 0xd0 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 17 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x59, 0xe8, 0x58, 0xea, 0xaa, 0x97, 0xfe, 0xc3, 0x81, 0x11, 0x27, 0x5b, 0x6c, 0xf5, 0xab, 0xc0 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 18 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x22, 0x39, 0x45, 0x5e, 0x7a, 0xfe, 0x3b, 0x06, 0x16, 0x10, 0x02, 0x88, 0xcc, 0x5a, 0x72, 0x3b }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 19 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3e, 0xe5, 0x00, 0xc5, 0xc8, 0xd6, 0x34, 0x79, 0x71, 0x71, 0x63, 0xe5, 0x5c, 0x5c, 0x45, 0x22 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 20 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd5, 0xe3, 0x8b, 0xf1, 0x5f, 0x16, 0xd9, 0x0e, 0x3e, 0x21, 0x40, 0x41, 0xd7, 0x74, 0xda, 0xa8 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 21 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb1, 0xf4, 0x06, 0x6e, 0x6f, 0x4f, 0x18, 0x7d, 0xfe, 0x5f, 0x2a, 0xd1, 0xb1, 0x78, 0x19, 0xd0 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 22 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6e, 0xf4, 0xcc, 0x4d, 0xe4, 0x9b, 0x11, 0x06, 0x5d, 0x7a, 0xf2, 0x90, 0x98, 0x54, 0x79, 0x4a }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 23 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xac, 0x86, 0xbc, 0x60, 0x6b, 0x66, 0x40, 0xc3, 0x09, 0xe7, 0x82, 0xf2, 0x32, 0xbf, 0x36, 0x7f }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 24 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x36, 0xaf, 0xf0, 0xef, 0x7b, 0xf3, 0x28, 0x07, 0x72, 0xcf, 0x4c, 0xac, 0x80, 0xa0, 0xd2, 0xb2 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 25 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1f, 0x8e, 0xed, 0xea, 0x0f, 0x62, 0xa1, 0x40, 0x6d, 0x58, 0xcf, 0xc3, 0xec, 0xea, 0x72, 0xcf }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 26 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xab, 0xf4, 0x15, 0x4a, 0x33, 0x75, 0xa1, 0xd3, 0xe6, 0xb1, 0xd4, 0x54, 0x43, 0x8f, 0x95, 0xa6 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 27 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x96, 0xf9, 0x6e, 0x9d, 0x60, 0x7f, 0x66, 0x15, 0xfc, 0x19, 0x20, 0x61, 0xee, 0x64, 0x8b, 0x07 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 28 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcf, 0x37, 0xcd, 0xaa, 0xa0, 0xd2, 0xd5, 0x36, 0xc7, 0x18, 0x57, 0x63, 0x4c, 0x79, 0x20, 0x64 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 29 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfb, 0xd6, 0x64, 0x0c, 0x80, 0x24, 0x5c, 0x2b, 0x80, 0x53, 0x73, 0xf1, 0x30, 0x70, 0x31, 0x27 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 30 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8d, 0x6a, 0x8a, 0xfe, 0x55, 0xa6, 0xe4, 0x81, 0xba, 0xda, 0xe0, 0xd1, 0x46, 0xf4, 0x36, 0xdb }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 31 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6a, 0x49, 0x81, 0xf2, 0x91, 0x5e, 0x3e, 0x68, 0xaf, 0x6c, 0x22, 0x38, 0x5d, 0xd0, 0x67, 0x56 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 32 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x42, 0xa1, 0x13, 0x6e, 0x5f, 0x8d, 0x8d, 0x21, 0xd3, 0x10, 0x19, 0x98, 0x64, 0x2d, 0x57, 0x3b }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 33 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9b, 0x47, 0x15, 0x96, 0xdc, 0x69, 0xae, 0x15, 0x86, 0xce, 0xe6, 0x15, 0x8b, 0x0b, 0x01, 0x81 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 34 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x75, 0x36, 0x65, 0xc4, 0xaf, 0x1e, 0xff, 0x33, 0xaa, 0x8b, 0x62, 0x8b, 0xf8, 0x74, 0x1c, 0xfd }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 35 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9a, 0x68, 0x2a, 0xcf, 0x40, 0xbe, 0x01, 0xf5, 0xb2, 0xa4, 0x19, 0x3c, 0x9a, 0x82, 0x40, 0x4d }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 36 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x54, 0xfa, 0xfe, 0x26, 0xe4, 0x28, 0x7f, 0x17, 0xd1, 0x93, 0x5f, 0x87, 0xeb, 0x9a, 0xde, 0x01 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 37 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x49, 0xd5, 0x41, 0xb2, 0xe7, 0x4c, 0xfe, 0x73, 0xe6, 0xa8, 0xe8, 0x22, 0x5f, 0x7b, 0xd4, 0x49 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 38 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0xa4, 0x55, 0x30, 0xf6, 0x24, 0xff, 0x6f, 0x76, 0xa1, 0xb3, 0x82, 0x66, 0x26, 0xff, 0x7b }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 39 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf9, 0x6b, 0x0c, 0x4a, 0x8b, 0xc6, 0xc8, 0x61, 0x30, 0x28, 0x9f, 0x60, 0xb4, 0x3b, 0x8f, 0xba }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 40 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x48, 0xc7, 0xd0, 0xe8, 0x08, 0x34, 0xeb, 0xdc, 0x35, 0xb6, 0x73, 0x5f, 0x76, 0xb4, 0x6c, 0x8b }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 41 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x24, 0x63, 0x53, 0x1a, 0xb5, 0x4d, 0x66, 0x95, 0x5e, 0x73, 0xed, 0xc4, 0xcb, 0x8e, 0xaa, 0x45 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 42 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xac, 0x9b, 0xd8, 0xe2, 0x53, 0x04, 0x69, 0x13, 0x4b, 0x9d, 0x5b, 0x06, 0x5d, 0x4f, 0x56, 0x5b }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 43 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3f, 0x5f, 0x91, 0x06, 0xd0, 0xe5, 0x2f, 0x97, 0x3d, 0x48, 0x90, 0xe6, 0xf3, 0x7e, 0x8a, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 44 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x20, 0xeb, 0xc8, 0x6f, 0x13, 0x04, 0xd2, 0x72, 0xe2, 0xe2, 0x07, 0xe5, 0x9d, 0xb6, 0x39, 0xf0 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 45 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe6, 0x7a, 0xe6, 0x42, 0x6b, 0xf9, 0x52, 0x6c, 0x97, 0x2c, 0xff, 0x07, 0x2b, 0x52, 0x25, 0x2c }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 46 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1a, 0x51, 0x8d, 0xdd, 0xaf, 0x9e, 0xfa, 0x0d, 0x00, 0x2c, 0xc5, 0x8d, 0x10, 0x7e, 0xdf, 0xc8 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 47 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xea, 0xd7, 0x31, 0xaf, 0x4d, 0x3a, 0x2f, 0xe3, 0xb3, 0x4b, 0xed, 0x04, 0x79, 0x42, 0xa4, 0x9f }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 48 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb1, 0xd4, 0xef, 0xe4, 0x02, 0x42, 0xf8, 0x3e, 0x93, 0xb6, 0xc8, 0xd7, 0xef, 0xb5, 0xea, 0xe9 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 49 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcd, 0x2b, 0x1f, 0xec, 0x11, 0xfd, 0x90, 0x6c, 0x5c, 0x76, 0x30, 0x09, 0x94, 0x43, 0x61, 0x0a }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 50 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa1, 0x85, 0x3f, 0xe4, 0x7f, 0xe2, 0x92, 0x89, 0xd1, 0x53, 0x16, 0x1d, 0x06, 0x38, 0x7d, 0x21 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 51 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x46, 0x32, 0x15, 0x41, 0x79, 0xa5, 0x55, 0xc1, 0x7e, 0xa6, 0x04, 0xd0, 0x88, 0x9f, 0xab, 0x14 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 52 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdd, 0x27, 0xca, 0xc6, 0x40, 0x1a, 0x02, 0x2e, 0x8f, 0x38, 0xf9, 0xf9, 0x3e, 0x77, 0x44, 0x17 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 53 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc0, 0x90, 0x31, 0x3e, 0xb9, 0x86, 0x74, 0xf3, 0x5f, 0x31, 0x23, 0x38, 0x5f, 0xb9, 0x5d, 0x4d }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 54 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcc, 0x35, 0x26, 0x26, 0x2b, 0x92, 0xf0, 0x2e, 0xdc, 0xe5, 0x48, 0xf7, 0x16, 0xb9, 0xf4, 0x5c }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 55 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc0, 0x83, 0x8d, 0x1a, 0x2b, 0x16, 0xa7, 0xc7, 0xf0, 0xdf, 0xcc, 0x43, 0x3c, 0x39, 0x9c, 0x33 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 56 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0d, 0x9a, 0xc7, 0x56, 0xeb, 0x29, 0x76, 0x95, 0xee, 0xd4, 0xd3, 0x82, 0xeb, 0x12, 0x6d, 0x26 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 57 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x56, 0xed, 0xe9, 0xdd, 0xa3, 0xf6, 0xf1, 0x41, 0xbf, 0xf1, 0x75, 0x7f, 0xa6, 0x89, 0xc3, 0xe1 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 58 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x76, 0x8f, 0x52, 0x0e, 0xfe, 0x0f, 0x23, 0xe6, 0x1d, 0x3e, 0xc8, 0xad, 0x9c, 0xe9, 0x17, 0x74 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 59 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb1, 0x14, 0x4d, 0xdf, 0xa7, 0x57, 0x55, 0x21, 0x33, 0x90, 0xe7, 0xc5, 0x96, 0x66, 0x04, 0x90 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 60 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1d, 0x7c, 0x0c, 0x40, 0x40, 0xb3, 0x55, 0xb9, 0xd1, 0x07, 0xa9, 0x93, 0x25, 0xe3, 0xb0, 0x50 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 61 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd8, 0xe2, 0xbb, 0x1a, 0xe8, 0xee, 0x3d, 0xcf, 0x5b, 0xf7, 0xd6, 0xc3, 0x8d, 0xa8, 0x2a, 0x1a }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 62 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfa, 0xf8, 0x2d, 0x17, 0x8a, 0xf2, 0x5a, 0x98, 0x86, 0xa4, 0x7e, 0x7f, 0x78, 0x9b, 0x98, 0xd7 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 63 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9b, 0x58, 0xdb, 0xfd, 0x77, 0xfe, 0x5a, 0xca, 0x9c, 0xfc, 0x19, 0x0c, 0xd1, 0xb8, 0x2d, 0x19 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 64 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x77, 0xf3, 0x92, 0x08, 0x90, 0x42, 0xe4, 0x78, 0xac, 0x16, 0xc0, 0xc8, 0x6a, 0x0b, 0x5d, 0xb5 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 65 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x19, 0xf0, 0x8e, 0x34, 0x20, 0xee, 0x69, 0xb4, 0x77, 0xca, 0x14, 0x20, 0x28, 0x1c, 0x47, 0x82 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 66 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa1, 0xb1, 0x9b, 0xee, 0xe4, 0xe1, 0x17, 0x13, 0x9f, 0x74, 0xb3, 0xc5, 0x3f, 0xdc, 0xb8, 0x75 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 67 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa3, 0x7a, 0x58, 0x69, 0xb2, 0x18, 0xa9, 0xf3, 0xa0, 0x86, 0x8d, 0x19, 0xae, 0xa0, 0xad, 0x6a }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 68 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbc, 0x35, 0x94, 0xe8, 0x65, 0xbc, 0xd0, 0x26, 0x1b, 0x13, 0x20, 0x27, 0x31, 0xf3, 0x35, 0x80 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 69 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x81, 0x14, 0x41, 0xce, 0x1d, 0x30, 0x9e, 0xee, 0x71, 0x85, 0xe8, 0xc7, 0x52, 0xc0, 0x75, 0x57 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 70 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x95, 0x99, 0x71, 0xce, 0x41, 0x34, 0x19, 0x05, 0x63, 0x51, 0x8e, 0x70, 0x0b, 0x98, 0x74, 0xd1 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 71 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x76, 0xb5, 0x61, 0x4a, 0x04, 0x27, 0x07, 0xc9, 0x8e, 0x21, 0x32, 0xe2, 0xe8, 0x05, 0xfe, 0x63 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 72 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7d, 0x9f, 0xa6, 0xa5, 0x75, 0x30, 0xd0, 0xf0, 0x36, 0xfe, 0xc3, 0x1c, 0x23, 0x0b, 0x0c, 0xc6 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 73 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x96, 0x41, 0x53, 0xa8, 0x3b, 0xf6, 0x98, 0x9a, 0x4b, 0xa8, 0x0d, 0xaa, 0x91, 0xc3, 0xe0, 0x81 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 74 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa0, 0x13, 0x01, 0x4d, 0x4c, 0xe8, 0x05, 0x4c, 0xf2, 0x59, 0x1d, 0x06, 0xf6, 0xf2, 0xf1, 0x76 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 75 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd1, 0xc5, 0xf6, 0x39, 0x9b, 0xf3, 0x82, 0x50, 0x2e, 0x38, 0x5e, 0xee, 0x14, 0x74, 0xa8, 0x69 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 76 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x07, 0xe2, 0x0b, 0x82, 0x98, 0xec, 0x35, 0x4f, 0x0f, 0x5f, 0xe7, 0x47, 0x0f, 0x36, 0xbd }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 77 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb9, 0x5b, 0xa0, 0x5b, 0x33, 0x2d, 0xa6, 0x1e, 0xf6, 0x3a, 0x2b, 0x31, 0xfc, 0xad, 0x98, 0x79 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 78 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x46, 0x20, 0xa4, 0x9b, 0xd9, 0x67, 0x49, 0x15, 0x61, 0x66, 0x9a, 0xb2, 0x5d, 0xce, 0x45, 0xf4 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 79 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x12, 0xe7, 0x12, 0x14, 0xae, 0x8e, 0x04, 0xf0, 0xbb, 0x63, 0xd7, 0x42, 0x5c, 0x6f, 0x14, 0xd5 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 80 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4c, 0xc4, 0x2f, 0xc1, 0x40, 0x7b, 0x00, 0x8f, 0xe3, 0x50, 0x90, 0x7c, 0x09, 0x2e, 0x80, 0xac }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 81 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x08, 0xb2, 0x44, 0xce, 0x7c, 0xbc, 0x8e, 0xe9, 0x7f, 0xbb, 0xa8, 0x08, 0xcb, 0x14, 0x6f, 0xda }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 82 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x39, 0xb3, 0x33, 0xe8, 0x69, 0x4f, 0x21, 0x54, 0x6a, 0xd1, 0xed, 0xd9, 0xd8, 0x7e, 0xd9, 0x5b }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 83 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3b, 0x27, 0x1f, 0x8a, 0xb2, 0xe6, 0xe4, 0xa2, 0x0b, 0xa8, 0x09, 0x0f, 0x43, 0xba, 0x78, 0xf3 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 84 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9a, 0xd9, 0x83, 0xf3, 0xbf, 0x65, 0x1c, 0xd0, 0x39, 0x3f, 0x0a, 0x73, 0xcc, 0xcd, 0xea, 0x50 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 85 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8f, 0x47, 0x6c, 0xbf, 0xf7, 0x5c, 0x1f, 0x72, 0x5c, 0xe1, 0x8e, 0x4b, 0xbc, 0xd1, 0x9b, 0x32 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 86 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0x5b, 0x62, 0x67, 0xf1, 0xd6, 0xab, 0x53, 0x20, 0x83, 0x5a, 0x13, 0x3f, 0x09, 0x6f, 0x2a }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 87 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x14, 0x5b, 0x60, 0xd6, 0xd0, 0x19, 0x3c, 0x23, 0xf4, 0x22, 0x18, 0x48, 0xa8, 0x92, 0xd6, 0x1a }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 88 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x55, 0xcf, 0xb3, 0xfb, 0x6d, 0x75, 0xca, 0xd0, 0x44, 0x5b, 0xbc, 0x8d, 0xaf, 0xa2, 0x5b, 0x0f }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 89 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7b, 0x8e, 0x70, 0x98, 0xe3, 0x57, 0xef, 0x71, 0x23, 0x7d, 0x46, 0xd8, 0xb0, 0x75, 0xb0, 0xf5 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 90 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2b, 0xf2, 0x72, 0x29, 0x90, 0x1e, 0xb4, 0x0f, 0x2d, 0xf9, 0xd8, 0x39, 0x8d, 0x15, 0x05, 0xae }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 91 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x83, 0xa6, 0x34, 0x02, 0xa7, 0x7f, 0x9a, 0xd5, 0xc1, 0xe9, 0x31, 0xa9, 0x31, 0xec, 0xd7, 0x06 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 92 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6f, 0x8b, 0xa6, 0x52, 0x11, 0x52, 0xd3, 0x1f, 0x2b, 0xad, 0xa1, 0x84, 0x3e, 0x26, 0xb9, 0x73 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 93 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe5, 0xc3, 0xb8, 0xe3, 0x0f, 0xd2, 0xd8, 0xe6, 0x23, 0x9b, 0x17, 0xb4, 0x4b, 0xd2, 0x3b, 0xbd }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 94 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1a, 0xc1, 0xf7, 0x10, 0x2c, 0x59, 0x93, 0x3e, 0x8b, 0x2d, 0xdc, 0x3f, 0x14, 0xe9, 0x4b, 0xaa }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 95 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x21, 0xd9, 0xba, 0x49, 0xf2, 0x76, 0xb4, 0x5f, 0x11, 0xaf, 0x8f, 0xc7, 0x1a, 0x08, 0x8e, 0x3d }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 96 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 }, 16, { 0x64, 0x9f, 0x1c, 0xdd, 0xc3, 0x79, 0x2b, 0x46, 0x38, 0x63, 0x5a, 0x39, 0x2b, 0xc9, 0xba, 0xde }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 97 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 }, 16, { 0xe2, 0x77, 0x5e, 0x4b, 0x59, 0xc1, 0xbc, 0x2e, 0x31, 0xa2, 0x07, 0x8c, 0x11, 0xb5, 0xa0, 0x8c }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 98 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 }, 16, { 0x2b, 0xe1, 0xfa, 0xe5, 0x04, 0x8a, 0x25, 0x58, 0x2a, 0x67, 0x9c, 0xa1, 0x09, 0x05, 0xeb, 0x80 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 99 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 }, 16, { 0xda, 0x86, 0xf2, 0x92, 0xc6, 0xf4, 0x1e, 0xa3, 0x4f, 0xb2, 0x06, 0x8d, 0xf7, 0x5e, 0xcc, 0x29 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 100 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 }, 16, { 0x22, 0x0d, 0xf1, 0x9f, 0x85, 0xd6, 0x9b, 0x1b, 0x56, 0x2f, 0xa6, 0x9a, 0x3c, 0x5b, 0xec, 0xa5 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 101 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 }, 16, { 0x1f, 0x11, 0xd5, 0xd0, 0x35, 0x5e, 0x0b, 0x55, 0x6c, 0xcd, 0xb6, 0xc7, 0xf5, 0x08, 0x3b, 0x4d }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 102 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 }, 16, { 0x62, 0x52, 0x6b, 0x78, 0xbe, 0x79, 0xcb, 0x38, 0x46, 0x33, 0xc9, 0x1f, 0x83, 0xb4, 0x15, 0x1b }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 103 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }, 16, { 0x90, 0xdd, 0xbc, 0xb9, 0x50, 0x84, 0x35, 0x92, 0xdd, 0x47, 0xbb, 0xef, 0x00, 0xfd, 0xc8, 0x76 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 104 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 }, 16, { 0x2f, 0xd0, 0xe4, 0x1c, 0x5b, 0x84, 0x02, 0x27, 0x73, 0x54, 0xa7, 0x39, 0x1d, 0x26, 0x18, 0xe2 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 105 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 }, 16, { 0x3c, 0xdf, 0x13, 0xe7, 0x2d, 0xee, 0x4c, 0x58, 0x1b, 0xaf, 0xec, 0x70, 0xb8, 0x5f, 0x96, 0x60 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 106 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 }, 16, { 0xaf, 0xa2, 0xff, 0xc1, 0x37, 0x57, 0x70, 0x92, 0xe2, 0xb6, 0x54, 0xfa, 0x19, 0x9d, 0x2c, 0x43 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 107 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 }, 16, { 0x8d, 0x68, 0x3e, 0xe6, 0x3e, 0x60, 0xd2, 0x08, 0xe3, 0x43, 0xce, 0x48, 0xdb, 0xc4, 0x4c, 0xac }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 108 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 }, 16, { 0x70, 0x5a, 0x4e, 0xf8, 0xba, 0x21, 0x33, 0x72, 0x9c, 0x20, 0x18, 0x5c, 0x3d, 0x3a, 0x47, 0x63 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 109 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 }, 16, { 0x08, 0x61, 0xa8, 0x61, 0xc3, 0xdb, 0x4e, 0x94, 0x19, 0x42, 0x11, 0xb7, 0x7e, 0xd7, 0x61, 0xb9 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 110 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 }, 16, { 0x4b, 0x00, 0xc2, 0x7e, 0x8b, 0x26, 0xda, 0x7e, 0xab, 0x9d, 0x3a, 0x88, 0xde, 0xc8, 0xb0, 0x31 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 111 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 }, 16, { 0x5f, 0x39, 0x7b, 0xf0, 0x30, 0x84, 0x82, 0x0c, 0xc8, 0x81, 0x0d, 0x52, 0xe5, 0xb6, 0x66, 0xe9 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 112 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 }, 16, { 0x63, 0xfa, 0xfa, 0xbb, 0x72, 0xc0, 0x7b, 0xfb, 0xd3, 0xdd, 0xc9, 0xb1, 0x20, 0x31, 0x04, 0xb8 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 113 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 }, 16, { 0x68, 0x3e, 0x21, 0x40, 0x58, 0x5b, 0x18, 0x45, 0x2d, 0xd4, 0xff, 0xbb, 0x93, 0xc9, 0x5d, 0xf9 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 114 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 }, 16, { 0x28, 0x68, 0x94, 0xe4, 0x8e, 0x53, 0x7f, 0x87, 0x63, 0xb5, 0x67, 0x07, 0xd7, 0xd1, 0x55, 0xc8 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 115 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 }, 16, { 0xa4, 0x23, 0xde, 0xab, 0xc1, 0x73, 0xdc, 0xf7, 0xe2, 0xc4, 0xc5, 0x3e, 0x77, 0xd3, 0x7c, 0xd1 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 116 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 }, 16, { 0xeb, 0x81, 0x68, 0x31, 0x3e, 0x1c, 0xfd, 0xfd, 0xb5, 0xe9, 0x86, 0xd5, 0x42, 0x9c, 0xf1, 0x72 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 117 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 }, 16, { 0x27, 0x12, 0x7d, 0xaa, 0xfc, 0x9a, 0xcc, 0xd2, 0xfb, 0x33, 0x4e, 0xc3, 0xeb, 0xa5, 0x23, 0x23 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 118 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 }, 16, { 0xee, 0x07, 0x15, 0xb9, 0x6f, 0x72, 0xe3, 0xf7, 0xa2, 0x2a, 0x50, 0x64, 0xfc, 0x59, 0x2f, 0x4c }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 119 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 }, 16, { 0x29, 0xee, 0x52, 0x67, 0x70, 0xf2, 0xa1, 0x1d, 0xcf, 0xa9, 0x89, 0xd1, 0xce, 0x88, 0x83, 0x0f }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 120 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 }, 16, { 0x04, 0x93, 0x37, 0x0e, 0x05, 0x4b, 0x09, 0x87, 0x11, 0x30, 0xfe, 0x49, 0xaf, 0x73, 0x0a, 0x5a }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 121 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 }, 16, { 0x9b, 0x7b, 0x94, 0x0f, 0x6c, 0x50, 0x9f, 0x9e, 0x44, 0xa4, 0xee, 0x14, 0x04, 0x48, 0xee, 0x46 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 122 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 }, 16, { 0x29, 0x15, 0xbe, 0x4a, 0x1e, 0xcf, 0xdc, 0xbe, 0x3e, 0x02, 0x38, 0x11, 0xa1, 0x2b, 0xb6, 0xc7 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 123 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 }, 16, { 0x72, 0x40, 0xe5, 0x24, 0xbc, 0x51, 0xd8, 0xc4, 0xd4, 0x40, 0xb1, 0xbe, 0x55, 0xd1, 0x06, 0x2c }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 124 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 }, 16, { 0xda, 0x63, 0x03, 0x9d, 0x38, 0xcb, 0x46, 0x12, 0xb2, 0xdc, 0x36, 0xba, 0x26, 0x68, 0x4b, 0x93 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 125 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc }, 16, { 0x0f, 0x59, 0xcb, 0x5a, 0x4b, 0x52, 0x2e, 0x2a, 0xc5, 0x6c, 0x1a, 0x64, 0xf5, 0x58, 0xad, 0x9a }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 126 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe }, 16, { 0x7b, 0xfe, 0x9d, 0x87, 0x6c, 0x6d, 0x63, 0xc1, 0xd0, 0x35, 0xda, 0x8f, 0xe2, 0x1c, 0x40, 0x9d }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 127 encrypt", LIBCAES_CRYPT_MODE_ENCRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }, 16, { 0xac, 0xda, 0xce, 0x80, 0x78, 0xa3, 0x2b, 0x1a, 0x18, 0x2b, 0xfa, 0x49, 0x87, 0xca, 0x13, 0x47 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 0 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdd, 0xc6, 0xbf, 0x79, 0x0c, 0x15, 0x76, 0x0d, 0x8d, 0x9a, 0xeb, 0x6f, 0x9a, 0x75, 0xfd, 0x4e }, 16, { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 1 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0a, 0x6b, 0xdc, 0x6d, 0x4c, 0x1e, 0x62, 0x80, 0x30, 0x1f, 0xd8, 0xe9, 0x7d, 0xdb, 0xe6, 0x01 }, 16, { 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 2 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9b, 0x80, 0xee, 0xfb, 0x7e, 0xbe, 0x2d, 0x2b, 0x16, 0x24, 0x7a, 0xa0, 0xef, 0xc7, 0x2f, 0x5d }, 16, { 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 3 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7f, 0x2c, 0x5e, 0xce, 0x07, 0xa9, 0x8d, 0x8b, 0xee, 0x13, 0xc5, 0x11, 0x77, 0x39, 0x5f, 0xf7 }, 16, { 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 4 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x78, 0x18, 0xd8, 0x00, 0xdc, 0xf6, 0xf4, 0xbe, 0x1e, 0x0e, 0x94, 0xf4, 0x03, 0xd1, 0xe4, 0xc2 }, 16, { 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 5 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe7, 0x4c, 0xd1, 0xc9, 0x2f, 0x09, 0x19, 0xc3, 0x5a, 0x03, 0x24, 0x12, 0x3d, 0x61, 0x77, 0xd3 }, 16, { 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 6 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x80, 0x92, 0xa4, 0xdc, 0xf2, 0xda, 0x7e, 0x77, 0xe9, 0x3b, 0xdd, 0x37, 0x1d, 0xfe, 0xd8, 0x2e }, 16, { 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 7 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x49, 0xaf, 0x6b, 0x37, 0x21, 0x35, 0xac, 0xef, 0x10, 0x13, 0x2e, 0x54, 0x8f, 0x21, 0x7b, 0x17 }, 16, { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 8 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8b, 0xcd, 0x40, 0xf9, 0x4e, 0xbb, 0x63, 0xb9, 0xf7, 0x90, 0x96, 0x76, 0xe6, 0x67, 0xf1, 0xe7 }, 16, { 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 9 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfe, 0x1c, 0xff, 0xb8, 0x3f, 0x45, 0xdc, 0xfb, 0x38, 0xb2, 0x9b, 0xe4, 0x38, 0xdb, 0xd3, 0xab }, 16, { 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 10 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0d, 0xc5, 0x8a, 0x8d, 0x88, 0x66, 0x23, 0x70, 0x5a, 0xec, 0x15, 0xcb, 0x1e, 0x70, 0xdc, 0x0e }, 16, { 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 11 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc2, 0x18, 0xfa, 0xa1, 0x60, 0x56, 0xbd, 0x07, 0x74, 0xc3, 0xe8, 0xd7, 0x9c, 0x35, 0xa5, 0xe4 }, 16, { 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 12 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x04, 0x7b, 0xba, 0x83, 0xf7, 0xaa, 0x84, 0x17, 0x31, 0x50, 0x4e, 0x01, 0x22, 0x08, 0xfc, 0x9e }, 16, { 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 13 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdc, 0x8f, 0x0e, 0x49, 0x15, 0xfd, 0x81, 0xba, 0x70, 0xa3, 0x31, 0x31, 0x08, 0x82, 0xf6, 0xda }, 16, { 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 14 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x15, 0x69, 0x85, 0x9e, 0xa6, 0xb7, 0x20, 0x6c, 0x30, 0xbf, 0x4f, 0xd0, 0xcb, 0xfa, 0xc3, 0x3c }, 16, { 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 15 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x30, 0x0a, 0xde, 0x92, 0xf8, 0x8f, 0x48, 0xfa, 0x2d, 0xf7, 0x30, 0xec, 0x16, 0xef, 0x44, 0xcd }, 16, { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 16 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1f, 0xe6, 0xcc, 0x3c, 0x05, 0x96, 0x5d, 0xc0, 0x8e, 0xb0, 0x59, 0x0c, 0x95, 0xac, 0x71, 0xd0 }, 16, { 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 17 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x59, 0xe8, 0x58, 0xea, 0xaa, 0x97, 0xfe, 0xc3, 0x81, 0x11, 0x27, 0x5b, 0x6c, 0xf5, 0xab, 0xc0 }, 16, { 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 18 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x22, 0x39, 0x45, 0x5e, 0x7a, 0xfe, 0x3b, 0x06, 0x16, 0x10, 0x02, 0x88, 0xcc, 0x5a, 0x72, 0x3b }, 16, { 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 19 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3e, 0xe5, 0x00, 0xc5, 0xc8, 0xd6, 0x34, 0x79, 0x71, 0x71, 0x63, 0xe5, 0x5c, 0x5c, 0x45, 0x22 }, 16, { 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 20 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd5, 0xe3, 0x8b, 0xf1, 0x5f, 0x16, 0xd9, 0x0e, 0x3e, 0x21, 0x40, 0x41, 0xd7, 0x74, 0xda, 0xa8 }, 16, { 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 21 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb1, 0xf4, 0x06, 0x6e, 0x6f, 0x4f, 0x18, 0x7d, 0xfe, 0x5f, 0x2a, 0xd1, 0xb1, 0x78, 0x19, 0xd0 }, 16, { 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 22 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6e, 0xf4, 0xcc, 0x4d, 0xe4, 0x9b, 0x11, 0x06, 0x5d, 0x7a, 0xf2, 0x90, 0x98, 0x54, 0x79, 0x4a }, 16, { 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 23 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xac, 0x86, 0xbc, 0x60, 0x6b, 0x66, 0x40, 0xc3, 0x09, 0xe7, 0x82, 0xf2, 0x32, 0xbf, 0x36, 0x7f }, 16, { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 24 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x36, 0xaf, 0xf0, 0xef, 0x7b, 0xf3, 0x28, 0x07, 0x72, 0xcf, 0x4c, 0xac, 0x80, 0xa0, 0xd2, 0xb2 }, 16, { 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 25 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1f, 0x8e, 0xed, 0xea, 0x0f, 0x62, 0xa1, 0x40, 0x6d, 0x58, 0xcf, 0xc3, 0xec, 0xea, 0x72, 0xcf }, 16, { 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 26 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xab, 0xf4, 0x15, 0x4a, 0x33, 0x75, 0xa1, 0xd3, 0xe6, 0xb1, 0xd4, 0x54, 0x43, 0x8f, 0x95, 0xa6 }, 16, { 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 27 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x96, 0xf9, 0x6e, 0x9d, 0x60, 0x7f, 0x66, 0x15, 0xfc, 0x19, 0x20, 0x61, 0xee, 0x64, 0x8b, 0x07 }, 16, { 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 28 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcf, 0x37, 0xcd, 0xaa, 0xa0, 0xd2, 0xd5, 0x36, 0xc7, 0x18, 0x57, 0x63, 0x4c, 0x79, 0x20, 0x64 }, 16, { 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 29 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfb, 0xd6, 0x64, 0x0c, 0x80, 0x24, 0x5c, 0x2b, 0x80, 0x53, 0x73, 0xf1, 0x30, 0x70, 0x31, 0x27 }, 16, { 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 30 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8d, 0x6a, 0x8a, 0xfe, 0x55, 0xa6, 0xe4, 0x81, 0xba, 0xda, 0xe0, 0xd1, 0x46, 0xf4, 0x36, 0xdb }, 16, { 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 31 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6a, 0x49, 0x81, 0xf2, 0x91, 0x5e, 0x3e, 0x68, 0xaf, 0x6c, 0x22, 0x38, 0x5d, 0xd0, 0x67, 0x56 }, 16, { 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 32 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x42, 0xa1, 0x13, 0x6e, 0x5f, 0x8d, 0x8d, 0x21, 0xd3, 0x10, 0x19, 0x98, 0x64, 0x2d, 0x57, 0x3b }, 16, { 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 33 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9b, 0x47, 0x15, 0x96, 0xdc, 0x69, 0xae, 0x15, 0x86, 0xce, 0xe6, 0x15, 0x8b, 0x0b, 0x01, 0x81 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 34 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x75, 0x36, 0x65, 0xc4, 0xaf, 0x1e, 0xff, 0x33, 0xaa, 0x8b, 0x62, 0x8b, 0xf8, 0x74, 0x1c, 0xfd }, 16, { 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 35 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9a, 0x68, 0x2a, 0xcf, 0x40, 0xbe, 0x01, 0xf5, 0xb2, 0xa4, 0x19, 0x3c, 0x9a, 0x82, 0x40, 0x4d }, 16, { 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 36 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x54, 0xfa, 0xfe, 0x26, 0xe4, 0x28, 0x7f, 0x17, 0xd1, 0x93, 0x5f, 0x87, 0xeb, 0x9a, 0xde, 0x01 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 37 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x49, 0xd5, 0x41, 0xb2, 0xe7, 0x4c, 0xfe, 0x73, 0xe6, 0xa8, 0xe8, 0x22, 0x5f, 0x7b, 0xd4, 0x49 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 38 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x11, 0xa4, 0x55, 0x30, 0xf6, 0x24, 0xff, 0x6f, 0x76, 0xa1, 0xb3, 0x82, 0x66, 0x26, 0xff, 0x7b }, 16, { 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 39 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xf9, 0x6b, 0x0c, 0x4a, 0x8b, 0xc6, 0xc8, 0x61, 0x30, 0x28, 0x9f, 0x60, 0xb4, 0x3b, 0x8f, 0xba }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 40 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x48, 0xc7, 0xd0, 0xe8, 0x08, 0x34, 0xeb, 0xdc, 0x35, 0xb6, 0x73, 0x5f, 0x76, 0xb4, 0x6c, 0x8b }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 41 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x24, 0x63, 0x53, 0x1a, 0xb5, 0x4d, 0x66, 0x95, 0x5e, 0x73, 0xed, 0xc4, 0xcb, 0x8e, 0xaa, 0x45 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 42 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xac, 0x9b, 0xd8, 0xe2, 0x53, 0x04, 0x69, 0x13, 0x4b, 0x9d, 0x5b, 0x06, 0x5d, 0x4f, 0x56, 0x5b }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 43 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3f, 0x5f, 0x91, 0x06, 0xd0, 0xe5, 0x2f, 0x97, 0x3d, 0x48, 0x90, 0xe6, 0xf3, 0x7e, 0x8a, 0x00 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 44 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x20, 0xeb, 0xc8, 0x6f, 0x13, 0x04, 0xd2, 0x72, 0xe2, 0xe2, 0x07, 0xe5, 0x9d, 0xb6, 0x39, 0xf0 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 45 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe6, 0x7a, 0xe6, 0x42, 0x6b, 0xf9, 0x52, 0x6c, 0x97, 0x2c, 0xff, 0x07, 0x2b, 0x52, 0x25, 0x2c }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 46 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1a, 0x51, 0x8d, 0xdd, 0xaf, 0x9e, 0xfa, 0x0d, 0x00, 0x2c, 0xc5, 0x8d, 0x10, 0x7e, 0xdf, 0xc8 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 47 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xea, 0xd7, 0x31, 0xaf, 0x4d, 0x3a, 0x2f, 0xe3, 0xb3, 0x4b, 0xed, 0x04, 0x79, 0x42, 0xa4, 0x9f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 48 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb1, 0xd4, 0xef, 0xe4, 0x02, 0x42, 0xf8, 0x3e, 0x93, 0xb6, 0xc8, 0xd7, 0xef, 0xb5, 0xea, 0xe9 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 49 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcd, 0x2b, 0x1f, 0xec, 0x11, 0xfd, 0x90, 0x6c, 0x5c, 0x76, 0x30, 0x09, 0x94, 0x43, 0x61, 0x0a }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 50 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa1, 0x85, 0x3f, 0xe4, 0x7f, 0xe2, 0x92, 0x89, 0xd1, 0x53, 0x16, 0x1d, 0x06, 0x38, 0x7d, 0x21 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 51 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x46, 0x32, 0x15, 0x41, 0x79, 0xa5, 0x55, 0xc1, 0x7e, 0xa6, 0x04, 0xd0, 0x88, 0x9f, 0xab, 0x14 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 52 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xdd, 0x27, 0xca, 0xc6, 0x40, 0x1a, 0x02, 0x2e, 0x8f, 0x38, 0xf9, 0xf9, 0x3e, 0x77, 0x44, 0x17 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 53 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc0, 0x90, 0x31, 0x3e, 0xb9, 0x86, 0x74, 0xf3, 0x5f, 0x31, 0x23, 0x38, 0x5f, 0xb9, 0x5d, 0x4d }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 54 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xcc, 0x35, 0x26, 0x26, 0x2b, 0x92, 0xf0, 0x2e, 0xdc, 0xe5, 0x48, 0xf7, 0x16, 0xb9, 0xf4, 0x5c }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 55 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xc0, 0x83, 0x8d, 0x1a, 0x2b, 0x16, 0xa7, 0xc7, 0xf0, 0xdf, 0xcc, 0x43, 0x3c, 0x39, 0x9c, 0x33 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 56 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0d, 0x9a, 0xc7, 0x56, 0xeb, 0x29, 0x76, 0x95, 0xee, 0xd4, 0xd3, 0x82, 0xeb, 0x12, 0x6d, 0x26 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 57 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x56, 0xed, 0xe9, 0xdd, 0xa3, 0xf6, 0xf1, 0x41, 0xbf, 0xf1, 0x75, 0x7f, 0xa6, 0x89, 0xc3, 0xe1 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 58 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x76, 0x8f, 0x52, 0x0e, 0xfe, 0x0f, 0x23, 0xe6, 0x1d, 0x3e, 0xc8, 0xad, 0x9c, 0xe9, 0x17, 0x74 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 59 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb1, 0x14, 0x4d, 0xdf, 0xa7, 0x57, 0x55, 0x21, 0x33, 0x90, 0xe7, 0xc5, 0x96, 0x66, 0x04, 0x90 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 60 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1d, 0x7c, 0x0c, 0x40, 0x40, 0xb3, 0x55, 0xb9, 0xd1, 0x07, 0xa9, 0x93, 0x25, 0xe3, 0xb0, 0x50 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 61 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd8, 0xe2, 0xbb, 0x1a, 0xe8, 0xee, 0x3d, 0xcf, 0x5b, 0xf7, 0xd6, 0xc3, 0x8d, 0xa8, 0x2a, 0x1a }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 62 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xfa, 0xf8, 0x2d, 0x17, 0x8a, 0xf2, 0x5a, 0x98, 0x86, 0xa4, 0x7e, 0x7f, 0x78, 0x9b, 0x98, 0xd7 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 63 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9b, 0x58, 0xdb, 0xfd, 0x77, 0xfe, 0x5a, 0xca, 0x9c, 0xfc, 0x19, 0x0c, 0xd1, 0xb8, 0x2d, 0x19 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 64 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x77, 0xf3, 0x92, 0x08, 0x90, 0x42, 0xe4, 0x78, 0xac, 0x16, 0xc0, 0xc8, 0x6a, 0x0b, 0x5d, 0xb5 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 65 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x19, 0xf0, 0x8e, 0x34, 0x20, 0xee, 0x69, 0xb4, 0x77, 0xca, 0x14, 0x20, 0x28, 0x1c, 0x47, 0x82 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 66 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa1, 0xb1, 0x9b, 0xee, 0xe4, 0xe1, 0x17, 0x13, 0x9f, 0x74, 0xb3, 0xc5, 0x3f, 0xdc, 0xb8, 0x75 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 67 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa3, 0x7a, 0x58, 0x69, 0xb2, 0x18, 0xa9, 0xf3, 0xa0, 0x86, 0x8d, 0x19, 0xae, 0xa0, 0xad, 0x6a }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 68 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xbc, 0x35, 0x94, 0xe8, 0x65, 0xbc, 0xd0, 0x26, 0x1b, 0x13, 0x20, 0x27, 0x31, 0xf3, 0x35, 0x80 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 69 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x81, 0x14, 0x41, 0xce, 0x1d, 0x30, 0x9e, 0xee, 0x71, 0x85, 0xe8, 0xc7, 0x52, 0xc0, 0x75, 0x57 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 70 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x95, 0x99, 0x71, 0xce, 0x41, 0x34, 0x19, 0x05, 0x63, 0x51, 0x8e, 0x70, 0x0b, 0x98, 0x74, 0xd1 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 71 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x76, 0xb5, 0x61, 0x4a, 0x04, 0x27, 0x07, 0xc9, 0x8e, 0x21, 0x32, 0xe2, 0xe8, 0x05, 0xfe, 0x63 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 72 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7d, 0x9f, 0xa6, 0xa5, 0x75, 0x30, 0xd0, 0xf0, 0x36, 0xfe, 0xc3, 0x1c, 0x23, 0x0b, 0x0c, 0xc6 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 73 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x96, 0x41, 0x53, 0xa8, 0x3b, 0xf6, 0x98, 0x9a, 0x4b, 0xa8, 0x0d, 0xaa, 0x91, 0xc3, 0xe0, 0x81 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 74 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa0, 0x13, 0x01, 0x4d, 0x4c, 0xe8, 0x05, 0x4c, 0xf2, 0x59, 0x1d, 0x06, 0xf6, 0xf2, 0xf1, 0x76 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 75 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xd1, 0xc5, 0xf6, 0x39, 0x9b, 0xf3, 0x82, 0x50, 0x2e, 0x38, 0x5e, 0xee, 0x14, 0x74, 0xa8, 0x69 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 76 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x00, 0x07, 0xe2, 0x0b, 0x82, 0x98, 0xec, 0x35, 0x4f, 0x0f, 0x5f, 0xe7, 0x47, 0x0f, 0x36, 0xbd }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 77 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xb9, 0x5b, 0xa0, 0x5b, 0x33, 0x2d, 0xa6, 0x1e, 0xf6, 0x3a, 0x2b, 0x31, 0xfc, 0xad, 0x98, 0x79 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 78 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x46, 0x20, 0xa4, 0x9b, 0xd9, 0x67, 0x49, 0x15, 0x61, 0x66, 0x9a, 0xb2, 0x5d, 0xce, 0x45, 0xf4 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 79 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x12, 0xe7, 0x12, 0x14, 0xae, 0x8e, 0x04, 0xf0, 0xbb, 0x63, 0xd7, 0x42, 0x5c, 0x6f, 0x14, 0xd5 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 80 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4c, 0xc4, 0x2f, 0xc1, 0x40, 0x7b, 0x00, 0x8f, 0xe3, 0x50, 0x90, 0x7c, 0x09, 0x2e, 0x80, 0xac }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 81 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x08, 0xb2, 0x44, 0xce, 0x7c, 0xbc, 0x8e, 0xe9, 0x7f, 0xbb, 0xa8, 0x08, 0xcb, 0x14, 0x6f, 0xda }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 82 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x39, 0xb3, 0x33, 0xe8, 0x69, 0x4f, 0x21, 0x54, 0x6a, 0xd1, 0xed, 0xd9, 0xd8, 0x7e, 0xd9, 0x5b }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 83 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3b, 0x27, 0x1f, 0x8a, 0xb2, 0xe6, 0xe4, 0xa2, 0x0b, 0xa8, 0x09, 0x0f, 0x43, 0xba, 0x78, 0xf3 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 84 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9a, 0xd9, 0x83, 0xf3, 0xbf, 0x65, 0x1c, 0xd0, 0x39, 0x3f, 0x0a, 0x73, 0xcc, 0xcd, 0xea, 0x50 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 85 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8f, 0x47, 0x6c, 0xbf, 0xf7, 0x5c, 0x1f, 0x72, 0x5c, 0xe1, 0x8e, 0x4b, 0xbc, 0xd1, 0x9b, 0x32 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 86 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0x5b, 0x62, 0x67, 0xf1, 0xd6, 0xab, 0x53, 0x20, 0x83, 0x5a, 0x13, 0x3f, 0x09, 0x6f, 0x2a }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 87 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x14, 0x5b, 0x60, 0xd6, 0xd0, 0x19, 0x3c, 0x23, 0xf4, 0x22, 0x18, 0x48, 0xa8, 0x92, 0xd6, 0x1a }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 88 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x55, 0xcf, 0xb3, 0xfb, 0x6d, 0x75, 0xca, 0xd0, 0x44, 0x5b, 0xbc, 0x8d, 0xaf, 0xa2, 0x5b, 0x0f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 89 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7b, 0x8e, 0x70, 0x98, 0xe3, 0x57, 0xef, 0x71, 0x23, 0x7d, 0x46, 0xd8, 0xb0, 0x75, 0xb0, 0xf5 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 90 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2b, 0xf2, 0x72, 0x29, 0x90, 0x1e, 0xb4, 0x0f, 0x2d, 0xf9, 0xd8, 0x39, 0x8d, 0x15, 0x05, 0xae }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 91 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x83, 0xa6, 0x34, 0x02, 0xa7, 0x7f, 0x9a, 0xd5, 0xc1, 0xe9, 0x31, 0xa9, 0x31, 0xec, 0xd7, 0x06 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 92 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x6f, 0x8b, 0xa6, 0x52, 0x11, 0x52, 0xd3, 0x1f, 0x2b, 0xad, 0xa1, 0x84, 0x3e, 0x26, 0xb9, 0x73 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 93 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe5, 0xc3, 0xb8, 0xe3, 0x0f, 0xd2, 0xd8, 0xe6, 0x23, 0x9b, 0x17, 0xb4, 0x4b, 0xd2, 0x3b, 0xbd }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 94 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1a, 0xc1, 0xf7, 0x10, 0x2c, 0x59, 0x93, 0x3e, 0x8b, 0x2d, 0xdc, 0x3f, 0x14, 0xe9, 0x4b, 0xaa }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 95 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x21, 0xd9, 0xba, 0x49, 0xf2, 0x76, 0xb4, 0x5f, 0x11, 0xaf, 0x8f, 0xc7, 0x1a, 0x08, 0x8e, 0x3d }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 96 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x64, 0x9f, 0x1c, 0xdd, 0xc3, 0x79, 0x2b, 0x46, 0x38, 0x63, 0x5a, 0x39, 0x2b, 0xc9, 0xba, 0xde }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 97 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xe2, 0x77, 0x5e, 0x4b, 0x59, 0xc1, 0xbc, 0x2e, 0x31, 0xa2, 0x07, 0x8c, 0x11, 0xb5, 0xa0, 0x8c }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 98 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2b, 0xe1, 0xfa, 0xe5, 0x04, 0x8a, 0x25, 0x58, 0x2a, 0x67, 0x9c, 0xa1, 0x09, 0x05, 0xeb, 0x80 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 99 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xda, 0x86, 0xf2, 0x92, 0xc6, 0xf4, 0x1e, 0xa3, 0x4f, 0xb2, 0x06, 0x8d, 0xf7, 0x5e, 0xcc, 0x29 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 100 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x22, 0x0d, 0xf1, 0x9f, 0x85, 0xd6, 0x9b, 0x1b, 0x56, 0x2f, 0xa6, 0x9a, 0x3c, 0x5b, 0xec, 0xa5 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 101 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x1f, 0x11, 0xd5, 0xd0, 0x35, 0x5e, 0x0b, 0x55, 0x6c, 0xcd, 0xb6, 0xc7, 0xf5, 0x08, 0x3b, 0x4d }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 102 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x62, 0x52, 0x6b, 0x78, 0xbe, 0x79, 0xcb, 0x38, 0x46, 0x33, 0xc9, 0x1f, 0x83, 0xb4, 0x15, 0x1b }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 103 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x90, 0xdd, 0xbc, 0xb9, 0x50, 0x84, 0x35, 0x92, 0xdd, 0x47, 0xbb, 0xef, 0x00, 0xfd, 0xc8, 0x76 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 104 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x2f, 0xd0, 0xe4, 0x1c, 0x5b, 0x84, 0x02, 0x27, 0x73, 0x54, 0xa7, 0x39, 0x1d, 0x26, 0x18, 0xe2 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 105 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x3c, 0xdf, 0x13, 0xe7, 0x2d, 0xee, 0x4c, 0x58, 0x1b, 0xaf, 0xec, 0x70, 0xb8, 0x5f, 0x96, 0x60 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 106 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xaf, 0xa2, 0xff, 0xc1, 0x37, 0x57, 0x70, 0x92, 0xe2, 0xb6, 0x54, 0xfa, 0x19, 0x9d, 0x2c, 0x43 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 107 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x8d, 0x68, 0x3e, 0xe6, 0x3e, 0x60, 0xd2, 0x08, 0xe3, 0x43, 0xce, 0x48, 0xdb, 0xc4, 0x4c, 0xac }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 108 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x70, 0x5a, 0x4e, 0xf8, 0xba, 0x21, 0x33, 0x72, 0x9c, 0x20, 0x18, 0x5c, 0x3d, 0x3a, 0x47, 0x63 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 109 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x08, 0x61, 0xa8, 0x61, 0xc3, 0xdb, 0x4e, 0x94, 0x19, 0x42, 0x11, 0xb7, 0x7e, 0xd7, 0x61, 0xb9 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 110 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x4b, 0x00, 0xc2, 0x7e, 0x8b, 0x26, 0xda, 0x7e, 0xab, 0x9d, 0x3a, 0x88, 0xde, 0xc8, 0xb0, 0x31 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 111 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x5f, 0x39, 0x7b, 0xf0, 0x30, 0x84, 0x82, 0x0c, 0xc8, 0x81, 0x0d, 0x52, 0xe5, 0xb6, 0x66, 0xe9 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 112 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x63, 0xfa, 0xfa, 0xbb, 0x72, 0xc0, 0x7b, 0xfb, 0xd3, 0xdd, 0xc9, 0xb1, 0x20, 0x31, 0x04, 0xb8 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 113 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x68, 0x3e, 0x21, 0x40, 0x58, 0x5b, 0x18, 0x45, 0x2d, 0xd4, 0xff, 0xbb, 0x93, 0xc9, 0x5d, 0xf9 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 114 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x28, 0x68, 0x94, 0xe4, 0x8e, 0x53, 0x7f, 0x87, 0x63, 0xb5, 0x67, 0x07, 0xd7, 0xd1, 0x55, 0xc8 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 115 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xa4, 0x23, 0xde, 0xab, 0xc1, 0x73, 0xdc, 0xf7, 0xe2, 0xc4, 0xc5, 0x3e, 0x77, 0xd3, 0x7c, 0xd1 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 116 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xeb, 0x81, 0x68, 0x31, 0x3e, 0x1c, 0xfd, 0xfd, 0xb5, 0xe9, 0x86, 0xd5, 0x42, 0x9c, 0xf1, 0x72 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 117 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x27, 0x12, 0x7d, 0xaa, 0xfc, 0x9a, 0xcc, 0xd2, 0xfb, 0x33, 0x4e, 0xc3, 0xeb, 0xa5, 0x23, 0x23 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 118 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xee, 0x07, 0x15, 0xb9, 0x6f, 0x72, 0xe3, 0xf7, 0xa2, 0x2a, 0x50, 0x64, 0xfc, 0x59, 0x2f, 0x4c }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 119 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x29, 0xee, 0x52, 0x67, 0x70, 0xf2, 0xa1, 0x1d, 0xcf, 0xa9, 0x89, 0xd1, 0xce, 0x88, 0x83, 0x0f }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 120 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x04, 0x93, 0x37, 0x0e, 0x05, 0x4b, 0x09, 0x87, 0x11, 0x30, 0xfe, 0x49, 0xaf, 0x73, 0x0a, 0x5a }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 121 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x9b, 0x7b, 0x94, 0x0f, 0x6c, 0x50, 0x9f, 0x9e, 0x44, 0xa4, 0xee, 0x14, 0x04, 0x48, 0xee, 0x46 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 122 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x29, 0x15, 0xbe, 0x4a, 0x1e, 0xcf, 0xdc, 0xbe, 0x3e, 0x02, 0x38, 0x11, 0xa1, 0x2b, 0xb6, 0xc7 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 123 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x72, 0x40, 0xe5, 0x24, 0xbc, 0x51, 0xd8, 0xc4, 0xd4, 0x40, 0xb1, 0xbe, 0x55, 0xd1, 0x06, 0x2c }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 124 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xda, 0x63, 0x03, 0x9d, 0x38, 0xcb, 0x46, 0x12, 0xb2, 0xdc, 0x36, 0xba, 0x26, 0x68, 0x4b, 0x93 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 125 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x0f, 0x59, 0xcb, 0x5a, 0x4b, 0x52, 0x2e, 0x2a, 0xc5, 0x6c, 0x1a, 0x64, 0xf5, 0x58, 0xad, 0x9a }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 126 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0x7b, 0xfe, 0x9d, 0x87, 0x6c, 0x6d, 0x63, 0xc1, 0xd0, 0x35, 0xda, 0x8f, 0xe2, 0x1c, 0x40, 0x9d }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe }, 16 }, { "NIST KAT-AES ECBVarTxt256.rsp test vector 127 decrypt", LIBCAES_CRYPT_MODE_DECRYPT, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 256, { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, 16, { 0xac, 0xda, 0xce, 0x80, 0x78, 0xa3, 0x2b, 0x1a, 0x18, 0x2b, 0xfa, 0x49, 0x87, 0xca, 0x13, 0x47 }, 16, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }, 16 }, }; #if defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_EBC_ENCRYPT ) ) /* Custom AES_set_encrypt_key for testing error cases * Returns 0 if successful or a negative value otherwise */ int AES_set_encrypt_key( const unsigned char *userKey, const int bits, AES_KEY *key ) { int result = 0; if( caes_test_real_AES_set_encrypt_key == NULL ) { caes_test_real_AES_set_encrypt_key = dlsym( RTLD_NEXT, "AES_set_encrypt_key" ); } if( caes_test_AES_set_encrypt_key_attempts_before_fail == 0 ) { caes_test_AES_set_encrypt_key_attempts_before_fail = -1; return( -1 ); } else if( caes_test_AES_set_encrypt_key_attempts_before_fail > 0 ) { caes_test_AES_set_encrypt_key_attempts_before_fail--; } result = caes_test_real_AES_set_encrypt_key( userKey, bits, key ); return( result ); } /* Custom AES_set_decrypt_key for testing error cases * Returns 0 if successful or a negative value otherwise */ int AES_set_decrypt_key( const unsigned char *userKey, const int bits, AES_KEY *key ) { int result = 0; if( caes_test_real_AES_set_decrypt_key == NULL ) { caes_test_real_AES_set_decrypt_key = dlsym( RTLD_NEXT, "AES_set_decrypt_key" ); } if( caes_test_AES_set_decrypt_key_attempts_before_fail == 0 ) { caes_test_AES_set_decrypt_key_attempts_before_fail = -1; return( -1 ); } else if( caes_test_AES_set_decrypt_key_attempts_before_fail > 0 ) { caes_test_AES_set_decrypt_key_attempts_before_fail--; } result = caes_test_real_AES_set_decrypt_key( userKey, bits, key ); return( result ); } #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && ( defined( HAVE_EVP_CRYPTO_AES_CBC ) || defined( HAVE_EVP_CRYPTO_AES_ECB ) ) /* Custom EVP_CIPHER_CTX_set_padding for testing error cases * Returns 1 if successful or 0 otherwise */ int EVP_CIPHER_CTX_set_padding( EVP_CIPHER_CTX *c, int pad ) { int result = 0; if( caes_test_real_EVP_CIPHER_CTX_set_padding == NULL ) { caes_test_real_EVP_CIPHER_CTX_set_padding = dlsym( RTLD_NEXT, "EVP_CIPHER_CTX_set_padding" ); } if( caes_test_EVP_CIPHER_CTX_set_padding_attempts_before_fail == 0 ) { caes_test_EVP_CIPHER_CTX_set_padding_attempts_before_fail = -1; return( 0 ); } else if( caes_test_EVP_CIPHER_CTX_set_padding_attempts_before_fail > 0 ) { caes_test_EVP_CIPHER_CTX_set_padding_attempts_before_fail--; } result = caes_test_real_EVP_CIPHER_CTX_set_padding( c, pad ); return( result ); } /* Custom EVP_CipherInit_ex for testing error cases * Returns 1 if successful or 0 otherwise */ int EVP_CipherInit_ex( EVP_CIPHER_CTX *ctx, const EVP_CIPHER *type, ENGINE *impl, const unsigned char *key, const unsigned char *iv, int enc ) { int result = 0; if( caes_test_real_EVP_CipherInit_ex == NULL ) { caes_test_real_EVP_CipherInit_ex = dlsym( RTLD_NEXT, "EVP_CipherInit_ex" ); } if( caes_test_EVP_CipherInit_ex_attempts_before_fail == 0 ) { caes_test_EVP_CipherInit_ex_attempts_before_fail = -1; return( 0 ); } else if( caes_test_EVP_CipherInit_ex_attempts_before_fail > 0 ) { caes_test_EVP_CipherInit_ex_attempts_before_fail--; } result = caes_test_real_EVP_CipherInit_ex( ctx, type, impl, key, iv, enc ); return( result ); } /* Custom EVP_CipherUpdate for testing error cases * Returns 1 if successful or 0 otherwise */ int EVP_CipherUpdate( EVP_CIPHER_CTX *ctx, unsigned char *out, int *outl, const unsigned char *in, int inl ) { int result = 0; if( caes_test_real_EVP_CipherUpdate == NULL ) { caes_test_real_EVP_CipherUpdate = dlsym( RTLD_NEXT, "EVP_CipherUpdate" ); } if( caes_test_EVP_CipherUpdate_attempts_before_fail == 0 ) { caes_test_EVP_CipherUpdate_attempts_before_fail = -1; return( 0 ); } else if( caes_test_EVP_CipherUpdate_attempts_before_fail > 0 ) { caes_test_EVP_CipherUpdate_attempts_before_fail--; } result = caes_test_real_EVP_CipherUpdate( ctx, out, outl, in, inl ); return( result ); } #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_EBC_ENCRYPT ) ) */ #endif /* defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) */ /* Tests the libcaes_context_initialize function * Returns 1 if successful or 0 if not */ int caes_test_context_initialize( void ) { libcaes_context_t *context = NULL; libcerror_error_t *error = NULL; int result = 0; #if defined( HAVE_CAES_TEST_MEMORY ) int number_of_malloc_fail_tests = 1; int number_of_memset_fail_tests = 1; int test_number = 0; #endif /* Test regular cases */ result = libcaes_context_initialize( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); result = libcaes_context_free( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test error cases */ result = libcaes_context_initialize( NULL, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); context = (libcaes_context_t *) 0x12345678UL; result = libcaes_context_initialize( &context, &error ); context = NULL; CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); #if defined( HAVE_CAES_TEST_MEMORY ) #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_EBC_ENCRYPT ) ) /* No additional test definitions needed */ #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && !defined( HAVE_EVP_CIPHER_CTX_INIT ) && ( defined( HAVE_EVP_CRYPTO_AES_CBC ) || defined( HAVE_EVP_CRYPTO_AES_ECB ) ) number_of_malloc_fail_tests = 2; #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_EBC_ENCRYPT ) ) */ /* 1 fail in memory_allocate_structure * 2 fail in EVP_CIPHER_CTX_new */ for( test_number = 0; test_number < number_of_malloc_fail_tests; test_number++ ) { /* Test libcaes_context_initialize with malloc failing */ caes_test_malloc_attempts_before_fail = test_number; result = libcaes_context_initialize( &context, &error ); if( caes_test_malloc_attempts_before_fail != -1 ) { caes_test_malloc_attempts_before_fail = -1; if( context != NULL ) { libcaes_context_free( &context, NULL ); } } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NULL( "context", context ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } } /* 1 fail in memset after memory_allocate_structure */ for( test_number = 0; test_number < number_of_memset_fail_tests; test_number++ ) { /* Test libcaes_context_initialize with memset failing */ caes_test_memset_attempts_before_fail = test_number; result = libcaes_context_initialize( &context, &error ); if( caes_test_memset_attempts_before_fail != -1 ) { caes_test_memset_attempts_before_fail = -1; if( context != NULL ) { libcaes_context_free( &context, NULL ); } } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NULL( "context", context ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } } #endif /* defined( HAVE_CAES_TEST_MEMORY ) */ return( 1 ); on_error: if( error != NULL ) { libcerror_error_free( &error ); } if( context != NULL ) { libcaes_context_free( &context, NULL ); } return( 0 ); } /* Tests the libcaes_context_free function * Returns 1 if successful or 0 if not */ int caes_test_context_free( void ) { libcerror_error_t *error = NULL; int result = 0; /* Test error cases */ result = libcaes_context_free( NULL, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); return( 1 ); on_error: if( error != NULL ) { libcerror_error_free( &error ); } return( 0 ); } /* Tests the libcaes_context_set_key function * Returns 1 if successful or 0 if not */ int caes_test_context_set_key( void ) { uint8_t key[ 16 ]; libcaes_context_t *context = NULL; libcerror_error_t *error = NULL; int result = 0; /* Initialize test */ result = libcaes_context_initialize( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test regular cases */ result = libcaes_context_set_key( context, LIBCAES_CRYPT_MODE_DECRYPT, key, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test error cases */ result = libcaes_context_set_key( NULL, LIBCAES_CRYPT_MODE_DECRYPT, key, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_context_set_key( context, -1, key, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_context_set_key( context, LIBCAES_CRYPT_MODE_DECRYPT, NULL, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_context_set_key( context, LIBCAES_CRYPT_MODE_DECRYPT, key, 0, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_EBC_ENCRYPT ) ) #if defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) /* Test libcaes_context_set_key with AES_set_encrypt_key failing */ caes_test_AES_set_encrypt_key_attempts_before_fail = 0; result = libcaes_context_set_key( context, LIBCAES_CRYPT_MODE_ENCRYPT, key, 128, &error ); if( caes_test_AES_set_encrypt_key_attempts_before_fail != -1 ) { caes_test_AES_set_encrypt_key_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } /* Test libcaes_context_set_key with AES_set_decrypt_key failing */ caes_test_AES_set_decrypt_key_attempts_before_fail = 0; result = libcaes_context_set_key( context, LIBCAES_CRYPT_MODE_DECRYPT, key, 128, &error ); if( caes_test_AES_set_decrypt_key_attempts_before_fail != -1 ) { caes_test_AES_set_decrypt_key_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) */ #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && ( defined( HAVE_EVP_CRYPTO_AES_CBC ) || defined( HAVE_EVP_CRYPTO_AES_ECB ) ) #if defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) /* Test libcaes_context_set_key with memcpy failing */ caes_test_memcpy_attempts_before_fail = 0; result = libcaes_context_set_key( context, LIBCAES_CRYPT_MODE_DECRYPT, key, 128, &error ); if( caes_test_memcpy_attempts_before_fail != -1 ) { caes_test_memcpy_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) */ #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_EBC_ENCRYPT ) ) */ /* Clean up */ result = libcaes_context_free( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); return( 1 ); on_error: if( error != NULL ) { libcerror_error_free( &error ); } if( context != NULL ) { libcaes_context_free( &context, NULL ); } return( 0 ); } #if !defined( LIBCAES_HAVE_AES_SUPPORT ) #if defined( __GNUC__ ) && !defined( LIBCAES_DLL_IMPORT ) /* Tests the libcaes_initialize_tables function * Returns 1 if successful or 0 if not */ int caes_test_initialize_tables( void ) { libcerror_error_t *error = NULL; int result = 0; /* Test regular cases */ result = libcaes_initialize_tables( &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test error cases */ #if defined( HAVE_CAES_TEST_MEMORY ) /* Test libcaes_initialize_tables with memset of logs_table failing */ caes_test_memset_attempts_before_fail = 0; result = libcaes_initialize_tables( &error ); if( caes_test_memset_attempts_before_fail != -1 ) { caes_test_memset_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_CAES_TEST_MEMORY ) */ return( 1 ); on_error: if( error != NULL ) { libcerror_error_free( &error ); } return( 0 ); } /* Tests the libcaes_internal_context_set_decryption_key function * Returns 1 if successful or 0 if not */ int caes_test_internal_context_set_decryption_key( void ) { uint8_t key[ 16 ]; libcaes_context_t *context = NULL; libcerror_error_t *error = NULL; int result = 0; /* Initialize test */ result = libcaes_context_initialize( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test regular cases */ result = libcaes_internal_context_set_decryption_key( (libcaes_internal_context_t *) context, key, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test error cases */ result = libcaes_internal_context_set_decryption_key( NULL, key, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_internal_context_set_decryption_key( (libcaes_internal_context_t *) context, NULL, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_internal_context_set_decryption_key( (libcaes_internal_context_t *) context, key, 0, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); /* Clean up */ result = libcaes_context_free( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); return( 1 ); on_error: if( error != NULL ) { libcerror_error_free( &error ); } if( context != NULL ) { libcaes_context_free( &context, NULL ); } return( 0 ); } /* Tests the libcaes_internal_context_set_encryption_key function * Returns 1 if successful or 0 if not */ int caes_test_internal_context_set_encryption_key( void ) { uint8_t key[ 16 ]; libcaes_context_t *context = NULL; libcerror_error_t *error = NULL; int result = 0; /* Initialize test */ result = libcaes_context_initialize( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test regular cases */ result = libcaes_internal_context_set_encryption_key( (libcaes_internal_context_t *) context, key, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test error cases */ result = libcaes_internal_context_set_encryption_key( NULL, key, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_internal_context_set_encryption_key( (libcaes_internal_context_t *) context, NULL, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_internal_context_set_encryption_key( (libcaes_internal_context_t *) context, key, 0, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); /* Clean up */ result = libcaes_context_free( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); return( 1 ); on_error: if( error != NULL ) { libcerror_error_free( &error ); } if( context != NULL ) { libcaes_context_free( &context, NULL ); } return( 0 ); } #endif /* defined( __GNUC__ ) && !defined( LIBCAES_DLL_IMPORT ) */ #endif /* !defined( LIBCAES_HAVE_AES_SUPPORT ) */ /* Tests the libcaes_crypt_cbc function * Returns 1 if successful or 0 if not */ int caes_test_crypt_cbc( void ) { uint8_t output_data[ 16 ]; libcaes_context_t *context = NULL; libcerror_error_t *error = NULL; size_t maximum_size = 0; int result = 0; int test_number = 0; /* Initialize test */ result = libcaes_context_initialize( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test regular cases */ for( test_number = 0; test_number < 24; test_number++ ) { result = libcaes_context_set_key( context, caes_context_aes_cbc_test_vectors[ test_number ].mode, caes_context_aes_cbc_test_vectors[ test_number ].key, caes_context_aes_cbc_test_vectors[ test_number ].key_bit_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ test_number ].mode, caes_context_aes_cbc_test_vectors[ test_number ].initialization_vector, caes_context_aes_cbc_test_vectors[ test_number ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ test_number ].input_data, caes_context_aes_cbc_test_vectors[ test_number ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ test_number ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); result = memory_compare( output_data, caes_context_aes_cbc_test_vectors[ test_number ].output_data, caes_context_aes_cbc_test_vectors[ test_number ].output_data_size ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 0 ); } /* Initialize test */ result = libcaes_context_set_key( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].key, caes_context_aes_cbc_test_vectors[ 1 ].key_bit_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test error cases */ result = libcaes_crypt_cbc( NULL, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_cbc( context, -1, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, NULL, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, 0, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, NULL, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && defined( HAVE_AES_CBC_ENCRYPT ) maximum_size = (size_t) SSIZE_MAX; #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_CBC ) maximum_size = (size_t) INT_MAX; #else maximum_size = (size_t) SSIZE_MAX; #endif if( maximum_size > 0 ) { result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, maximum_size + 1, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, 8, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, NULL, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); if( maximum_size > 0 ) { result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, maximum_size + 1, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, 8, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_EBC_ENCRYPT ) ) #if defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) /* Test libcaes_crypt_cbc with memcpy of initialization_vector to safe_initialization_vector failing */ caes_test_memcpy_attempts_before_fail = 0; result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); if( caes_test_memcpy_attempts_before_fail != -1 ) { caes_test_memcpy_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) */ #if defined( HAVE_CAES_TEST_MEMORY ) /* Test libcaes_crypt_cbc with memset of safe_initialization_vector failing */ caes_test_memset_attempts_before_fail = 0; result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); if( caes_test_memset_attempts_before_fail != -1 ) { caes_test_memset_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_CAES_TEST_MEMORY ) */ #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_CBC ) #if defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) /* Test libcaes_crypt_cbc with memset of block_data failing */ caes_test_memset_attempts_before_fail = 0; result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); if( caes_test_memset_attempts_before_fail != -1 ) { caes_test_memset_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) */ #if defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) /* Test libcaes_crypt_cbc with EVP_CipherInit_ex failing */ caes_test_EVP_CipherInit_ex_attempts_before_fail = 0; result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); if( caes_test_EVP_CipherInit_ex_attempts_before_fail != -1 ) { caes_test_EVP_CipherInit_ex_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } /* Test libcaes_crypt_cbc with EVP_CIPHER_CTX_set_padding failing */ /* TODO implement */ /* Test libcaes_crypt_cbc with EVP_CipherUpdate failing */ caes_test_EVP_CipherUpdate_attempts_before_fail = 0; result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); if( caes_test_EVP_CipherUpdate_attempts_before_fail != -1 ) { caes_test_EVP_CipherUpdate_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) */ #else #if defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) /* Test libcaes_crypt_cbc with memcpy of initialization_vector to internal_initialization_vector failing */ caes_test_memcpy_attempts_before_fail = 0; result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); if( caes_test_memcpy_attempts_before_fail != -1 ) { caes_test_memcpy_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } /* Test libcaes_crypt_cbc with memcpy of input_data to output_data failing */ caes_test_memcpy_attempts_before_fail = 1; result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 0 ].mode, caes_context_aes_cbc_test_vectors[ 0 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 0 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 0 ].input_data, caes_context_aes_cbc_test_vectors[ 0 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 0 ].output_data_size, &error ); if( caes_test_memcpy_attempts_before_fail != -1 ) { caes_test_memcpy_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } /* Test libcaes_crypt_cbc with memcpy of output_data to internal_initialization_vector failing */ caes_test_memcpy_attempts_before_fail = 2; result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 0 ].mode, caes_context_aes_cbc_test_vectors[ 0 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 0 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 0 ].input_data, caes_context_aes_cbc_test_vectors[ 0 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 0 ].output_data_size, &error ); if( caes_test_memcpy_attempts_before_fail != -1 ) { caes_test_memcpy_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } /* Test libcaes_crypt_cbc with memcpy of input_data to internal_initialization_vector failing */ caes_test_memcpy_attempts_before_fail = 1; result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); if( caes_test_memcpy_attempts_before_fail != -1 ) { caes_test_memcpy_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) */ #if defined( HAVE_CAES_TEST_MEMORY ) /* Test libcaes_crypt_cbc with memset of internal_initialization_vector failing */ caes_test_memset_attempts_before_fail = 0; result = libcaes_crypt_cbc( context, caes_context_aes_cbc_test_vectors[ 1 ].mode, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector, caes_context_aes_cbc_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cbc_test_vectors[ 1 ].input_data, caes_context_aes_cbc_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cbc_test_vectors[ 1 ].output_data_size, &error ); if( caes_test_memset_attempts_before_fail != -1 ) { caes_test_memset_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_CAES_TEST_MEMORY ) */ #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_EBC_ENCRYPT ) ) */ /* Clean up */ result = libcaes_context_free( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); return( 1 ); on_error: if( error != NULL ) { libcerror_error_free( &error ); } if( context != NULL ) { libcaes_context_free( &context, NULL ); } return( 0 ); } /* Tests the libcaes_crypt_ccm function * Returns 1 if successful or 0 if not */ int caes_test_crypt_ccm( void ) { uint8_t input_data[ 208 ]; uint8_t key[ 16 ]; uint8_t nonce[ 8 ]; uint8_t output_data[ 208 ]; libcaes_context_t *context = NULL; libcerror_error_t *error = NULL; int result = 0; #if defined( HAVE_CAES_TEST_MEMORY ) int number_of_memset_fail_tests = 1; int test_number = 0; #if defined( OPTIMIZATION_DISABLED ) int number_of_memcpy_fail_tests = 2; #endif #endif /* defined( HAVE_CAES_TEST_MEMORY ) */ /* Initialize test */ result = libcaes_context_initialize( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); result = libcaes_context_set_key( context, LIBCAES_CRYPT_MODE_DECRYPT, key, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test regular cases */ result = libcaes_crypt_ccm( context, LIBCAES_CRYPT_MODE_DECRYPT, nonce, 8, input_data, 208, output_data, 208, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test error cases */ result = libcaes_crypt_ccm( NULL, LIBCAES_CRYPT_MODE_DECRYPT, nonce, 8, input_data, 208, output_data, 208, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_ccm( context, -1, nonce, 8, input_data, 208, output_data, 208, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_ccm( context, LIBCAES_CRYPT_MODE_DECRYPT, NULL, 8, input_data, 208, output_data, 208, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_ccm( context, LIBCAES_CRYPT_MODE_DECRYPT, nonce, 15, input_data, 208, output_data, 208, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_ccm( context, LIBCAES_CRYPT_MODE_DECRYPT, nonce, 8, NULL, 208, output_data, 208, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_ccm( context, LIBCAES_CRYPT_MODE_DECRYPT, nonce, 8, input_data, (size_t) SSIZE_MAX + 1, output_data, 208, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_ccm( context, LIBCAES_CRYPT_MODE_DECRYPT, nonce, 8, input_data, 208, NULL, 208, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_ccm( context, LIBCAES_CRYPT_MODE_DECRYPT, nonce, 8, input_data, 208, output_data, (size_t) SSIZE_MAX + 1, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); #if defined( HAVE_CAES_TEST_MEMORY ) /* 1 memset of internal_initialization_vector * * TODO determine how many memsets are introduced by libcaes_crypt_ecb * # - 1 memset of block_data * # memset of internal_initialization_vector */ for( test_number = 0; test_number < number_of_memset_fail_tests; test_number++ ) { /* Test libcaes_context_initialize with memset failing */ caes_test_memset_attempts_before_fail = test_number; result = libcaes_crypt_ccm( context, LIBCAES_CRYPT_MODE_DECRYPT, nonce, 8, input_data, 208, output_data, 208, &error ); if( caes_test_memset_attempts_before_fail != -1 ) { caes_test_memset_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } } #if defined( OPTIMIZATION_DISABLED ) /* 1 memcpy of nonce to internal_initialization_vector * 2 memcpy of input_data cwtoot output_data */ for( test_number = 0; test_number < number_of_memcpy_fail_tests; test_number++ ) { /* Test libcaes_context_initialize with memcpy failing */ caes_test_memcpy_attempts_before_fail = test_number; result = libcaes_crypt_ccm( context, LIBCAES_CRYPT_MODE_DECRYPT, nonce, 8, input_data, 208, output_data, 208, &error ); if( caes_test_memcpy_attempts_before_fail != -1 ) { caes_test_memcpy_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } } #endif /* defined( OPTIMIZATION_DISABLED ) */ #endif /* defined( HAVE_CAES_TEST_MEMORY ) */ /* Clean up */ result = libcaes_context_free( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); return( 1 ); on_error: if( error != NULL ) { libcerror_error_free( &error ); } if( context != NULL ) { libcaes_context_free( &context, NULL ); } return( 0 ); } /* Tests the libcaes_crypt_cfb function * Returns 1 if successful or 0 if not */ int caes_test_crypt_cfb( void ) { uint8_t output_data[ 208 ]; libcaes_context_t *context = NULL; libcerror_error_t *error = NULL; int result = 0; int test_number = 0; /* Initialize test */ result = libcaes_context_initialize( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test regular cases */ for( test_number = 0; test_number < 8; test_number++ ) { result = libcaes_context_set_key( context, LIBCAES_CRYPT_MODE_ENCRYPT, caes_context_aes_cfb_test_vectors[ test_number ].key, caes_context_aes_cfb_test_vectors[ test_number ].key_bit_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); result = libcaes_crypt_cfb( context, caes_context_aes_cfb_test_vectors[ test_number ].mode, caes_context_aes_cfb_test_vectors[ test_number ].initialization_vector, caes_context_aes_cfb_test_vectors[ test_number ].initialization_vector_size, caes_context_aes_cfb_test_vectors[ test_number ].input_data, caes_context_aes_cfb_test_vectors[ test_number ].input_data_size, output_data, caes_context_aes_cfb_test_vectors[ test_number ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); result = memory_compare( output_data, caes_context_aes_cfb_test_vectors[ test_number ].output_data, caes_context_aes_cfb_test_vectors[ test_number ].output_data_size ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 0 ); } /* Test error cases */ result = libcaes_crypt_cfb( NULL, caes_context_aes_cfb_test_vectors[ 1 ].mode, caes_context_aes_cfb_test_vectors[ 1 ].initialization_vector, caes_context_aes_cfb_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cfb_test_vectors[ 1 ].input_data, caes_context_aes_cfb_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cfb_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_cfb( context, -1, caes_context_aes_cfb_test_vectors[ 1 ].initialization_vector, caes_context_aes_cfb_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cfb_test_vectors[ 1 ].input_data, caes_context_aes_cfb_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cfb_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_cfb( context, caes_context_aes_cfb_test_vectors[ 1 ].mode, NULL, caes_context_aes_cfb_test_vectors[ 1 ].initialization_vector_size, caes_context_aes_cfb_test_vectors[ 1 ].input_data, caes_context_aes_cfb_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cfb_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_cfb( context, caes_context_aes_cfb_test_vectors[ 1 ].mode, caes_context_aes_cfb_test_vectors[ 1 ].initialization_vector, 0, caes_context_aes_cfb_test_vectors[ 1 ].input_data, caes_context_aes_cfb_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cfb_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_cfb( context, caes_context_aes_cfb_test_vectors[ 1 ].mode, caes_context_aes_cfb_test_vectors[ 1 ].initialization_vector, caes_context_aes_cfb_test_vectors[ 1 ].initialization_vector_size, NULL, caes_context_aes_cfb_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_cfb_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); /* Clean up */ result = libcaes_context_free( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); return( 1 ); on_error: if( error != NULL ) { libcerror_error_free( &error ); } if( context != NULL ) { libcaes_context_free( &context, NULL ); } return( 0 ); } /* Tests the libcaes_crypt_ecb function * Returns 1 if successful or 0 if not */ int caes_test_crypt_ecb( void ) { uint8_t output_data[ 16 ]; libcaes_context_t *context = NULL; libcerror_error_t *error = NULL; size_t maximum_size = 0; int result = 0; int test_number = 0; /* Initialize test */ result = libcaes_context_initialize( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test regular cases */ for( test_number = 0; test_number < 1950; test_number++ ) { result = libcaes_context_set_key( context, caes_context_aes_ecb_test_vectors[ test_number ].mode, caes_context_aes_ecb_test_vectors[ test_number ].key, caes_context_aes_ecb_test_vectors[ test_number ].key_bit_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); result = libcaes_crypt_ecb( context, caes_context_aes_ecb_test_vectors[ test_number ].mode, caes_context_aes_ecb_test_vectors[ test_number ].input_data, caes_context_aes_ecb_test_vectors[ test_number ].input_data_size, output_data, caes_context_aes_ecb_test_vectors[ test_number ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); result = memory_compare( output_data, caes_context_aes_ecb_test_vectors[ test_number ].output_data, caes_context_aes_ecb_test_vectors[ test_number ].output_data_size ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 0 ); } /* Initialize test */ result = libcaes_context_set_key( context, caes_context_aes_ecb_test_vectors[ 1 ].mode, caes_context_aes_ecb_test_vectors[ 1 ].key, caes_context_aes_ecb_test_vectors[ 1 ].key_bit_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test error cases */ result = libcaes_crypt_ecb( NULL, caes_context_aes_ecb_test_vectors[ 1 ].mode, caes_context_aes_ecb_test_vectors[ 1 ].input_data, caes_context_aes_ecb_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_ecb_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_ecb( context, -1, caes_context_aes_ecb_test_vectors[ 1 ].input_data, caes_context_aes_ecb_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_ecb_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_ecb( context, caes_context_aes_ecb_test_vectors[ 1 ].mode, NULL, caes_context_aes_ecb_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_ecb_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_EBC_ENCRYPT ) ) maximum_size = (size_t) SSIZE_MAX; #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_ECB ) maximum_size = (size_t) INT_MAX; #else maximum_size = (size_t) SSIZE_MAX; #endif if( maximum_size > 0 ) { result = libcaes_crypt_ecb( context, caes_context_aes_ecb_test_vectors[ 1 ].mode, caes_context_aes_ecb_test_vectors[ 1 ].input_data, (size_t) maximum_size + 1, output_data, caes_context_aes_ecb_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } result = libcaes_crypt_ecb( context, caes_context_aes_ecb_test_vectors[ 1 ].mode, caes_context_aes_ecb_test_vectors[ 1 ].input_data, 0, output_data, caes_context_aes_ecb_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_ecb( context, caes_context_aes_ecb_test_vectors[ 1 ].mode, caes_context_aes_ecb_test_vectors[ 1 ].input_data, caes_context_aes_ecb_test_vectors[ 1 ].input_data_size, NULL, caes_context_aes_ecb_test_vectors[ 1 ].output_data_size, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); if( maximum_size > 0 ) { result = libcaes_crypt_ecb( context, caes_context_aes_ecb_test_vectors[ 1 ].mode, caes_context_aes_ecb_test_vectors[ 1 ].input_data, caes_context_aes_ecb_test_vectors[ 1 ].input_data_size, output_data, (size_t) maximum_size + 1, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } result = libcaes_crypt_ecb( context, caes_context_aes_ecb_test_vectors[ 1 ].mode, caes_context_aes_ecb_test_vectors[ 1 ].input_data, caes_context_aes_ecb_test_vectors[ 1 ].input_data_size, output_data, 0, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_EBC_ENCRYPT ) ) /* No additional test definitions needed */ #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_ECB ) #if defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) /* Test libcaes_crypt_ecb with memset of block_data failing */ caes_test_memset_attempts_before_fail = 0; result = libcaes_crypt_ecb( context, caes_context_aes_ecb_test_vectors[ 1 ].mode, caes_context_aes_ecb_test_vectors[ 1 ].input_data, caes_context_aes_ecb_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_ecb_test_vectors[ 1 ].output_data_size, &error ); if( caes_test_memset_attempts_before_fail != -1 ) { caes_test_memset_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) */ #if defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) /* Test libcaes_crypt_ecb with EVP_CipherInit_ex failing */ caes_test_EVP_CipherInit_ex_attempts_before_fail = 0; result = libcaes_crypt_ecb( context, caes_context_aes_ecb_test_vectors[ 1 ].mode, caes_context_aes_ecb_test_vectors[ 1 ].input_data, caes_context_aes_ecb_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_ecb_test_vectors[ 1 ].output_data_size, &error ); if( caes_test_EVP_CipherInit_ex_attempts_before_fail != -1 ) { caes_test_EVP_CipherInit_ex_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } /* Test libcaes_crypt_ecb with EVP_CIPHER_CTX_set_padding failing */ /* TODO implement */ /* Test libcaes_crypt_ecb with EVP_CipherUpdate failing */ caes_test_EVP_CipherUpdate_attempts_before_fail = 0; result = libcaes_crypt_ecb( context, caes_context_aes_ecb_test_vectors[ 1 ].mode, caes_context_aes_ecb_test_vectors[ 1 ].input_data, caes_context_aes_ecb_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_ecb_test_vectors[ 1 ].output_data_size, &error ); if( caes_test_EVP_CipherUpdate_attempts_before_fail != -1 ) { caes_test_EVP_CipherUpdate_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) */ #else #if defined( HAVE_CAES_TEST_MEMORY ) /* Test libcaes_crypt_ecb with memset of values_32bit failing */ caes_test_memset_attempts_before_fail = 0; result = libcaes_crypt_ecb( context, caes_context_aes_ecb_test_vectors[ 1 ].mode, caes_context_aes_ecb_test_vectors[ 1 ].input_data, caes_context_aes_ecb_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_ecb_test_vectors[ 1 ].output_data_size, &error ); if( caes_test_memset_attempts_before_fail != -1 ) { caes_test_memset_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } /* Test libcaes_crypt_ecb with memset of cipher_values_32bit failing */ caes_test_memset_attempts_before_fail = 1; result = libcaes_crypt_ecb( context, caes_context_aes_ecb_test_vectors[ 1 ].mode, caes_context_aes_ecb_test_vectors[ 1 ].input_data, caes_context_aes_ecb_test_vectors[ 1 ].input_data_size, output_data, caes_context_aes_ecb_test_vectors[ 1 ].output_data_size, &error ); if( caes_test_memset_attempts_before_fail != -1 ) { caes_test_memset_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_CAES_TEST_MEMORY ) */ #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) && ( defined( HAVE_AES_CBC_ENCRYPT ) || defined( HAVE_AES_EBC_ENCRYPT ) ) */ /* Clean up */ result = libcaes_context_free( &context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "context", context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); return( 1 ); on_error: if( error != NULL ) { libcerror_error_free( &error ); } if( context != NULL ) { libcaes_context_free( &context, NULL ); } return( 0 ); } /* The main program */ #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) int wmain( int argc CAES_TEST_ATTRIBUTE_UNUSED, wchar_t * const argv[] CAES_TEST_ATTRIBUTE_UNUSED ) #else int main( int argc CAES_TEST_ATTRIBUTE_UNUSED, char * const argv[] CAES_TEST_ATTRIBUTE_UNUSED ) #endif { CAES_TEST_UNREFERENCED_PARAMETER( argc ) CAES_TEST_UNREFERENCED_PARAMETER( argv ) CAES_TEST_RUN( "libcaes_context_initialize", caes_test_context_initialize ); CAES_TEST_RUN( "libcaes_context_free", caes_test_context_free ); CAES_TEST_RUN( "libcaes_context_set_key", caes_test_context_set_key ); #if !defined( LIBCAES_HAVE_AES_SUPPORT ) #if defined( __GNUC__ ) && !defined( LIBCAES_DLL_IMPORT ) CAES_TEST_RUN( "libcaes_initialize_tables", caes_test_initialize_tables ); CAES_TEST_RUN( "libcaes_internal_context_set_decryption_key", caes_test_internal_context_set_decryption_key ); CAES_TEST_RUN( "libcaes_internal_context_set_encryption_key", caes_test_internal_context_set_encryption_key ); #endif /* defined( __GNUC__ ) && !defined( LIBCAES_DLL_IMPORT ) */ #endif /* !defined( LIBCAES_HAVE_AES_SUPPORT ) */ CAES_TEST_RUN( "libcaes_crypt_cbc", caes_test_crypt_cbc ); CAES_TEST_RUN( "libcaes_crypt_ccm", caes_test_crypt_ccm ); CAES_TEST_RUN( "libcaes_crypt_cfb", caes_test_crypt_cfb ); CAES_TEST_RUN( "libcaes_crypt_ecb", caes_test_crypt_ecb ); return( EXIT_SUCCESS ); on_error: return( EXIT_FAILURE ); } libcaes-20240413/tests/caes_test_crypt_ccm.c0000644000175000017500000001414314606473413021551 0ustar00lordyestalordyesta/* * Library AES-CCM de/encryption testing program * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include #include #if defined( HAVE_STDLIB_H ) || defined( WINAPI ) #include #endif #include "caes_test_libcaes.h" #include "caes_test_libcerror.h" #include "caes_test_unused.h" /* Tests AES-CCM de/encryption * Returns 1 if successful, 0 if not or -1 on error */ int caes_test_crypt_ccm( int mode, const uint8_t *key, size_t key_bit_size, const uint8_t *nonce, size_t nonce_size, const uint8_t *input_data, size_t input_data_size, const uint8_t *expected_output_data, size_t expected_output_data_size ) { uint8_t output_data[ 256 ]; libcaes_context_t *context = NULL; libcerror_error_t *error = NULL; static char *function = "caes_test_crypt_ccm"; size_t output_data_size = 256; int result = 0; if( input_data_size > output_data_size ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid input data size value out of bounds.", function ); goto on_error; } if( libcaes_context_initialize( &context, &error ) != 1 ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to create context.", function ); goto on_error; } if( libcaes_context_set_key( context, LIBCAES_CRYPT_MODE_ENCRYPT, key, key_bit_size, &error ) != 1 ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to set key in context.", function ); goto on_error; } if( libcaes_crypt_ccm( context, mode, nonce, nonce_size, input_data, input_data_size, output_data, output_data_size, &error ) != 1 ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_ENCRYPTION, LIBCERROR_ENCRYPTION_ERROR_GENERIC, "%s: unable to de/encrypt data.", function ); goto on_error; } result = memory_compare( output_data, expected_output_data, expected_output_data_size ); if( libcaes_context_free( &context, &error ) != 1 ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_FINALIZE_FAILED, "%s: unable to free context.", function ); goto on_error; } if( result != 0 ) { return( 0 ); } return( 1 ); on_error: if( error != NULL ) { libcerror_error_backtrace_fprint( error, stdout ); libcerror_error_free( &error ); } if( context != NULL ) { libcaes_context_free( &context, NULL ); } return( -1 ); } /* The main program */ #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) int wmain( int argc, wchar_t * const argv[] CAES_TEST_ATTRIBUTE_UNUSED ) #else int main( int argc, char * const argv[] CAES_TEST_ATTRIBUTE_UNUSED ) #endif { uint8_t key[ 32 ] = { 0x8a, 0x29, 0x41, 0xff, 0x7b, 0x3a, 0x5e, 0xe9, 0x0b, 0xca, 0x70, 0xfb, 0xb2, 0x65, 0xaf, 0xab, 0xed, 0x68, 0xb1, 0x55, 0x07, 0x65, 0x25, 0x55, 0x40, 0xc8, 0x86, 0x1e, 0x13, 0x7e, 0xd0, 0x94 }; uint8_t nonce[ 12 ] = { 0x60, 0xd5, 0x17, 0x86, 0x5b, 0x53, 0xcc, 0x01, 0x03, 0x00, 0x00, 0x00 }; uint8_t cipher_text[ 60 ] = { 0xa8, 0xdf, 0x3d, 0x7c, 0x99, 0x74, 0x2c, 0x49, 0x68, 0x85, 0x70, 0x84, 0x6a, 0xd5, 0xf8, 0x0c, 0x6b, 0x66, 0xc6, 0x8a, 0x3e, 0x30, 0xb7, 0x5b, 0xed, 0x61, 0x52, 0x9c, 0x73, 0xce, 0x36, 0x5c, 0xa1, 0x96, 0x0e, 0x91, 0xa1, 0x48, 0x83, 0x67, 0x8d, 0x09, 0x41, 0xde, 0x51, 0x0b, 0x04, 0x49, 0xa4, 0x19, 0xb5, 0x1e, 0x49, 0xd2, 0xac, 0xfd, 0x6a, 0x0a, 0x78, 0x8c }; uint8_t plain_text[ 60 ] = { 0x18, 0x27, 0x1c, 0x74, 0xeb, 0x49, 0x16, 0xbf, 0x6b, 0x46, 0x31, 0x74, 0x15, 0x41, 0xf1, 0x99, 0x2c, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x03, 0x20, 0x00, 0x00, 0x68, 0x8a, 0x51, 0x70, 0x06, 0x14, 0xdb, 0xd1, 0xc1, 0x00, 0xf5, 0x68, 0xc4, 0xbd, 0x29, 0xa6, 0x3c, 0x46, 0x36, 0x72, 0xbe, 0x6b, 0xde, 0xf5, 0x4b, 0x91, 0x8b, 0xb9, 0xa3, 0xa4, 0x3c, 0xbc }; int result = 0; CAES_TEST_UNREFERENCED_PARAMETER( argv ) if( argc != 1 ) { fprintf( stderr, "Unsupported number of arguments.\n" ); return( EXIT_FAILURE ); } /* Decryption tests */ fprintf( stdout, "Testing AES-CCM 256-bit decryption\t" ); result = caes_test_crypt_ccm( LIBCAES_CRYPT_MODE_DECRYPT, key, 256, nonce, 12, cipher_text, 60, plain_text, 60 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-CCM 256-bit decryption.\n" ); return( EXIT_FAILURE ); } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } /* Encryption tests */ fprintf( stdout, "Testing AES-CCM 256-bit encryption\t" ); result = caes_test_crypt_ccm( LIBCAES_CRYPT_MODE_ENCRYPT, key, 256, nonce, 12, plain_text, 60, cipher_text, 60 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-CCM 256-bit encryption.\n" ); return( EXIT_FAILURE ); } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } return( EXIT_SUCCESS ); } libcaes-20240413/tests/pycaes_test_crypt_ccm.py0000644000175000017500000000655214606473413022335 0ustar00lordyestalordyesta#!/usr/bin/env python # # Python-bindings AES-CCM de/encryption testing program # # Copyright (C) 2011-2024, Joachim Metz # # Refer to AUTHORS for acknowledgements. # # This software is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This software 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 Lesser General Public License # along with this software. If not, see . # import sys import pycaes def pycaes_test_crypt_ccm(mode, key, nonce, input_data, expected_output_data): caes_context = pycaes.context() # The key must be set in encryption mode (LIBCAES_CRYPT_MODE_ENCRYPT) # for both de- and encryption. caes_context.set_key(pycaes.crypt_modes.ENCRYPT, key) output_data = pycaes.crypt_ccm(caes_context, mode, nonce, input_data) return output_data == expected_output_data def main(): key = [ 0x8a, 0x29, 0x41, 0xff, 0x7b, 0x3a, 0x5e, 0xe9, 0x0b, 0xca, 0x70, 0xfb, 0xb2, 0x65, 0xaf, 0xab, 0xed, 0x68, 0xb1, 0x55, 0x07, 0x65, 0x25, 0x55, 0x40, 0xc8, 0x86, 0x1e, 0x13, 0x7e, 0xd0, 0x94 ] nonce = [ 0x60, 0xd5, 0x17, 0x86, 0x5b, 0x53, 0xcc, 0x01, 0x03, 0x00, 0x00, 0x00 ] cipher_text = [ 0xa8, 0xdf, 0x3d, 0x7c, 0x99, 0x74, 0x2c, 0x49, 0x68, 0x85, 0x70, 0x84, 0x6a, 0xd5, 0xf8, 0x0c, 0x6b, 0x66, 0xc6, 0x8a, 0x3e, 0x30, 0xb7, 0x5b, 0xed, 0x61, 0x52, 0x9c, 0x73, 0xce, 0x36, 0x5c, 0xa1, 0x96, 0x0e, 0x91, 0xa1, 0x48, 0x83, 0x67, 0x8d, 0x09, 0x41, 0xde, 0x51, 0x0b, 0x04, 0x49, 0xa4, 0x19, 0xb5, 0x1e, 0x49, 0xd2, 0xac, 0xfd, 0x6a, 0x0a, 0x78, 0x8c ] plain_text = [ 0x18, 0x27, 0x1c, 0x74, 0xeb, 0x49, 0x16, 0xbf, 0x6b, 0x46, 0x31, 0x74, 0x15, 0x41, 0xf1, 0x99, 0x2c, 0x00, 0x00, 0x00, 0x01, 0x00, 0x00, 0x00, 0x03, 0x20, 0x00, 0x00, 0x68, 0x8a, 0x51, 0x70, 0x06, 0x14, 0xdb, 0xd1, 0xc1, 0x00, 0xf5, 0x68, 0xc4, 0xbd, 0x29, 0xa6, 0x3c, 0x46, 0x36, 0x72, 0xbe, 0x6b, 0xde, 0xf5, 0x4b, 0x91, 0x8b, 0xb9, 0xa3, 0xa4, 0x3c, 0xbc ] print("Testing AES-CCM 256-bit decryption\t"), test_key = bytes(bytearray(key)) test_nonce = bytes(bytearray(nonce)) test_cipher_text = bytes(bytearray(cipher_text)) test_plain_text = bytes(bytearray(plain_text)) result = pycaes_test_crypt_ccm( pycaes.crypt_modes.DECRYPT, test_key, test_nonce, test_cipher_text, test_plain_text) if not result: print("(FAIL)") else: print("(PASS)") if not result: return False print("Testing AES-CCM 256-bit encryption\t"), test_key = bytes(bytearray(key)) test_nonce = bytes(bytearray(nonce)) test_cipher_text = bytes(bytearray(cipher_text)) test_plain_text = bytes(bytearray(plain_text)) result = pycaes_test_crypt_ccm( pycaes.crypt_modes.ENCRYPT, test_key, test_nonce, test_plain_text, test_cipher_text) if not result: print("(FAIL)") else: print("(PASS)") if not result: return False return True if __name__ == "__main__": if not main(): sys.exit(1) else: sys.exit(0) libcaes-20240413/tests/caes_test_error.c0000644000175000017500000000603314606473413020716 0ustar00lordyestalordyesta/* * Library error functions test program * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include #if defined( HAVE_STDLIB_H ) || defined( WINAPI ) #include #endif #include "caes_test_libcaes.h" #include "caes_test_macros.h" #include "caes_test_unused.h" /* Tests the libcaes_error_free function * Returns 1 if successful or 0 if not */ int caes_test_error_free( void ) { /* Test invocation of function only */ libcaes_error_free( NULL ); return( 1 ); } /* Tests the libcaes_error_fprint function * Returns 1 if successful or 0 if not */ int caes_test_error_fprint( void ) { /* Test invocation of function only */ libcaes_error_fprint( NULL, NULL ); return( 1 ); } /* Tests the libcaes_error_sprint function * Returns 1 if successful or 0 if not */ int caes_test_error_sprint( void ) { /* Test invocation of function only */ libcaes_error_sprint( NULL, NULL, 0 ); return( 1 ); } /* Tests the libcaes_error_backtrace_fprint function * Returns 1 if successful or 0 if not */ int caes_test_error_backtrace_fprint( void ) { /* Test invocation of function only */ libcaes_error_backtrace_fprint( NULL, NULL ); return( 1 ); } /* Tests the libcaes_error_backtrace_sprint function * Returns 1 if successful or 0 if not */ int caes_test_error_backtrace_sprint( void ) { /* Test invocation of function only */ libcaes_error_backtrace_sprint( NULL, NULL, 0 ); return( 1 ); } /* The main program */ #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) int wmain( int argc CAES_TEST_ATTRIBUTE_UNUSED, wchar_t * const argv[] CAES_TEST_ATTRIBUTE_UNUSED ) #else int main( int argc CAES_TEST_ATTRIBUTE_UNUSED, char * const argv[] CAES_TEST_ATTRIBUTE_UNUSED ) #endif { CAES_TEST_UNREFERENCED_PARAMETER( argc ) CAES_TEST_UNREFERENCED_PARAMETER( argv ) CAES_TEST_RUN( "libcaes_error_free", caes_test_error_free ); CAES_TEST_RUN( "libcaes_error_fprint", caes_test_error_fprint ); CAES_TEST_RUN( "libcaes_error_sprint", caes_test_error_sprint ); CAES_TEST_RUN( "libcaes_error_backtrace_fprint", caes_test_error_backtrace_fprint ); CAES_TEST_RUN( "libcaes_error_backtrace_sprint", caes_test_error_backtrace_sprint ); return( EXIT_SUCCESS ); on_error: return( EXIT_FAILURE ); } libcaes-20240413/tests/caes_test_tweaked_context.c0000644000175000017500000006671114606473557022777 0ustar00lordyestalordyesta/* * Library tweaked_context type test program * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include #if defined( HAVE_STDLIB_H ) || defined( WINAPI ) #include #endif #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) #include #endif #if defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) #define __USE_GNU #include #undef __USE_GNU #endif #include "caes_test_libcaes.h" #include "caes_test_libcerror.h" #include "caes_test_macros.h" #include "caes_test_memory.h" #include "caes_test_unused.h" #if defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) static int (*caes_test_real_EVP_CIPHER_CTX_set_padding)(EVP_CIPHER_CTX *, int) = NULL; static int (*caes_test_real_EVP_CipherInit_ex)(EVP_CIPHER_CTX *, const EVP_CIPHER *, ENGINE *, const unsigned char *, const unsigned char *, int) = NULL; static int (*caes_test_real_EVP_CipherUpdate)(EVP_CIPHER_CTX *, unsigned char *, int *, const unsigned char *, int) = NULL; int caes_test_EVP_CIPHER_CTX_set_padding_attempts_before_fail = -1; int caes_test_EVP_CipherInit_ex_attempts_before_fail = -1; int caes_test_EVP_CipherUpdate_attempts_before_fail = -1; #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) */ #endif /* defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) */ #if defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) /* Custom EVP_CIPHER_CTX_set_padding for testing error cases * Returns 1 if successful or 0 otherwise */ int EVP_CIPHER_CTX_set_padding( EVP_CIPHER_CTX *c, int pad ) { int result = 0; if( caes_test_real_EVP_CIPHER_CTX_set_padding == NULL ) { caes_test_real_EVP_CIPHER_CTX_set_padding = dlsym( RTLD_NEXT, "EVP_CIPHER_CTX_set_padding" ); } if( caes_test_EVP_CIPHER_CTX_set_padding_attempts_before_fail == 0 ) { caes_test_EVP_CIPHER_CTX_set_padding_attempts_before_fail = -1; return( 0 ); } else if( caes_test_EVP_CIPHER_CTX_set_padding_attempts_before_fail > 0 ) { caes_test_EVP_CIPHER_CTX_set_padding_attempts_before_fail--; } result = caes_test_real_EVP_CIPHER_CTX_set_padding( c, pad ); return( result ); } /* Custom EVP_CipherInit_ex for testing error cases * Returns 1 if successful or 0 otherwise */ int EVP_CipherInit_ex( EVP_CIPHER_CTX *ctx, const EVP_CIPHER *type, ENGINE *impl, const unsigned char *key, const unsigned char *iv, int enc ) { int result = 0; if( caes_test_real_EVP_CipherInit_ex == NULL ) { caes_test_real_EVP_CipherInit_ex = dlsym( RTLD_NEXT, "EVP_CipherInit_ex" ); } if( caes_test_EVP_CipherInit_ex_attempts_before_fail == 0 ) { caes_test_EVP_CipherInit_ex_attempts_before_fail = -1; return( 0 ); } else if( caes_test_EVP_CipherInit_ex_attempts_before_fail > 0 ) { caes_test_EVP_CipherInit_ex_attempts_before_fail--; } result = caes_test_real_EVP_CipherInit_ex( ctx, type, impl, key, iv, enc ); return( result ); } /* Custom EVP_CipherUpdate for testing error cases * Returns 1 if successful or 0 otherwise */ int EVP_CipherUpdate( EVP_CIPHER_CTX *ctx, unsigned char *out, int *outl, const unsigned char *in, int inl ) { int result = 0; if( caes_test_real_EVP_CipherUpdate == NULL ) { caes_test_real_EVP_CipherUpdate = dlsym( RTLD_NEXT, "EVP_CipherUpdate" ); } if( caes_test_EVP_CipherUpdate_attempts_before_fail == 0 ) { caes_test_EVP_CipherUpdate_attempts_before_fail = -1; return( 0 ); } else if( caes_test_EVP_CipherUpdate_attempts_before_fail > 0 ) { caes_test_EVP_CipherUpdate_attempts_before_fail--; } result = caes_test_real_EVP_CipherUpdate( ctx, out, outl, in, inl ); return( result ); } #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) */ #endif /* defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) */ /* Tests the libcaes_tweaked_context_initialize function * Returns 1 if successful or 0 if not */ int caes_test_tweaked_context_initialize( void ) { libcaes_tweaked_context_t *tweaked_context = NULL; libcerror_error_t *error = NULL; int result = 0; #if defined( HAVE_CAES_TEST_MEMORY ) int number_of_malloc_fail_tests = 3; int number_of_memset_fail_tests = 1; int test_number = 0; #endif /* Test regular cases */ result = libcaes_tweaked_context_initialize( &tweaked_context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "tweaked_context", tweaked_context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); result = libcaes_tweaked_context_free( &tweaked_context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "tweaked_context", tweaked_context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test error cases */ result = libcaes_tweaked_context_initialize( NULL, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); tweaked_context = (libcaes_tweaked_context_t *) 0x12345678UL; result = libcaes_tweaked_context_initialize( &tweaked_context, &error ); tweaked_context = NULL; CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); #if defined( HAVE_CAES_TEST_MEMORY ) #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) /* No additional test definitions needed */ #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && !defined( HAVE_EVP_CIPHER_CTX_INIT ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) number_of_malloc_fail_tests = 2; #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && !defined( HAVE_EVP_CIPHER_CTX_INIT ) && ( defined( HAVE_EVP_CRYPTO_AES_CBC ) || defined( HAVE_EVP_CRYPTO_AES_ECB ) ) number_of_malloc_fail_tests = 5; #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) */ /* 1 fail in memory_allocate_structure * 2 fail in memory_allocate_structure of libcaes_context_initialize of main context or in EVP_CIPHER_CTX_new * 3 fail in memory_allocate_structure of libcaes_context_initialize of tweak context or in EVP_CIPHER_CTX_new of libcaes_context_initialize * 4 fail in memory_allocate_structure of libcaes_context_initialize of tweak context * 5 fail in EVP_CIPHER_CTX_new of libcaes_context_initialize of tweak context */ for( test_number = 0; test_number < number_of_malloc_fail_tests; test_number++ ) { /* Test libcaes_tweaked_context_initialize with malloc failing */ caes_test_malloc_attempts_before_fail = test_number; result = libcaes_tweaked_context_initialize( &tweaked_context, &error ); if( caes_test_malloc_attempts_before_fail != -1 ) { caes_test_malloc_attempts_before_fail = -1; if( tweaked_context != NULL ) { libcaes_tweaked_context_free( &tweaked_context, NULL ); } } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NULL( "tweaked_context", tweaked_context ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } } for( test_number = 0; test_number < number_of_memset_fail_tests; test_number++ ) { /* Test libcaes_tweaked_context_initialize with memset failing */ caes_test_memset_attempts_before_fail = test_number; result = libcaes_tweaked_context_initialize( &tweaked_context, &error ); if( caes_test_memset_attempts_before_fail != -1 ) { caes_test_memset_attempts_before_fail = -1; if( tweaked_context != NULL ) { libcaes_tweaked_context_free( &tweaked_context, NULL ); } } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NULL( "tweaked_context", tweaked_context ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } } #endif /* defined( HAVE_CAES_TEST_MEMORY ) */ return( 1 ); on_error: if( error != NULL ) { libcerror_error_free( &error ); } if( tweaked_context != NULL ) { libcaes_tweaked_context_free( &tweaked_context, NULL ); } return( 0 ); } /* Tests the libcaes_tweaked_context_free function * Returns 1 if successful or 0 if not */ int caes_test_tweaked_context_free( void ) { libcerror_error_t *error = NULL; int result = 0; /* Test error cases */ result = libcaes_tweaked_context_free( NULL, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); return( 1 ); on_error: if( error != NULL ) { libcerror_error_free( &error ); } return( 0 ); } /* Tests the libcaes_tweaked_context_set_keys function * Returns 1 if successful or 0 if not */ int caes_test_tweaked_context_set_keys( void ) { uint8_t key[ 16 ]; uint8_t tweak_key[ 16 ]; libcaes_tweaked_context_t *tweaked_context = NULL; libcerror_error_t *error = NULL; int result = 0; /* Initialize test */ result = libcaes_tweaked_context_initialize( &tweaked_context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "tweaked_context", tweaked_context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test regular cases */ result = libcaes_tweaked_context_set_keys( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, key, 128, tweak_key, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test error cases */ result = libcaes_tweaked_context_set_keys( NULL, LIBCAES_CRYPT_MODE_DECRYPT, key, 128, tweak_key, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_tweaked_context_set_keys( tweaked_context, -1, key, 128, tweak_key, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_tweaked_context_set_keys( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, NULL, 128, tweak_key, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_tweaked_context_set_keys( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, key, 0, tweak_key, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_tweaked_context_set_keys( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, key, 128, NULL, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_tweaked_context_set_keys( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, key, 128, tweak_key, 0, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) /* No additional test definitions needed */ #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) #if defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) /* Test libcaes_tweaked_context_set_key with memcpy failing */ caes_test_memcpy_attempts_before_fail = 0; result = libcaes_tweaked_context_set_keys( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, key, 128, tweak_key, 128, &error ); if( caes_test_memcpy_attempts_before_fail != -1 ) { caes_test_memcpy_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) */ #elif defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && ( defined( HAVE_EVP_CRYPTO_AES_CBC ) || defined( HAVE_EVP_CRYPTO_AES_ECB ) ) #if defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) /* Test libcaes_tweaked_context_set_keys with memcpy failing in libcaes_context_set_key of main context */ caes_test_memcpy_attempts_before_fail = 0; result = libcaes_tweaked_context_set_keys( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, key, 128, tweak_key, 128, &error ); if( caes_test_memcpy_attempts_before_fail != -1 ) { caes_test_memcpy_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } /* Test libcaes_tweaked_context_set_keys with memcpy failing in libcaes_context_set_key of tweak context */ caes_test_memcpy_attempts_before_fail = 1; result = libcaes_tweaked_context_set_keys( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, key, 128, tweak_key, 128, &error ); if( caes_test_memcpy_attempts_before_fail != -1 ) { caes_test_memcpy_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) */ #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_AES_H ) */ /* Clean up */ result = libcaes_tweaked_context_free( &tweaked_context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "tweaked_context", tweaked_context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); return( 1 ); on_error: if( error != NULL ) { libcerror_error_free( &error ); } if( tweaked_context != NULL ) { libcaes_tweaked_context_free( &tweaked_context, NULL ); } return( 0 ); } /* Tests the libcaes_crypt_xts function * Returns 1 if successful or 0 if not */ int caes_test_crypt_xts( void ) { uint8_t input_data[ 200 ]; uint8_t key[ 16 ]; uint8_t output_data[ 200 ]; uint8_t tweak_key[ 16 ]; uint8_t tweak_value[ 16 ]; libcaes_tweaked_context_t *tweaked_context = NULL; libcerror_error_t *error = NULL; size_t maximum_size = 0; int result = 0; #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) maximum_size = (size_t) INT_MAX; #else maximum_size = (size_t) SSIZE_MAX; #endif /* Initialize test */ result = libcaes_tweaked_context_initialize( &tweaked_context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "tweaked_context", tweaked_context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); result = libcaes_tweaked_context_set_keys( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, key, 128, tweak_key, 128, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test regular cases */ result = libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, tweak_value, 16, input_data, 200, output_data, 200, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "error", error ); /* Test error cases */ result = libcaes_crypt_xts( NULL, LIBCAES_CRYPT_MODE_DECRYPT, tweak_value, 16, input_data, 200, output_data, 200, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_xts( tweaked_context, -1, tweak_value, 16, input_data, 200, output_data, 200, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, NULL, 16, input_data, 200, output_data, 200, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, tweak_value, 0, input_data, 200, output_data, 200, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, tweak_value, 16, NULL, 200, output_data, 200, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); if( maximum_size > 0 ) { result = libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, tweak_value, 16, input_data, maximum_size + 1, output_data, 200, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } result = libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, tweak_value, 16, input_data, 0, output_data, 200, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, tweak_value, 16, input_data, 200, NULL, 200, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, tweak_value, 16, input_data, 200, output_data, (size_t) SSIZE_MAX + 1, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); result = libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, tweak_value, 16, input_data, 200, output_data, 0, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); #if defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) #if defined( HAVE_CAES_TEST_MEMORY ) /* Test libcaes_crypt_xts with memset of block_data failing */ caes_test_memset_attempts_before_fail = 0; result = libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, tweak_value, 16, input_data, 200, output_data, 200, &error ); if( caes_test_memset_attempts_before_fail != -1 ) { caes_test_memset_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_CAES_TEST_MEMORY ) */ #if defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) /* Test libcaes_crypt_xts with EVP_CipherInit_ex failing */ caes_test_EVP_CipherInit_ex_attempts_before_fail = 0; result = libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, tweak_value, 16, input_data, 200, output_data, 200, &error ); if( caes_test_EVP_CipherInit_ex_attempts_before_fail != -1 ) { caes_test_EVP_CipherInit_ex_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } /* Test libcaes_crypt_xts with EVP_CipherUpdate failing */ caes_test_EVP_CipherUpdate_attempts_before_fail = 0; result = libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, tweak_value, 16, input_data, 200, output_data, 200, &error ); if( caes_test_EVP_CipherUpdate_attempts_before_fail != -1 ) { caes_test_EVP_CipherUpdate_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) */ #else #if defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) /* Test libcaes_crypt_xts with memcpy of input_data to output_data failing */ caes_test_memcpy_attempts_before_fail = 0; result = libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, tweak_value, 16, input_data, 200, output_data, 200, &error ); if( caes_test_memcpy_attempts_before_fail != -1 ) { caes_test_memcpy_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } /* Even though optimization should be disabled here earlier versions of GNU C do optimize this memcpy */ #if __GNUC__ > 5 /* Test libcaes_crypt_xts with memcpy of encrypted_tweak_value to encrypted_tweak_value_copy failing */ caes_test_memcpy_attempts_before_fail = 1; result = libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_DECRYPT, tweak_value, 16, input_data, 200, output_data, 200, &error ); if( caes_test_memcpy_attempts_before_fail != -1 ) { caes_test_memcpy_attempts_before_fail = -1; } else { CAES_TEST_ASSERT_EQUAL_INT( "result", result, -1 ); CAES_TEST_ASSERT_IS_NOT_NULL( "error", error ); libcerror_error_free( &error ); } #endif /* __GNUC__ > 5 */ #endif /* defined( HAVE_CAES_TEST_MEMORY ) && defined( OPTIMIZATION_DISABLED ) */ #endif /* defined( HAVE_LIBCRYPTO ) && defined( HAVE_OPENSSL_EVP_H ) && defined( HAVE_EVP_CRYPTO_AES_XTS ) */ /* Clean up */ result = libcaes_tweaked_context_free( &tweaked_context, &error ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 1 ); CAES_TEST_ASSERT_IS_NULL( "tweaked_context", tweaked_context ); CAES_TEST_ASSERT_IS_NULL( "error", error ); return( 1 ); on_error: if( error != NULL ) { libcerror_error_free( &error ); } if( tweaked_context != NULL ) { libcaes_tweaked_context_free( &tweaked_context, NULL ); } return( 0 ); } /* The main program */ #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) int wmain( int argc CAES_TEST_ATTRIBUTE_UNUSED, wchar_t * const argv[] CAES_TEST_ATTRIBUTE_UNUSED ) #else int main( int argc CAES_TEST_ATTRIBUTE_UNUSED, char * const argv[] CAES_TEST_ATTRIBUTE_UNUSED ) #endif { CAES_TEST_UNREFERENCED_PARAMETER( argc ) CAES_TEST_UNREFERENCED_PARAMETER( argv ) CAES_TEST_RUN( "libcaes_tweaked_context_initialize", caes_test_tweaked_context_initialize ); CAES_TEST_RUN( "libcaes_tweaked_context_free", caes_test_tweaked_context_free ); CAES_TEST_RUN( "libcaes_tweaked_context_set_keys", caes_test_tweaked_context_set_keys ); CAES_TEST_RUN( "libcaes_crypt_xts", caes_test_crypt_xts ); return( EXIT_SUCCESS ); on_error: return( EXIT_FAILURE ); } libcaes-20240413/tests/pycaes_test_support.py0000644000175000017500000000220014606473413022050 0ustar00lordyestalordyesta#!/usr/bin/env python # # Python-bindings support functions test script # # Copyright (C) 2011-2024, Joachim Metz # # Refer to AUTHORS for acknowledgements. # # This program is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This program 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 Lesser General Public License # along with this program. If not, see . import unittest import pycaes class SupportFunctionsTests(unittest.TestCase): """Tests the support functions.""" def test_get_version(self): """Tests the get_version function.""" version = pycaes.get_version() self.assertIsNotNone(version) if __name__ == "__main__": unittest.main(verbosity=2) libcaes-20240413/tests/caes_test_unused.h0000644000175000017500000000300014606473413021064 0ustar00lordyestalordyesta/* * Definitions to silence compiler warnings about unused function attributes/parameters. * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _CAES_TEST_UNUSED_H ) #define _CAES_TEST_UNUSED_H #include #if !defined( CAES_TEST_ATTRIBUTE_UNUSED ) #if defined( __GNUC__ ) && __GNUC__ >= 3 #define CAES_TEST_ATTRIBUTE_UNUSED __attribute__ ((__unused__)) #else #define CAES_TEST_ATTRIBUTE_UNUSED #endif /* defined( __GNUC__ ) && __GNUC__ >= 3 */ #endif /* !defined( CAES_TEST_ATTRIBUTE_UNUSED ) */ #if defined( _MSC_VER ) #define CAES_TEST_UNREFERENCED_PARAMETER( parameter ) \ UNREFERENCED_PARAMETER( parameter ); #else #define CAES_TEST_UNREFERENCED_PARAMETER( parameter ) \ /* parameter */ #endif /* defined( _MSC_VER ) */ #endif /* !defined( _CAES_TEST_UNUSED_H ) */ libcaes-20240413/tests/caes_test_macros.h0000644000175000017500000002053314606473413021057 0ustar00lordyestalordyesta/* * Macros for testing * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _CAES_TEST_MACROS_H ) #define _CAES_TEST_MACROS_H #include #include #if defined( HAVE_STDLIB_H ) || defined( WINAPI ) #include #endif #define CAES_TEST_ASSERT_EQUAL_INT( name, value, expected_value ) \ if( value != expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%d) != %d\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_NOT_EQUAL_INT( name, value, expected_value ) \ if( value == expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%d) == %d\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_GREATER_THAN_INT( name, value, expected_value ) \ if( value <= expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%d) <= %d\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_LESS_THAN_INT( name, value, expected_value ) \ if( value >= expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%d) >= %d\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_EQUAL_INTPTR( name, value, expected_value ) \ if( value != expected_value ) \ { \ fprintf( stdout, "%s:%d %s (0x%08x" PRIjx ") != 0x%08x" PRIjx "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_NOT_EQUAL_INTPTR( name, value, expected_value ) \ if( value == expected_value ) \ { \ fprintf( stdout, "%s:%d %s (0x%08x" PRIjx ") == 0x%08x" PRIjx "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_EQUAL_FLOAT( name, value, expected_value ) \ if( value != expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%f) != %f\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_NOT_EQUAL_FLOAT( name, value, expected_value ) \ if( value == expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%f) == %f\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_EQUAL_SIZE( name, value, expected_value ) \ if( value != expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIzd ") != %" PRIzd "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_EQUAL_SSIZE( name, value, expected_value ) \ if( value != expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIzd ") != %" PRIzd "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_NOT_EQUAL_SSIZE( name, value, expected_value ) \ if( value == expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIzd ") == %" PRIzd "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_EQUAL_INT8( name, value, expected_value ) \ if( value != expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIi8 ") != %" PRIi8 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_NOT_EQUAL_INT8( name, value, expected_value ) \ if( value == expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIi8 ") == %" PRIi8 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_EQUAL_UINT8( name, value, expected_value ) \ if( value != expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIi8 ") != %" PRIu8 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_LESS_THAN_UINT8( name, value, expected_value ) \ if( value >= expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIi8 ") >= %" PRIu8 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_EQUAL_INT16( name, value, expected_value ) \ if( value != expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIi16 ") != %" PRIi16 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_NOT_EQUAL_INT16( name, value, expected_value ) \ if( value == expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIi16 ") == %" PRIi16 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_EQUAL_UINT16( name, value, expected_value ) \ if( value != expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIi16 ") != %" PRIu16 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_LESS_THAN_UINT16( name, value, expected_value ) \ if( value >= expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIi16 ") >= %" PRIu16 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_EQUAL_INT32( name, value, expected_value ) \ if( value != expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIi32 ") != %" PRIi32 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_NOT_EQUAL_INT32( name, value, expected_value ) \ if( value == expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIi32 ") == %" PRIi32 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_EQUAL_UINT32( name, value, expected_value ) \ if( value != expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIu32 ") != %" PRIu32 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_LESS_THAN_UINT32( name, value, expected_value ) \ if( value >= expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIu32 ") >= %" PRIu32 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_EQUAL_INT64( name, value, expected_value ) \ if( value != expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIi64 ") != %" PRIi64 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_NOT_EQUAL_INT64( name, value, expected_value ) \ if( value == expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIi64 ") == %" PRIi64 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_EQUAL_UINT64( name, value, expected_value ) \ if( value != expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIu64 ") != %" PRIu64 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_LESS_THAN_UINT64( name, value, expected_value ) \ if( value >= expected_value ) \ { \ fprintf( stdout, "%s:%d %s (%" PRIu64 ") >= %" PRIu64 "\n", __FILE__, __LINE__, name, value, expected_value ); \ goto on_error; \ } #define CAES_TEST_ASSERT_IS_NOT_NULL( name, value ) \ if( value == NULL ) \ { \ fprintf( stdout, "%s:%d %s == NULL\n", __FILE__, __LINE__, name ); \ goto on_error; \ } #define CAES_TEST_ASSERT_IS_NULL( name, value ) \ if( value != NULL ) \ { \ fprintf( stdout, "%s:%d %s != NULL\n", __FILE__, __LINE__, name ); \ goto on_error; \ } #define CAES_TEST_RUN( name, function ) \ if( function() != 1 ) \ { \ fprintf( stdout, "Unable to run test: %s\n", name ); \ goto on_error; \ } #if !defined( __BORLANDC__ ) || ( __BORLANDC__ >= 0x0560 ) #define CAES_TEST_RUN_WITH_ARGS( name, function, ... ) \ if( function( __VA_ARGS__ ) != 1 ) \ { \ fprintf( stdout, "Unable to run test: %s\n", name ); \ goto on_error; \ } #endif /* !defined( __BORLANDC__ ) || ( __BORLANDC__ >= 0x0560 ) */ #define CAES_TEST_FPRINT_ERROR( error ) \ libcerror_error_backtrace_fprint( error, stdout ); #endif /* !defined( _CAES_TEST_MACROS_H ) */ libcaes-20240413/tests/Makefile.am0000644000175000017500000000432014606475354017426 0ustar00lordyestalordyestaAM_CPPFLAGS = \ -I../include -I$(top_srcdir)/include \ -I../common -I$(top_srcdir)/common \ @LIBCERROR_CPPFLAGS@ \ @LIBCRYPTO_CPPFLAGS@ \ @LIBCAES_DLL_IMPORT@ if HAVE_PYTHON_TESTS TESTS_PYCAES = \ test_python_module.sh endif TESTS = \ test_library.sh \ $(TESTS_PYCAES) check_SCRIPTS = \ pycaes_test_crypt_cbc.py \ pycaes_test_crypt_ccm.py \ pycaes_test_crypt_ecb.py \ pycaes_test_crypt_xts.py \ pycaes_test_support.py \ test_library.sh \ test_manpage.sh \ test_python_module.sh \ test_runner.sh EXTRA_DIST = \ $(check_SCRIPTS) check_PROGRAMS = \ caes_test_context \ caes_test_crypt_cbc \ caes_test_crypt_ccm \ caes_test_crypt_xts \ caes_test_error \ caes_test_support \ caes_test_tweaked_context caes_test_context_SOURCES = \ caes_test_context.c \ caes_test_libcaes.h \ caes_test_libcerror.h \ caes_test_macros.h \ caes_test_memory.c caes_test_memory.h \ caes_test_unused.h caes_test_context_LDADD = \ ../libcaes/libcaes.la \ @LIBCERROR_LIBADD@ caes_test_crypt_cbc_SOURCES = \ caes_test_crypt_cbc.c \ caes_test_libcaes.h \ caes_test_libcerror.h \ caes_test_unused.h caes_test_crypt_cbc_LDADD = \ ../libcaes/libcaes.la \ @LIBCERROR_LIBADD@ caes_test_crypt_ccm_SOURCES = \ caes_test_crypt_ccm.c \ caes_test_libcaes.h \ caes_test_libcerror.h \ caes_test_unused.h caes_test_crypt_ccm_LDADD = \ ../libcaes/libcaes.la \ @LIBCERROR_LIBADD@ caes_test_crypt_xts_SOURCES = \ caes_test_crypt_xts.c \ caes_test_libcaes.h \ caes_test_libcerror.h \ caes_test_unused.h caes_test_crypt_xts_LDADD = \ ../libcaes/libcaes.la \ @LIBCERROR_LIBADD@ caes_test_error_SOURCES = \ caes_test_error.c \ caes_test_libcaes.h \ caes_test_macros.h \ caes_test_unused.h caes_test_error_LDADD = \ ../libcaes/libcaes.la caes_test_support_SOURCES = \ caes_test_libcaes.h \ caes_test_macros.h \ caes_test_support.c \ caes_test_unused.h caes_test_support_LDADD = \ ../libcaes/libcaes.la caes_test_tweaked_context_SOURCES = \ caes_test_libcaes.h \ caes_test_libcerror.h \ caes_test_macros.h \ caes_test_memory.c caes_test_memory.h \ caes_test_tweaked_context.c \ caes_test_unused.h caes_test_tweaked_context_LDADD = \ ../libcaes/libcaes.la \ @LIBCERROR_LIBADD@ DISTCLEANFILES = \ Makefile \ Makefile.in libcaes-20240413/tests/caes_test_memory.h0000644000175000017500000000323314606473413021101 0ustar00lordyestalordyesta/* * Memory allocation functions for testing * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _CAES_TEST_MEMORY_H ) #define _CAES_TEST_MEMORY_H #include #if defined( __cplusplus ) extern "C" { #endif #if defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) && !defined( LIBCAES_DLL_IMPORT ) && !defined( __arm__ ) && !defined( __clang__ ) && !defined( __CYGWIN__ ) && !defined( __hppa__ ) && !defined( __loongarch__ ) && !defined( __mips__ ) && !defined( __riscv ) && !defined( __sparc__ ) && !defined( HAVE_ASAN ) #define HAVE_CAES_TEST_MEMORY 1 #endif #if defined( HAVE_CAES_TEST_MEMORY ) extern int caes_test_malloc_attempts_before_fail; extern int caes_test_memcpy_attempts_before_fail; extern int caes_test_memset_attempts_before_fail; extern int caes_test_realloc_attempts_before_fail; #endif /* defined( HAVE_CAES_TEST_MEMORY ) */ #if defined( __cplusplus ) } #endif #endif /* !defined( _CAES_TEST_MEMORY_H ) */ libcaes-20240413/tests/caes_test_memory.c0000644000175000017500000001105514606473413021075 0ustar00lordyestalordyesta/* * Memory allocation functions for testing * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #if defined( HAVE_STDLIB_H ) || defined( WINAPI ) #include #endif #if defined( HAVE_GNU_DL_DLSYM ) && defined( __GNUC__ ) #define __USE_GNU #include #undef __USE_GNU #endif #include "caes_test_memory.h" #if defined( HAVE_CAES_TEST_MEMORY ) static void *(*caes_test_real_malloc)(size_t) = NULL; static void *(*caes_test_real_memcpy)(void *, const void *, size_t) = NULL; static void *(*caes_test_real_memset)(void *, int, size_t) = NULL; static void *(*caes_test_real_realloc)(void *, size_t) = NULL; int caes_test_malloc_attempts_before_fail = -1; int caes_test_memcpy_attempts_before_fail = -1; int caes_test_memset_attempts_before_fail = -1; int caes_test_realloc_attempts_before_fail = -1; /* Custom malloc for testing memory error cases * Note this function might fail if compiled with optimation * Returns a pointer to newly allocated data or NULL */ void *malloc( size_t size ) { void *ptr = NULL; if( caes_test_real_malloc == NULL ) { caes_test_real_malloc = dlsym( RTLD_NEXT, "malloc" ); } if( caes_test_malloc_attempts_before_fail == 0 ) { caes_test_malloc_attempts_before_fail = -1; return( NULL ); } else if( caes_test_malloc_attempts_before_fail > 0 ) { caes_test_malloc_attempts_before_fail--; } ptr = caes_test_real_malloc( size ); return( ptr ); } /* Custom memcpy for testing memory error cases * Note this function might fail if compiled with optimation and as a shared libary * Returns a pointer to newly allocated data or NULL */ void *memcpy( void *destination, const void *source, size_t size ) { if( caes_test_real_memcpy == NULL ) { caes_test_real_memcpy = dlsym( RTLD_NEXT, "memcpy" ); } if( caes_test_memcpy_attempts_before_fail == 0 ) { caes_test_memcpy_attempts_before_fail = -1; return( NULL ); } else if( caes_test_memcpy_attempts_before_fail > 0 ) { caes_test_memcpy_attempts_before_fail--; } destination = caes_test_real_memcpy( destination, source, size ); return( destination ); } /* Custom memset for testing memory error cases * Note this function might fail if compiled with optimation and as a shared libary * Returns a pointer to newly allocated data or NULL */ void *memset( void *ptr, int constant, size_t size ) { if( caes_test_real_memset == NULL ) { caes_test_real_memset = dlsym( RTLD_NEXT, "memset" ); } if( caes_test_memset_attempts_before_fail == 0 ) { caes_test_memset_attempts_before_fail = -1; return( NULL ); } else if( caes_test_memset_attempts_before_fail > 0 ) { caes_test_memset_attempts_before_fail--; } ptr = caes_test_real_memset( ptr, constant, size ); return( ptr ); } /* Custom realloc for testing memory error cases * Note this function might fail if compiled with optimation * Returns a pointer to reallocated data or NULL */ void *realloc( void *ptr, size_t size ) { if( caes_test_real_realloc == NULL ) { caes_test_real_realloc = dlsym( RTLD_NEXT, "realloc" ); } if( caes_test_realloc_attempts_before_fail == 0 ) { caes_test_realloc_attempts_before_fail = -1; return( NULL ); } else if( caes_test_realloc_attempts_before_fail > 0 ) { caes_test_realloc_attempts_before_fail--; } ptr = caes_test_real_realloc( ptr, size ); return( ptr ); } #endif /* defined( HAVE_CAES_TEST_MEMORY ) */ libcaes-20240413/tests/test_manpage.sh0000744000175000017500000000312614606476420020374 0ustar00lordyestalordyesta#!/usr/bin/env bash # Tests man pages. # # Version: 20240413 EXIT_SUCCESS=0; EXIT_FAILURE=1; EXIT_IGNORE=77; run_test() { local INPUT_FILE=$1; local RESULT=0 TEST_NAME=`basename ${INPUT_FILE}`; echo -n "Testing man with input: ${TEST_NAME}"; LC_ALL=en_US.UTF-8 MANROFFSEQ='' MANWIDTH=80 man --warnings -E UTF-8 -l -Tutf8 -Z ${INPUT_FILE} > /dev/null 2> ${TMPDIR}/${TEST_NAME}.warnings; RESULT=$?; # For now line break warnings are ignored. if test -f ${TMPDIR}/${TEST_NAME}.warnings; then sed "/can't break line/ d" -i ${TMPDIR}/${TEST_NAME}.warnings; fi if test -s ${TMPDIR}/${TEST_NAME}.warnings; then RESULT=${EXIT_FAILURE}; fi if test ${RESULT} -ne ${EXIT_SUCCESS}; then echo " (FAIL)"; else echo " (PASS)"; fi if test -s ${TMPDIR}/${TEST_NAME}.warnings; then cat ${TMPDIR}/${TEST_NAME}.warnings; fi return ${RESULT}; } if test "${OSTYPE}" = "msys"; then exit ${EXIT_IGNORE}; fi TEST_DIRECTORY=`dirname $0`; TEST_RUNNER="${TEST_DIRECTORY}/test_runner.sh"; if ! test -f "${TEST_RUNNER}"; then echo "Missing test runner: ${TEST_RUNNER}"; exit ${EXIT_FAILURE}; fi source ${TEST_RUNNER}; assert_availability_binary man; RESULT=${EXIT_IGNORE}; TMPDIR="tmp$$"; rm -rf ${TMPDIR}; mkdir ${TMPDIR}; MANUALS_PATH="../manuals"; if ! test -d ${MANUALS_PATH}; then MANUALS_PATH="manuals"; fi if ! test -d ${MANUALS_PATH}; then echo "Manuals directory not found."; exit ${EXIT_IGNORE}; fi for INPUT_FILE in ${MANUALS_PATH}/*.[13]; do run_test "${INPUT_FILE}"; RESULT=$?; if test ${RESULT} -ne ${EXIT_SUCCESS}; then break; fi done rm -rf ${TMPDIR}; exit ${RESULT}; libcaes-20240413/tests/pycaes_test_crypt_cbc.py0000644000175000017500000052641414606473413022326 0ustar00lordyestalordyesta#!/usr/bin/env python # # Python-bindings AES-CBC de/encryption testing program # # Copyright (C) 2011-2024, Joachim Metz # # Refer to AUTHORS for acknowledgements. # # This software is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This software 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 Lesser General Public License # along with this software. If not, see . # import sys import pycaes def pycaes_test_crypt_cbc( mode, key, initialization_vector, input_data, expected_output_data): caes_context = pycaes.context() caes_context.set_key(mode, key) output_data = pycaes.crypt_cbc( caes_context, mode, initialization_vector, input_data) return output_data == expected_output_data def main(): # Values from NIST KAT-AES CBCVarKey128.rsp, CBCVarKey192.rsp and CBCVarKey256.rsp keys = [ [ 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff ] ]; # Values from NIST KAT-AES CBCVarTxt128.rsp cipher_texts1_128bit = [ [ 0x3a, 0xd7, 0x8e, 0x72, 0x6c, 0x1e, 0xc0, 0x2b, 0x7e, 0xbf, 0xe9, 0x2b, 0x23, 0xd9, 0xec, 0x34 ], [ 0xaa, 0xe5, 0x93, 0x9c, 0x8e, 0xfd, 0xf2, 0xf0, 0x4e, 0x60, 0xb9, 0xfe, 0x71, 0x17, 0xb2, 0xc2 ], [ 0xf0, 0x31, 0xd4, 0xd7, 0x4f, 0x5d, 0xcb, 0xf3, 0x9d, 0xaa, 0xf8, 0xca, 0x3a, 0xf6, 0xe5, 0x27 ], [ 0x96, 0xd9, 0xfd, 0x5c, 0xc4, 0xf0, 0x74, 0x41, 0x72, 0x7d, 0xf0, 0xf3, 0x3e, 0x40, 0x1a, 0x36 ], [ 0x30, 0xcc, 0xdb, 0x04, 0x46, 0x46, 0xd7, 0xe1, 0xf3, 0xcc, 0xea, 0x3d, 0xca, 0x08, 0xb8, 0xc0 ], [ 0x16, 0xae, 0x4c, 0xe5, 0x04, 0x2a, 0x67, 0xee, 0x8e, 0x17, 0x7b, 0x7c, 0x58, 0x7e, 0xcc, 0x82 ], [ 0xb6, 0xda, 0x0b, 0xb1, 0x1a, 0x23, 0x85, 0x5d, 0x9c, 0x5c, 0xb1, 0xb4, 0xc6, 0x41, 0x2e, 0x0a ], [ 0xdb, 0x4f, 0x1a, 0xa5, 0x30, 0x96, 0x7d, 0x67, 0x32, 0xce, 0x47, 0x15, 0xeb, 0x0e, 0xe2, 0x4b ], [ 0xa8, 0x17, 0x38, 0x25, 0x26, 0x21, 0xdd, 0x18, 0x0a, 0x34, 0xf3, 0x45, 0x5b, 0x4b, 0xaa, 0x2f ], [ 0x77, 0xe2, 0xb5, 0x08, 0xdb, 0x7f, 0xd8, 0x92, 0x34, 0xca, 0xf7, 0x93, 0x9e, 0xe5, 0x62, 0x1a ], [ 0xb8, 0x49, 0x9c, 0x25, 0x1f, 0x84, 0x42, 0xee, 0x13, 0xf0, 0x93, 0x3b, 0x68, 0x8f, 0xcd, 0x19 ], [ 0x96, 0x51, 0x35, 0xf8, 0xa8, 0x1f, 0x25, 0xc9, 0xd6, 0x30, 0xb1, 0x75, 0x02, 0xf6, 0x8e, 0x53 ], [ 0x8b, 0x87, 0x14, 0x5a, 0x01, 0xad, 0x1c, 0x6c, 0xed, 0xe9, 0x95, 0xea, 0x36, 0x70, 0x45, 0x4f ], [ 0x8e, 0xae, 0x3b, 0x10, 0xa0, 0xc8, 0xca, 0x6d, 0x1d, 0x3b, 0x0f, 0xa6, 0x1e, 0x56, 0xb0, 0xb2 ], [ 0x64, 0xb4, 0xd6, 0x29, 0x81, 0x0f, 0xda, 0x6b, 0xaf, 0xdf, 0x08, 0xf3, 0xb0, 0xd8, 0xd2, 0xc5 ], [ 0xd7, 0xe5, 0xdb, 0xd3, 0x32, 0x45, 0x95, 0xf8, 0xfd, 0xc7, 0xd7, 0xc5, 0x71, 0xda, 0x6c, 0x2a ], [ 0xf3, 0xf7, 0x23, 0x75, 0x26, 0x4e, 0x16, 0x7f, 0xca, 0x9d, 0xe2, 0xc1, 0x52, 0x7d, 0x96, 0x06 ], [ 0x8e, 0xe7, 0x9d, 0xd4, 0xf4, 0x01, 0xff, 0x9b, 0x7e, 0xa9, 0x45, 0xd8, 0x66, 0x66, 0xc1, 0x3b ], [ 0xdd, 0x35, 0xce, 0xa2, 0x79, 0x99, 0x40, 0xb4, 0x0d, 0xb3, 0xf8, 0x19, 0xcb, 0x94, 0xc0, 0x8b ], [ 0x69, 0x41, 0xcb, 0x6b, 0x3e, 0x08, 0xc2, 0xb7, 0xaf, 0xa5, 0x81, 0xeb, 0xdd, 0x60, 0x7b, 0x87 ], [ 0x2c, 0x20, 0xf4, 0x39, 0xf6, 0xbb, 0x09, 0x7b, 0x29, 0xb8, 0xbd, 0x6d, 0x99, 0xaa, 0xd7, 0x99 ], [ 0x62, 0x5d, 0x01, 0xf0, 0x58, 0xe5, 0x65, 0xf7, 0x7a, 0xe8, 0x63, 0x78, 0xbd, 0x2c, 0x49, 0xb3 ], [ 0xc0, 0xb5, 0xfd, 0x98, 0x19, 0x0e, 0xf4, 0x5f, 0xbb, 0x43, 0x01, 0x43, 0x8d, 0x09, 0x59, 0x50 ], [ 0x13, 0x00, 0x1f, 0xf5, 0xd9, 0x98, 0x06, 0xef, 0xd2, 0x5d, 0xa3, 0x4f, 0x56, 0xbe, 0x85, 0x4b ], [ 0x3b, 0x59, 0x4c, 0x60, 0xf5, 0xc8, 0x27, 0x7a, 0x51, 0x13, 0x67, 0x7f, 0x94, 0x20, 0x8d, 0x82 ], [ 0xe9, 0xc0, 0xfc, 0x18, 0x18, 0xe4, 0xaa, 0x46, 0xbd, 0x2e, 0x39, 0xd6, 0x38, 0xf8, 0x9e, 0x05 ], [ 0xf8, 0x02, 0x3e, 0xe9, 0xc3, 0xfd, 0xc4, 0x5a, 0x01, 0x9b, 0x4e, 0x98, 0x5c, 0x7e, 0x1a, 0x54 ], [ 0x35, 0xf4, 0x01, 0x82, 0xab, 0x46, 0x62, 0xf3, 0x02, 0x3b, 0xae, 0xc1, 0xee, 0x79, 0x6b, 0x57 ], [ 0x3a, 0xeb, 0xba, 0xd7, 0x30, 0x36, 0x49, 0xb4, 0x19, 0x4a, 0x69, 0x45, 0xc6, 0xcc, 0x36, 0x94 ], [ 0xa2, 0x12, 0x4b, 0xea, 0x53, 0xec, 0x28, 0x34, 0x27, 0x9b, 0xed, 0x7f, 0x7e, 0xb0, 0xf9, 0x38 ], [ 0xb9, 0xfb, 0x43, 0x99, 0xfa, 0x4f, 0xac, 0xc7, 0x30, 0x9e, 0x14, 0xec, 0x98, 0x36, 0x0b, 0x0a ], [ 0xc2, 0x62, 0x77, 0x43, 0x74, 0x20, 0xc5, 0xd6, 0x34, 0xf7, 0x15, 0xae, 0xa8, 0x1a, 0x91, 0x32 ], [ 0x17, 0x1a, 0x0e, 0x1b, 0x2d, 0xd4, 0x24, 0xf0, 0xe0, 0x89, 0xaf, 0x2c, 0x4c, 0x10, 0xf3, 0x2f ], [ 0x7c, 0xad, 0xbe, 0x40, 0x2d, 0x1b, 0x20, 0x8f, 0xe7, 0x35, 0xed, 0xce, 0x00, 0xae, 0xe7, 0xce ], [ 0x43, 0xb0, 0x2f, 0xf9, 0x29, 0xa1, 0x48, 0x5a, 0xf6, 0xf5, 0xc6, 0xd6, 0x55, 0x8b, 0xaa, 0x0f ], [ 0x09, 0x2f, 0xaa, 0xcc, 0x9b, 0xf4, 0x35, 0x08, 0xbf, 0x8f, 0xa8, 0x61, 0x3c, 0xa7, 0x5d, 0xea ], [ 0xcb, 0x2b, 0xf8, 0x28, 0x0f, 0x3f, 0x97, 0x42, 0xc7, 0xed, 0x51, 0x3f, 0xe8, 0x02, 0x62, 0x9c ], [ 0x21, 0x5a, 0x41, 0xee, 0x44, 0x2f, 0xa9, 0x92, 0xa6, 0xe3, 0x23, 0x98, 0x6d, 0xed, 0x3f, 0x68 ], [ 0xf2, 0x1e, 0x99, 0xcf, 0x4f, 0x0f, 0x77, 0xce, 0xa8, 0x36, 0xe1, 0x1a, 0x2f, 0xe7, 0x5f, 0xb1 ], [ 0x95, 0xe3, 0xa0, 0xca, 0x90, 0x79, 0xe6, 0x46, 0x33, 0x1d, 0xf8, 0xb4, 0xe7, 0x0d, 0x2c, 0xd6 ], [ 0x4a, 0xfe, 0x7f, 0x12, 0x0c, 0xe7, 0x61, 0x3f, 0x74, 0xfc, 0x12, 0xa0, 0x1a, 0x82, 0x80, 0x73 ], [ 0x82, 0x7f, 0x00, 0x0e, 0x75, 0xe2, 0xc8, 0xb9, 0xd4, 0x79, 0xbe, 0xed, 0x91, 0x3f, 0xe6, 0x78 ], [ 0x35, 0x83, 0x0c, 0x8e, 0x7a, 0xae, 0xfe, 0x2d, 0x30, 0x31, 0x0e, 0xf3, 0x81, 0xcb, 0xf6, 0x91 ], [ 0x19, 0x1a, 0xa0, 0xf2, 0xc8, 0x57, 0x01, 0x44, 0xf3, 0x86, 0x57, 0xea, 0x40, 0x85, 0xeb, 0xe5 ], [ 0x85, 0x06, 0x2c, 0x2c, 0x90, 0x9f, 0x15, 0xd9, 0x26, 0x9b, 0x6c, 0x18, 0xce, 0x99, 0xc4, 0xf0 ], [ 0x67, 0x80, 0x34, 0xdc, 0x9e, 0x41, 0xb5, 0xa5, 0x60, 0xed, 0x23, 0x9e, 0xea, 0xb1, 0xbc, 0x78 ], [ 0xc2, 0xf9, 0x3a, 0x4c, 0xe5, 0xab, 0x6d, 0x5d, 0x56, 0xf1, 0xb9, 0x3c, 0xf1, 0x99, 0x11, 0xc1 ], [ 0x1c, 0x31, 0x12, 0xbc, 0xb0, 0xc1, 0xdc, 0xc7, 0x49, 0xd7, 0x99, 0x74, 0x36, 0x91, 0xbf, 0x82 ], [ 0x00, 0xc5, 0x5b, 0xd7, 0x5c, 0x7f, 0x9c, 0x88, 0x19, 0x89, 0xd3, 0xec, 0x19, 0x11, 0xc0, 0xd4 ], [ 0xea, 0x2e, 0x6b, 0x5e, 0xf1, 0x82, 0xb7, 0xdf, 0xf3, 0x62, 0x9a, 0xbd, 0x6a, 0x12, 0x04, 0x5f ], [ 0x22, 0x32, 0x23, 0x27, 0xe0, 0x17, 0x80, 0xb1, 0x73, 0x97, 0xf2, 0x40, 0x87, 0xf8, 0xcc, 0x6f ], [ 0xc9, 0xca, 0xcb, 0x5c, 0xd1, 0x16, 0x92, 0xc3, 0x73, 0xb2, 0x41, 0x17, 0x68, 0x14, 0x9e, 0xe7 ], [ 0xa1, 0x8e, 0x3d, 0xbb, 0xca, 0x57, 0x78, 0x60, 0xda, 0xb6, 0xb8, 0x0d, 0xa3, 0x13, 0x92, 0x56 ], [ 0x79, 0xb6, 0x1c, 0x37, 0xbf, 0x32, 0x8e, 0xcc, 0xa8, 0xd7, 0x43, 0x26, 0x5a, 0x3d, 0x42, 0x5c ], [ 0xd2, 0xd9, 0x9c, 0x6b, 0xcc, 0x1f, 0x06, 0xfd, 0xa8, 0xe2, 0x7e, 0x8a, 0xe3, 0xf1, 0xcc, 0xc7 ], [ 0x1b, 0xfd, 0x4b, 0x91, 0xc7, 0x01, 0xfd, 0x6b, 0x61, 0xb7, 0xf9, 0x97, 0x82, 0x9d, 0x66, 0x3b ], [ 0x11, 0x00, 0x5d, 0x52, 0xf2, 0x5f, 0x16, 0xbd, 0xc9, 0x54, 0x5a, 0x87, 0x6a, 0x63, 0x49, 0x0a ], [ 0x3a, 0x4d, 0x35, 0x4f, 0x02, 0xbb, 0x5a, 0x5e, 0x47, 0xd3, 0x96, 0x66, 0x86, 0x7f, 0x24, 0x6a ], [ 0xd4, 0x51, 0xb8, 0xd6, 0xe1, 0xe1, 0xa0, 0xeb, 0xb1, 0x55, 0xfb, 0xbf, 0x6e, 0x7b, 0x7d, 0xc3 ], [ 0x68, 0x98, 0xd4, 0xf4, 0x2f, 0xa7, 0xba, 0x6a, 0x10, 0xac, 0x05, 0xe8, 0x7b, 0x9f, 0x20, 0x80 ], [ 0xb6, 0x11, 0x29, 0x5e, 0x73, 0x9c, 0xa7, 0xd9, 0xb5, 0x0f, 0x8e, 0x4c, 0x0e, 0x75, 0x4a, 0x3f ], [ 0x7d, 0x33, 0xfc, 0x7d, 0x8a, 0xbe, 0x3c, 0xa1, 0x93, 0x67, 0x59, 0xf8, 0xf5, 0xde, 0xaf, 0x20 ], [ 0x3b, 0x5e, 0x0f, 0x56, 0x6d, 0xc9, 0x6c, 0x29, 0x8f, 0x0c, 0x12, 0x63, 0x75, 0x39, 0xb2, 0x5c ], [ 0xf8, 0x07, 0xc3, 0xe7, 0x98, 0x5f, 0xe0, 0xf5, 0xa5, 0x0e, 0x2c, 0xdb, 0x25, 0xc5, 0x10, 0x9e ], [ 0x41, 0xf9, 0x92, 0xa8, 0x56, 0xfb, 0x27, 0x8b, 0x38, 0x9a, 0x62, 0xf5, 0xd2, 0x74, 0xd7, 0xe9 ], [ 0x10, 0xd3, 0xed, 0x7a, 0x6f, 0xe1, 0x5a, 0xb4, 0xd9, 0x1a, 0xcb, 0xc7, 0xd0, 0x76, 0x7a, 0xb1 ], [ 0x21, 0xfe, 0xec, 0xd4, 0x5b, 0x2e, 0x67, 0x59, 0x73, 0xac, 0x33, 0xbf, 0x0c, 0x54, 0x24, 0xfc ], [ 0x14, 0x80, 0xcb, 0x39, 0x55, 0xba, 0x62, 0xd0, 0x9e, 0xea, 0x66, 0x8f, 0x7c, 0x70, 0x88, 0x17 ], [ 0x66, 0x40, 0x40, 0x33, 0xd6, 0xb7, 0x2b, 0x60, 0x93, 0x54, 0xd5, 0x49, 0x6e, 0x7e, 0xb5, 0x11 ], [ 0x1c, 0x31, 0x7a, 0x22, 0x0a, 0x7d, 0x70, 0x0d, 0xa2, 0xb1, 0xe0, 0x75, 0xb0, 0x02, 0x66, 0xe1 ], [ 0xab, 0x3b, 0x89, 0x54, 0x22, 0x33, 0xf1, 0x27, 0x1b, 0xf8, 0xfd, 0x0c, 0x0f, 0x40, 0x35, 0x45 ], [ 0xd9, 0x3e, 0xae, 0x96, 0x6f, 0xac, 0x46, 0xdc, 0xa9, 0x27, 0xd6, 0xb1, 0x14, 0xfa, 0x3f, 0x9e ], [ 0x1b, 0xde, 0xc5, 0x21, 0x31, 0x65, 0x03, 0xd9, 0xd5, 0xee, 0x65, 0xdf, 0x3e, 0xa9, 0x4d, 0xdf ], [ 0xee, 0xf4, 0x56, 0x43, 0x1d, 0xea, 0x8b, 0x4a, 0xcf, 0x83, 0xbd, 0xae, 0x37, 0x17, 0xf7, 0x5f ], [ 0x06, 0xf2, 0x51, 0x9a, 0x2f, 0xaf, 0xaa, 0x59, 0x6b, 0xfe, 0xf5, 0xcf, 0xa1, 0x5c, 0x21, 0xb9 ], [ 0x25, 0x1a, 0x7e, 0xac, 0x7e, 0x2f, 0xe8, 0x09, 0xe4, 0xaa, 0x8d, 0x0d, 0x70, 0x12, 0x53, 0x1a ], [ 0x3b, 0xff, 0xc1, 0x6e, 0x4c, 0x49, 0xb2, 0x68, 0xa2, 0x0f, 0x8d, 0x96, 0xa6, 0x0b, 0x40, 0x58 ], [ 0xe8, 0x86, 0xf9, 0x28, 0x19, 0x99, 0xc5, 0xbb, 0x3b, 0x3e, 0x88, 0x62, 0xe2, 0xf7, 0xc9, 0x88 ], [ 0x56, 0x3b, 0xf9, 0x0d, 0x61, 0xbe, 0xef, 0x39, 0xf4, 0x8d, 0xd6, 0x25, 0xfc, 0xef, 0x13, 0x61 ], [ 0x4d, 0x37, 0xc8, 0x50, 0x64, 0x45, 0x63, 0xc6, 0x9f, 0xd0, 0xac, 0xd9, 0xa0, 0x49, 0x32, 0x5b ], [ 0xb8, 0x7c, 0x92, 0x1b, 0x91, 0x82, 0x9e, 0xf3, 0xb1, 0x3c, 0xa5, 0x41, 0xee, 0x11, 0x30, 0xa6 ], [ 0x2e, 0x65, 0xeb, 0x6b, 0x6e, 0xa3, 0x83, 0xe1, 0x09, 0xac, 0xcc, 0xe8, 0x32, 0x6b, 0x03, 0x93 ], [ 0x9c, 0xa5, 0x47, 0xf7, 0x43, 0x9e, 0xdc, 0x3e, 0x25, 0x5c, 0x0f, 0x4d, 0x49, 0xaa, 0x89, 0x90 ], [ 0xa5, 0xe6, 0x52, 0x61, 0x4c, 0x93, 0x00, 0xf3, 0x78, 0x16, 0xb1, 0xf9, 0xfd, 0x0c, 0x87, 0xf9 ], [ 0x14, 0x95, 0x4f, 0x0b, 0x46, 0x97, 0x77, 0x6f, 0x44, 0x49, 0x4f, 0xe4, 0x58, 0xd8, 0x14, 0xed ], [ 0x7c, 0x8d, 0x9a, 0xb6, 0xc2, 0x76, 0x17, 0x23, 0xfe, 0x42, 0xf8, 0xbb, 0x50, 0x6c, 0xbc, 0xf7 ], [ 0xdb, 0x7e, 0x19, 0x32, 0x67, 0x9f, 0xdd, 0x99, 0x74, 0x2a, 0xab, 0x04, 0xaa, 0x0d, 0x5a, 0x80 ], [ 0x4c, 0x6a, 0x1c, 0x83, 0xe5, 0x68, 0xcd, 0x10, 0xf2, 0x7c, 0x2d, 0x73, 0xde, 0xd1, 0x9c, 0x28 ], [ 0x90, 0xec, 0xbe, 0x61, 0x77, 0xe6, 0x74, 0xc9, 0x8d, 0xe4, 0x12, 0x41, 0x3f, 0x7a, 0xc9, 0x15 ], [ 0x90, 0x68, 0x4a, 0x2a, 0xc5, 0x5f, 0xe1, 0xec, 0x2b, 0x8e, 0xbd, 0x56, 0x22, 0x52, 0x0b, 0x73 ], [ 0x74, 0x72, 0xf9, 0xa7, 0x98, 0x86, 0x07, 0xca, 0x79, 0x70, 0x77, 0x95, 0x99, 0x10, 0x35, 0xe6 ], [ 0x56, 0xaf, 0xf0, 0x89, 0x87, 0x8b, 0xf3, 0x35, 0x2f, 0x8d, 0xf1, 0x72, 0xa3, 0xae, 0x47, 0xd8 ], [ 0x65, 0xc0, 0x52, 0x6c, 0xbe, 0x40, 0x16, 0x1b, 0x80, 0x19, 0xa2, 0xa3, 0x17, 0x1a, 0xbd, 0x23 ], [ 0x37, 0x7b, 0xe0, 0xbe, 0x33, 0xb4, 0xe3, 0xe3, 0x10, 0xb4, 0xaa, 0xbd, 0xa1, 0x73, 0xf8, 0x4f ], [ 0x94, 0x02, 0xe9, 0xaa, 0x6f, 0x69, 0xde, 0x65, 0x04, 0xda, 0x8d, 0x20, 0xc4, 0xfc, 0xaa, 0x2f ], [ 0x12, 0x3c, 0x1f, 0x4a, 0xf3, 0x13, 0xad, 0x8c, 0x2c, 0xe6, 0x48, 0xb2, 0xe7, 0x1f, 0xb6, 0xe1 ], [ 0x1f, 0xfc, 0x62, 0x6d, 0x30, 0x20, 0x3d, 0xcd, 0xb0, 0x01, 0x9f, 0xb8, 0x0f, 0x72, 0x6c, 0xf4 ], [ 0x76, 0xda, 0x1f, 0xbe, 0x3a, 0x50, 0x72, 0x8c, 0x50, 0xfd, 0x2e, 0x62, 0x1b, 0x5a, 0xd8, 0x85 ], [ 0x08, 0x2e, 0xb8, 0xbe, 0x35, 0xf4, 0x42, 0xfb, 0x52, 0x66, 0x8e, 0x16, 0xa5, 0x91, 0xd1, 0xd6 ], [ 0xe6, 0x56, 0xf9, 0xec, 0xf5, 0xfe, 0x27, 0xec, 0x3e, 0x4a, 0x73, 0xd0, 0x0c, 0x28, 0x2f, 0xb3 ], [ 0x2c, 0xa8, 0x20, 0x9d, 0x63, 0x27, 0x4c, 0xd9, 0xa2, 0x9b, 0xb7, 0x4b, 0xcd, 0x77, 0x68, 0x3a ], [ 0x79, 0xbf, 0x5d, 0xce, 0x14, 0xbb, 0x7d, 0xd7, 0x3a, 0x8e, 0x36, 0x11, 0xde, 0x7c, 0xe0, 0x26 ], [ 0x3c, 0x84, 0x99, 0x39, 0xa5, 0xd2, 0x93, 0x99, 0xf3, 0x44, 0xc4, 0xa0, 0xec, 0xa8, 0xa5, 0x76 ], [ 0xed, 0x3c, 0x0a, 0x94, 0xd5, 0x9b, 0xec, 0xe9, 0x88, 0x35, 0xda, 0x7a, 0xa4, 0xf0, 0x7c, 0xa2 ], [ 0x63, 0x91, 0x9e, 0xd4, 0xce, 0x10, 0x19, 0x64, 0x38, 0xb6, 0xad, 0x09, 0xd9, 0x9c, 0xd7, 0x95 ], [ 0x76, 0x78, 0xf3, 0xa8, 0x33, 0xf1, 0x9f, 0xea, 0x95, 0xf3, 0xc6, 0x02, 0x9e, 0x2b, 0xc6, 0x10 ], [ 0x3a, 0xa4, 0x26, 0x83, 0x10, 0x67, 0xd3, 0x6b, 0x92, 0xbe, 0x7c, 0x5f, 0x81, 0xc1, 0x3c, 0x56 ], [ 0x92, 0x72, 0xe2, 0xd2, 0xcd, 0xd1, 0x10, 0x50, 0x99, 0x8c, 0x84, 0x50, 0x77, 0xa3, 0x0e, 0xa0 ], [ 0x08, 0x8c, 0x4b, 0x53, 0xf5, 0xec, 0x0f, 0xf8, 0x14, 0xc1, 0x9a, 0xda, 0xe7, 0xf6, 0x24, 0x6c ], [ 0x40, 0x10, 0xa5, 0xe4, 0x01, 0xfd, 0xf0, 0xa0, 0x35, 0x4d, 0xdb, 0xcc, 0x0d, 0x01, 0x2b, 0x17 ], [ 0xa8, 0x7a, 0x38, 0x57, 0x36, 0xc0, 0xa6, 0x18, 0x9b, 0xd6, 0x58, 0x9b, 0xd8, 0x44, 0x5a, 0x93 ], [ 0x54, 0x5f, 0x2b, 0x83, 0xd9, 0x61, 0x6d, 0xcc, 0xf6, 0x0f, 0xa9, 0x83, 0x0e, 0x9c, 0xd2, 0x87 ], [ 0x4b, 0x70, 0x6f, 0x7f, 0x92, 0x40, 0x63, 0x52, 0x39, 0x40, 0x37, 0xa6, 0xd4, 0xf4, 0x68, 0x8d ], [ 0xb7, 0x97, 0x2b, 0x39, 0x41, 0xc4, 0x4b, 0x90, 0xaf, 0xa7, 0xb2, 0x64, 0xbf, 0xba, 0x73, 0x87 ], [ 0x6f, 0x45, 0x73, 0x2c, 0xf1, 0x08, 0x81, 0x54, 0x6f, 0x0f, 0xd2, 0x38, 0x96, 0xd2, 0xbb, 0x60 ], [ 0x2e, 0x35, 0x79, 0xca, 0x15, 0xaf, 0x27, 0xf6, 0x4b, 0x3c, 0x95, 0x5a, 0x5b, 0xfc, 0x30, 0xba ], [ 0x34, 0xa2, 0xc5, 0xa9, 0x1a, 0xe2, 0xae, 0xc9, 0x9b, 0x7d, 0x1b, 0x5f, 0xa6, 0x78, 0x04, 0x47 ], [ 0xa4, 0xd6, 0x61, 0x6b, 0xd0, 0x4f, 0x87, 0x33, 0x5b, 0x0e, 0x53, 0x35, 0x12, 0x27, 0xa9, 0xee ], [ 0x7f, 0x69, 0x2b, 0x03, 0x94, 0x58, 0x67, 0xd1, 0x61, 0x79, 0xa8, 0xce, 0xfc, 0x83, 0xea, 0x3f ], [ 0x3b, 0xd1, 0x41, 0xee, 0x84, 0xa0, 0xe6, 0x41, 0x4a, 0x26, 0xe7, 0xa4, 0xf2, 0x81, 0xf8, 0xa2 ], [ 0xd1, 0x78, 0x8f, 0x57, 0x2d, 0x98, 0xb2, 0xb1, 0x6e, 0xc5, 0xd5, 0xf3, 0x92, 0x2b, 0x99, 0xbc ], [ 0x08, 0x33, 0xff, 0x6f, 0x61, 0xd9, 0x8a, 0x57, 0xb2, 0x88, 0xe8, 0xc3, 0x58, 0x6b, 0x85, 0xa6 ], [ 0x85, 0x68, 0x26, 0x17, 0x97, 0xde, 0x17, 0x6b, 0xf0, 0xb4, 0x3b, 0xec, 0xc6, 0x28, 0x5a, 0xfb ], [ 0xf9, 0xb0, 0xfd, 0xa0, 0xc4, 0xa8, 0x98, 0xf5, 0xb9, 0xe6, 0xf6, 0x61, 0xc4, 0xce, 0x4d, 0x07 ], [ 0x8a, 0xde, 0x89, 0x59, 0x13, 0x68, 0x5c, 0x67, 0xc5, 0x26, 0x9f, 0x8a, 0xae, 0x42, 0x98, 0x3e ], [ 0x39, 0xbd, 0xe6, 0x7d, 0x5c, 0x8e, 0xd8, 0xa8, 0xb1, 0xc3, 0x7e, 0xb8, 0xfa, 0x9f, 0x5a, 0xc0 ], [ 0x5c, 0x00, 0x5e, 0x72, 0xc1, 0x41, 0x8c, 0x44, 0xf5, 0x69, 0xf2, 0xea, 0x33, 0xba, 0x54, 0xf3 ], [ 0x3f, 0x5b, 0x8c, 0xc9, 0xea, 0x85, 0x5a, 0x0a, 0xfa, 0x73, 0x47, 0xd2, 0x3e, 0x8d, 0x66, 0x4e ] ]; # Values from NIST KAT-AES CBCVarKey128.rsp cipher_texts2_128bit = [ [ 0x0e, 0xdd, 0x33, 0xd3, 0xc6, 0x21, 0xe5, 0x46, 0x45, 0x5b, 0xd8, 0xba, 0x14, 0x18, 0xbe, 0xc8 ], [ 0x4b, 0xc3, 0xf8, 0x83, 0x45, 0x0c, 0x11, 0x3c, 0x64, 0xca, 0x42, 0xe1, 0x11, 0x2a, 0x9e, 0x87 ], [ 0x72, 0xa1, 0xda, 0x77, 0x0f, 0x5d, 0x7a, 0xc4, 0xc9, 0xef, 0x94, 0xd8, 0x22, 0xaf, 0xfd, 0x97 ], [ 0x97, 0x00, 0x14, 0xd6, 0x34, 0xe2, 0xb7, 0x65, 0x07, 0x77, 0xe8, 0xe8, 0x4d, 0x03, 0xcc, 0xd8 ], [ 0xf1, 0x7e, 0x79, 0xae, 0xd0, 0xdb, 0x7e, 0x27, 0x9e, 0x95, 0x5b, 0x5f, 0x49, 0x38, 0x75, 0xa7 ], [ 0x9e, 0xd5, 0xa7, 0x51, 0x36, 0xa9, 0x40, 0xd0, 0x96, 0x3d, 0xa3, 0x79, 0xdb, 0x4a, 0xf2, 0x6a ], [ 0xc4, 0x29, 0x5f, 0x83, 0x46, 0x5c, 0x77, 0x55, 0xe8, 0xfa, 0x36, 0x4b, 0xac, 0x6a, 0x7e, 0xa5 ], [ 0xb1, 0xd7, 0x58, 0x25, 0x6b, 0x28, 0xfd, 0x85, 0x0a, 0xd4, 0x94, 0x42, 0x08, 0xcf, 0x11, 0x55 ], [ 0x42, 0xff, 0xb3, 0x4c, 0x74, 0x3d, 0xe4, 0xd8, 0x8c, 0xa3, 0x80, 0x11, 0xc9, 0x90, 0x89, 0x0b ], [ 0x99, 0x58, 0xf0, 0xec, 0xea, 0x8b, 0x21, 0x72, 0xc0, 0xc1, 0x99, 0x5f, 0x91, 0x82, 0xc0, 0xf3 ], [ 0x95, 0x6d, 0x77, 0x98, 0xfa, 0xc2, 0x0f, 0x82, 0xa8, 0x82, 0x3f, 0x98, 0x4d, 0x06, 0xf7, 0xf5 ], [ 0xa0, 0x1b, 0xf4, 0x4f, 0x2d, 0x16, 0xbe, 0x92, 0x8c, 0xa4, 0x4a, 0xaf, 0x7b, 0x9b, 0x10, 0x6b ], [ 0xb5, 0xf1, 0xa3, 0x3e, 0x50, 0xd4, 0x0d, 0x10, 0x37, 0x64, 0xc7, 0x6b, 0xd4, 0xc6, 0xb6, 0xf8 ], [ 0x26, 0x37, 0x05, 0x0c, 0x9f, 0xc0, 0xd4, 0x81, 0x7e, 0x2d, 0x69, 0xde, 0x87, 0x8a, 0xee, 0x8d ], [ 0x11, 0x3e, 0xcb, 0xe4, 0xa4, 0x53, 0x26, 0x9a, 0x0d, 0xd2, 0x60, 0x69, 0x46, 0x7f, 0xb5, 0xb5 ], [ 0x97, 0xd0, 0x75, 0x4f, 0xe6, 0x8f, 0x11, 0xb9, 0xe3, 0x75, 0xd0, 0x70, 0xa6, 0x08, 0xc8, 0x84 ], [ 0xc6, 0xa0, 0xb3, 0xe9, 0x98, 0xd0, 0x50, 0x68, 0xa5, 0x39, 0x97, 0x78, 0x40, 0x52, 0x00, 0xb4 ], [ 0xdf, 0x55, 0x6a, 0x33, 0x43, 0x8d, 0xb8, 0x7b, 0xc4, 0x1b, 0x17, 0x52, 0xc5, 0x5e, 0x5e, 0x49 ], [ 0x90, 0xfb, 0x12, 0x8d, 0x3a, 0x1a, 0xf6, 0xe5, 0x48, 0x52, 0x1b, 0xb9, 0x62, 0xbf, 0x1f, 0x05 ], [ 0x26, 0x29, 0x8e, 0x9c, 0x1d, 0xb5, 0x17, 0xc2, 0x15, 0xfa, 0xdf, 0xb7, 0xd2, 0xa8, 0xd6, 0x91 ], [ 0xa6, 0xcb, 0x76, 0x1d, 0x61, 0xf8, 0x29, 0x2d, 0x0d, 0xf3, 0x93, 0xa2, 0x79, 0xad, 0x03, 0x80 ], [ 0x12, 0xac, 0xd8, 0x9b, 0x13, 0xcd, 0x5f, 0x87, 0x26, 0xe3, 0x4d, 0x44, 0xfd, 0x48, 0x61, 0x08 ], [ 0x95, 0xb1, 0x70, 0x3f, 0xc5, 0x7b, 0xa0, 0x9f, 0xe0, 0xc3, 0x58, 0x0f, 0xeb, 0xdd, 0x7e, 0xd4 ], [ 0xde, 0x11, 0x72, 0x2d, 0x89, 0x3e, 0x9f, 0x91, 0x21, 0xc3, 0x81, 0xbe, 0xcc, 0x1d, 0xa5, 0x9a ], [ 0x6d, 0x11, 0x4c, 0xcb, 0x27, 0xbf, 0x39, 0x10, 0x12, 0xe8, 0x97, 0x4c, 0x54, 0x6d, 0x9b, 0xf2 ], [ 0x5c, 0xe3, 0x7e, 0x17, 0xeb, 0x46, 0x46, 0xec, 0xfa, 0xc2, 0x9b, 0x9c, 0xc3, 0x8d, 0x93, 0x40 ], [ 0x18, 0xc1, 0xb6, 0xe2, 0x15, 0x71, 0x22, 0x05, 0x6d, 0x02, 0x43, 0xd8, 0xa1, 0x65, 0xcd, 0xdb ], [ 0x99, 0x69, 0x3e, 0x6a, 0x59, 0xd1, 0x36, 0x6c, 0x74, 0xd8, 0x23, 0x56, 0x2d, 0x7e, 0x14, 0x31 ], [ 0x6c, 0x7c, 0x64, 0xdc, 0x84, 0xa8, 0xbb, 0xa7, 0x58, 0xed, 0x17, 0xeb, 0x02, 0x5a, 0x57, 0xe3 ], [ 0xe1, 0x7b, 0xc7, 0x9f, 0x30, 0xea, 0xab, 0x2f, 0xac, 0x2c, 0xbb, 0xe3, 0x45, 0x8d, 0x68, 0x7a ], [ 0x11, 0x14, 0xbc, 0x20, 0x28, 0x00, 0x9b, 0x92, 0x3f, 0x0b, 0x01, 0x91, 0x5c, 0xe5, 0xe7, 0xc4 ], [ 0x9c, 0x28, 0x52, 0x4a, 0x16, 0xa1, 0xe1, 0xc1, 0x45, 0x29, 0x71, 0xca, 0xa8, 0xd1, 0x34, 0x76 ], [ 0xed, 0x62, 0xe1, 0x63, 0x63, 0x63, 0x83, 0x60, 0xfd, 0xd6, 0xad, 0x62, 0x11, 0x27, 0x94, 0xf0 ], [ 0x5a, 0x86, 0x88, 0xf0, 0xb2, 0xa2, 0xc1, 0x62, 0x24, 0xc1, 0x61, 0x65, 0x8f, 0xfd, 0x40, 0x44 ], [ 0x23, 0xf7, 0x10, 0x84, 0x2b, 0x9b, 0xb9, 0xc3, 0x2f, 0x26, 0x64, 0x8c, 0x78, 0x68, 0x07, 0xca ], [ 0x44, 0xa9, 0x8b, 0xf1, 0x1e, 0x16, 0x3f, 0x63, 0x2c, 0x47, 0xec, 0x6a, 0x49, 0x68, 0x3a, 0x89 ], [ 0x0f, 0x18, 0xaf, 0xf9, 0x42, 0x74, 0x69, 0x6d, 0x9b, 0x61, 0x84, 0x8b, 0xd5, 0x0a, 0xc5, 0xe5 ], [ 0x82, 0x40, 0x85, 0x71, 0xc3, 0xe2, 0x42, 0x45, 0x40, 0x20, 0x7f, 0x83, 0x3b, 0x6d, 0xda, 0x69 ], [ 0x30, 0x3f, 0xf9, 0x96, 0x94, 0x7f, 0x0c, 0x7d, 0x1f, 0x43, 0xc8, 0xf3, 0x02, 0x7b, 0x9b, 0x75 ], [ 0x7d, 0xf4, 0xda, 0xf4, 0xad, 0x29, 0xa3, 0x61, 0x5a, 0x9b, 0x6e, 0xce, 0x5c, 0x99, 0x51, 0x8a ], [ 0xc7, 0x29, 0x54, 0xa4, 0x8d, 0x07, 0x74, 0xdb, 0x0b, 0x49, 0x71, 0xc5, 0x26, 0x26, 0x04, 0x15 ], [ 0x1d, 0xf9, 0xb7, 0x61, 0x12, 0xdc, 0x65, 0x31, 0xe0, 0x7d, 0x2c, 0xfd, 0xa0, 0x44, 0x11, 0xf0 ], [ 0x8e, 0x4d, 0x8e, 0x69, 0x91, 0x19, 0xe1, 0xfc, 0x87, 0x54, 0x5a, 0x64, 0x7f, 0xb1, 0xd3, 0x4f ], [ 0xe6, 0xc4, 0x80, 0x7a, 0xe1, 0x1f, 0x36, 0xf0, 0x91, 0xc5, 0x7d, 0x9f, 0xb6, 0x85, 0x48, 0xd1 ], [ 0x8e, 0xbf, 0x73, 0xaa, 0xd4, 0x9c, 0x82, 0x00, 0x7f, 0x77, 0xa5, 0xc1, 0xcc, 0xec, 0x6a, 0xb4 ], [ 0x4f, 0xb2, 0x88, 0xcc, 0x20, 0x40, 0x04, 0x90, 0x01, 0xd2, 0xc7, 0x58, 0x5a, 0xd1, 0x23, 0xfc ], [ 0x04, 0x49, 0x71, 0x10, 0xef, 0xb9, 0xdc, 0xeb, 0x13, 0xe2, 0xb1, 0x3f, 0xb4, 0x46, 0x55, 0x64 ], [ 0x75, 0x55, 0x0e, 0x6c, 0xb5, 0xa8, 0x8e, 0x49, 0x63, 0x4c, 0x9a, 0xb6, 0x9e, 0xda, 0x04, 0x30 ], [ 0xb6, 0x76, 0x84, 0x73, 0xce, 0x98, 0x43, 0xea, 0x66, 0xa8, 0x14, 0x05, 0xdd, 0x50, 0xb3, 0x45 ], [ 0xcb, 0x2f, 0x43, 0x03, 0x83, 0xf9, 0x08, 0x4e, 0x03, 0xa6, 0x53, 0x57, 0x1e, 0x06, 0x5d, 0xe6 ], [ 0xff, 0x4e, 0x66, 0xc0, 0x7b, 0xae, 0x3e, 0x79, 0xfb, 0x7d, 0x21, 0x08, 0x47, 0xa3, 0xb0, 0xba ], [ 0x7b, 0x90, 0x78, 0x51, 0x25, 0x50, 0x5f, 0xad, 0x59, 0xb1, 0x3c, 0x18, 0x6d, 0xd6, 0x6c, 0xe3 ], [ 0x8b, 0x52, 0x7a, 0x6a, 0xeb, 0xda, 0xec, 0x9e, 0xae, 0xf8, 0xed, 0xa2, 0xcb, 0x77, 0x83, 0xe5 ], [ 0x43, 0xfd, 0xaf, 0x53, 0xeb, 0xbc, 0x98, 0x80, 0xc2, 0x28, 0x61, 0x7d, 0x6a, 0x9b, 0x54, 0x8b ], [ 0x53, 0x78, 0x61, 0x04, 0xb9, 0x74, 0x4b, 0x98, 0xf0, 0x52, 0xc4, 0x6f, 0x1c, 0x85, 0x0d, 0x0b ], [ 0xb5, 0xab, 0x30, 0x13, 0xdd, 0x1e, 0x61, 0xdf, 0x06, 0xcb, 0xaf, 0x34, 0xca, 0x2a, 0xee, 0x78 ], [ 0x74, 0x70, 0x46, 0x9b, 0xe9, 0x72, 0x30, 0x30, 0xfd, 0xcc, 0x73, 0xa8, 0xcd, 0x4f, 0xbb, 0x10 ], [ 0xa3, 0x5a, 0x63, 0xf5, 0x34, 0x3e, 0xbe, 0x9e, 0xf8, 0x16, 0x7b, 0xcb, 0x48, 0xad, 0x12, 0x2e ], [ 0xfd, 0x86, 0x87, 0xf0, 0x75, 0x7a, 0x21, 0x0e, 0x9f, 0xdf, 0x18, 0x12, 0x04, 0xc3, 0x08, 0x63 ], [ 0x7a, 0x18, 0x1e, 0x84, 0xbd, 0x54, 0x57, 0xd2, 0x6a, 0x88, 0xfb, 0xae, 0x96, 0x01, 0x8f, 0xb0 ], [ 0x65, 0x33, 0x17, 0xb9, 0x36, 0x2b, 0x6f, 0x9b, 0x9e, 0x1a, 0x58, 0x0e, 0x68, 0xd4, 0x94, 0xb5 ], [ 0x99, 0x5c, 0x9d, 0xc0, 0xb6, 0x89, 0xf0, 0x3c, 0x45, 0x86, 0x7b, 0x5f, 0xaa, 0x5c, 0x18, 0xd1 ], [ 0x77, 0xa4, 0xd9, 0x6d, 0x56, 0xdd, 0xa3, 0x98, 0xb9, 0xaa, 0xbe, 0xcf, 0xc7, 0x57, 0x29, 0xfd ], [ 0x84, 0xbe, 0x19, 0xe0, 0x53, 0x63, 0x5f, 0x09, 0xf2, 0x66, 0x5e, 0x7b, 0xae, 0x85, 0xb4, 0x2d ], [ 0x32, 0xcd, 0x65, 0x28, 0x42, 0x92, 0x6a, 0xea, 0x4a, 0xa6, 0x13, 0x7b, 0xb2, 0xbe, 0x2b, 0x5e ], [ 0x49, 0x3d, 0x4a, 0x4f, 0x38, 0xeb, 0xb3, 0x37, 0xd1, 0x0a, 0xa8, 0x4e, 0x91, 0x71, 0xa5, 0x54 ], [ 0xd9, 0xbf, 0xf7, 0xff, 0x45, 0x4b, 0x0e, 0xc5, 0xa4, 0xa2, 0xa6, 0x95, 0x66, 0xe2, 0xcb, 0x84 ], [ 0x35, 0x35, 0xd5, 0x65, 0xac, 0xe3, 0xf3, 0x1e, 0xb2, 0x49, 0xba, 0x2c, 0xc6, 0x76, 0x5d, 0x7a ], [ 0xf6, 0x0e, 0x91, 0xfc, 0x32, 0x69, 0xee, 0xcf, 0x32, 0x31, 0xc6, 0xe9, 0x94, 0x56, 0x97, 0xc6 ], [ 0xab, 0x69, 0xcf, 0xad, 0xf5, 0x1f, 0x8e, 0x60, 0x4d, 0x9c, 0xc3, 0x71, 0x82, 0xf6, 0x63, 0x5a ], [ 0x78, 0x66, 0x37, 0x3f, 0x24, 0xa0, 0xb6, 0xed, 0x56, 0xe0, 0xd9, 0x6f, 0xcd, 0xaf, 0xb8, 0x77 ], [ 0x1e, 0xa4, 0x48, 0xc2, 0xaa, 0xc9, 0x54, 0xf5, 0xd8, 0x12, 0xe9, 0xd7, 0x84, 0x94, 0x44, 0x6a ], [ 0xac, 0xc5, 0x59, 0x9d, 0xd8, 0xac, 0x02, 0x23, 0x9a, 0x0f, 0xef, 0x4a, 0x36, 0xdd, 0x16, 0x68 ], [ 0xd8, 0x76, 0x44, 0x68, 0xbb, 0x10, 0x38, 0x28, 0xcf, 0x7e, 0x14, 0x73, 0xce, 0x89, 0x50, 0x73 ], [ 0x1b, 0x0d, 0x02, 0x89, 0x36, 0x83, 0xb9, 0xf1, 0x80, 0x45, 0x8e, 0x4a, 0xa6, 0xb7, 0x39, 0x82 ], [ 0x96, 0xd9, 0xb0, 0x17, 0xd3, 0x02, 0xdf, 0x41, 0x0a, 0x93, 0x7d, 0xcd, 0xb8, 0xbb, 0x6e, 0x43 ], [ 0xef, 0x16, 0x23, 0xcc, 0x44, 0x31, 0x3c, 0xff, 0x44, 0x0b, 0x15, 0x94, 0xa7, 0xe2, 0x1c, 0xc6 ], [ 0x28, 0x4c, 0xa2, 0xfa, 0x35, 0x80, 0x7b, 0x8b, 0x0a, 0xe4, 0xd1, 0x9e, 0x11, 0xd7, 0xdb, 0xd7 ], [ 0xf2, 0xe9, 0x76, 0x87, 0x57, 0x55, 0xf9, 0x40, 0x1d, 0x54, 0xf3, 0x6e, 0x2a, 0x23, 0xa5, 0x94 ], [ 0xec, 0x19, 0x8a, 0x18, 0xe1, 0x0e, 0x53, 0x24, 0x03, 0xb7, 0xe2, 0x08, 0x87, 0xc8, 0xdd, 0x80 ], [ 0x54, 0x5d, 0x50, 0xeb, 0xd9, 0x19, 0xe4, 0xa6, 0x94, 0x9d, 0x96, 0xad, 0x47, 0xe4, 0x6a, 0x80 ], [ 0xdb, 0xdf, 0xb5, 0x27, 0x06, 0x0e, 0x0a, 0x71, 0x00, 0x9c, 0x7b, 0xb0, 0xc6, 0x8f, 0x1d, 0x44 ], [ 0x9c, 0xfa, 0x13, 0x22, 0xea, 0x33, 0xda, 0x21, 0x73, 0xa0, 0x24, 0xf2, 0xff, 0x0d, 0x89, 0x6d ], [ 0x87, 0x85, 0xb1, 0xa7, 0x5b, 0x0f, 0x3b, 0xd9, 0x58, 0xdc, 0xd0, 0xe2, 0x93, 0x18, 0xc5, 0x21 ], [ 0x38, 0xf6, 0x7b, 0x9e, 0x98, 0xe4, 0xa9, 0x7b, 0x6d, 0xf0, 0x30, 0xa9, 0xfc, 0xdd, 0x01, 0x04 ], [ 0x19, 0x2a, 0xff, 0xfb, 0x2c, 0x88, 0x0e, 0x82, 0xb0, 0x59, 0x26, 0xd0, 0xfc, 0x6c, 0x44, 0x8b ], [ 0x6a, 0x79, 0x80, 0xce, 0x7b, 0x10, 0x5c, 0xf5, 0x30, 0x95, 0x2d, 0x74, 0xda, 0xaf, 0x79, 0x8c ], [ 0xea, 0x36, 0x95, 0xe1, 0x35, 0x1b, 0x9d, 0x68, 0x58, 0xbd, 0x95, 0x8c, 0xf5, 0x13, 0xef, 0x6c ], [ 0x6d, 0xa0, 0x49, 0x0b, 0xa0, 0xba, 0x03, 0x43, 0xb9, 0x35, 0x68, 0x1d, 0x2c, 0xce, 0x5b, 0xa1 ], [ 0xf0, 0xea, 0x23, 0xaf, 0x08, 0x53, 0x40, 0x11, 0xc6, 0x00, 0x09, 0xab, 0x29, 0xad, 0xa2, 0xf1 ], [ 0xff, 0x13, 0x80, 0x6c, 0xf1, 0x9c, 0xc3, 0x87, 0x21, 0x55, 0x4d, 0x7c, 0x0f, 0xcd, 0xcd, 0x4b ], [ 0x68, 0x38, 0xaf, 0x1f, 0x4f, 0x69, 0xba, 0xe9, 0xd8, 0x5d, 0xd1, 0x88, 0xdc, 0xdf, 0x06, 0x88 ], [ 0x36, 0xcf, 0x44, 0xc9, 0x2d, 0x55, 0x0b, 0xfb, 0x1e, 0xd2, 0x8e, 0xf5, 0x83, 0xdd, 0xf5, 0xd7 ], [ 0xd0, 0x6e, 0x31, 0x95, 0xb5, 0x37, 0x6f, 0x10, 0x9d, 0x5c, 0x4e, 0xc6, 0xc5, 0xd6, 0x2c, 0xed ], [ 0xc4, 0x40, 0xde, 0x01, 0x4d, 0x3d, 0x61, 0x07, 0x07, 0x27, 0x9b, 0x13, 0x24, 0x2a, 0x5c, 0x36 ], [ 0xf0, 0xc5, 0xc6, 0xff, 0xa5, 0xe0, 0xbd, 0x3a, 0x94, 0xc8, 0x8f, 0x6b, 0x6f, 0x7c, 0x16, 0xb9 ], [ 0x3e, 0x40, 0xc3, 0x90, 0x1c, 0xd7, 0xef, 0xfc, 0x22, 0xbf, 0xfc, 0x35, 0xde, 0xe0, 0xb4, 0xd9 ], [ 0xb6, 0x33, 0x05, 0xc7, 0x2b, 0xed, 0xfa, 0xb9, 0x73, 0x82, 0xc4, 0x06, 0xd0, 0xc4, 0x9b, 0xc6 ], [ 0x36, 0xbb, 0xaa, 0xb2, 0x2a, 0x6b, 0xd4, 0x92, 0x5a, 0x99, 0xa2, 0xb4, 0x08, 0xd2, 0xdb, 0xae ], [ 0x30, 0x7c, 0x5b, 0x8f, 0xcd, 0x05, 0x33, 0xab, 0x98, 0xbc, 0x51, 0xe2, 0x7a, 0x6c, 0xe4, 0x61 ], [ 0x82, 0x9c, 0x04, 0xff, 0x4c, 0x07, 0x51, 0x3c, 0x0b, 0x3e, 0xf0, 0x5c, 0x03, 0xe3, 0x37, 0xb5 ], [ 0xf1, 0x7a, 0xf0, 0xe8, 0x95, 0xdd, 0xa5, 0xeb, 0x98, 0xef, 0xc6, 0x80, 0x66, 0xe8, 0x4c, 0x54 ], [ 0x27, 0x71, 0x67, 0xf3, 0x81, 0x2a, 0xff, 0xf1, 0xff, 0xac, 0xb4, 0xa9, 0x34, 0x37, 0x9f, 0xc3 ], [ 0x2c, 0xb1, 0xdc, 0x3a, 0x9c, 0x72, 0x97, 0x2e, 0x42, 0x5a, 0xe2, 0xef, 0x3e, 0xb5, 0x97, 0xcd ], [ 0x36, 0xae, 0xaa, 0x3a, 0x21, 0x3e, 0x96, 0x8d, 0x4b, 0x5b, 0x67, 0x9d, 0x3a, 0x2c, 0x97, 0xfe ], [ 0x92, 0x41, 0xda, 0xca, 0x4f, 0xdd, 0x03, 0x4a, 0x82, 0x37, 0x2d, 0xb5, 0x0e, 0x1a, 0x0f, 0x3f ], [ 0xc1, 0x45, 0x74, 0xd9, 0xcd, 0x00, 0xcf, 0x2b, 0x5a, 0x7f, 0x77, 0xe5, 0x3c, 0xd5, 0x78, 0x85 ], [ 0x79, 0x3d, 0xe3, 0x92, 0x36, 0x57, 0x0a, 0xba, 0x83, 0xab, 0x9b, 0x73, 0x7c, 0xb5, 0x21, 0xc9 ], [ 0x16, 0x59, 0x1c, 0x0f, 0x27, 0xd6, 0x0e, 0x29, 0xb8, 0x5a, 0x96, 0xc3, 0x38, 0x61, 0xa7, 0xef ], [ 0x44, 0xfb, 0x5c, 0x4d, 0x4f, 0x5c, 0xb7, 0x9b, 0xe5, 0xc1, 0x74, 0xa3, 0xb1, 0xc9, 0x73, 0x48 ], [ 0x67, 0x4d, 0x2b, 0x61, 0x63, 0x3d, 0x16, 0x2b, 0xe5, 0x9d, 0xde, 0x04, 0x22, 0x2f, 0x47, 0x40 ], [ 0xb4, 0x75, 0x0f, 0xf2, 0x63, 0xa6, 0x5e, 0x1f, 0x9e, 0x92, 0x4c, 0xcf, 0xd9, 0x8f, 0x3e, 0x37 ], [ 0x62, 0xd0, 0x66, 0x2d, 0x6e, 0xae, 0xdd, 0xed, 0xeb, 0xae, 0x7f, 0x7e, 0xa3, 0xa4, 0xf6, 0xb6 ], [ 0x70, 0xc4, 0x6b, 0xb3, 0x06, 0x92, 0xbe, 0x65, 0x7f, 0x7e, 0xaa, 0x93, 0xeb, 0xad, 0x98, 0x97 ], [ 0x32, 0x39, 0x94, 0xcf, 0xb9, 0xda, 0x28, 0x5a, 0x5d, 0x96, 0x42, 0xe1, 0x75, 0x9b, 0x22, 0x4a ], [ 0x1d, 0xbf, 0x57, 0x87, 0x7b, 0x7b, 0x17, 0x38, 0x5c, 0x85, 0xd0, 0xb5, 0x48, 0x51, 0xe3, 0x71 ], [ 0xdf, 0xa5, 0xc0, 0x97, 0xcd, 0xc1, 0x53, 0x2a, 0xc0, 0x71, 0xd5, 0x7b, 0x1d, 0x28, 0xd1, 0xbd ], [ 0x3a, 0x0c, 0x53, 0xfa, 0x37, 0x31, 0x1f, 0xc1, 0x0b, 0xd2, 0xa9, 0x98, 0x1f, 0x51, 0x31, 0x74 ], [ 0xba, 0x4f, 0x97, 0x0c, 0x0a, 0x25, 0xc4, 0x18, 0x14, 0xbd, 0xae, 0x2e, 0x50, 0x6b, 0xe3, 0xb4 ], [ 0x2d, 0xce, 0x3a, 0xcb, 0x72, 0x7c, 0xd1, 0x3c, 0xcd, 0x76, 0xd4, 0x25, 0xea, 0x56, 0xe4, 0xf6 ], [ 0x51, 0x60, 0x47, 0x4d, 0x50, 0x4b, 0x9b, 0x3e, 0xef, 0xb6, 0x8d, 0x35, 0xf2, 0x45, 0xf4, 0xb3 ], [ 0x41, 0xa8, 0xa9, 0x47, 0x76, 0x66, 0x35, 0xde, 0xc3, 0x75, 0x53, 0xd9, 0xa6, 0xc0, 0xcb, 0xb7 ], [ 0x25, 0xd6, 0xcf, 0xe6, 0x88, 0x1f, 0x2b, 0xf4, 0x97, 0xdd, 0x14, 0xcd, 0x4d, 0xdf, 0x44, 0x5b ], [ 0x41, 0xc7, 0x8c, 0x13, 0x5e, 0xd9, 0xe9, 0x8c, 0x09, 0x66, 0x40, 0x64, 0x72, 0x65, 0xda, 0x1e ], [ 0x5a, 0x4d, 0x40, 0x4d, 0x89, 0x17, 0xe3, 0x53, 0xe9, 0x2a, 0x21, 0x07, 0x2c, 0x3b, 0x23, 0x05 ], [ 0x02, 0xbc, 0x96, 0x84, 0x6b, 0x3f, 0xdc, 0x71, 0x64, 0x3f, 0x38, 0x4c, 0xd3, 0xcc, 0x3e, 0xaf ], [ 0x9b, 0xa4, 0xa9, 0x14, 0x3f, 0x4e, 0x5d, 0x40, 0x48, 0x52, 0x1c, 0x4f, 0x88, 0x77, 0xd8, 0x8e ], [ 0xa1, 0xf6, 0x25, 0x8c, 0x87, 0x7d, 0x5f, 0xcd, 0x89, 0x64, 0x48, 0x45, 0x38, 0xbf, 0xc9, 0x2c ] ]; # Values from NIST KAT-AES CBCVarTxt192.rsp cipher_texts1_192bit = [ [ 0x6c, 0xd0, 0x25, 0x13, 0xe8, 0xd4, 0xdc, 0x98, 0x6b, 0x4a, 0xfe, 0x08, 0x7a, 0x60, 0xbd, 0x0c ], [ 0x2c, 0xe1, 0xf8, 0xb7, 0xe3, 0x06, 0x27, 0xc1, 0xc4, 0x51, 0x9e, 0xad, 0xa4, 0x4b, 0xc4, 0x36 ], [ 0x99, 0x46, 0xb5, 0xf8, 0x7a, 0xf4, 0x46, 0xf5, 0x79, 0x6c, 0x1f, 0xee, 0x63, 0xa2, 0xda, 0x24 ], [ 0x2a, 0x56, 0x03, 0x64, 0xce, 0x52, 0x9e, 0xfc, 0x21, 0x78, 0x87, 0x79, 0x56, 0x8d, 0x55, 0x55 ], [ 0x35, 0xc1, 0x47, 0x18, 0x37, 0xaf, 0x44, 0x61, 0x53, 0xbc, 0xe5, 0x5d, 0x5b, 0xa7, 0x2a, 0x0a ], [ 0xce, 0x60, 0xbc, 0x52, 0x38, 0x62, 0x34, 0xf1, 0x58, 0xf8, 0x43, 0x41, 0xe5, 0x34, 0xcd, 0x9e ], [ 0x8c, 0x7c, 0x27, 0xff, 0x32, 0xbc, 0xf8, 0xdc, 0x2d, 0xc5, 0x7c, 0x90, 0xc2, 0x90, 0x39, 0x61 ], [ 0x32, 0xbb, 0x6a, 0x7e, 0xc8, 0x44, 0x99, 0xe1, 0x66, 0xf9, 0x36, 0x00, 0x3d, 0x55, 0xa5, 0xbb ], [ 0xa5, 0xc7, 0x72, 0xe5, 0xc6, 0x26, 0x31, 0xef, 0x66, 0x0e, 0xe1, 0xd5, 0x87, 0x7f, 0x6d, 0x1b ], [ 0x03, 0x0d, 0x7e, 0x5b, 0x64, 0xf3, 0x80, 0xa7, 0xe4, 0xea, 0x53, 0x87, 0xb5, 0xcd, 0x7f, 0x49 ], [ 0x0d, 0xc9, 0xa2, 0x61, 0x00, 0x37, 0x00, 0x9b, 0x69, 0x8f, 0x11, 0xbb, 0x7e, 0x86, 0xc8, 0x3e ], [ 0x00, 0x46, 0x61, 0x2c, 0x76, 0x6d, 0x18, 0x40, 0xc2, 0x26, 0x36, 0x4f, 0x1f, 0xa7, 0xed, 0x72 ], [ 0x48, 0x80, 0xc7, 0xe0, 0x8f, 0x27, 0xbe, 0xfe, 0x78, 0x59, 0x07, 0x43, 0xc0, 0x5e, 0x69, 0x8b ], [ 0x25, 0x20, 0xce, 0x82, 0x9a, 0x26, 0x57, 0x7f, 0x0f, 0x48, 0x22, 0xc4, 0xec, 0xc8, 0x74, 0x01 ], [ 0x87, 0x65, 0xe8, 0xac, 0xc1, 0x69, 0x75, 0x83, 0x19, 0xcb, 0x46, 0xdc, 0x7b, 0xcf, 0x3d, 0xca ], [ 0xe9, 0x8f, 0x4b, 0xa4, 0xf0, 0x73, 0xdf, 0x4b, 0xaa, 0x11, 0x6d, 0x01, 0x1d, 0xc2, 0x4a, 0x28 ], [ 0xf3, 0x78, 0xf6, 0x8c, 0x5d, 0xbf, 0x59, 0xe2, 0x11, 0xb3, 0xa6, 0x59, 0xa7, 0x31, 0x7d, 0x94 ], [ 0x28, 0x3d, 0x3b, 0x06, 0x9d, 0x8e, 0xb9, 0xfb, 0x43, 0x2d, 0x74, 0xb9, 0x6c, 0xa7, 0x62, 0xb4 ], [ 0xa7, 0xe1, 0x84, 0x2e, 0x8a, 0x87, 0x86, 0x1c, 0x22, 0x1a, 0x50, 0x08, 0x83, 0x24, 0x5c, 0x51 ], [ 0x77, 0xaa, 0x27, 0x04, 0x71, 0x88, 0x1b, 0xe0, 0x70, 0xfb, 0x52, 0xc7, 0x06, 0x7c, 0xe7, 0x32 ], [ 0x01, 0xb0, 0xf4, 0x76, 0xd4, 0x84, 0xf4, 0x3f, 0x1a, 0xeb, 0x6e, 0xfa, 0x93, 0x61, 0xa8, 0xac ], [ 0x1c, 0x3a, 0x94, 0xf1, 0xc0, 0x52, 0xc5, 0x5c, 0x2d, 0x83, 0x59, 0xaf, 0xf2, 0x16, 0x3b, 0x4f ], [ 0xe8, 0xa0, 0x67, 0xb6, 0x04, 0xd5, 0x37, 0x3d, 0x8b, 0x0f, 0x2e, 0x05, 0xa0, 0x3b, 0x34, 0x1b ], [ 0xa7, 0x87, 0x6e, 0xc8, 0x7f, 0x5a, 0x09, 0xbf, 0xea, 0x42, 0xc7, 0x7d, 0xa3, 0x0f, 0xd5, 0x0e ], [ 0x0c, 0xf3, 0xe9, 0xd3, 0xa4, 0x2b, 0xe5, 0xb8, 0x54, 0xca, 0x65, 0xb1, 0x3f, 0x35, 0xf4, 0x8d ], [ 0x6c, 0x62, 0xf6, 0xbb, 0xca, 0xb7, 0xc3, 0xe8, 0x21, 0xc9, 0x29, 0x0f, 0x08, 0x89, 0x2d, 0xda ], [ 0x7f, 0x5e, 0x05, 0xbd, 0x20, 0x68, 0x73, 0x81, 0x96, 0xfe, 0xe7, 0x9a, 0xce, 0x7e, 0x3a, 0xec ], [ 0x44, 0x0e, 0x0d, 0x73, 0x32, 0x55, 0xcd, 0xa9, 0x2f, 0xb4, 0x6e, 0x84, 0x2f, 0xe5, 0x80, 0x54 ], [ 0xaa, 0x5d, 0x5b, 0x1c, 0x4e, 0xa1, 0xb7, 0xa2, 0x2e, 0x55, 0x83, 0xac, 0x2e, 0x9e, 0xd8, 0xa7 ], [ 0x77, 0xe5, 0x37, 0xe8, 0x9e, 0x84, 0x91, 0xe8, 0x66, 0x2a, 0xae, 0x3b, 0xc8, 0x09, 0x42, 0x1d ], [ 0x99, 0x7d, 0xd3, 0xe9, 0xf1, 0x59, 0x8b, 0xfa, 0x73, 0xf7, 0x59, 0x73, 0xf7, 0xe9, 0x3b, 0x76 ], [ 0x1b, 0x38, 0xd4, 0xf7, 0x45, 0x2a, 0xfe, 0xfc, 0xb7, 0xfc, 0x72, 0x12, 0x44, 0xe4, 0xb7, 0x2e ], [ 0x0b, 0xe2, 0xb1, 0x82, 0x52, 0xe7, 0x74, 0xdd, 0xa3, 0x0c, 0xdd, 0xa0, 0x2c, 0x69, 0x06, 0xe3 ], [ 0xd2, 0x69, 0x5e, 0x59, 0xc2, 0x03, 0x61, 0xd8, 0x26, 0x52, 0xd7, 0xd5, 0x8b, 0x6f, 0x11, 0xb2 ], [ 0x90, 0x2d, 0x88, 0xd1, 0x3e, 0xae, 0x52, 0x08, 0x9a, 0xbd, 0x61, 0x43, 0xcf, 0xe3, 0x94, 0xe9 ], [ 0xd4, 0x9b, 0xce, 0xb3, 0xb8, 0x23, 0xfe, 0xdd, 0x60, 0x2c, 0x30, 0x53, 0x45, 0x73, 0x4b, 0xd2 ], [ 0x70, 0x7b, 0x1d, 0xbb, 0x0f, 0xfa, 0x40, 0xef, 0x7d, 0x95, 0xde, 0xf4, 0x21, 0x23, 0x3f, 0xae ], [ 0x7c, 0xa0, 0xc1, 0xd9, 0x33, 0x56, 0xd9, 0xeb, 0x8a, 0xa9, 0x52, 0x08, 0x4d, 0x75, 0xf9, 0x13 ], [ 0xf2, 0xcb, 0xf9, 0xcb, 0x18, 0x6e, 0x27, 0x0d, 0xd7, 0xbd, 0xb0, 0xc2, 0x8f, 0xeb, 0xc5, 0x7d ], [ 0xc9, 0x43, 0x37, 0xc3, 0x7c, 0x4e, 0x79, 0x0a, 0xb4, 0x57, 0x80, 0xbd, 0x9c, 0x36, 0x74, 0xa0 ], [ 0x8e, 0x35, 0x58, 0xc1, 0x35, 0x25, 0x2f, 0xb9, 0xc9, 0xf3, 0x67, 0xed, 0x60, 0x94, 0x67, 0xa1 ], [ 0x1b, 0x72, 0xee, 0xae, 0xe4, 0x89, 0x9b, 0x44, 0x39, 0x14, 0xe5, 0xb3, 0xa5, 0x7f, 0xba, 0x92 ], [ 0x01, 0x18, 0x65, 0xf9, 0x1b, 0xc5, 0x68, 0x68, 0xd0, 0x51, 0xe5, 0x2c, 0x9e, 0xfd, 0x59, 0xb7 ], [ 0xe4, 0x77, 0x13, 0x18, 0xad, 0x7a, 0x63, 0xdd, 0x68, 0x0f, 0x6e, 0x58, 0x3b, 0x77, 0x47, 0xea ], [ 0x61, 0xe3, 0xd1, 0x94, 0x08, 0x8d, 0xc8, 0xd9, 0x7e, 0x9e, 0x6d, 0xb3, 0x74, 0x57, 0xea, 0xc5 ], [ 0x36, 0xff, 0x1e, 0xc9, 0xcc, 0xfb, 0xc3, 0x49, 0xe5, 0xd3, 0x56, 0xd0, 0x63, 0x69, 0x3a, 0xd6 ], [ 0x3c, 0xc9, 0xe9, 0xa9, 0xbe, 0x8c, 0xc3, 0xf6, 0xfb, 0x2e, 0xa2, 0x40, 0x88, 0xe9, 0xbb, 0x19 ], [ 0x1e, 0xe5, 0xab, 0x00, 0x3d, 0xc8, 0x72, 0x2e, 0x74, 0x90, 0x5d, 0x9a, 0x8f, 0xe3, 0xd3, 0x50 ], [ 0x24, 0x53, 0x39, 0x31, 0x95, 0x84, 0xb0, 0xa4, 0x12, 0x41, 0x28, 0x69, 0xd6, 0xc2, 0xea, 0xda ], [ 0x7b, 0xd4, 0x96, 0x91, 0x81, 0x15, 0xd1, 0x4e, 0xd5, 0x38, 0x08, 0x52, 0x71, 0x6c, 0x88, 0x14 ], [ 0x27, 0x3a, 0xb2, 0xf2, 0xb4, 0xa3, 0x66, 0xa5, 0x7d, 0x58, 0x2a, 0x33, 0x93, 0x13, 0xc8, 0xb1 ], [ 0x11, 0x33, 0x65, 0xa9, 0xff, 0xbe, 0x3b, 0x0c, 0xa6, 0x1e, 0x98, 0x50, 0x75, 0x54, 0x16, 0x8b ], [ 0xaf, 0xa9, 0x9c, 0x99, 0x7a, 0xc4, 0x78, 0xa0, 0xde, 0xa4, 0x11, 0x9c, 0x9e, 0x45, 0xf8, 0xb1 ], [ 0x92, 0x16, 0x30, 0x9a, 0x78, 0x42, 0x43, 0x0b, 0x83, 0xff, 0xb9, 0x86, 0x38, 0x01, 0x15, 0x12 ], [ 0x62, 0xab, 0xc7, 0x92, 0x28, 0x82, 0x58, 0x49, 0x2a, 0x7c, 0xb4, 0x51, 0x45, 0xf4, 0xb7, 0x59 ], [ 0x53, 0x49, 0x23, 0xc1, 0x69, 0xd5, 0x04, 0xd7, 0x51, 0x9c, 0x15, 0xd3, 0x0e, 0x75, 0x6c, 0x50 ], [ 0xfa, 0x75, 0xe0, 0x5b, 0xcd, 0xc7, 0xe0, 0x0c, 0x27, 0x3f, 0xa3, 0x3f, 0x6e, 0xe4, 0x41, 0xd2 ], [ 0x7d, 0x35, 0x0f, 0xa6, 0x05, 0x70, 0x80, 0xf1, 0x08, 0x6a, 0x56, 0xb1, 0x7e, 0xc2, 0x40, 0xdb ], [ 0xf3, 0x4e, 0x4a, 0x63, 0x24, 0xea, 0x4a, 0x5c, 0x39, 0xa6, 0x61, 0xc8, 0xfe, 0x5a, 0xda, 0x8f ], [ 0x08, 0x82, 0xa1, 0x6f, 0x44, 0x08, 0x8d, 0x42, 0x44, 0x7a, 0x29, 0xac, 0x09, 0x0e, 0xc1, 0x7e ], [ 0x3a, 0x3c, 0x15, 0xbf, 0xc1, 0x1a, 0x95, 0x37, 0xc1, 0x30, 0x68, 0x70, 0x04, 0xe1, 0x36, 0xee ], [ 0x22, 0xc0, 0xa7, 0x67, 0x8d, 0xc6, 0xd8, 0xcf, 0x5c, 0x8a, 0x6d, 0x5a, 0x99, 0x60, 0x76, 0x7c ], [ 0xb4, 0x6b, 0x09, 0x80, 0x9d, 0x68, 0xb9, 0xa4, 0x56, 0x43, 0x2a, 0x79, 0xbd, 0xc2, 0xe3, 0x8c ], [ 0x93, 0xba, 0xaf, 0xfb, 0x35, 0xfb, 0xe7, 0x39, 0xc1, 0x7c, 0x6a, 0xc2, 0x2e, 0xec, 0xf1, 0x8f ], [ 0xc8, 0xaa, 0x80, 0xa7, 0x85, 0x06, 0x75, 0xbc, 0x00, 0x7c, 0x46, 0xdf, 0x06, 0xb4, 0x98, 0x68 ], [ 0x12, 0xc6, 0xf3, 0x87, 0x7a, 0xf4, 0x21, 0xa9, 0x18, 0xa8, 0x4b, 0x77, 0x58, 0x58, 0x02, 0x1d ], [ 0x33, 0xf1, 0x23, 0x28, 0x2c, 0x5d, 0x63, 0x39, 0x24, 0xf7, 0xd5, 0xba, 0x3f, 0x3c, 0xab, 0x11 ], [ 0xa8, 0xf1, 0x61, 0x00, 0x27, 0x33, 0xe9, 0x3c, 0xa4, 0x52, 0x7d, 0x22, 0xc1, 0xa0, 0xc5, 0xbb ], [ 0xb7, 0x2f, 0x70, 0xeb, 0xf3, 0xe3, 0xfd, 0xa2, 0x3f, 0x50, 0x8e, 0xec, 0x76, 0xb4, 0x2c, 0x02 ], [ 0x6a, 0x9d, 0x96, 0x5e, 0x62, 0x74, 0x14, 0x3f, 0x25, 0xaf, 0xdc, 0xfc, 0x88, 0xff, 0xd7, 0x7c ], [ 0xa0, 0xc7, 0x4f, 0xd0, 0xb9, 0x36, 0x17, 0x64, 0xce, 0x91, 0xc5, 0x20, 0x0b, 0x09, 0x53, 0x57 ], [ 0x09, 0x1d, 0x1f, 0xdc, 0x2b, 0xd2, 0xc3, 0x46, 0xcd, 0x50, 0x46, 0xa8, 0xc6, 0x20, 0x91, 0x46 ], [ 0xe2, 0xa3, 0x75, 0x80, 0x11, 0x6c, 0xfb, 0x71, 0x85, 0x62, 0x54, 0x49, 0x6a, 0xb0, 0xac, 0xa8 ], [ 0xe0, 0xb3, 0xa0, 0x07, 0x85, 0x91, 0x7c, 0x7e, 0xfc, 0x9a, 0xdb, 0xa3, 0x22, 0x81, 0x35, 0x71 ], [ 0x73, 0x3d, 0x41, 0xf4, 0x72, 0x7b, 0x5e, 0xf0, 0xdf, 0x4a, 0xf4, 0xcf, 0x3c, 0xff, 0xa0, 0xcb ], [ 0xa9, 0x9e, 0xbb, 0x03, 0x02, 0x60, 0x82, 0x6f, 0x98, 0x1a, 0xd3, 0xe6, 0x44, 0x90, 0xaa, 0x4f ], [ 0x73, 0xf3, 0x4c, 0x7d, 0x3e, 0xae, 0x5e, 0x80, 0x08, 0x2c, 0x16, 0x47, 0x52, 0x43, 0x08, 0xee ], [ 0x40, 0xeb, 0xd5, 0xad, 0x08, 0x23, 0x45, 0xb7, 0xa2, 0x09, 0x7c, 0xcd, 0x34, 0x64, 0xda, 0x02 ], [ 0x7c, 0xc4, 0xae, 0x9a, 0x42, 0x4b, 0x2c, 0xec, 0x90, 0xc9, 0x71, 0x53, 0xc2, 0x45, 0x7e, 0xc5 ], [ 0x54, 0xd6, 0x32, 0xd0, 0x3a, 0xba, 0x0b, 0xd0, 0xf9, 0x18, 0x77, 0xeb, 0xdd, 0x4d, 0x09, 0xcb ], [ 0xd3, 0x42, 0x7b, 0xe7, 0xe4, 0xd2, 0x7c, 0xd5, 0x4f, 0x5f, 0xe3, 0x7b, 0x03, 0xcf, 0x08, 0x97 ], [ 0xb2, 0x09, 0x97, 0x95, 0xe8, 0x8c, 0xc1, 0x58, 0xfd, 0x75, 0xea, 0x13, 0x3d, 0x7e, 0x7f, 0xbe ], [ 0xa6, 0xca, 0xe4, 0x6f, 0xb6, 0xfa, 0xdf, 0xe7, 0xa2, 0xc3, 0x02, 0xa3, 0x42, 0x42, 0x81, 0x7b ], [ 0x02, 0x6a, 0x70, 0x24, 0xd6, 0xa9, 0x02, 0xe0, 0xb3, 0xff, 0xcc, 0xba, 0xa9, 0x10, 0xcc, 0x3f ], [ 0x15, 0x6f, 0x07, 0x76, 0x7a, 0x85, 0xa4, 0x31, 0x23, 0x21, 0xf6, 0x39, 0x68, 0x33, 0x8a, 0x01 ], [ 0x15, 0xee, 0xc9, 0xeb, 0xf4, 0x2b, 0x9c, 0xa7, 0x68, 0x97, 0xd2, 0xcd, 0x6c, 0x5a, 0x12, 0xe2 ], [ 0xdb, 0x0d, 0x3a, 0x6f, 0xdc, 0xc1, 0x3f, 0x91, 0x5e, 0x2b, 0x30, 0x2c, 0xee, 0xb7, 0x0f, 0xd8 ], [ 0x71, 0xdb, 0xf3, 0x7e, 0x87, 0xa2, 0xe3, 0x4d, 0x15, 0xb2, 0x0e, 0x8f, 0x10, 0xe4, 0x89, 0x24 ], [ 0xc7, 0x45, 0xc4, 0x51, 0xe9, 0x6f, 0xf3, 0xc0, 0x45, 0xe4, 0x36, 0x7c, 0x83, 0x3e, 0x3b, 0x54 ], [ 0x34, 0x0d, 0xa0, 0x9c, 0x2d, 0xd1, 0x1c, 0x3b, 0x67, 0x9d, 0x08, 0xcc, 0xd2, 0x7d, 0xd5, 0x95 ], [ 0x82, 0x79, 0xf7, 0xc0, 0xc2, 0xa0, 0x3e, 0xe6, 0x60, 0xc6, 0xd3, 0x92, 0xdb, 0x02, 0x5d, 0x18 ], [ 0xa4, 0xb2, 0xc7, 0xd8, 0xeb, 0xa5, 0x31, 0xff, 0x47, 0xc5, 0x04, 0x1a, 0x55, 0xfb, 0xd1, 0xec ], [ 0x74, 0x56, 0x9a, 0x2c, 0xa5, 0xa7, 0xbd, 0x51, 0x31, 0xce, 0x8d, 0xc7, 0xcb, 0xfb, 0xf7, 0x2f ], [ 0x37, 0x13, 0xda, 0x0c, 0x02, 0x19, 0xb6, 0x34, 0x54, 0x03, 0x56, 0x13, 0xb5, 0xa4, 0x03, 0xdd ], [ 0x88, 0x27, 0x55, 0x1d, 0xdc, 0xc9, 0xdf, 0x23, 0xfa, 0x72, 0xa3, 0xde, 0x4e, 0x9f, 0x0b, 0x07 ], [ 0x2e, 0x3f, 0xeb, 0xfd, 0x62, 0x5b, 0xfc, 0xd0, 0xa2, 0xc0, 0x6e, 0xb4, 0x60, 0xda, 0x17, 0x32 ], [ 0xee, 0x82, 0xe6, 0xba, 0x48, 0x81, 0x56, 0xf7, 0x64, 0x96, 0x31, 0x1d, 0xa6, 0x94, 0x1d, 0xeb ], [ 0x47, 0x70, 0x44, 0x6f, 0x01, 0xd1, 0xf3, 0x91, 0x25, 0x6e, 0x85, 0xa1, 0xb3, 0x0d, 0x89, 0xd3 ], [ 0xaf, 0x04, 0xb6, 0x8f, 0x10, 0x4f, 0x21, 0xef, 0x2a, 0xfb, 0x47, 0x67, 0xcf, 0x74, 0x14, 0x3c ], [ 0xcf, 0x35, 0x79, 0xa9, 0xba, 0x38, 0xc8, 0xe4, 0x36, 0x53, 0x17, 0x3e, 0x14, 0xf3, 0xa4, 0xc6 ], [ 0xb3, 0xbb, 0xa9, 0x04, 0xf4, 0x95, 0x3e, 0x09, 0xb5, 0x48, 0x00, 0xaf, 0x2f, 0x62, 0xe7, 0xd4 ], [ 0xfc, 0x42, 0x49, 0x65, 0x6e, 0x14, 0xb2, 0x9e, 0xb9, 0xc4, 0x48, 0x29, 0xb4, 0xc5, 0x9a, 0x46 ], [ 0x9b, 0x31, 0x56, 0x8f, 0xeb, 0xe8, 0x1c, 0xfc, 0x2e, 0x65, 0xaf, 0x1c, 0x86, 0xd1, 0xa3, 0x08 ], [ 0x9c, 0xa0, 0x9c, 0x25, 0xf2, 0x73, 0xa7, 0x66, 0xdb, 0x98, 0xa4, 0x80, 0xce, 0x8d, 0xfe, 0xdc ], [ 0xb9, 0x09, 0x92, 0x57, 0x86, 0xf3, 0x4c, 0x3c, 0x92, 0xd9, 0x71, 0x88, 0x3c, 0x9f, 0xbe, 0xdf ], [ 0x82, 0x64, 0x7f, 0x13, 0x32, 0xfe, 0x57, 0x0a, 0x9d, 0x4d, 0x92, 0xb2, 0xee, 0x77, 0x1d, 0x3b ], [ 0x36, 0x04, 0xa7, 0xe8, 0x08, 0x32, 0xb3, 0xa9, 0x99, 0x54, 0xbc, 0xa6, 0xf5, 0xb9, 0xf5, 0x01 ], [ 0x88, 0x46, 0x07, 0xb1, 0x28, 0xc5, 0xde, 0x3a, 0xb3, 0x9a, 0x52, 0x9a, 0x1e, 0xf5, 0x1b, 0xef ], [ 0x67, 0x0c, 0xfa, 0x09, 0x3d, 0x1d, 0xbd, 0xb2, 0x31, 0x70, 0x41, 0x40, 0x41, 0x02, 0x43, 0x5e ], [ 0x7a, 0x86, 0x71, 0x95, 0xf3, 0xce, 0x87, 0x69, 0xcb, 0xd3, 0x36, 0x50, 0x2f, 0xbb, 0x51, 0x30 ], [ 0x52, 0xef, 0xcf, 0x64, 0xc7, 0x2b, 0x2f, 0x7c, 0xa5, 0xb3, 0xc8, 0x36, 0xb1, 0x07, 0x8c, 0x15 ], [ 0x40, 0x19, 0x25, 0x0f, 0x6e, 0xef, 0xb2, 0xac, 0x5c, 0xcb, 0xca, 0xe0, 0x44, 0xe7, 0x5c, 0x7e ], [ 0x02, 0x2c, 0x4f, 0x6f, 0x5a, 0x01, 0x7d, 0x29, 0x27, 0x85, 0x62, 0x76, 0x67, 0xdd, 0xef, 0x24 ], [ 0xe9, 0xc2, 0x10, 0x78, 0xa2, 0xeb, 0x7e, 0x03, 0x25, 0x0f, 0x71, 0x00, 0x0f, 0xa9, 0xe3, 0xed ], [ 0xa1, 0x3e, 0xae, 0xeb, 0x9c, 0xd3, 0x91, 0xda, 0x4e, 0x2b, 0x09, 0x49, 0x0b, 0x3e, 0x7f, 0xad ], [ 0xc9, 0x58, 0xa1, 0x71, 0xdc, 0xa1, 0xd4, 0xed, 0x53, 0xe1, 0xaf, 0x1d, 0x38, 0x08, 0x03, 0xa9 ], [ 0x21, 0x44, 0x2e, 0x07, 0xa1, 0x10, 0x66, 0x7f, 0x25, 0x83, 0xea, 0xee, 0xee, 0x44, 0xdc, 0x8c ], [ 0x59, 0xbb, 0xb3, 0x53, 0xcf, 0x1d, 0xd8, 0x67, 0xa6, 0xe3, 0x37, 0x37, 0xaf, 0x65, 0x5e, 0x99 ], [ 0x43, 0xcd, 0x3b, 0x25, 0x37, 0x5d, 0x0c, 0xe4, 0x10, 0x87, 0xff, 0x9f, 0xe2, 0x82, 0x96, 0x39 ], [ 0x6b, 0x98, 0xb1, 0x7e, 0x80, 0xd1, 0x11, 0x8e, 0x35, 0x16, 0xbd, 0x76, 0x8b, 0x28, 0x5a, 0x84 ], [ 0xae, 0x47, 0xed, 0x36, 0x76, 0xca, 0x0c, 0x08, 0xde, 0xea, 0x02, 0xd9, 0x5b, 0x81, 0xdb, 0x58 ], [ 0x34, 0xec, 0x40, 0xdc, 0x20, 0x41, 0x37, 0x95, 0xed, 0x53, 0x62, 0x8e, 0xa7, 0x48, 0x72, 0x0b ], [ 0x4d, 0xc6, 0x81, 0x63, 0xf8, 0xe9, 0x83, 0x54, 0x73, 0x25, 0x35, 0x42, 0xc8, 0xa6, 0x5d, 0x46 ], [ 0x2a, 0xab, 0xb9, 0x99, 0xf4, 0x36, 0x93, 0x17, 0x5a, 0xf6, 0x5c, 0x6c, 0x61, 0x2c, 0x46, 0xfb ], [ 0xe0, 0x1f, 0x94, 0x49, 0x9d, 0xac, 0x35, 0x47, 0x51, 0x5c, 0x5b, 0x1d, 0x75, 0x6f, 0x0f, 0x58 ], [ 0x9d, 0x12, 0x43, 0x5a, 0x46, 0x48, 0x0c, 0xe0, 0x0e, 0xa3, 0x49, 0xf7, 0x17, 0x99, 0xdf, 0x9a ], [ 0xce, 0xf4, 0x1d, 0x16, 0xd2, 0x66, 0xbd, 0xfe, 0x46, 0x93, 0x8a, 0xd7, 0x88, 0x4c, 0xc0, 0xcf ], [ 0xb1, 0x3d, 0xb4, 0xda, 0x1f, 0x71, 0x8b, 0xc6, 0x90, 0x47, 0x97, 0xc8, 0x2b, 0xcf, 0x2d, 0x32 ] ]; # Values from NIST KAT-AES CBCVarKey192.rsp cipher_texts2_192bit = [ [ 0xde, 0x88, 0x5d, 0xc8, 0x7f, 0x5a, 0x92, 0x59, 0x40, 0x82, 0xd0, 0x2c, 0xc1, 0xe1, 0xb4, 0x2c ], [ 0x13, 0x2b, 0x07, 0x4e, 0x80, 0xf2, 0xa5, 0x97, 0xbf, 0x5f, 0xeb, 0xd8, 0xea, 0x5d, 0xa5, 0x5e ], [ 0x6e, 0xcc, 0xed, 0xf8, 0xde, 0x59, 0x2c, 0x22, 0xfb, 0x81, 0x34, 0x7b, 0x79, 0xf2, 0xdb, 0x1f ], [ 0x18, 0x0b, 0x09, 0xf2, 0x67, 0xc4, 0x51, 0x45, 0xdb, 0x2f, 0x82, 0x6c, 0x25, 0x82, 0xd3, 0x5c ], [ 0xed, 0xd8, 0x07, 0xef, 0x76, 0x52, 0xd7, 0xeb, 0x0e, 0x13, 0xc8, 0xb5, 0xe1, 0x5b, 0x3b, 0xc0 ], [ 0x99, 0x78, 0xbc, 0xf8, 0xdd, 0x8f, 0xd7, 0x22, 0x41, 0x22, 0x3a, 0xd2, 0x4b, 0x31, 0xb8, 0xa4 ], [ 0x53, 0x10, 0xf6, 0x54, 0x34, 0x3e, 0x8f, 0x27, 0xe1, 0x2c, 0x83, 0xa4, 0x8d, 0x24, 0xff, 0x81 ], [ 0x83, 0x3f, 0x71, 0x25, 0x8d, 0x53, 0x03, 0x6b, 0x02, 0x95, 0x2c, 0x76, 0xc7, 0x44, 0xf5, 0xa1 ], [ 0xeb, 0xa8, 0x3f, 0xf2, 0x00, 0xcf, 0xf9, 0x31, 0x8a, 0x92, 0xf8, 0x69, 0x1a, 0x06, 0xb0, 0x9f ], [ 0xff, 0x62, 0x0c, 0xcb, 0xe9, 0xf3, 0x29, 0x2a, 0xbd, 0xf2, 0x17, 0x6b, 0x09, 0xf0, 0x4e, 0xba ], [ 0x7a, 0xba, 0xbc, 0x4b, 0x3f, 0x51, 0x6c, 0x9a, 0xaf, 0xb3, 0x5f, 0x41, 0x40, 0xb5, 0x48, 0xf9 ], [ 0xaa, 0x18, 0x78, 0x24, 0xd9, 0xc4, 0x58, 0x2b, 0x09, 0x16, 0x49, 0x3e, 0xcb, 0xde, 0x8c, 0x57 ], [ 0x1c, 0x0a, 0xd5, 0x53, 0x17, 0x7f, 0xd5, 0xea, 0x10, 0x92, 0xc9, 0xd6, 0x26, 0xa2, 0x9d, 0xc4 ], [ 0xa5, 0xdc, 0x46, 0xc3, 0x72, 0x61, 0x19, 0x41, 0x24, 0xec, 0xae, 0xbd, 0x68, 0x04, 0x08, 0xec ], [ 0xe4, 0xf2, 0xf2, 0xae, 0x23, 0xe9, 0xb1, 0x0b, 0xac, 0xfa, 0x58, 0x60, 0x15, 0x31, 0xba, 0x54 ], [ 0xb7, 0xd6, 0x7c, 0xf1, 0xa1, 0xe9, 0x1e, 0x8f, 0xf3, 0xa5, 0x7a, 0x17, 0x2c, 0x7b, 0xf4, 0x12 ], [ 0x26, 0x70, 0x6b, 0xe0, 0x69, 0x67, 0x88, 0x4e, 0x84, 0x7d, 0x13, 0x71, 0x28, 0xce, 0x47, 0xb3 ], [ 0xb2, 0xf8, 0xb4, 0x09, 0xb0, 0x58, 0x59, 0x09, 0xaa, 0xd3, 0xa7, 0xb5, 0xa2, 0x19, 0x07, 0x2a ], [ 0x5e, 0x4b, 0x7b, 0xff, 0x02, 0x90, 0xc7, 0x83, 0x44, 0xc5, 0x4a, 0x23, 0xb7, 0x22, 0xcd, 0x20 ], [ 0x07, 0x09, 0x36, 0x57, 0x55, 0x2d, 0x44, 0x14, 0x22, 0x7c, 0xe1, 0x61, 0xe9, 0xeb, 0xf7, 0xdd ], [ 0xe1, 0xaf, 0x1e, 0x7d, 0x8b, 0xc2, 0x25, 0xed, 0x4d, 0xff, 0xb7, 0x71, 0xec, 0xbb, 0x9e, 0x67 ], [ 0xef, 0x65, 0x55, 0x25, 0x36, 0x35, 0xd8, 0x43, 0x21, 0x56, 0xcf, 0xd9, 0xc1, 0x1b, 0x14, 0x5a ], [ 0xfb, 0x40, 0x35, 0x07, 0x4a, 0x5d, 0x42, 0x60, 0xc9, 0x0c, 0xbd, 0x6d, 0xa6, 0xc3, 0xfc, 0xeb ], [ 0x44, 0x6e, 0xe4, 0x16, 0xf9, 0xad, 0x1c, 0x10, 0x3e, 0xb0, 0xcc, 0x96, 0x75, 0x1c, 0x88, 0xe1 ], [ 0x19, 0x8a, 0xe2, 0xa4, 0x63, 0x7a, 0xc0, 0xa7, 0x89, 0x0a, 0x8f, 0xd1, 0x48, 0x54, 0x45, 0xc9 ], [ 0x56, 0x20, 0x12, 0xec, 0x8f, 0xad, 0xed, 0x08, 0x25, 0xfb, 0x2f, 0xa7, 0x0a, 0xb3, 0x0c, 0xbd ], [ 0xcc, 0x8a, 0x64, 0xb4, 0x6b, 0x5d, 0x88, 0xbf, 0x7f, 0x24, 0x7d, 0x4d, 0xba, 0xf3, 0x8f, 0x05 ], [ 0xa1, 0x68, 0x25, 0x37, 0x62, 0xe2, 0xcc, 0x81, 0xb4, 0x2d, 0x1e, 0x50, 0x01, 0x76, 0x26, 0x99 ], [ 0x1b, 0x41, 0xf8, 0x3b, 0x38, 0xce, 0x50, 0x32, 0xc6, 0xcd, 0x7a, 0xf9, 0x8c, 0xf6, 0x20, 0x61 ], [ 0x61, 0xa8, 0x99, 0x90, 0xcd, 0x14, 0x11, 0x75, 0x0d, 0x5f, 0xb0, 0xdc, 0x98, 0x84, 0x47, 0xd4 ], [ 0xb5, 0xac, 0xcc, 0x8e, 0xd6, 0x29, 0xed, 0xf8, 0xc6, 0x8a, 0x53, 0x91, 0x83, 0xb1, 0xea, 0x82 ], [ 0xb1, 0x6f, 0xa7, 0x1f, 0x84, 0x6b, 0x81, 0xa1, 0x3f, 0x36, 0x1c, 0x43, 0xa8, 0x51, 0xf2, 0x90 ], [ 0x4f, 0xad, 0x6e, 0xfd, 0xff, 0x59, 0x75, 0xae, 0xe7, 0x69, 0x22, 0x34, 0xbc, 0xd5, 0x44, 0x88 ], [ 0xeb, 0xfd, 0xb0, 0x5a, 0x78, 0x3d, 0x03, 0x08, 0x2d, 0xfe, 0x5f, 0xdd, 0x80, 0xa0, 0x0b, 0x17 ], [ 0xeb, 0x81, 0xb5, 0x84, 0x76, 0x69, 0x97, 0xaf, 0x6b, 0xa5, 0x52, 0x9d, 0x3b, 0xdd, 0x86, 0x09 ], [ 0x0c, 0xf4, 0xff, 0x4f, 0x49, 0xc8, 0xa0, 0xca, 0x06, 0x0c, 0x44, 0x34, 0x99, 0xe2, 0x93, 0x13 ], [ 0xcc, 0x4b, 0xa8, 0xa8, 0xe0, 0x29, 0xf8, 0xb2, 0x6d, 0x8a, 0xff, 0xf9, 0xdf, 0x13, 0x3b, 0xb6 ], [ 0xfe, 0xfe, 0xbf, 0x64, 0x36, 0x0f, 0x38, 0xe4, 0xe6, 0x35, 0x58, 0xf0, 0xff, 0xc5, 0x50, 0xc3 ], [ 0x12, 0xad, 0x98, 0xcb, 0xf7, 0x25, 0x13, 0x7d, 0x6a, 0x81, 0x08, 0xc2, 0xbe, 0xd9, 0x93, 0x22 ], [ 0x6a, 0xfa, 0xa9, 0x96, 0x22, 0x61, 0x98, 0xb3, 0xe2, 0x61, 0x04, 0x13, 0xce, 0x1b, 0x3f, 0x78 ], [ 0x2a, 0x8c, 0xe6, 0x74, 0x7a, 0x7e, 0x39, 0x36, 0x78, 0x28, 0xe2, 0x90, 0x84, 0x85, 0x02, 0xd9 ], [ 0x22, 0x37, 0x36, 0xe8, 0xb8, 0xf8, 0x9c, 0xa1, 0xe3, 0x7b, 0x6d, 0xea, 0xb4, 0x0f, 0xac, 0xf1 ], [ 0xc0, 0xf7, 0x97, 0xe5, 0x04, 0x18, 0xb9, 0x5f, 0xa6, 0x01, 0x33, 0x33, 0x91, 0x7a, 0x94, 0x80 ], [ 0xa7, 0x58, 0xde, 0x37, 0xc2, 0xec, 0xe2, 0xa0, 0x2c, 0x73, 0xc0, 0x1f, 0xed, 0xc9, 0xa1, 0x32 ], [ 0x3a, 0x9b, 0x87, 0xae, 0x77, 0xba, 0xe7, 0x06, 0x80, 0x39, 0x66, 0xc6, 0x6c, 0x73, 0xad, 0xbd ], [ 0xd3, 0x65, 0xab, 0x8d, 0xf8, 0xff, 0xd7, 0x82, 0xe3, 0x58, 0x12, 0x1a, 0x4a, 0x4f, 0xc5, 0x41 ], [ 0xc8, 0xdc, 0xd9, 0xe6, 0xf7, 0x5e, 0x6c, 0x36, 0xc8, 0xda, 0xee, 0x04, 0x66, 0xf0, 0xed, 0x74 ], [ 0xc7, 0x9a, 0x63, 0x7b, 0xeb, 0x1c, 0x03, 0x04, 0xf1, 0x40, 0x14, 0xc0, 0x37, 0xe7, 0x36, 0xdd ], [ 0x10, 0x5f, 0x0a, 0x25, 0xe8, 0x4a, 0xc9, 0x30, 0xd9, 0x96, 0x28, 0x1a, 0x5f, 0x95, 0x4d, 0xd9 ], [ 0x42, 0xe4, 0x07, 0x4b, 0x29, 0x27, 0x97, 0x3e, 0x8d, 0x17, 0xff, 0xa9, 0x2f, 0x7f, 0xe6, 0x15 ], [ 0x4f, 0xe2, 0xa9, 0xd2, 0xc1, 0x82, 0x44, 0x49, 0xc6, 0x9e, 0x3e, 0x03, 0x98, 0xf1, 0x29, 0x63 ], [ 0xb7, 0xf2, 0x9c, 0x1e, 0x1f, 0x62, 0x84, 0x7a, 0x15, 0x25, 0x3b, 0x28, 0xa1, 0xe9, 0xd7, 0x12 ], [ 0x36, 0xed, 0x5d, 0x29, 0xb9, 0x03, 0xf3, 0x1e, 0x89, 0x83, 0xef, 0x8b, 0x0a, 0x2b, 0xf9, 0x90 ], [ 0x27, 0xb8, 0x07, 0x02, 0x70, 0x81, 0x0f, 0x9d, 0x02, 0x3f, 0x9d, 0xd7, 0xff, 0x3b, 0x4a, 0xa2 ], [ 0x94, 0xd4, 0x6e, 0x15, 0x5c, 0x12, 0x28, 0xf6, 0x1d, 0x1a, 0x0d, 0xb4, 0x81, 0x5e, 0xcc, 0x4b ], [ 0xca, 0x61, 0x08, 0xd1, 0xd9, 0x80, 0x71, 0x42, 0x8e, 0xec, 0xee, 0xf1, 0x71, 0x4b, 0x96, 0xdd ], [ 0xdc, 0x5b, 0x25, 0xb7, 0x1b, 0x62, 0x96, 0xcf, 0x73, 0xdd, 0x2c, 0xdc, 0xac, 0x2f, 0x70, 0xb1 ], [ 0x44, 0xab, 0xa9, 0x5e, 0x8a, 0x06, 0xa2, 0xd9, 0xd3, 0x53, 0x0d, 0x26, 0x77, 0x87, 0x8c, 0x80 ], [ 0xa5, 0x70, 0xd2, 0x0e, 0x89, 0xb4, 0x67, 0xe8, 0xf5, 0x17, 0x60, 0x61, 0xb8, 0x1d, 0xd3, 0x96 ], [ 0x75, 0x8f, 0x44, 0x67, 0xa5, 0xd8, 0xf1, 0xe7, 0x30, 0x7d, 0xc3, 0x0b, 0x34, 0xe4, 0x04, 0xf4 ], [ 0xbc, 0xea, 0x28, 0xe9, 0x07, 0x1b, 0x5a, 0x23, 0x02, 0x97, 0x0f, 0xf3, 0x52, 0x45, 0x1b, 0xc5 ], [ 0x75, 0x23, 0xc0, 0x0b, 0xc1, 0x77, 0xd3, 0x31, 0xad, 0x31, 0x2e, 0x09, 0xc9, 0x01, 0x5c, 0x1c ], [ 0xcc, 0xac, 0x61, 0xe3, 0x18, 0x37, 0x47, 0xb3, 0xf5, 0x83, 0x6d, 0xa2, 0x1a, 0x1b, 0xc4, 0xf4 ], [ 0x70, 0x7b, 0x07, 0x57, 0x91, 0x87, 0x88, 0x80, 0xb4, 0x41, 0x89, 0xd3, 0x52, 0x2b, 0x8c, 0x30 ], [ 0x71, 0x32, 0xd0, 0xc0, 0xe4, 0xa0, 0x75, 0x93, 0xcf, 0x12, 0xeb, 0xb1, 0x2b, 0xe7, 0x68, 0x8c ], [ 0xef, 0xfb, 0xac, 0x16, 0x44, 0xde, 0xb0, 0xc7, 0x84, 0x27, 0x5f, 0xe5, 0x6e, 0x19, 0xea, 0xd3 ], [ 0xa0, 0x05, 0x06, 0x3f, 0x30, 0xf4, 0x22, 0x8b, 0x37, 0x4e, 0x24, 0x59, 0x73, 0x8f, 0x26, 0xbb ], [ 0x29, 0x97, 0x5b, 0x5f, 0x48, 0xbb, 0x68, 0xfc, 0xbb, 0xc7, 0xce, 0xa9, 0x3b, 0x45, 0x2e, 0xd7 ], [ 0xcf, 0x3f, 0x25, 0x76, 0xe2, 0xaf, 0xed, 0xc7, 0x4b, 0xb1, 0xca, 0x7e, 0xee, 0xc1, 0xc0, 0xe7 ], [ 0x07, 0xc4, 0x03, 0xf5, 0xf9, 0x66, 0xe0, 0xe3, 0xd9, 0xf2, 0x96, 0xd6, 0x22, 0x6d, 0xca, 0x28 ], [ 0xc8, 0xc2, 0x09, 0x08, 0x24, 0x9a, 0xb4, 0xa3, 0x4d, 0x6d, 0xd0, 0xa3, 0x13, 0x27, 0xff, 0x1a ], [ 0xc0, 0x54, 0x13, 0x29, 0xec, 0xb6, 0x15, 0x9a, 0xb2, 0x3b, 0x7f, 0xc5, 0xe6, 0xa2, 0x1b, 0xca ], [ 0x7a, 0xa1, 0xac, 0xf1, 0xa2, 0xed, 0x9b, 0xa7, 0x2b, 0xc6, 0xde, 0xb3, 0x1d, 0x88, 0xb8, 0x63 ], [ 0x80, 0x8b, 0xd8, 0xed, 0xda, 0xbb, 0x6f, 0x3b, 0xf0, 0xd5, 0xa8, 0xa2, 0x7b, 0xe1, 0xfe, 0x8a ], [ 0x27, 0x3c, 0x7d, 0x76, 0x85, 0xe1, 0x4e, 0xc6, 0x6b, 0xbb, 0x96, 0xb8, 0xf0, 0x5b, 0x6d, 0xdd ], [ 0x32, 0x75, 0x2e, 0xef, 0xc8, 0xc2, 0xa9, 0x3f, 0x91, 0xb6, 0xe7, 0x3e, 0xb0, 0x7c, 0xca, 0x6e ], [ 0xd8, 0x93, 0xe7, 0xd6, 0x2f, 0x6c, 0xe5, 0x02, 0xc6, 0x4f, 0x75, 0xe2, 0x81, 0xf9, 0xc0, 0x00 ], [ 0x8d, 0xfd, 0x99, 0x9b, 0xe5, 0xd0, 0xcf, 0xa3, 0x57, 0x32, 0xc0, 0xdd, 0xc8, 0x8f, 0xf5, 0xa5 ], [ 0x02, 0x64, 0x7c, 0x76, 0xa3, 0x00, 0xc3, 0x17, 0x3b, 0x84, 0x14, 0x87, 0xeb, 0x2b, 0xae, 0x9f ], [ 0x17, 0x2d, 0xf8, 0xb0, 0x2f, 0x04, 0xb5, 0x3a, 0xda, 0xb0, 0x28, 0xb4, 0xe0, 0x1a, 0xcd, 0x87 ], [ 0x05, 0x4b, 0x3b, 0xf4, 0x99, 0x8a, 0xeb, 0x05, 0xaf, 0xd8, 0x7e, 0xc5, 0x36, 0x53, 0x3a, 0x36 ], [ 0x37, 0x83, 0xf7, 0xbf, 0x44, 0xc9, 0x7f, 0x06, 0x52, 0x58, 0xa6, 0x66, 0xca, 0xe0, 0x30, 0x20 ], [ 0xaa, 0xd4, 0xc8, 0xa6, 0x3f, 0x80, 0x95, 0x41, 0x04, 0xde, 0x7b, 0x92, 0xce, 0xde, 0x1b, 0xe1 ], [ 0xcb, 0xfe, 0x61, 0x81, 0x0f, 0xd5, 0x46, 0x7c, 0xcd, 0xac, 0xb7, 0x58, 0x00, 0xf3, 0xac, 0x07 ], [ 0x83, 0x0d, 0x8a, 0x25, 0x90, 0xf7, 0xd8, 0xe1, 0xb5, 0x5a, 0x73, 0x7f, 0x4a, 0xf4, 0x5f, 0x34 ], [ 0xff, 0xfc, 0xd4, 0x68, 0x3f, 0x85, 0x80, 0x58, 0xe7, 0x43, 0x14, 0x67, 0x1d, 0x43, 0xfa, 0x2c ], [ 0x52, 0x3d, 0x0b, 0xab, 0xbb, 0x82, 0xf4, 0x6e, 0xbc, 0x9e, 0x70, 0xb1, 0xcd, 0x41, 0xdd, 0xd0 ], [ 0x34, 0x4a, 0xab, 0x37, 0x08, 0x0d, 0x74, 0x86, 0xf7, 0xd5, 0x42, 0xa3, 0x09, 0xe5, 0x3e, 0xed ], [ 0x56, 0xc5, 0x60, 0x9d, 0x09, 0x06, 0xb2, 0x3a, 0xb9, 0xca, 0xca, 0x81, 0x6f, 0x5d, 0xbe, 0xbd ], [ 0x70, 0x26, 0x02, 0x6e, 0xed, 0xd9, 0x1a, 0xdc, 0x6d, 0x83, 0x1c, 0xdf, 0x98, 0x94, 0xbd, 0xc6 ], [ 0x88, 0x33, 0x0b, 0xaa, 0x4f, 0x2b, 0x61, 0x8f, 0xc9, 0xd9, 0xb0, 0x21, 0xbf, 0x50, 0x3d, 0x5a ], [ 0xfc, 0x9e, 0x0e, 0xa2, 0x24, 0x80, 0xb0, 0xba, 0xc9, 0x35, 0xc8, 0xa8, 0xeb, 0xef, 0xcd, 0xcf ], [ 0x29, 0xca, 0x77, 0x9f, 0x39, 0x8f, 0xb0, 0x4f, 0x86, 0x7d, 0xa7, 0xe8, 0xa4, 0x47, 0x56, 0xcb ], [ 0x51, 0xf8, 0x9c, 0x42, 0x98, 0x57, 0x86, 0xbf, 0xc4, 0x3c, 0x6d, 0xf8, 0xad, 0xa3, 0x68, 0x32 ], [ 0x6a, 0xc1, 0xde, 0x5f, 0xb8, 0xf2, 0x1d, 0x87, 0x4e, 0x91, 0xc5, 0x3b, 0x56, 0x0c, 0x50, 0xe3 ], [ 0x03, 0xaa, 0x90, 0x58, 0x49, 0x0e, 0xda, 0x30, 0x60, 0x01, 0xa8, 0xa9, 0xf4, 0x8d, 0x0c, 0xa7 ], [ 0xe3, 0x4e, 0xc7, 0x1d, 0x61, 0x28, 0xd4, 0x87, 0x18, 0x65, 0xd6, 0x17, 0xc3, 0x0b, 0x37, 0xe3 ], [ 0x14, 0xbe, 0x1c, 0x53, 0x5b, 0x17, 0xca, 0xbd, 0x0c, 0x4d, 0x93, 0x52, 0x9d, 0x69, 0xbf, 0x47 ], [ 0xc9, 0xef, 0x67, 0x75, 0x65, 0x07, 0xbe, 0xec, 0x9d, 0xd3, 0x86, 0x28, 0x83, 0x47, 0x80, 0x44 ], [ 0x40, 0xe2, 0x31, 0xfa, 0x5a, 0x59, 0x48, 0xce, 0x21, 0x34, 0xe9, 0x2f, 0xc0, 0x66, 0x4d, 0x4b ], [ 0x03, 0x19, 0x4b, 0x8e, 0x5d, 0xda, 0x55, 0x30, 0xd0, 0xc6, 0x78, 0xc0, 0xb4, 0x8f, 0x5d, 0x92 ], [ 0x90, 0xbd, 0x08, 0x6f, 0x23, 0x7c, 0xc4, 0xfd, 0x99, 0xf4, 0xd7, 0x6b, 0xde, 0x6b, 0x48, 0x26 ], [ 0x19, 0x25, 0x97, 0x61, 0xca, 0x17, 0x13, 0x0d, 0x6e, 0xd8, 0x6d, 0x57, 0xcd, 0x79, 0x51, 0xee ], [ 0xd7, 0xcb, 0xb3, 0xf3, 0x4b, 0x9b, 0x45, 0x0f, 0x24, 0xb0, 0xe8, 0x51, 0x8e, 0x54, 0xda, 0x6d ], [ 0x72, 0x5b, 0x9c, 0xae, 0xbe, 0x9f, 0x7f, 0x41, 0x7f, 0x40, 0x68, 0xd0, 0xd2, 0xee, 0x20, 0xb3 ], [ 0x9d, 0x92, 0x4b, 0x93, 0x4a, 0x90, 0xce, 0x1f, 0xd3, 0x9b, 0x8a, 0x97, 0x94, 0xf8, 0x26, 0x72 ], [ 0xc5, 0x05, 0x62, 0xbf, 0x09, 0x45, 0x26, 0xa9, 0x1c, 0x5b, 0xc6, 0x3c, 0x0c, 0x22, 0x49, 0x95 ], [ 0xd2, 0xf1, 0x18, 0x05, 0x04, 0x67, 0x43, 0xbd, 0x74, 0xf5, 0x71, 0x88, 0xd9, 0x18, 0x8d, 0xf7 ], [ 0x8d, 0xd2, 0x74, 0xbd, 0x0f, 0x1b, 0x58, 0xae, 0x34, 0x5d, 0x9e, 0x72, 0x33, 0xf9, 0xb8, 0xf3 ], [ 0x9d, 0x6b, 0xdc, 0x8f, 0x4c, 0xe5, 0xfe, 0xb0, 0xf3, 0xbe, 0xd2, 0xe4, 0xb9, 0xa9, 0xbb, 0x0b ], [ 0xfd, 0x55, 0x48, 0xbc, 0xf3, 0xf4, 0x25, 0x65, 0xf7, 0xef, 0xa9, 0x45, 0x62, 0x52, 0x8d, 0x46 ], [ 0xd2, 0xcc, 0xae, 0xbd, 0x3a, 0x4c, 0x3e, 0x80, 0xb0, 0x63, 0x74, 0x81, 0x31, 0xba, 0x4a, 0x71 ], [ 0xe0, 0x3c, 0xb2, 0x3d, 0x9e, 0x11, 0xc9, 0xd9, 0x3f, 0x11, 0x7e, 0x9c, 0x0a, 0x91, 0xb5, 0x76 ], [ 0x78, 0xf9, 0x33, 0xa2, 0x08, 0x1a, 0xc1, 0xdb, 0x84, 0xf6, 0x9d, 0x10, 0xf4, 0x52, 0x3f, 0xe0 ], [ 0x40, 0x61, 0xf7, 0x41, 0x2e, 0xd3, 0x20, 0xde, 0x0e, 0xdc, 0x88, 0x51, 0xc2, 0xe2, 0x43, 0x6f ], [ 0x90, 0x64, 0xba, 0x1c, 0xd0, 0x4c, 0xe6, 0xba, 0xb9, 0x84, 0x74, 0x33, 0x08, 0x14, 0xb4, 0xd4 ], [ 0x48, 0x39, 0x1b, 0xff, 0xb9, 0xcf, 0xff, 0x80, 0xac, 0x23, 0x8c, 0x88, 0x6e, 0xf0, 0xa4, 0x61 ], [ 0xb8, 0xd2, 0xa6, 0x7d, 0xf5, 0xa9, 0x99, 0xfd, 0xbf, 0x93, 0xed, 0xd0, 0x34, 0x32, 0x96, 0xc9 ], [ 0xaa, 0xca, 0x73, 0x67, 0x39, 0x6b, 0x69, 0xa2, 0x21, 0xbd, 0x63, 0x2b, 0xea, 0x38, 0x6e, 0xec ], [ 0xa8, 0x0f, 0xd5, 0x02, 0x0d, 0xfe, 0x65, 0xf5, 0xf1, 0x62, 0x93, 0xec, 0x92, 0xc6, 0xfd, 0x89 ], [ 0x21, 0x62, 0x99, 0x5b, 0x82, 0x17, 0xa6, 0x7f, 0x1a, 0xbc, 0x34, 0x2e, 0x14, 0x64, 0x06, 0xf8 ], [ 0xc6, 0xa6, 0x16, 0x4b, 0x7a, 0x60, 0xba, 0xe4, 0xe9, 0x86, 0xff, 0xac, 0x28, 0xdf, 0xad, 0xd9 ], [ 0x64, 0xe0, 0xd7, 0xf9, 0x00, 0xe3, 0xd9, 0xc8, 0x3e, 0x4b, 0x8f, 0x96, 0x71, 0x7b, 0x21, 0x46 ], [ 0x1a, 0xd2, 0x56, 0x1d, 0xe8, 0xc1, 0x23, 0x2f, 0x5d, 0x8d, 0xba, 0xb4, 0x73, 0x9b, 0x6c, 0xbb ], [ 0x27, 0x96, 0x89, 0xe9, 0xa5, 0x57, 0xf5, 0x8b, 0x1c, 0x3b, 0xf4, 0x0c, 0x97, 0xa9, 0x09, 0x64 ], [ 0xc4, 0x63, 0x7e, 0x4a, 0x5e, 0x63, 0x77, 0xf9, 0xcc, 0x5a, 0x86, 0x38, 0x04, 0x5d, 0xe0, 0x29 ], [ 0x49, 0x2e, 0x60, 0x7e, 0x5a, 0xea, 0x46, 0x88, 0x59, 0x4b, 0x45, 0xf3, 0xae, 0xe3, 0xdf, 0x90 ], [ 0xe8, 0xc4, 0xe4, 0x38, 0x1f, 0xee, 0xc7, 0x40, 0x54, 0x95, 0x4c, 0x05, 0xb7, 0x77, 0xa0, 0x0a ], [ 0x91, 0x54, 0x95, 0x14, 0x60, 0x5f, 0x38, 0x24, 0x6c, 0x9b, 0x72, 0x4a, 0xd8, 0x39, 0xf0, 0x1d ], [ 0x74, 0xb2, 0x4e, 0x3b, 0x6f, 0xef, 0xe4, 0x0a, 0x4f, 0x9e, 0xf7, 0xac, 0x6e, 0x44, 0xd7, 0x6a ], [ 0x24, 0x37, 0xa6, 0x83, 0xdc, 0x5d, 0x4b, 0x52, 0xab, 0xb4, 0xa1, 0x23, 0xa8, 0xdf, 0x86, 0xc6 ], [ 0xbb, 0x28, 0x52, 0xc8, 0x91, 0xc5, 0x94, 0x7d, 0x2e, 0xd4, 0x40, 0x32, 0xc4, 0x21, 0xb8, 0x5f ], [ 0x1b, 0x9f, 0x5f, 0xbd, 0x5e, 0x8a, 0x42, 0x64, 0xc0, 0xa8, 0x5b, 0x80, 0x40, 0x9a, 0xfa, 0x5e ], [ 0x30, 0xda, 0xb8, 0x09, 0xf8, 0x5a, 0x91, 0x7f, 0xe9, 0x24, 0x73, 0x3f, 0x42, 0x4a, 0xc5, 0x89 ], [ 0xea, 0xef, 0x5c, 0x1f, 0x8d, 0x60, 0x51, 0x92, 0x64, 0x66, 0x95, 0xce, 0xad, 0xc6, 0x5f, 0x32 ], [ 0xb8, 0xaa, 0x90, 0x04, 0x0b, 0x4c, 0x15, 0xa1, 0x23, 0x16, 0xb7, 0x8e, 0x0f, 0x95, 0x86, 0xfc ], [ 0x97, 0xfa, 0xc8, 0x29, 0x7c, 0xea, 0xab, 0xc8, 0x7d, 0x45, 0x43, 0x50, 0x60, 0x1e, 0x06, 0x73 ], [ 0x9b, 0x47, 0xef, 0x56, 0x7a, 0xc2, 0x8d, 0xfe, 0x48, 0x84, 0x92, 0xf1, 0x57, 0xe2, 0xb2, 0xe0 ], [ 0x1b, 0x84, 0x26, 0x02, 0x7d, 0xdb, 0x96, 0x2b, 0x5c, 0x5b, 0xa7, 0xeb, 0x8b, 0xc9, 0xab, 0x63 ], [ 0xe9, 0x17, 0xfc, 0x77, 0xe7, 0x19, 0x92, 0xa1, 0x2d, 0xbe, 0x4c, 0x18, 0x06, 0x8b, 0xec, 0x82 ], [ 0xdc, 0xee, 0xbb, 0xc9, 0x88, 0x40, 0xf8, 0xae, 0x6d, 0xaf, 0x76, 0x57, 0x3b, 0x7e, 0x56, 0xf4 ], [ 0x4e, 0x11, 0xa9, 0xf7, 0x42, 0x05, 0x12, 0x5b, 0x61, 0xe0, 0xae, 0xe0, 0x47, 0xec, 0xa2, 0x0d ], [ 0xf6, 0x04, 0x67, 0xf5, 0x5a, 0x1f, 0x17, 0xea, 0xb8, 0x8e, 0x80, 0x01, 0x20, 0xcb, 0xc2, 0x84 ], [ 0xd4, 0x36, 0x64, 0x9f, 0x60, 0x0b, 0x44, 0x9e, 0xe2, 0x76, 0x53, 0x0f, 0x0c, 0xd8, 0x3c, 0x11 ], [ 0x3b, 0xc0, 0xe3, 0x65, 0x6a, 0x9e, 0x3a, 0xc7, 0xcd, 0x37, 0x8a, 0x73, 0x7f, 0x53, 0xb6, 0x37 ], [ 0x6b, 0xac, 0xae, 0x63, 0xd3, 0x3b, 0x92, 0x8a, 0xa8, 0x38, 0x0f, 0x8d, 0x54, 0xd8, 0x8c, 0x17 ], [ 0x89, 0x35, 0xff, 0xbc, 0x75, 0xae, 0x62, 0x51, 0xbf, 0x8e, 0x85, 0x9f, 0x08, 0x5a, 0xdc, 0xb9 ], [ 0x93, 0xdc, 0x49, 0x70, 0xfe, 0x35, 0xf6, 0x77, 0x47, 0xcb, 0x05, 0x62, 0xc0, 0x6d, 0x87, 0x5a ], [ 0x14, 0xf9, 0xdf, 0x85, 0x89, 0x75, 0x85, 0x17, 0x97, 0xba, 0x60, 0x4f, 0xb0, 0xd1, 0x6c, 0xc7 ], [ 0x02, 0xea, 0x0c, 0x98, 0xdc, 0xa1, 0x0b, 0x38, 0xc2, 0x1b, 0x3b, 0x14, 0xe8, 0xd1, 0xb7, 0x1f ], [ 0x8f, 0x09, 0x1b, 0x1b, 0x5b, 0x07, 0x49, 0xb2, 0xad, 0xc8, 0x03, 0xe6, 0x3d, 0xda, 0x9b, 0x72 ], [ 0x05, 0xb3, 0x89, 0xe3, 0x32, 0x2c, 0x6d, 0xa0, 0x83, 0x84, 0x34, 0x5a, 0x41, 0x37, 0xfd, 0x08 ], [ 0x38, 0x13, 0x08, 0xc4, 0x38, 0xf3, 0x5b, 0x39, 0x9f, 0x10, 0xad, 0x71, 0xb0, 0x50, 0x27, 0xd8 ], [ 0x68, 0xc2, 0x30, 0xfc, 0xfa, 0x92, 0x79, 0xc3, 0x40, 0x9f, 0xc4, 0x23, 0xe2, 0xac, 0xbe, 0x04 ], [ 0x1c, 0x84, 0xa4, 0x75, 0xac, 0xb0, 0x11, 0xf3, 0xf5, 0x9f, 0x4f, 0x46, 0xb7, 0x62, 0x74, 0xc0 ], [ 0x45, 0x11, 0x9b, 0x68, 0xcb, 0x3f, 0x83, 0x99, 0xee, 0x60, 0x06, 0x6b, 0x56, 0x11, 0xa4, 0xd7 ], [ 0x94, 0x23, 0x76, 0x2f, 0x52, 0x7a, 0x40, 0x60, 0xff, 0xca, 0x31, 0x2d, 0xcc, 0xa2, 0x2a, 0x16 ], [ 0xf3, 0x61, 0xa2, 0x74, 0x5a, 0x33, 0xf0, 0x56, 0xa5, 0xac, 0x6a, 0xce, 0x2f, 0x08, 0xe3, 0x44 ], [ 0x5e, 0xf1, 0x45, 0x76, 0x6e, 0xca, 0x84, 0x9f, 0x5d, 0x01, 0x15, 0x36, 0xa6, 0x55, 0x7f, 0xdb ], [ 0xc9, 0xaf, 0x27, 0xb2, 0xc8, 0x9c, 0x9b, 0x4c, 0xf4, 0xa0, 0xc4, 0x10, 0x6a, 0xc8, 0x03, 0x18 ], [ 0xfb, 0x9c, 0x4f, 0x16, 0xc6, 0x21, 0xf4, 0xea, 0xb7, 0xe9, 0xac, 0x1d, 0x75, 0x51, 0xdd, 0x57 ], [ 0x13, 0x8e, 0x06, 0xfb, 0xa4, 0x66, 0xfa, 0x70, 0x85, 0x4d, 0x8c, 0x2e, 0x52, 0x4c, 0xff, 0xb2 ], [ 0xfb, 0x4b, 0xc7, 0x8b, 0x22, 0x50, 0x70, 0x77, 0x3f, 0x04, 0xc4, 0x04, 0x66, 0xd4, 0xe9, 0x0c ], [ 0x8b, 0x2c, 0xbf, 0xf1, 0xed, 0x01, 0x50, 0xfe, 0xda, 0x8a, 0x47, 0x99, 0xbe, 0x94, 0x55, 0x1f ], [ 0x08, 0xb3, 0x0d, 0x7b, 0x3f, 0x27, 0x96, 0x27, 0x09, 0xa3, 0x6b, 0xca, 0xdf, 0xb9, 0x74, 0xbd ], [ 0xfd, 0xf6, 0xd3, 0x2e, 0x04, 0x4d, 0x77, 0xad, 0xcf, 0x37, 0xfb, 0x97, 0xac, 0x21, 0x33, 0x26 ], [ 0x93, 0xcb, 0x28, 0x4e, 0xcd, 0xcf, 0xd7, 0x81, 0xa8, 0xaf, 0xe3, 0x20, 0x77, 0x94, 0x9e, 0x88 ], [ 0x7b, 0x01, 0x7b, 0xb0, 0x2e, 0xc8, 0x7b, 0x2b, 0x94, 0xc9, 0x6e, 0x40, 0xa2, 0x6f, 0xc7, 0x1a ], [ 0xc5, 0xc0, 0x38, 0xb6, 0x99, 0x06, 0x64, 0xab, 0x08, 0xa3, 0xaa, 0xa5, 0xdf, 0x9f, 0x32, 0x66 ], [ 0x4b, 0x70, 0x20, 0xbe, 0x37, 0xfa, 0xb6, 0x25, 0x9b, 0x2a, 0x27, 0xf4, 0xec, 0x55, 0x15, 0x76 ], [ 0x60, 0x13, 0x67, 0x03, 0x37, 0x4f, 0x64, 0xe8, 0x60, 0xb4, 0x8c, 0xe3, 0x1f, 0x93, 0x07, 0x16 ], [ 0x8d, 0x63, 0xa2, 0x69, 0xb1, 0x4d, 0x50, 0x6c, 0xcc, 0x40, 0x1a, 0xb8, 0xa9, 0xf1, 0xb5, 0x91 ], [ 0xd3, 0x17, 0xf8, 0x1d, 0xc6, 0xaa, 0x45, 0x4a, 0xee, 0x4b, 0xd4, 0xa5, 0xa5, 0xcf, 0xf4, 0xbd ], [ 0xdd, 0xde, 0xce, 0xcd, 0x53, 0x54, 0xf0, 0x4d, 0x53, 0x0d, 0x76, 0xed, 0x88, 0x42, 0x46, 0xeb ], [ 0x41, 0xc5, 0x20, 0x5c, 0xc8, 0xfd, 0x8e, 0xda, 0x9a, 0x3c, 0xff, 0xd2, 0x51, 0x8f, 0x36, 0x5a ], [ 0xcf, 0x42, 0xfb, 0x47, 0x42, 0x93, 0xd9, 0x6e, 0xca, 0x9d, 0xb1, 0xb3, 0x7b, 0x1b, 0xa6, 0x76 ], [ 0xa2, 0x31, 0x69, 0x26, 0x07, 0x16, 0x9b, 0x4e, 0xcd, 0xea, 0xd5, 0xcd, 0x3b, 0x10, 0xdb, 0x3e ], [ 0xac, 0xe4, 0xb9, 0x1c, 0x9c, 0x66, 0x9e, 0x77, 0xe7, 0xac, 0xac, 0xd1, 0x98, 0x59, 0xed, 0x49 ], [ 0x75, 0xdb, 0x7c, 0xfd, 0x4a, 0x7b, 0x2b, 0x62, 0xab, 0x78, 0xa4, 0x8f, 0x3d, 0xda, 0xf4, 0xaf ], [ 0xc1, 0xfa, 0xba, 0x2d, 0x46, 0xe2, 0x59, 0xcf, 0x48, 0x0d, 0x7c, 0x38, 0xe4, 0x57, 0x2a, 0x58 ], [ 0x24, 0x1c, 0x45, 0xbc, 0x6a, 0xe1, 0x6d, 0xee, 0x6e, 0xb7, 0xbe, 0xa1, 0x28, 0x70, 0x15, 0x82 ], [ 0x8f, 0xd0, 0x30, 0x57, 0xcf, 0x13, 0x64, 0x42, 0x0c, 0x2b, 0x78, 0x06, 0x9a, 0x3e, 0x25, 0x02 ], [ 0xdd, 0xb5, 0x05, 0xe6, 0xcc, 0x13, 0x84, 0xcb, 0xae, 0xc1, 0xdf, 0x90, 0xb8, 0x0b, 0xeb, 0x20 ], [ 0x56, 0x74, 0xa3, 0xbe, 0xd2, 0x7b, 0xf4, 0xbd, 0x36, 0x22, 0xf9, 0xf5, 0xfe, 0x20, 0x83, 0x06 ], [ 0xb6, 0x87, 0xf2, 0x6a, 0x89, 0xcf, 0xbf, 0xbb, 0x8e, 0x5e, 0xea, 0xc5, 0x40, 0x55, 0x31, 0x5e ], [ 0x05, 0x47, 0xdd, 0x32, 0xd3, 0xb2, 0x9a, 0xb6, 0xa4, 0xca, 0xeb, 0x60, 0x6c, 0x5b, 0x6f, 0x78 ], [ 0x18, 0x68, 0x61, 0xf8, 0xbc, 0x53, 0x86, 0xd3, 0x1f, 0xb7, 0x7f, 0x72, 0x0c, 0x32, 0x26, 0xe6 ], [ 0xea, 0xcf, 0x1e, 0x6c, 0x42, 0x24, 0xef, 0xb3, 0x89, 0x00, 0xb1, 0x85, 0xab, 0x1d, 0xfd, 0x42 ], [ 0xd2, 0x41, 0xaa, 0xb0, 0x5a, 0x42, 0xd3, 0x19, 0xde, 0x81, 0xd8, 0x74, 0xf5, 0xc7, 0xb9, 0x0d ], [ 0x5e, 0xb9, 0xbc, 0x75, 0x9e, 0x2a, 0xd8, 0xd2, 0x14, 0x0a, 0x6c, 0x76, 0x2a, 0xe9, 0xe1, 0xab ], [ 0x01, 0x85, 0x96, 0xe1, 0x5e, 0x78, 0xe2, 0xc0, 0x64, 0x15, 0x9d, 0xef, 0xce, 0x5f, 0x30, 0x85 ], [ 0xdd, 0x8a, 0x49, 0x35, 0x14, 0x23, 0x1c, 0xbf, 0x56, 0xec, 0xce, 0xe4, 0xc4, 0x08, 0x89, 0xfb ] ]; # Values from NIST KAT-AES CBCVarTxt256.rsp cipher_texts1_256bit = [ [ 0xdd, 0xc6, 0xbf, 0x79, 0x0c, 0x15, 0x76, 0x0d, 0x8d, 0x9a, 0xeb, 0x6f, 0x9a, 0x75, 0xfd, 0x4e ], [ 0x0a, 0x6b, 0xdc, 0x6d, 0x4c, 0x1e, 0x62, 0x80, 0x30, 0x1f, 0xd8, 0xe9, 0x7d, 0xdb, 0xe6, 0x01 ], [ 0x9b, 0x80, 0xee, 0xfb, 0x7e, 0xbe, 0x2d, 0x2b, 0x16, 0x24, 0x7a, 0xa0, 0xef, 0xc7, 0x2f, 0x5d ], [ 0x7f, 0x2c, 0x5e, 0xce, 0x07, 0xa9, 0x8d, 0x8b, 0xee, 0x13, 0xc5, 0x11, 0x77, 0x39, 0x5f, 0xf7 ], [ 0x78, 0x18, 0xd8, 0x00, 0xdc, 0xf6, 0xf4, 0xbe, 0x1e, 0x0e, 0x94, 0xf4, 0x03, 0xd1, 0xe4, 0xc2 ], [ 0xe7, 0x4c, 0xd1, 0xc9, 0x2f, 0x09, 0x19, 0xc3, 0x5a, 0x03, 0x24, 0x12, 0x3d, 0x61, 0x77, 0xd3 ], [ 0x80, 0x92, 0xa4, 0xdc, 0xf2, 0xda, 0x7e, 0x77, 0xe9, 0x3b, 0xdd, 0x37, 0x1d, 0xfe, 0xd8, 0x2e ], [ 0x49, 0xaf, 0x6b, 0x37, 0x21, 0x35, 0xac, 0xef, 0x10, 0x13, 0x2e, 0x54, 0x8f, 0x21, 0x7b, 0x17 ], [ 0x8b, 0xcd, 0x40, 0xf9, 0x4e, 0xbb, 0x63, 0xb9, 0xf7, 0x90, 0x96, 0x76, 0xe6, 0x67, 0xf1, 0xe7 ], [ 0xfe, 0x1c, 0xff, 0xb8, 0x3f, 0x45, 0xdc, 0xfb, 0x38, 0xb2, 0x9b, 0xe4, 0x38, 0xdb, 0xd3, 0xab ], [ 0x0d, 0xc5, 0x8a, 0x8d, 0x88, 0x66, 0x23, 0x70, 0x5a, 0xec, 0x15, 0xcb, 0x1e, 0x70, 0xdc, 0x0e ], [ 0xc2, 0x18, 0xfa, 0xa1, 0x60, 0x56, 0xbd, 0x07, 0x74, 0xc3, 0xe8, 0xd7, 0x9c, 0x35, 0xa5, 0xe4 ], [ 0x04, 0x7b, 0xba, 0x83, 0xf7, 0xaa, 0x84, 0x17, 0x31, 0x50, 0x4e, 0x01, 0x22, 0x08, 0xfc, 0x9e ], [ 0xdc, 0x8f, 0x0e, 0x49, 0x15, 0xfd, 0x81, 0xba, 0x70, 0xa3, 0x31, 0x31, 0x08, 0x82, 0xf6, 0xda ], [ 0x15, 0x69, 0x85, 0x9e, 0xa6, 0xb7, 0x20, 0x6c, 0x30, 0xbf, 0x4f, 0xd0, 0xcb, 0xfa, 0xc3, 0x3c ], [ 0x30, 0x0a, 0xde, 0x92, 0xf8, 0x8f, 0x48, 0xfa, 0x2d, 0xf7, 0x30, 0xec, 0x16, 0xef, 0x44, 0xcd ], [ 0x1f, 0xe6, 0xcc, 0x3c, 0x05, 0x96, 0x5d, 0xc0, 0x8e, 0xb0, 0x59, 0x0c, 0x95, 0xac, 0x71, 0xd0 ], [ 0x59, 0xe8, 0x58, 0xea, 0xaa, 0x97, 0xfe, 0xc3, 0x81, 0x11, 0x27, 0x5b, 0x6c, 0xf5, 0xab, 0xc0 ], [ 0x22, 0x39, 0x45, 0x5e, 0x7a, 0xfe, 0x3b, 0x06, 0x16, 0x10, 0x02, 0x88, 0xcc, 0x5a, 0x72, 0x3b ], [ 0x3e, 0xe5, 0x00, 0xc5, 0xc8, 0xd6, 0x34, 0x79, 0x71, 0x71, 0x63, 0xe5, 0x5c, 0x5c, 0x45, 0x22 ], [ 0xd5, 0xe3, 0x8b, 0xf1, 0x5f, 0x16, 0xd9, 0x0e, 0x3e, 0x21, 0x40, 0x41, 0xd7, 0x74, 0xda, 0xa8 ], [ 0xb1, 0xf4, 0x06, 0x6e, 0x6f, 0x4f, 0x18, 0x7d, 0xfe, 0x5f, 0x2a, 0xd1, 0xb1, 0x78, 0x19, 0xd0 ], [ 0x6e, 0xf4, 0xcc, 0x4d, 0xe4, 0x9b, 0x11, 0x06, 0x5d, 0x7a, 0xf2, 0x90, 0x98, 0x54, 0x79, 0x4a ], [ 0xac, 0x86, 0xbc, 0x60, 0x6b, 0x66, 0x40, 0xc3, 0x09, 0xe7, 0x82, 0xf2, 0x32, 0xbf, 0x36, 0x7f ], [ 0x36, 0xaf, 0xf0, 0xef, 0x7b, 0xf3, 0x28, 0x07, 0x72, 0xcf, 0x4c, 0xac, 0x80, 0xa0, 0xd2, 0xb2 ], [ 0x1f, 0x8e, 0xed, 0xea, 0x0f, 0x62, 0xa1, 0x40, 0x6d, 0x58, 0xcf, 0xc3, 0xec, 0xea, 0x72, 0xcf ], [ 0xab, 0xf4, 0x15, 0x4a, 0x33, 0x75, 0xa1, 0xd3, 0xe6, 0xb1, 0xd4, 0x54, 0x43, 0x8f, 0x95, 0xa6 ], [ 0x96, 0xf9, 0x6e, 0x9d, 0x60, 0x7f, 0x66, 0x15, 0xfc, 0x19, 0x20, 0x61, 0xee, 0x64, 0x8b, 0x07 ], [ 0xcf, 0x37, 0xcd, 0xaa, 0xa0, 0xd2, 0xd5, 0x36, 0xc7, 0x18, 0x57, 0x63, 0x4c, 0x79, 0x20, 0x64 ], [ 0xfb, 0xd6, 0x64, 0x0c, 0x80, 0x24, 0x5c, 0x2b, 0x80, 0x53, 0x73, 0xf1, 0x30, 0x70, 0x31, 0x27 ], [ 0x8d, 0x6a, 0x8a, 0xfe, 0x55, 0xa6, 0xe4, 0x81, 0xba, 0xda, 0xe0, 0xd1, 0x46, 0xf4, 0x36, 0xdb ], [ 0x6a, 0x49, 0x81, 0xf2, 0x91, 0x5e, 0x3e, 0x68, 0xaf, 0x6c, 0x22, 0x38, 0x5d, 0xd0, 0x67, 0x56 ], [ 0x42, 0xa1, 0x13, 0x6e, 0x5f, 0x8d, 0x8d, 0x21, 0xd3, 0x10, 0x19, 0x98, 0x64, 0x2d, 0x57, 0x3b ], [ 0x9b, 0x47, 0x15, 0x96, 0xdc, 0x69, 0xae, 0x15, 0x86, 0xce, 0xe6, 0x15, 0x8b, 0x0b, 0x01, 0x81 ], [ 0x75, 0x36, 0x65, 0xc4, 0xaf, 0x1e, 0xff, 0x33, 0xaa, 0x8b, 0x62, 0x8b, 0xf8, 0x74, 0x1c, 0xfd ], [ 0x9a, 0x68, 0x2a, 0xcf, 0x40, 0xbe, 0x01, 0xf5, 0xb2, 0xa4, 0x19, 0x3c, 0x9a, 0x82, 0x40, 0x4d ], [ 0x54, 0xfa, 0xfe, 0x26, 0xe4, 0x28, 0x7f, 0x17, 0xd1, 0x93, 0x5f, 0x87, 0xeb, 0x9a, 0xde, 0x01 ], [ 0x49, 0xd5, 0x41, 0xb2, 0xe7, 0x4c, 0xfe, 0x73, 0xe6, 0xa8, 0xe8, 0x22, 0x5f, 0x7b, 0xd4, 0x49 ], [ 0x11, 0xa4, 0x55, 0x30, 0xf6, 0x24, 0xff, 0x6f, 0x76, 0xa1, 0xb3, 0x82, 0x66, 0x26, 0xff, 0x7b ], [ 0xf9, 0x6b, 0x0c, 0x4a, 0x8b, 0xc6, 0xc8, 0x61, 0x30, 0x28, 0x9f, 0x60, 0xb4, 0x3b, 0x8f, 0xba ], [ 0x48, 0xc7, 0xd0, 0xe8, 0x08, 0x34, 0xeb, 0xdc, 0x35, 0xb6, 0x73, 0x5f, 0x76, 0xb4, 0x6c, 0x8b ], [ 0x24, 0x63, 0x53, 0x1a, 0xb5, 0x4d, 0x66, 0x95, 0x5e, 0x73, 0xed, 0xc4, 0xcb, 0x8e, 0xaa, 0x45 ], [ 0xac, 0x9b, 0xd8, 0xe2, 0x53, 0x04, 0x69, 0x13, 0x4b, 0x9d, 0x5b, 0x06, 0x5d, 0x4f, 0x56, 0x5b ], [ 0x3f, 0x5f, 0x91, 0x06, 0xd0, 0xe5, 0x2f, 0x97, 0x3d, 0x48, 0x90, 0xe6, 0xf3, 0x7e, 0x8a, 0x00 ], [ 0x20, 0xeb, 0xc8, 0x6f, 0x13, 0x04, 0xd2, 0x72, 0xe2, 0xe2, 0x07, 0xe5, 0x9d, 0xb6, 0x39, 0xf0 ], [ 0xe6, 0x7a, 0xe6, 0x42, 0x6b, 0xf9, 0x52, 0x6c, 0x97, 0x2c, 0xff, 0x07, 0x2b, 0x52, 0x25, 0x2c ], [ 0x1a, 0x51, 0x8d, 0xdd, 0xaf, 0x9e, 0xfa, 0x0d, 0x00, 0x2c, 0xc5, 0x8d, 0x10, 0x7e, 0xdf, 0xc8 ], [ 0xea, 0xd7, 0x31, 0xaf, 0x4d, 0x3a, 0x2f, 0xe3, 0xb3, 0x4b, 0xed, 0x04, 0x79, 0x42, 0xa4, 0x9f ], [ 0xb1, 0xd4, 0xef, 0xe4, 0x02, 0x42, 0xf8, 0x3e, 0x93, 0xb6, 0xc8, 0xd7, 0xef, 0xb5, 0xea, 0xe9 ], [ 0xcd, 0x2b, 0x1f, 0xec, 0x11, 0xfd, 0x90, 0x6c, 0x5c, 0x76, 0x30, 0x09, 0x94, 0x43, 0x61, 0x0a ], [ 0xa1, 0x85, 0x3f, 0xe4, 0x7f, 0xe2, 0x92, 0x89, 0xd1, 0x53, 0x16, 0x1d, 0x06, 0x38, 0x7d, 0x21 ], [ 0x46, 0x32, 0x15, 0x41, 0x79, 0xa5, 0x55, 0xc1, 0x7e, 0xa6, 0x04, 0xd0, 0x88, 0x9f, 0xab, 0x14 ], [ 0xdd, 0x27, 0xca, 0xc6, 0x40, 0x1a, 0x02, 0x2e, 0x8f, 0x38, 0xf9, 0xf9, 0x3e, 0x77, 0x44, 0x17 ], [ 0xc0, 0x90, 0x31, 0x3e, 0xb9, 0x86, 0x74, 0xf3, 0x5f, 0x31, 0x23, 0x38, 0x5f, 0xb9, 0x5d, 0x4d ], [ 0xcc, 0x35, 0x26, 0x26, 0x2b, 0x92, 0xf0, 0x2e, 0xdc, 0xe5, 0x48, 0xf7, 0x16, 0xb9, 0xf4, 0x5c ], [ 0xc0, 0x83, 0x8d, 0x1a, 0x2b, 0x16, 0xa7, 0xc7, 0xf0, 0xdf, 0xcc, 0x43, 0x3c, 0x39, 0x9c, 0x33 ], [ 0x0d, 0x9a, 0xc7, 0x56, 0xeb, 0x29, 0x76, 0x95, 0xee, 0xd4, 0xd3, 0x82, 0xeb, 0x12, 0x6d, 0x26 ], [ 0x56, 0xed, 0xe9, 0xdd, 0xa3, 0xf6, 0xf1, 0x41, 0xbf, 0xf1, 0x75, 0x7f, 0xa6, 0x89, 0xc3, 0xe1 ], [ 0x76, 0x8f, 0x52, 0x0e, 0xfe, 0x0f, 0x23, 0xe6, 0x1d, 0x3e, 0xc8, 0xad, 0x9c, 0xe9, 0x17, 0x74 ], [ 0xb1, 0x14, 0x4d, 0xdf, 0xa7, 0x57, 0x55, 0x21, 0x33, 0x90, 0xe7, 0xc5, 0x96, 0x66, 0x04, 0x90 ], [ 0x1d, 0x7c, 0x0c, 0x40, 0x40, 0xb3, 0x55, 0xb9, 0xd1, 0x07, 0xa9, 0x93, 0x25, 0xe3, 0xb0, 0x50 ], [ 0xd8, 0xe2, 0xbb, 0x1a, 0xe8, 0xee, 0x3d, 0xcf, 0x5b, 0xf7, 0xd6, 0xc3, 0x8d, 0xa8, 0x2a, 0x1a ], [ 0xfa, 0xf8, 0x2d, 0x17, 0x8a, 0xf2, 0x5a, 0x98, 0x86, 0xa4, 0x7e, 0x7f, 0x78, 0x9b, 0x98, 0xd7 ], [ 0x9b, 0x58, 0xdb, 0xfd, 0x77, 0xfe, 0x5a, 0xca, 0x9c, 0xfc, 0x19, 0x0c, 0xd1, 0xb8, 0x2d, 0x19 ], [ 0x77, 0xf3, 0x92, 0x08, 0x90, 0x42, 0xe4, 0x78, 0xac, 0x16, 0xc0, 0xc8, 0x6a, 0x0b, 0x5d, 0xb5 ], [ 0x19, 0xf0, 0x8e, 0x34, 0x20, 0xee, 0x69, 0xb4, 0x77, 0xca, 0x14, 0x20, 0x28, 0x1c, 0x47, 0x82 ], [ 0xa1, 0xb1, 0x9b, 0xee, 0xe4, 0xe1, 0x17, 0x13, 0x9f, 0x74, 0xb3, 0xc5, 0x3f, 0xdc, 0xb8, 0x75 ], [ 0xa3, 0x7a, 0x58, 0x69, 0xb2, 0x18, 0xa9, 0xf3, 0xa0, 0x86, 0x8d, 0x19, 0xae, 0xa0, 0xad, 0x6a ], [ 0xbc, 0x35, 0x94, 0xe8, 0x65, 0xbc, 0xd0, 0x26, 0x1b, 0x13, 0x20, 0x27, 0x31, 0xf3, 0x35, 0x80 ], [ 0x81, 0x14, 0x41, 0xce, 0x1d, 0x30, 0x9e, 0xee, 0x71, 0x85, 0xe8, 0xc7, 0x52, 0xc0, 0x75, 0x57 ], [ 0x95, 0x99, 0x71, 0xce, 0x41, 0x34, 0x19, 0x05, 0x63, 0x51, 0x8e, 0x70, 0x0b, 0x98, 0x74, 0xd1 ], [ 0x76, 0xb5, 0x61, 0x4a, 0x04, 0x27, 0x07, 0xc9, 0x8e, 0x21, 0x32, 0xe2, 0xe8, 0x05, 0xfe, 0x63 ], [ 0x7d, 0x9f, 0xa6, 0xa5, 0x75, 0x30, 0xd0, 0xf0, 0x36, 0xfe, 0xc3, 0x1c, 0x23, 0x0b, 0x0c, 0xc6 ], [ 0x96, 0x41, 0x53, 0xa8, 0x3b, 0xf6, 0x98, 0x9a, 0x4b, 0xa8, 0x0d, 0xaa, 0x91, 0xc3, 0xe0, 0x81 ], [ 0xa0, 0x13, 0x01, 0x4d, 0x4c, 0xe8, 0x05, 0x4c, 0xf2, 0x59, 0x1d, 0x06, 0xf6, 0xf2, 0xf1, 0x76 ], [ 0xd1, 0xc5, 0xf6, 0x39, 0x9b, 0xf3, 0x82, 0x50, 0x2e, 0x38, 0x5e, 0xee, 0x14, 0x74, 0xa8, 0x69 ], [ 0x00, 0x07, 0xe2, 0x0b, 0x82, 0x98, 0xec, 0x35, 0x4f, 0x0f, 0x5f, 0xe7, 0x47, 0x0f, 0x36, 0xbd ], [ 0xb9, 0x5b, 0xa0, 0x5b, 0x33, 0x2d, 0xa6, 0x1e, 0xf6, 0x3a, 0x2b, 0x31, 0xfc, 0xad, 0x98, 0x79 ], [ 0x46, 0x20, 0xa4, 0x9b, 0xd9, 0x67, 0x49, 0x15, 0x61, 0x66, 0x9a, 0xb2, 0x5d, 0xce, 0x45, 0xf4 ], [ 0x12, 0xe7, 0x12, 0x14, 0xae, 0x8e, 0x04, 0xf0, 0xbb, 0x63, 0xd7, 0x42, 0x5c, 0x6f, 0x14, 0xd5 ], [ 0x4c, 0xc4, 0x2f, 0xc1, 0x40, 0x7b, 0x00, 0x8f, 0xe3, 0x50, 0x90, 0x7c, 0x09, 0x2e, 0x80, 0xac ], [ 0x08, 0xb2, 0x44, 0xce, 0x7c, 0xbc, 0x8e, 0xe9, 0x7f, 0xbb, 0xa8, 0x08, 0xcb, 0x14, 0x6f, 0xda ], [ 0x39, 0xb3, 0x33, 0xe8, 0x69, 0x4f, 0x21, 0x54, 0x6a, 0xd1, 0xed, 0xd9, 0xd8, 0x7e, 0xd9, 0x5b ], [ 0x3b, 0x27, 0x1f, 0x8a, 0xb2, 0xe6, 0xe4, 0xa2, 0x0b, 0xa8, 0x09, 0x0f, 0x43, 0xba, 0x78, 0xf3 ], [ 0x9a, 0xd9, 0x83, 0xf3, 0xbf, 0x65, 0x1c, 0xd0, 0x39, 0x3f, 0x0a, 0x73, 0xcc, 0xcd, 0xea, 0x50 ], [ 0x8f, 0x47, 0x6c, 0xbf, 0xf7, 0x5c, 0x1f, 0x72, 0x5c, 0xe1, 0x8e, 0x4b, 0xbc, 0xd1, 0x9b, 0x32 ], [ 0x90, 0x5b, 0x62, 0x67, 0xf1, 0xd6, 0xab, 0x53, 0x20, 0x83, 0x5a, 0x13, 0x3f, 0x09, 0x6f, 0x2a ], [ 0x14, 0x5b, 0x60, 0xd6, 0xd0, 0x19, 0x3c, 0x23, 0xf4, 0x22, 0x18, 0x48, 0xa8, 0x92, 0xd6, 0x1a ], [ 0x55, 0xcf, 0xb3, 0xfb, 0x6d, 0x75, 0xca, 0xd0, 0x44, 0x5b, 0xbc, 0x8d, 0xaf, 0xa2, 0x5b, 0x0f ], [ 0x7b, 0x8e, 0x70, 0x98, 0xe3, 0x57, 0xef, 0x71, 0x23, 0x7d, 0x46, 0xd8, 0xb0, 0x75, 0xb0, 0xf5 ], [ 0x2b, 0xf2, 0x72, 0x29, 0x90, 0x1e, 0xb4, 0x0f, 0x2d, 0xf9, 0xd8, 0x39, 0x8d, 0x15, 0x05, 0xae ], [ 0x83, 0xa6, 0x34, 0x02, 0xa7, 0x7f, 0x9a, 0xd5, 0xc1, 0xe9, 0x31, 0xa9, 0x31, 0xec, 0xd7, 0x06 ], [ 0x6f, 0x8b, 0xa6, 0x52, 0x11, 0x52, 0xd3, 0x1f, 0x2b, 0xad, 0xa1, 0x84, 0x3e, 0x26, 0xb9, 0x73 ], [ 0xe5, 0xc3, 0xb8, 0xe3, 0x0f, 0xd2, 0xd8, 0xe6, 0x23, 0x9b, 0x17, 0xb4, 0x4b, 0xd2, 0x3b, 0xbd ], [ 0x1a, 0xc1, 0xf7, 0x10, 0x2c, 0x59, 0x93, 0x3e, 0x8b, 0x2d, 0xdc, 0x3f, 0x14, 0xe9, 0x4b, 0xaa ], [ 0x21, 0xd9, 0xba, 0x49, 0xf2, 0x76, 0xb4, 0x5f, 0x11, 0xaf, 0x8f, 0xc7, 0x1a, 0x08, 0x8e, 0x3d ], [ 0x64, 0x9f, 0x1c, 0xdd, 0xc3, 0x79, 0x2b, 0x46, 0x38, 0x63, 0x5a, 0x39, 0x2b, 0xc9, 0xba, 0xde ], [ 0xe2, 0x77, 0x5e, 0x4b, 0x59, 0xc1, 0xbc, 0x2e, 0x31, 0xa2, 0x07, 0x8c, 0x11, 0xb5, 0xa0, 0x8c ], [ 0x2b, 0xe1, 0xfa, 0xe5, 0x04, 0x8a, 0x25, 0x58, 0x2a, 0x67, 0x9c, 0xa1, 0x09, 0x05, 0xeb, 0x80 ], [ 0xda, 0x86, 0xf2, 0x92, 0xc6, 0xf4, 0x1e, 0xa3, 0x4f, 0xb2, 0x06, 0x8d, 0xf7, 0x5e, 0xcc, 0x29 ], [ 0x22, 0x0d, 0xf1, 0x9f, 0x85, 0xd6, 0x9b, 0x1b, 0x56, 0x2f, 0xa6, 0x9a, 0x3c, 0x5b, 0xec, 0xa5 ], [ 0x1f, 0x11, 0xd5, 0xd0, 0x35, 0x5e, 0x0b, 0x55, 0x6c, 0xcd, 0xb6, 0xc7, 0xf5, 0x08, 0x3b, 0x4d ], [ 0x62, 0x52, 0x6b, 0x78, 0xbe, 0x79, 0xcb, 0x38, 0x46, 0x33, 0xc9, 0x1f, 0x83, 0xb4, 0x15, 0x1b ], [ 0x90, 0xdd, 0xbc, 0xb9, 0x50, 0x84, 0x35, 0x92, 0xdd, 0x47, 0xbb, 0xef, 0x00, 0xfd, 0xc8, 0x76 ], [ 0x2f, 0xd0, 0xe4, 0x1c, 0x5b, 0x84, 0x02, 0x27, 0x73, 0x54, 0xa7, 0x39, 0x1d, 0x26, 0x18, 0xe2 ], [ 0x3c, 0xdf, 0x13, 0xe7, 0x2d, 0xee, 0x4c, 0x58, 0x1b, 0xaf, 0xec, 0x70, 0xb8, 0x5f, 0x96, 0x60 ], [ 0xaf, 0xa2, 0xff, 0xc1, 0x37, 0x57, 0x70, 0x92, 0xe2, 0xb6, 0x54, 0xfa, 0x19, 0x9d, 0x2c, 0x43 ], [ 0x8d, 0x68, 0x3e, 0xe6, 0x3e, 0x60, 0xd2, 0x08, 0xe3, 0x43, 0xce, 0x48, 0xdb, 0xc4, 0x4c, 0xac ], [ 0x70, 0x5a, 0x4e, 0xf8, 0xba, 0x21, 0x33, 0x72, 0x9c, 0x20, 0x18, 0x5c, 0x3d, 0x3a, 0x47, 0x63 ], [ 0x08, 0x61, 0xa8, 0x61, 0xc3, 0xdb, 0x4e, 0x94, 0x19, 0x42, 0x11, 0xb7, 0x7e, 0xd7, 0x61, 0xb9 ], [ 0x4b, 0x00, 0xc2, 0x7e, 0x8b, 0x26, 0xda, 0x7e, 0xab, 0x9d, 0x3a, 0x88, 0xde, 0xc8, 0xb0, 0x31 ], [ 0x5f, 0x39, 0x7b, 0xf0, 0x30, 0x84, 0x82, 0x0c, 0xc8, 0x81, 0x0d, 0x52, 0xe5, 0xb6, 0x66, 0xe9 ], [ 0x63, 0xfa, 0xfa, 0xbb, 0x72, 0xc0, 0x7b, 0xfb, 0xd3, 0xdd, 0xc9, 0xb1, 0x20, 0x31, 0x04, 0xb8 ], [ 0x68, 0x3e, 0x21, 0x40, 0x58, 0x5b, 0x18, 0x45, 0x2d, 0xd4, 0xff, 0xbb, 0x93, 0xc9, 0x5d, 0xf9 ], [ 0x28, 0x68, 0x94, 0xe4, 0x8e, 0x53, 0x7f, 0x87, 0x63, 0xb5, 0x67, 0x07, 0xd7, 0xd1, 0x55, 0xc8 ], [ 0xa4, 0x23, 0xde, 0xab, 0xc1, 0x73, 0xdc, 0xf7, 0xe2, 0xc4, 0xc5, 0x3e, 0x77, 0xd3, 0x7c, 0xd1 ], [ 0xeb, 0x81, 0x68, 0x31, 0x3e, 0x1c, 0xfd, 0xfd, 0xb5, 0xe9, 0x86, 0xd5, 0x42, 0x9c, 0xf1, 0x72 ], [ 0x27, 0x12, 0x7d, 0xaa, 0xfc, 0x9a, 0xcc, 0xd2, 0xfb, 0x33, 0x4e, 0xc3, 0xeb, 0xa5, 0x23, 0x23 ], [ 0xee, 0x07, 0x15, 0xb9, 0x6f, 0x72, 0xe3, 0xf7, 0xa2, 0x2a, 0x50, 0x64, 0xfc, 0x59, 0x2f, 0x4c ], [ 0x29, 0xee, 0x52, 0x67, 0x70, 0xf2, 0xa1, 0x1d, 0xcf, 0xa9, 0x89, 0xd1, 0xce, 0x88, 0x83, 0x0f ], [ 0x04, 0x93, 0x37, 0x0e, 0x05, 0x4b, 0x09, 0x87, 0x11, 0x30, 0xfe, 0x49, 0xaf, 0x73, 0x0a, 0x5a ], [ 0x9b, 0x7b, 0x94, 0x0f, 0x6c, 0x50, 0x9f, 0x9e, 0x44, 0xa4, 0xee, 0x14, 0x04, 0x48, 0xee, 0x46 ], [ 0x29, 0x15, 0xbe, 0x4a, 0x1e, 0xcf, 0xdc, 0xbe, 0x3e, 0x02, 0x38, 0x11, 0xa1, 0x2b, 0xb6, 0xc7 ], [ 0x72, 0x40, 0xe5, 0x24, 0xbc, 0x51, 0xd8, 0xc4, 0xd4, 0x40, 0xb1, 0xbe, 0x55, 0xd1, 0x06, 0x2c ], [ 0xda, 0x63, 0x03, 0x9d, 0x38, 0xcb, 0x46, 0x12, 0xb2, 0xdc, 0x36, 0xba, 0x26, 0x68, 0x4b, 0x93 ], [ 0x0f, 0x59, 0xcb, 0x5a, 0x4b, 0x52, 0x2e, 0x2a, 0xc5, 0x6c, 0x1a, 0x64, 0xf5, 0x58, 0xad, 0x9a ], [ 0x7b, 0xfe, 0x9d, 0x87, 0x6c, 0x6d, 0x63, 0xc1, 0xd0, 0x35, 0xda, 0x8f, 0xe2, 0x1c, 0x40, 0x9d ], [ 0xac, 0xda, 0xce, 0x80, 0x78, 0xa3, 0x2b, 0x1a, 0x18, 0x2b, 0xfa, 0x49, 0x87, 0xca, 0x13, 0x47 ] ]; # Values from NIST KAT-AES CBCVarKey256.rsp cipher_texts2_256bit = [ [ 0xe3, 0x5a, 0x6d, 0xcb, 0x19, 0xb2, 0x01, 0xa0, 0x1e, 0xbc, 0xfa, 0x8a, 0xa2, 0x2b, 0x57, 0x59 ], [ 0xb2, 0x91, 0x69, 0xcd, 0xcf, 0x2d, 0x83, 0xe8, 0x38, 0x12, 0x5a, 0x12, 0xee, 0x6a, 0xa4, 0x00 ], [ 0xd8, 0xf3, 0xa7, 0x2f, 0xc3, 0xcd, 0xf7, 0x4d, 0xfa, 0xf6, 0xc3, 0xe6, 0xb9, 0x7b, 0x2f, 0xa6 ], [ 0x1c, 0x77, 0x76, 0x79, 0xd5, 0x00, 0x37, 0xc7, 0x94, 0x91, 0xa9, 0x4d, 0xa7, 0x6a, 0x9a, 0x35 ], [ 0x9c, 0xf4, 0x89, 0x3e, 0xca, 0xfa, 0x0a, 0x02, 0x47, 0xa8, 0x98, 0xe0, 0x40, 0x69, 0x15, 0x59 ], [ 0x8f, 0xbb, 0x41, 0x37, 0x03, 0x73, 0x53, 0x26, 0x31, 0x0a, 0x26, 0x9b, 0xd3, 0xaa, 0x94, 0xb2 ], [ 0x60, 0xe3, 0x22, 0x46, 0xbe, 0xd2, 0xb0, 0xe8, 0x59, 0xe5, 0x5c, 0x1c, 0xc6, 0xb2, 0x65, 0x02 ], [ 0xec, 0x52, 0xa2, 0x12, 0xf8, 0x0a, 0x09, 0xdf, 0x63, 0x17, 0x02, 0x1b, 0xc2, 0xa9, 0x81, 0x9e ], [ 0xf2, 0x3e, 0x5b, 0x60, 0x0e, 0xb7, 0x0d, 0xbc, 0xcf, 0x6c, 0x0b, 0x1d, 0x9a, 0x68, 0x18, 0x2c ], [ 0xa3, 0xf5, 0x99, 0xd6, 0x3a, 0x82, 0xa9, 0x68, 0xc3, 0x3f, 0xe2, 0x65, 0x90, 0x74, 0x59, 0x70 ], [ 0xd1, 0xcc, 0xb9, 0xb1, 0x33, 0x70, 0x02, 0xcb, 0xac, 0x42, 0xc5, 0x20, 0xb5, 0xd6, 0x77, 0x22 ], [ 0xcc, 0x11, 0x1f, 0x6c, 0x37, 0xcf, 0x40, 0xa1, 0x15, 0x9d, 0x00, 0xfb, 0x59, 0xfb, 0x04, 0x88 ], [ 0xdc, 0x43, 0xb5, 0x1a, 0xb6, 0x09, 0x05, 0x23, 0x72, 0x98, 0x9a, 0x26, 0xe9, 0xcd, 0xd7, 0x14 ], [ 0x4d, 0xce, 0xde, 0x8d, 0xa9, 0xe2, 0x57, 0x8f, 0x39, 0x70, 0x3d, 0x44, 0x33, 0xdc, 0x64, 0x59 ], [ 0x1a, 0x4c, 0x1c, 0x26, 0x3b, 0xbc, 0xcf, 0xaf, 0xc1, 0x17, 0x82, 0x89, 0x46, 0x85, 0xe3, 0xa8 ], [ 0x93, 0x7a, 0xd8, 0x48, 0x80, 0xdb, 0x50, 0x61, 0x34, 0x23, 0xd6, 0xd5, 0x27, 0xa2, 0x82, 0x3d ], [ 0x61, 0x0b, 0x71, 0xdf, 0xc6, 0x88, 0xe1, 0x50, 0xd8, 0x15, 0x2c, 0x5b, 0x35, 0xeb, 0xc1, 0x4d ], [ 0x27, 0xef, 0x24, 0x95, 0xda, 0xbf, 0x32, 0x38, 0x85, 0xaa, 0xb3, 0x9c, 0x80, 0xf1, 0x8d, 0x8b ], [ 0x63, 0x3c, 0xaf, 0xea, 0x39, 0x5b, 0xc0, 0x3a, 0xda, 0xe3, 0xa1, 0xe2, 0x06, 0x8e, 0x4b, 0x4e ], [ 0x6e, 0x1b, 0x48, 0x2b, 0x53, 0x76, 0x1c, 0xf6, 0x31, 0x81, 0x9b, 0x74, 0x9a, 0x6f, 0x37, 0x24 ], [ 0x97, 0x6e, 0x6f, 0x85, 0x1a, 0xb5, 0x2c, 0x77, 0x19, 0x98, 0xdb, 0xb2, 0xd7, 0x1c, 0x75, 0xa9 ], [ 0x85, 0xf2, 0xba, 0x84, 0xf8, 0xc3, 0x07, 0xcf, 0x52, 0x5e, 0x12, 0x4c, 0x3e, 0x22, 0xe6, 0xcc ], [ 0x6b, 0xcc, 0xa9, 0x8b, 0xf6, 0xa8, 0x35, 0xfa, 0x64, 0x95, 0x5f, 0x72, 0xde, 0x41, 0x15, 0xfe ], [ 0x2c, 0x75, 0xe2, 0xd3, 0x6e, 0xeb, 0xd6, 0x54, 0x11, 0xf1, 0x4f, 0xd0, 0xeb, 0x1d, 0x2a, 0x06 ], [ 0xbd, 0x49, 0x29, 0x50, 0x06, 0x25, 0x0f, 0xfc, 0xa5, 0x10, 0x0b, 0x60, 0x07, 0xa0, 0xea, 0xde ], [ 0xa1, 0x90, 0x52, 0x7d, 0x0e, 0xf7, 0xc7, 0x0f, 0x45, 0x9c, 0xd3, 0x94, 0x0d, 0xf3, 0x16, 0xec ], [ 0xbb, 0xd1, 0x09, 0x7a, 0x62, 0x43, 0x3f, 0x79, 0x44, 0x9f, 0xa9, 0x7d, 0x4e, 0xe8, 0x0d, 0xbf ], [ 0x07, 0x05, 0x8e, 0x40, 0x8f, 0x5b, 0x99, 0xb0, 0xe0, 0xf0, 0x61, 0xa1, 0x76, 0x1b, 0x5b, 0x3b ], [ 0x5f, 0xd1, 0xf1, 0x3f, 0xa0, 0xf3, 0x1e, 0x37, 0xfa, 0xbd, 0xe3, 0x28, 0xf8, 0x94, 0xea, 0xc2 ], [ 0xfc, 0x4a, 0xf7, 0xc9, 0x48, 0xdf, 0x26, 0xe2, 0xef, 0x3e, 0x01, 0xc1, 0xee, 0x5b, 0x8f, 0x6f ], [ 0x82, 0x9f, 0xd7, 0x20, 0x8f, 0xb9, 0x2d, 0x44, 0xa0, 0x74, 0xa6, 0x77, 0xee, 0x98, 0x61, 0xac ], [ 0xad, 0x9f, 0xc6, 0x13, 0xa7, 0x03, 0x25, 0x1b, 0x54, 0xc6, 0x4a, 0x0e, 0x76, 0x43, 0x17, 0x11 ], [ 0x33, 0xac, 0x9e, 0xcc, 0xc4, 0xcc, 0x75, 0xe2, 0x71, 0x16, 0x18, 0xf8, 0x0b, 0x15, 0x48, 0xe8 ], [ 0x20, 0x25, 0xc7, 0x4b, 0x8a, 0xd8, 0xf4, 0xcd, 0xa1, 0x7e, 0xe2, 0x04, 0x9c, 0x4c, 0x90, 0x2d ], [ 0xf8, 0x5c, 0xa0, 0x5f, 0xe5, 0x28, 0xf1, 0xce, 0x9b, 0x79, 0x01, 0x66, 0xe8, 0xd5, 0x51, 0xe7 ], [ 0x6f, 0x62, 0x38, 0xd8, 0x96, 0x60, 0x48, 0xd4, 0x96, 0x71, 0x54, 0xe0, 0xda, 0xd5, 0xa6, 0xc9 ], [ 0xf2, 0xb2, 0x1b, 0x4e, 0x76, 0x40, 0xa9, 0xb3, 0x34, 0x6d, 0xe8, 0xb8, 0x2f, 0xb4, 0x1e, 0x49 ], [ 0xf8, 0x36, 0xf2, 0x51, 0xad, 0x1d, 0x11, 0xd4, 0x9d, 0xc3, 0x44, 0x62, 0x8b, 0x18, 0x84, 0xe1 ], [ 0x07, 0x7e, 0x94, 0x70, 0xae, 0x7a, 0xbe, 0xa5, 0xa9, 0x76, 0x9d, 0x49, 0x18, 0x26, 0x28, 0xc3 ], [ 0xe0, 0xdc, 0xc2, 0xd2, 0x7f, 0xc9, 0x86, 0x56, 0x33, 0xf8, 0x52, 0x23, 0xcf, 0x0d, 0x61, 0x1f ], [ 0xbe, 0x66, 0xcf, 0xea, 0x2f, 0xec, 0xd6, 0xbf, 0x0e, 0xc7, 0xb4, 0x35, 0x2c, 0x99, 0xbc, 0xaa ], [ 0xdf, 0x31, 0x14, 0x4f, 0x87, 0xa2, 0xef, 0x52, 0x3f, 0xac, 0xdc, 0xf2, 0x1a, 0x42, 0x78, 0x04 ], [ 0xb5, 0xbb, 0x0f, 0x56, 0x29, 0xfb, 0x6a, 0xae, 0x5e, 0x18, 0x39, 0xa3, 0xc3, 0x62, 0x5d, 0x63 ], [ 0x3c, 0x9d, 0xb3, 0x33, 0x53, 0x06, 0xfe, 0x1e, 0xc6, 0x12, 0xbd, 0xbf, 0xae, 0x6b, 0x60, 0x28 ], [ 0x3d, 0xd5, 0xc3, 0x46, 0x34, 0xa7, 0x9d, 0x3c, 0xfc, 0xc8, 0x33, 0x97, 0x60, 0xe6, 0xf5, 0xf4 ], [ 0x82, 0xbd, 0xa1, 0x18, 0xa3, 0xed, 0x7a, 0xf3, 0x14, 0xfa, 0x2c, 0xcc, 0x5c, 0x07, 0xb7, 0x61 ], [ 0x29, 0x37, 0xa6, 0x4f, 0x7d, 0x4f, 0x46, 0xfe, 0x6f, 0xea, 0x3b, 0x34, 0x9e, 0xc7, 0x8e, 0x38 ], [ 0x22, 0x5f, 0x06, 0x8c, 0x28, 0x47, 0x66, 0x05, 0x73, 0x5a, 0xd6, 0x71, 0xbb, 0x8f, 0x39, 0xf3 ], [ 0xae, 0x68, 0x2c, 0x5e, 0xcd, 0x71, 0x89, 0x8e, 0x08, 0x94, 0x2a, 0xc9, 0xaa, 0x89, 0x87, 0x5c ], [ 0x5e, 0x03, 0x1c, 0xb9, 0xd6, 0x76, 0xc3, 0x02, 0x2d, 0x7f, 0x26, 0x22, 0x7e, 0x85, 0xc3, 0x8f ], [ 0xa7, 0x84, 0x63, 0xfb, 0x06, 0x4d, 0xb5, 0xd5, 0x2b, 0xb6, 0x4b, 0xfe, 0xf6, 0x4f, 0x2d, 0xda ], [ 0x8a, 0xa9, 0xb7, 0x5e, 0x78, 0x45, 0x93, 0x87, 0x6c, 0x53, 0xa0, 0x0e, 0xae, 0x5a, 0xf5, 0x2b ], [ 0x3f, 0x84, 0x56, 0x6d, 0xf2, 0x3d, 0xa4, 0x8a, 0xf6, 0x92, 0x72, 0x2f, 0xe9, 0x80, 0x57, 0x3a ], [ 0x31, 0x69, 0x0b, 0x5e, 0xd4, 0x1c, 0x7e, 0xb4, 0x2a, 0x1e, 0x83, 0x27, 0x0a, 0x7f, 0xf0, 0xe6 ], [ 0x77, 0xdd, 0x77, 0x02, 0x64, 0x6d, 0x55, 0xf0, 0x83, 0x65, 0xe4, 0x77, 0xd3, 0x59, 0x0e, 0xda ], [ 0x4c, 0x02, 0x2a, 0xc6, 0x2b, 0x3c, 0xb7, 0x8d, 0x73, 0x9c, 0xc6, 0x7b, 0x3e, 0x20, 0xbb, 0x7e ], [ 0x09, 0x2f, 0xa1, 0x37, 0xce, 0x18, 0xb5, 0xdf, 0xe7, 0x90, 0x6f, 0x55, 0x0b, 0xb1, 0x33, 0x70 ], [ 0x3e, 0x0c, 0xda, 0xdf, 0x2e, 0x68, 0x35, 0x3c, 0x00, 0x27, 0x67, 0x2c, 0x97, 0x14, 0x4d, 0xd3 ], [ 0xd8, 0xc4, 0xb2, 0x00, 0xb3, 0x83, 0xfc, 0x1f, 0x2b, 0x2e, 0xa6, 0x77, 0x61, 0x8a, 0x1d, 0x27 ], [ 0x11, 0x82, 0x5f, 0x99, 0xb0, 0xe9, 0xbb, 0x34, 0x77, 0xc1, 0xc0, 0x71, 0x3b, 0x01, 0x5a, 0xac ], [ 0xf8, 0xb9, 0xff, 0xfb, 0x5c, 0x18, 0x7f, 0x7d, 0xdc, 0x7a, 0xb1, 0x0f, 0x4f, 0xb7, 0x75, 0x76 ], [ 0xff, 0xb4, 0xe8, 0x7a, 0x32, 0xb3, 0x7d, 0x6f, 0x2c, 0x83, 0x28, 0xd3, 0xb5, 0x37, 0x78, 0x02 ], [ 0xd2, 0x76, 0xc1, 0x3a, 0x5d, 0x22, 0x0f, 0x4d, 0xa9, 0x22, 0x4e, 0x74, 0x89, 0x63, 0x91, 0xce ], [ 0x94, 0xef, 0xe7, 0xa0, 0xe2, 0xe0, 0x31, 0xe2, 0x53, 0x6d, 0xa0, 0x1d, 0xf7, 0x99, 0xc9, 0x27 ], [ 0x8f, 0x8f, 0xd8, 0x22, 0x68, 0x0a, 0x85, 0x97, 0x4e, 0x53, 0xa5, 0xa8, 0xeb, 0x9d, 0x38, 0xde ], [ 0xe0, 0xf0, 0xa9, 0x1b, 0x2e, 0x45, 0xf8, 0xcc, 0x37, 0xb7, 0x80, 0x5a, 0x30, 0x42, 0x58, 0x8d ], [ 0x59, 0x7a, 0x62, 0x52, 0x25, 0x5e, 0x46, 0xd6, 0x36, 0x4d, 0xbe, 0xed, 0xa3, 0x1e, 0x27, 0x9c ], [ 0xf5, 0x1a, 0x0f, 0x69, 0x44, 0x42, 0xb8, 0xf0, 0x55, 0x71, 0x79, 0x7f, 0xec, 0x7e, 0xe8, 0xbf ], [ 0x9f, 0xf0, 0x71, 0xb1, 0x65, 0xb5, 0x19, 0x8a, 0x93, 0xdd, 0xde, 0xeb, 0xc5, 0x4d, 0x09, 0xb5 ], [ 0xc2, 0x0a, 0x19, 0xfd, 0x57, 0x58, 0xb0, 0xc4, 0xbc, 0x1a, 0x5d, 0xf8, 0x9c, 0xf7, 0x38, 0x77 ], [ 0x97, 0x12, 0x01, 0x66, 0x30, 0x71, 0x19, 0xca, 0x22, 0x80, 0xe9, 0x31, 0x56, 0x68, 0xe9, 0x6f ], [ 0x4b, 0x3b, 0x9f, 0x1e, 0x09, 0x9c, 0x2a, 0x09, 0xdc, 0x09, 0x1e, 0x90, 0xe4, 0xf1, 0x8f, 0x0a ], [ 0xeb, 0x04, 0x0b, 0x89, 0x1d, 0x4b, 0x37, 0xf6, 0x85, 0x1f, 0x7e, 0xc2, 0x19, 0xcd, 0x3f, 0x6d ], [ 0x9f, 0x0f, 0xde, 0xc0, 0x8b, 0x7f, 0xd7, 0x9a, 0xa3, 0x95, 0x35, 0xbe, 0xa4, 0x2d, 0xb9, 0x2a ], [ 0x2e, 0x70, 0xf1, 0x68, 0xfc, 0x74, 0xbf, 0x91, 0x1d, 0xf2, 0x40, 0xbc, 0xd2, 0xce, 0xf2, 0x36 ], [ 0x46, 0x2c, 0xcd, 0x7f, 0x5f, 0xd1, 0x10, 0x8d, 0xbc, 0x15, 0x2f, 0x3c, 0xac, 0xad, 0x32, 0x8b ], [ 0xa4, 0xaf, 0x53, 0x4a, 0x7d, 0x0b, 0x64, 0x3a, 0x01, 0x86, 0x87, 0x85, 0xd8, 0x6d, 0xfb, 0x95 ], [ 0xab, 0x98, 0x02, 0x96, 0x19, 0x7e, 0x1a, 0x50, 0x22, 0x32, 0x6c, 0x31, 0xda, 0x4b, 0xf6, 0xf3 ], [ 0xf9, 0x7d, 0x57, 0xb3, 0x33, 0x3b, 0x62, 0x81, 0xb0, 0x7d, 0x48, 0x6d, 0xb2, 0xd4, 0xe2, 0x0c ], [ 0xf3, 0x3f, 0xa3, 0x67, 0x20, 0x23, 0x1a, 0xfe, 0x4c, 0x75, 0x9a, 0xde, 0x6b, 0xd6, 0x2e, 0xb6 ], [ 0xfd, 0xcf, 0xac, 0x0c, 0x02, 0xca, 0x53, 0x83, 0x43, 0xc6, 0x81, 0x17, 0xe0, 0xa1, 0x59, 0x38 ], [ 0xad, 0x49, 0x16, 0xf5, 0xee, 0x57, 0x72, 0xbe, 0x76, 0x4f, 0xc0, 0x27, 0xb8, 0xa6, 0xe5, 0x39 ], [ 0x2e, 0x16, 0x87, 0x3e, 0x16, 0x78, 0x61, 0x0d, 0x7e, 0x14, 0xc0, 0x2d, 0x00, 0x2e, 0xa8, 0x45 ], [ 0x4e, 0x6e, 0x62, 0x7c, 0x1a, 0xcc, 0x51, 0x34, 0x00, 0x53, 0xa8, 0x23, 0x6d, 0x57, 0x95, 0x76 ], [ 0xab, 0x0c, 0x84, 0x10, 0xae, 0xee, 0xad, 0x92, 0xfe, 0xec, 0x1e, 0xb4, 0x30, 0xd6, 0x52, 0xcb ], [ 0xe8, 0x6f, 0x7e, 0x23, 0xe8, 0x35, 0xe1, 0x14, 0x97, 0x7f, 0x60, 0xe1, 0xa5, 0x92, 0x20, 0x2e ], [ 0xe6, 0x8a, 0xd5, 0x05, 0x5a, 0x36, 0x70, 0x41, 0xfa, 0xde, 0x09, 0xd9, 0xa7, 0x0a, 0x79, 0x4b ], [ 0x07, 0x91, 0x82, 0x3a, 0x3c, 0x66, 0x6b, 0xb6, 0x16, 0x28, 0x25, 0xe7, 0x86, 0x06, 0xa7, 0xfe ], [ 0xdc, 0xca, 0x36, 0x6a, 0x9b, 0xf4, 0x7b, 0x7b, 0x86, 0x8b, 0x77, 0xe2, 0x5c, 0x18, 0xa3, 0x64 ], [ 0x68, 0x4c, 0x9e, 0xfc, 0x23, 0x7e, 0x4a, 0x44, 0x29, 0x65, 0xf8, 0x4b, 0xce, 0x20, 0x24, 0x7a ], [ 0xa8, 0x58, 0x41, 0x1f, 0xfb, 0xe6, 0x3f, 0xdb, 0x9c, 0x8a, 0xa1, 0xbf, 0xae, 0xd6, 0x7b, 0x52 ], [ 0x04, 0xbc, 0x3d, 0xa2, 0x17, 0x9c, 0x30, 0x15, 0x49, 0x8b, 0x0e, 0x03, 0x91, 0x0d, 0xb5, 0xb8 ], [ 0x40, 0x07, 0x1e, 0xea, 0xb3, 0xf9, 0x35, 0xdb, 0xc2, 0x5d, 0x00, 0x84, 0x14, 0x60, 0x26, 0x0f ], [ 0x0e, 0xbd, 0x7c, 0x30, 0xed, 0x20, 0x16, 0xe0, 0x8b, 0xa8, 0x06, 0xdd, 0xb0, 0x08, 0xbc, 0xc8 ], [ 0x15, 0xc6, 0xbe, 0xcf, 0x0f, 0x4c, 0xec, 0x71, 0x29, 0xcb, 0xd2, 0x2d, 0x1a, 0x79, 0xb1, 0xb8 ], [ 0x0a, 0xee, 0xde, 0x5b, 0x91, 0xf7, 0x21, 0x70, 0x0e, 0x9e, 0x62, 0xed, 0xbf, 0x60, 0xb7, 0x81 ], [ 0x26, 0x65, 0x81, 0xaf, 0x0d, 0xcf, 0xbe, 0xd1, 0x58, 0x5e, 0x0a, 0x24, 0x2c, 0x64, 0xb8, 0xdf ], [ 0x66, 0x93, 0xdc, 0x91, 0x16, 0x62, 0xae, 0x47, 0x32, 0x16, 0xba, 0x22, 0x18, 0x9a, 0x51, 0x1a ], [ 0x76, 0x06, 0xfa, 0x36, 0xd8, 0x64, 0x73, 0xe6, 0xfb, 0x3a, 0x1b, 0xb0, 0xe2, 0xc0, 0xad, 0xf5 ], [ 0x11, 0x20, 0x78, 0xe9, 0xe1, 0x1f, 0xbb, 0x78, 0xe2, 0x6f, 0xfb, 0x88, 0x99, 0xe9, 0x6b, 0x9a ], [ 0x40, 0xb2, 0x64, 0xe9, 0x21, 0xe9, 0xe4, 0xa8, 0x26, 0x94, 0x58, 0x9e, 0xf3, 0x79, 0x82, 0x62 ], [ 0x8d, 0x45, 0x95, 0xcb, 0x4f, 0xa7, 0x02, 0x67, 0x15, 0xf5, 0x5b, 0xd6, 0x8e, 0x28, 0x82, 0xf9 ], [ 0xb5, 0x88, 0xa3, 0x02, 0xbd, 0xbc, 0x09, 0x19, 0x7d, 0xf1, 0xed, 0xae, 0x68, 0x92, 0x6e, 0xd9 ], [ 0x33, 0xf7, 0x50, 0x23, 0x90, 0xb8, 0xa4, 0xa2, 0x21, 0xcf, 0xec, 0xd0, 0x66, 0x66, 0x24, 0xba ], [ 0x3d, 0x20, 0x25, 0x3a, 0xdb, 0xce, 0x3b, 0xe2, 0x37, 0x37, 0x67, 0xc4, 0xd8, 0x22, 0xc5, 0x66 ], [ 0xa4, 0x27, 0x34, 0xa3, 0x92, 0x9b, 0xf8, 0x4c, 0xf0, 0x11, 0x6c, 0x98, 0x56, 0xa3, 0xc1, 0x8c ], [ 0xe3, 0xab, 0xc4, 0x93, 0x94, 0x57, 0x42, 0x2b, 0xb9, 0x57, 0xda, 0x3c, 0x56, 0x93, 0x8c, 0x6d ], [ 0x97, 0x2b, 0xdd, 0x2e, 0x7c, 0x52, 0x51, 0x30, 0xfa, 0xdc, 0x8f, 0x76, 0xfc, 0x6f, 0x4b, 0x3f ], [ 0x84, 0xa8, 0x3d, 0x7b, 0x94, 0xc6, 0x99, 0xcb, 0xcb, 0x8a, 0x7d, 0x9b, 0x61, 0xf6, 0x40, 0x93 ], [ 0xce, 0x61, 0xd6, 0x35, 0x14, 0xad, 0xed, 0x03, 0xd4, 0x3e, 0x6e, 0xbf, 0xc3, 0xa9, 0x00, 0x1f ], [ 0x6c, 0x83, 0x9d, 0xd5, 0x8e, 0xea, 0xe6, 0xb8, 0xa3, 0x6a, 0xf4, 0x8e, 0xd6, 0x3d, 0x2d, 0xc9 ], [ 0xcd, 0x5e, 0xce, 0x55, 0xb8, 0xda, 0x3b, 0xf6, 0x22, 0xc4, 0x10, 0x0d, 0xf5, 0xde, 0x46, 0xf9 ], [ 0x3b, 0x6f, 0x46, 0xf4, 0x0e, 0x0a, 0xc5, 0xfc, 0x0a, 0x9c, 0x11, 0x05, 0xf8, 0x00, 0xf4, 0x8d ], [ 0xba, 0x26, 0xd4, 0x7d, 0xa3, 0xae, 0xb0, 0x28, 0xde, 0x4f, 0xb5, 0xb3, 0xa8, 0x54, 0xa2, 0x4b ], [ 0x87, 0xf5, 0x3b, 0xf6, 0x20, 0xd3, 0x67, 0x72, 0x68, 0x44, 0x52, 0x12, 0x90, 0x43, 0x89, 0xd5 ], [ 0x10, 0x61, 0x7d, 0x28, 0xb5, 0xe0, 0xf4, 0x60, 0x54, 0x92, 0xb1, 0x82, 0xa5, 0xd7, 0xf9, 0xf6 ], [ 0x9a, 0xae, 0xc4, 0xfa, 0xbb, 0xf6, 0xfa, 0xe2, 0xa7, 0x1f, 0xef, 0xf0, 0x2e, 0x37, 0x2b, 0x39 ], [ 0x3a, 0x90, 0xc6, 0x2d, 0x88, 0xb5, 0xc4, 0x28, 0x09, 0xab, 0xf7, 0x82, 0x48, 0x8e, 0xd1, 0x30 ], [ 0xf1, 0xf1, 0xc5, 0xa4, 0x08, 0x99, 0xe1, 0x57, 0x72, 0x85, 0x7c, 0xcb, 0x65, 0xc7, 0xa0, 0x9a ], [ 0x19, 0x08, 0x43, 0xd2, 0x9b, 0x25, 0xa3, 0x89, 0x7c, 0x69, 0x2c, 0xe1, 0xdd, 0x81, 0xee, 0x52 ], [ 0xa8, 0x66, 0xbc, 0x65, 0xb6, 0x94, 0x1d, 0x86, 0xe8, 0x42, 0x0a, 0x7f, 0xfb, 0x09, 0x64, 0xdb ], [ 0x81, 0x93, 0xc6, 0xff, 0x85, 0x22, 0x5c, 0xed, 0x42, 0x55, 0xe9, 0x2f, 0x6e, 0x07, 0x8a, 0x14 ], [ 0x96, 0x61, 0xcb, 0x24, 0x24, 0xd7, 0xd4, 0xa3, 0x80, 0xd5, 0x47, 0xf9, 0xe7, 0xec, 0x1c, 0xb9 ], [ 0x86, 0xf9, 0x3d, 0x9e, 0xc0, 0x84, 0x53, 0xa0, 0x71, 0xe2, 0xe2, 0x87, 0x78, 0x77, 0xa9, 0xc8 ], [ 0x27, 0xee, 0xfa, 0x80, 0xce, 0x6a, 0x4a, 0x9d, 0x59, 0x8e, 0x3f, 0xec, 0x36, 0x54, 0x34, 0xd2 ], [ 0xd6, 0x20, 0x68, 0x44, 0x45, 0x78, 0xe3, 0xab, 0x39, 0xce, 0x7e, 0xc9, 0x5d, 0xd0, 0x45, 0xdc ], [ 0xb5, 0xf7, 0x1d, 0x4d, 0xd9, 0xa7, 0x1f, 0xe5, 0xd8, 0xbc, 0x8b, 0xa7, 0xe6, 0xea, 0x30, 0x48 ], [ 0x68, 0x25, 0xa3, 0x47, 0xac, 0x47, 0x9d, 0x4f, 0x9d, 0x95, 0xc5, 0xcb, 0x8d, 0x3f, 0xd7, 0xe9 ], [ 0xe3, 0x71, 0x4e, 0x94, 0xa5, 0x77, 0x89, 0x55, 0xcc, 0x03, 0x46, 0x35, 0x8e, 0x94, 0x78, 0x3a ], [ 0xd8, 0x36, 0xb4, 0x4b, 0xb2, 0x9e, 0x0c, 0x7d, 0x89, 0xfa, 0x4b, 0x2d, 0x4b, 0x67, 0x7d, 0x2a ], [ 0x5d, 0x45, 0x4b, 0x75, 0x02, 0x1d, 0x76, 0xd4, 0xb8, 0x4f, 0x87, 0x3a, 0x8f, 0x87, 0x7b, 0x92 ], [ 0xc3, 0x49, 0x8f, 0x7e, 0xce, 0xd2, 0x09, 0x53, 0x14, 0xfc, 0x28, 0x11, 0x58, 0x85, 0xb3, 0x3f ], [ 0x6e, 0x66, 0x88, 0x56, 0x53, 0x9a, 0xd8, 0xe4, 0x05, 0xbd, 0x12, 0x3f, 0xe6, 0xc8, 0x85, 0x30 ], [ 0x86, 0x80, 0xdb, 0x7f, 0x3a, 0x87, 0xb8, 0x60, 0x55, 0x43, 0xcf, 0xdb, 0xe6, 0x75, 0x40, 0x76 ], [ 0x6c, 0x5d, 0x03, 0xb1, 0x30, 0x69, 0xc3, 0x65, 0x8b, 0x31, 0x79, 0xbe, 0x91, 0xb0, 0x80, 0x0c ], [ 0xef, 0x1b, 0x38, 0x4a, 0xc4, 0xd9, 0x3e, 0xda, 0x00, 0xc9, 0x2a, 0xdd, 0x09, 0x95, 0xea, 0x5f ], [ 0xbf, 0x81, 0x15, 0x80, 0x54, 0x71, 0x74, 0x1b, 0xd5, 0xad, 0x20, 0xa0, 0x39, 0x44, 0x79, 0x0f ], [ 0xc6, 0x4c, 0x24, 0xb6, 0x89, 0x4b, 0x03, 0x8b, 0x3c, 0x0d, 0x09, 0xb1, 0xdf, 0x06, 0x8b, 0x0b ], [ 0x39, 0x67, 0xa1, 0x0c, 0xff, 0xe2, 0x7d, 0x01, 0x78, 0x54, 0x5f, 0xbf, 0x6a, 0x40, 0x54, 0x4b ], [ 0x7c, 0x85, 0xe9, 0xc9, 0x5d, 0xe1, 0xa9, 0xec, 0x5a, 0x53, 0x63, 0xa8, 0xa0, 0x53, 0x47, 0x2d ], [ 0xa9, 0xee, 0xc0, 0x3c, 0x8a, 0xbe, 0xc7, 0xba, 0x68, 0x31, 0x5c, 0x2c, 0x8c, 0x23, 0x16, 0xe0 ], [ 0xca, 0xc8, 0xe4, 0x14, 0xc2, 0xf3, 0x88, 0x22, 0x7a, 0xe1, 0x49, 0x86, 0xfc, 0x98, 0x35, 0x24 ], [ 0x5d, 0x94, 0x2b, 0x7f, 0x46, 0x22, 0xce, 0x05, 0x6c, 0x3c, 0xe3, 0xce, 0x5f, 0x1d, 0xd9, 0xd6 ], [ 0xd2, 0x40, 0xd6, 0x48, 0xce, 0x21, 0xa3, 0x02, 0x02, 0x82, 0xc3, 0xf1, 0xb5, 0x28, 0xa0, 0xb6 ], [ 0x45, 0xd0, 0x89, 0xc3, 0x6d, 0x5c, 0x5a, 0x4e, 0xfc, 0x68, 0x9e, 0x3b, 0x0d, 0xe1, 0x0d, 0xd5 ], [ 0xb4, 0xda, 0x5d, 0xf4, 0xbe, 0xcb, 0x54, 0x62, 0xe0, 0x3a, 0x0e, 0xd0, 0x0d, 0x29, 0x56, 0x29 ], [ 0xdc, 0xf4, 0xe1, 0x29, 0x13, 0x6c, 0x1a, 0x4b, 0x7a, 0x0f, 0x38, 0x93, 0x5c, 0xc3, 0x4b, 0x2b ], [ 0xd9, 0xa4, 0xc7, 0x61, 0x8b, 0x0c, 0xe4, 0x8a, 0x3d, 0x5a, 0xee, 0x1a, 0x1c, 0x01, 0x14, 0xc4 ], [ 0xca, 0x35, 0x2d, 0xf0, 0x25, 0xc6, 0x5c, 0x7b, 0x0b, 0xf3, 0x06, 0xfb, 0xee, 0x0f, 0x36, 0xba ], [ 0x23, 0x8a, 0xca, 0x23, 0xfd, 0x34, 0x09, 0xf3, 0x8a, 0xf6, 0x33, 0x78, 0xed, 0x2f, 0x54, 0x73 ], [ 0x59, 0x83, 0x6a, 0x0e, 0x06, 0xa7, 0x96, 0x91, 0xb3, 0x66, 0x67, 0xd5, 0x38, 0x0d, 0x81, 0x88 ], [ 0x33, 0x90, 0x50, 0x80, 0xf7, 0xac, 0xf1, 0xcd, 0xae, 0x0a, 0x91, 0xfc, 0x3e, 0x85, 0xae, 0xe4 ], [ 0x72, 0xc9, 0xe4, 0x64, 0x6d, 0xbc, 0x3d, 0x63, 0x20, 0xfc, 0x66, 0x89, 0xd9, 0x3e, 0x88, 0x33 ], [ 0xba, 0x77, 0x41, 0x3d, 0xea, 0x59, 0x25, 0xb7, 0xf5, 0x41, 0x7e, 0xa4, 0x7f, 0xf1, 0x9f, 0x59 ], [ 0x6c, 0xae, 0x81, 0x29, 0xf8, 0x43, 0xd8, 0x6d, 0xc7, 0x86, 0xa0, 0xfb, 0x1a, 0x18, 0x49, 0x70 ], [ 0xfc, 0xfe, 0xfb, 0x53, 0x41, 0x00, 0x79, 0x6e, 0xeb, 0xbd, 0x99, 0x02, 0x06, 0x75, 0x4e, 0x19 ], [ 0x8c, 0x79, 0x1d, 0x5f, 0xdd, 0xdf, 0x47, 0x0d, 0xa0, 0x4f, 0x3e, 0x6d, 0xc4, 0xa5, 0xb5, 0xb5 ], [ 0xc9, 0x3b, 0xbd, 0xc0, 0x7a, 0x46, 0x11, 0xae, 0x4b, 0xb2, 0x66, 0xea, 0x50, 0x34, 0xa3, 0x87 ], [ 0xc1, 0x02, 0xe3, 0x8e, 0x48, 0x9a, 0xa7, 0x47, 0x62, 0xf3, 0xef, 0xc5, 0xbb, 0x23, 0x20, 0x5a ], [ 0x93, 0x20, 0x14, 0x81, 0x66, 0x5c, 0xba, 0xfc, 0x1f, 0xcc, 0x22, 0x0b, 0xc5, 0x45, 0xfb, 0x3d ], [ 0x49, 0x60, 0x75, 0x7e, 0xc6, 0xce, 0x68, 0xcf, 0x19, 0x5e, 0x45, 0x4c, 0xfd, 0x0f, 0x32, 0xca ], [ 0xfe, 0xec, 0x7c, 0xe6, 0xa6, 0xcb, 0xd0, 0x7c, 0x04, 0x34, 0x16, 0x73, 0x7f, 0x1b, 0xbb, 0x33 ], [ 0x11, 0xc5, 0x41, 0x39, 0x04, 0x48, 0x7a, 0x80, 0x5d, 0x70, 0xa8, 0xed, 0xd9, 0xc3, 0x55, 0x27 ], [ 0x34, 0x78, 0x46, 0xb2, 0xb2, 0xe3, 0x6f, 0x1f, 0x03, 0x24, 0xc8, 0x6f, 0x7f, 0x1b, 0x98, 0xe2 ], [ 0x33, 0x2e, 0xee, 0x1a, 0x0c, 0xbd, 0x19, 0xca, 0x2d, 0x69, 0xb4, 0x26, 0x89, 0x40, 0x44, 0xf0 ], [ 0x86, 0x6b, 0x5b, 0x39, 0x77, 0xba, 0x6e, 0xfa, 0x51, 0x28, 0xef, 0xbd, 0xa9, 0xff, 0x03, 0xcd ], [ 0xcc, 0x14, 0x45, 0xee, 0x94, 0xc0, 0xf0, 0x8c, 0xde, 0xe5, 0xc3, 0x44, 0xec, 0xd1, 0xe2, 0x33 ], [ 0xbe, 0x28, 0x83, 0x19, 0x02, 0x93, 0x63, 0xc2, 0x62, 0x2f, 0xeb, 0xa4, 0xb0, 0x5d, 0xfd, 0xfe ], [ 0xcf, 0xd1, 0x87, 0x55, 0x23, 0xf3, 0xcd, 0x21, 0xc3, 0x95, 0x65, 0x1e, 0x6e, 0xe1, 0x5e, 0x56 ], [ 0xcb, 0x5a, 0x40, 0x86, 0x57, 0x83, 0x7c, 0x53, 0xbf, 0x16, 0xf9, 0xd8, 0x46, 0x5d, 0xce, 0x19 ], [ 0xca, 0x0b, 0xf4, 0x2c, 0xb1, 0x07, 0xf5, 0x5c, 0xcf, 0xf2, 0xfc, 0x09, 0xee, 0x08, 0xca, 0x15 ], [ 0xfd, 0xd9, 0xbb, 0xb4, 0xa7, 0xdc, 0x2e, 0x4a, 0x23, 0x53, 0x6a, 0x58, 0x80, 0xa2, 0xdb, 0x67 ], [ 0xed, 0xe4, 0x47, 0xb3, 0x62, 0xc4, 0x84, 0x99, 0x3d, 0xec, 0x94, 0x42, 0xa3, 0xb4, 0x6a, 0xef ], [ 0x10, 0xdf, 0xfb, 0x05, 0x90, 0x4b, 0xff, 0x7c, 0x47, 0x81, 0xdf, 0x78, 0x0a, 0xd2, 0x68, 0x37 ], [ 0xc3, 0x3b, 0xc1, 0x3e, 0x8d, 0xe8, 0x8a, 0xc2, 0x52, 0x32, 0xaa, 0x74, 0x96, 0x39, 0x87, 0x83 ], [ 0xca, 0x35, 0x9c, 0x70, 0x80, 0x3a, 0x3b, 0x2a, 0x3d, 0x54, 0x2e, 0x87, 0x81, 0xde, 0xa9, 0x75 ], [ 0xbc, 0xc6, 0x5b, 0x52, 0x6f, 0x88, 0xd0, 0x5b, 0x89, 0xce, 0x8a, 0x52, 0x02, 0x1f, 0xdb, 0x06 ], [ 0xdb, 0x91, 0xa3, 0x88, 0x55, 0xc8, 0xc4, 0x64, 0x38, 0x51, 0xfb, 0xfb, 0x35, 0x8b, 0x01, 0x09 ], [ 0xca, 0x6e, 0x88, 0x93, 0xa1, 0x14, 0xae, 0x8e, 0x27, 0xd5, 0xab, 0x03, 0xa5, 0x49, 0x96, 0x10 ], [ 0x66, 0x29, 0xd2, 0xb8, 0xdf, 0x97, 0xda, 0x72, 0x8c, 0xdd, 0x8b, 0x1e, 0x7f, 0x94, 0x50, 0x77 ], [ 0x45, 0x70, 0xa5, 0xa1, 0x8c, 0xfc, 0x0d, 0xd5, 0x82, 0xf1, 0xd8, 0x8d, 0x5c, 0x9a, 0x17, 0x20 ], [ 0x72, 0xbc, 0x65, 0xaa, 0x8e, 0x89, 0x56, 0x2e, 0x3f, 0x27, 0x4d, 0x45, 0xaf, 0x1c, 0xd1, 0x0b ], [ 0x98, 0x55, 0x1d, 0xa1, 0xa6, 0x50, 0x32, 0x76, 0xae, 0x1c, 0x77, 0x62, 0x5f, 0x9e, 0xa6, 0x15 ], [ 0x0d, 0xdf, 0xe5, 0x1c, 0xed, 0x7e, 0x3f, 0x4a, 0xe9, 0x27, 0xda, 0xa3, 0xfe, 0x45, 0x2c, 0xee ], [ 0xdb, 0x82, 0x62, 0x51, 0xe4, 0xce, 0x38, 0x4b, 0x80, 0x21, 0x8b, 0x0e, 0x1d, 0xa1, 0xdd, 0x4c ], [ 0x2c, 0xac, 0xf7, 0x28, 0xb8, 0x8a, 0xbb, 0xad, 0x70, 0x11, 0xed, 0x0e, 0x64, 0xa1, 0x68, 0x0c ], [ 0x33, 0x0d, 0x8e, 0xe7, 0xc5, 0x67, 0x7e, 0x09, 0x9a, 0xc7, 0x4c, 0x99, 0x94, 0xee, 0x4c, 0xfb ], [ 0xed, 0xf6, 0x1a, 0xe3, 0x62, 0xe8, 0x82, 0xdd, 0xc0, 0x16, 0x74, 0x74, 0xa7, 0xa7, 0x7f, 0x3a ], [ 0x61, 0x68, 0xb0, 0x0b, 0xa7, 0x85, 0x9e, 0x09, 0x70, 0xec, 0xfd, 0x75, 0x7e, 0xfe, 0xcf, 0x7c ], [ 0xd1, 0x41, 0x54, 0x47, 0x86, 0x62, 0x30, 0xd2, 0x8b, 0xb1, 0xea, 0x18, 0xa4, 0xcd, 0xfd, 0x02 ], [ 0x51, 0x61, 0x83, 0x39, 0x2f, 0x7a, 0x87, 0x63, 0xaf, 0xec, 0x68, 0xa0, 0x60, 0x26, 0x41, 0x41 ], [ 0x77, 0x56, 0x5c, 0x8d, 0x73, 0xcf, 0xd4, 0x13, 0x0b, 0x4a, 0xa1, 0x4d, 0x89, 0x11, 0x71, 0x0f ], [ 0x37, 0x23, 0x2a, 0x4e, 0xd2, 0x1c, 0xcc, 0x27, 0xc1, 0x9c, 0x96, 0x10, 0x07, 0x8c, 0xab, 0xac ], [ 0x80, 0x4f, 0x32, 0xea, 0x71, 0x82, 0x8c, 0x7d, 0x32, 0x90, 0x77, 0xe7, 0x12, 0x23, 0x16, 0x66 ], [ 0xd6, 0x44, 0x24, 0xf2, 0x3c, 0xb9, 0x72, 0x15, 0xe9, 0xc2, 0xc6, 0xf2, 0x8d, 0x29, 0xea, 0xb7 ], [ 0x02, 0x3e, 0x82, 0xb5, 0x33, 0xf6, 0x8c, 0x75, 0xc2, 0x38, 0xce, 0xbd, 0xb2, 0xee, 0x89, 0xa2 ], [ 0x19, 0x3a, 0x3d, 0x24, 0x15, 0x7a, 0x51, 0xf1, 0xee, 0x08, 0x93, 0xf6, 0x77, 0x74, 0x17, 0xe7 ], [ 0x84, 0xec, 0xac, 0xfc, 0xd4, 0x00, 0x08, 0x4d, 0x07, 0x86, 0x12, 0xb1, 0x94, 0x5f, 0x2e, 0xf5 ], [ 0x1d, 0xcd, 0x8b, 0xb1, 0x73, 0x25, 0x9e, 0xb3, 0x3a, 0x52, 0x42, 0xb0, 0xde, 0x31, 0xa4, 0x55 ], [ 0x35, 0xe9, 0xed, 0xdb, 0xc3, 0x75, 0xe7, 0x92, 0xc1, 0x99, 0x92, 0xc1, 0x91, 0x65, 0x01, 0x2b ], [ 0x8a, 0x77, 0x22, 0x31, 0xc0, 0x1d, 0xfd, 0xd7, 0xc9, 0x8e, 0x4c, 0xfd, 0xdc, 0xc0, 0x80, 0x7a ], [ 0x6e, 0xda, 0x7f, 0xf6, 0xb8, 0x31, 0x91, 0x80, 0xff, 0x0d, 0x6e, 0x65, 0x62, 0x9d, 0x01, 0xc3 ], [ 0xc2, 0x67, 0xef, 0x0e, 0x2d, 0x01, 0xa9, 0x93, 0x94, 0x4d, 0xd3, 0x97, 0x10, 0x14, 0x13, 0xcb ], [ 0xe9, 0xf8, 0x0e, 0x9d, 0x84, 0x5b, 0xcc, 0x0f, 0x62, 0x92, 0x6a, 0xf7, 0x2e, 0xab, 0xca, 0x39 ], [ 0x67, 0x02, 0x99, 0x07, 0x27, 0xaa, 0x08, 0x78, 0x63, 0x7b, 0x45, 0xdc, 0xd3, 0xa3, 0xb0, 0x74 ], [ 0x2e, 0x2e, 0x64, 0x7d, 0x53, 0x60, 0xe0, 0x92, 0x30, 0xa5, 0xd7, 0x38, 0xca, 0x33, 0x47, 0x1e ], [ 0x1f, 0x56, 0x41, 0x3c, 0x7a, 0xdd, 0x6f, 0x43, 0xd1, 0xd5, 0x6e, 0x4f, 0x02, 0x19, 0x03, 0x30 ], [ 0x69, 0xcd, 0x06, 0x06, 0xe1, 0x5a, 0xf7, 0x29, 0xd6, 0xbc, 0xa1, 0x43, 0x01, 0x6d, 0x98, 0x42 ], [ 0xa0, 0x85, 0xd7, 0xc1, 0xa5, 0x00, 0x87, 0x3a, 0x20, 0x09, 0x9c, 0x4c, 0xaa, 0x3c, 0x3f, 0x5b ], [ 0x4f, 0xc0, 0xd2, 0x30, 0xf8, 0x89, 0x14, 0x15, 0xb8, 0x7b, 0x83, 0xf9, 0x5f, 0x2e, 0x09, 0xd1 ], [ 0x43, 0x27, 0xd0, 0x8c, 0x52, 0x3d, 0x8e, 0xba, 0x69, 0x7a, 0x43, 0x36, 0x50, 0x7d, 0x1f, 0x42 ], [ 0x7a, 0x15, 0xaa, 0xb8, 0x27, 0x01, 0xef, 0xa5, 0xae, 0x36, 0xab, 0x1d, 0x6b, 0x76, 0x29, 0x0f ], [ 0x5b, 0xf0, 0x05, 0x18, 0x93, 0xa1, 0x8b, 0xb3, 0x0e, 0x13, 0x9a, 0x58, 0xfe, 0xd0, 0xfa, 0x54 ], [ 0x97, 0xe8, 0xad, 0xf6, 0x56, 0x38, 0xfd, 0x9c, 0xdf, 0x3b, 0xc2, 0x2c, 0x17, 0xfe, 0x4d, 0xbd ], [ 0x1e, 0xe6, 0xee, 0x32, 0x65, 0x83, 0xa0, 0x58, 0x64, 0x91, 0xc9, 0x64, 0x18, 0xd1, 0xa3, 0x5d ], [ 0x26, 0xb5, 0x49, 0xc2, 0xec, 0x75, 0x6f, 0x82, 0xec, 0xc4, 0x80, 0x08, 0xe5, 0x29, 0x95, 0x6b ], [ 0x70, 0x37, 0x7b, 0x6d, 0xa6, 0x69, 0xb0, 0x72, 0x12, 0x9e, 0x05, 0x7c, 0xc2, 0x8e, 0x9c, 0xa5 ], [ 0x9c, 0x94, 0xb8, 0xb0, 0xcb, 0x8b, 0xcc, 0x91, 0x90, 0x72, 0x26, 0x2b, 0x3f, 0xa0, 0x5a, 0xd9 ], [ 0x2f, 0xbb, 0x83, 0xdf, 0xd0, 0xd7, 0xab, 0xcb, 0x05, 0xcd, 0x28, 0xca, 0xd2, 0xdf, 0xb5, 0x23 ], [ 0x96, 0x87, 0x78, 0x03, 0xde, 0x77, 0x74, 0x4b, 0xb9, 0x70, 0xd0, 0xa9, 0x1f, 0x4d, 0xeb, 0xae ], [ 0x73, 0x79, 0xf3, 0x37, 0x0c, 0xf6, 0xe5, 0xce, 0x12, 0xae, 0x59, 0x69, 0xc8, 0xee, 0xa3, 0x12 ], [ 0x02, 0xdc, 0x99, 0xfa, 0x3d, 0x4f, 0x98, 0xce, 0x80, 0x98, 0x5e, 0x72, 0x33, 0x88, 0x93, 0x13 ], [ 0x1e, 0x38, 0xe7, 0x59, 0x07, 0x5b, 0xa5, 0xca, 0xb6, 0x45, 0x7d, 0xa5, 0x18, 0x44, 0x29, 0x5a ], [ 0x70, 0xbe, 0xd8, 0xdb, 0xf6, 0x15, 0x86, 0x8a, 0x1f, 0x9d, 0x9b, 0x05, 0xd3, 0xe7, 0xa2, 0x67 ], [ 0x23, 0x4b, 0x14, 0x8b, 0x8c, 0xb1, 0xd8, 0xc3, 0x2b, 0x28, 0x7e, 0x89, 0x69, 0x03, 0xd1, 0x50 ], [ 0x29, 0x4b, 0x03, 0x3d, 0xf4, 0xda, 0x85, 0x3f, 0x4b, 0xe3, 0xe2, 0x43, 0xf7, 0xe5, 0x13, 0xf4 ], [ 0x3f, 0x58, 0xc9, 0x50, 0xf0, 0x36, 0x71, 0x60, 0xad, 0xec, 0x45, 0xf2, 0x44, 0x1e, 0x74, 0x11 ], [ 0x37, 0xf6, 0x55, 0x53, 0x6a, 0x70, 0x4e, 0x5a, 0xce, 0x18, 0x2d, 0x74, 0x2a, 0x82, 0x0c, 0xf4 ], [ 0xea, 0x7b, 0xd6, 0xbb, 0x63, 0x41, 0x87, 0x31, 0xae, 0xac, 0x79, 0x0f, 0xe4, 0x2d, 0x61, 0xe8 ], [ 0xe7, 0x4a, 0x4c, 0x99, 0x9b, 0x4c, 0x06, 0x4e, 0x48, 0xbb, 0x1e, 0x41, 0x3f, 0x51, 0xe5, 0xea ], [ 0xba, 0x9e, 0xbe, 0xfd, 0xb4, 0xcc, 0xf3, 0x0f, 0x29, 0x6c, 0xec, 0xb3, 0xbc, 0x19, 0x43, 0xe8 ], [ 0x31, 0x94, 0x36, 0x7a, 0x48, 0x98, 0xc5, 0x02, 0xc1, 0x3b, 0xb7, 0x47, 0x86, 0x40, 0xa7, 0x2d ], [ 0xda, 0x79, 0x77, 0x13, 0x26, 0x3d, 0x6f, 0x33, 0xa5, 0x47, 0x8a, 0x65, 0xef, 0x60, 0xd4, 0x12 ], [ 0xd1, 0xac, 0x39, 0xbb, 0x1e, 0xf8, 0x6b, 0x9c, 0x13, 0x44, 0xf2, 0x14, 0x67, 0x9a, 0xa3, 0x76 ], [ 0x2f, 0xde, 0xa9, 0xe6, 0x50, 0x53, 0x2b, 0xe5, 0xbc, 0x0e, 0x73, 0x25, 0x33, 0x7f, 0xd3, 0x63 ], [ 0xd3, 0xa2, 0x04, 0xdb, 0xd9, 0xc2, 0xaf, 0x15, 0x8b, 0x6c, 0xa6, 0x7a, 0x51, 0x56, 0xce, 0x4a ], [ 0x3a, 0x0a, 0x0e, 0x75, 0xa8, 0xda, 0x36, 0x73, 0x5a, 0xee, 0x66, 0x84, 0xd9, 0x65, 0xa7, 0x78 ], [ 0x52, 0xfc, 0x3e, 0x62, 0x04, 0x92, 0xea, 0x99, 0x64, 0x1e, 0xa1, 0x68, 0xda, 0x5b, 0x6d, 0x52 ], [ 0xd2, 0xe0, 0xc7, 0xf1, 0x5b, 0x47, 0x72, 0x46, 0x7d, 0x2c, 0xfc, 0x87, 0x30, 0x00, 0xb2, 0xca ], [ 0x56, 0x35, 0x31, 0x13, 0x5e, 0x0c, 0x4d, 0x70, 0xa3, 0x8f, 0x8b, 0xdb, 0x19, 0x0b, 0xa0, 0x4e ], [ 0xa8, 0xa3, 0x9a, 0x0f, 0x56, 0x63, 0xf4, 0xc0, 0xfe, 0x5f, 0x2d, 0x3c, 0xaf, 0xff, 0x42, 0x1a ], [ 0xd9, 0x4b, 0x5e, 0x90, 0xdb, 0x35, 0x4c, 0x1e, 0x42, 0xf6, 0x1f, 0xab, 0xe1, 0x67, 0xb2, 0xc0 ], [ 0x50, 0xe6, 0xd3, 0xc9, 0xb6, 0x69, 0x8a, 0x7c, 0xd2, 0x76, 0xf9, 0x6b, 0x14, 0x73, 0xf3, 0x5a ], [ 0x93, 0x38, 0xf0, 0x8e, 0x0e, 0xbe, 0xe9, 0x69, 0x05, 0xd8, 0xf2, 0xe8, 0x25, 0x20, 0x8f, 0x43 ], [ 0x8b, 0x37, 0x8c, 0x86, 0x67, 0x2a, 0xa5, 0x4a, 0x3a, 0x26, 0x6b, 0xa1, 0x9d, 0x25, 0x80, 0xca ], [ 0xcc, 0xa7, 0xc3, 0x08, 0x6f, 0x5f, 0x95, 0x11, 0xb3, 0x12, 0x33, 0xda, 0x7c, 0xab, 0x91, 0x60 ], [ 0x5b, 0x40, 0xff, 0x4e, 0xc9, 0xbe, 0x53, 0x6b, 0xa2, 0x30, 0x35, 0xfa, 0x4f, 0x06, 0x06, 0x4c ], [ 0x60, 0xeb, 0x5a, 0xf8, 0x41, 0x6b, 0x25, 0x71, 0x49, 0x37, 0x21, 0x94, 0xe8, 0xb8, 0x87, 0x49 ], [ 0x2f, 0x00, 0x5a, 0x8a, 0xed, 0x8a, 0x36, 0x1c, 0x92, 0xe4, 0x40, 0xc1, 0x55, 0x20, 0xcb, 0xd1 ], [ 0x7b, 0x03, 0x62, 0x76, 0x11, 0x67, 0x8a, 0x99, 0x77, 0x17, 0x57, 0x88, 0x07, 0xa8, 0x00, 0xe2 ], [ 0xcf, 0x78, 0x61, 0x8f, 0x74, 0xf6, 0xf3, 0x69, 0x6e, 0x0a, 0x47, 0x79, 0xb9, 0x0b, 0x5a, 0x77 ], [ 0x03, 0x72, 0x03, 0x71, 0xa0, 0x49, 0x62, 0xea, 0xea, 0x0a, 0x85, 0x2e, 0x69, 0x97, 0x28, 0x58 ], [ 0x1f, 0x8a, 0x81, 0x33, 0xaa, 0x8c, 0xcf, 0x70, 0xe2, 0xbd, 0x32, 0x85, 0x83, 0x1c, 0xa6, 0xb7 ], [ 0x27, 0x93, 0x6b, 0xd2, 0x7f, 0xb1, 0x46, 0x8f, 0xc8, 0xb4, 0x8b, 0xc4, 0x83, 0x32, 0x17, 0x25 ], [ 0xb0, 0x7d, 0x4f, 0x3e, 0x2c, 0xd2, 0xef, 0x2e, 0xb5, 0x45, 0x98, 0x07, 0x54, 0xdf, 0xea, 0x0f ], [ 0x4b, 0xf8, 0x5f, 0x1b, 0x5d, 0x54, 0xad, 0xbc, 0x30, 0x7b, 0x0a, 0x04, 0x83, 0x89, 0xad, 0xcb ] ]; # Values from NIST KAT-AES CBCVarTxt128.rsp, CBCVarTxt192.rsp and CBCVarTxt256.rsp plain_texts1 = [ [ 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff ] ] key = [ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ] initialization_vector = [ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ] plain_text = [ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ] print("Testing AES-CBC 128-bit decryption\t"), result = True for test_index in range(0, 128): test_key = bytes(bytearray(key[:16])) test_initialization_vector = bytes(bytearray(initialization_vector)) test_cipher_text = bytes(bytearray(cipher_texts1_128bit[test_index])) test_plain_text = bytes(bytearray(plain_texts1[test_index])) result = pycaes_test_crypt_cbc( pycaes.crypt_modes.DECRYPT, test_key, test_initialization_vector, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False print("Testing AES-CBC 128-bit decryption\t"), result = True for test_index in range(0, 128): test_key = bytes(bytearray(keys[test_index][:16])) test_initialization_vector = bytes(bytearray(initialization_vector)) test_cipher_text = bytes(bytearray(cipher_texts2_128bit[test_index])) test_plain_text = bytes(bytearray(plain_text)) result = pycaes_test_crypt_cbc( pycaes.crypt_modes.DECRYPT, test_key, test_initialization_vector, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False print("Testing AES-CBC 192-bit decryption\t"), result = True for test_index in range(0, 128): test_key = bytes(bytearray(key[:24])) test_initialization_vector = bytes(bytearray(initialization_vector)) test_cipher_text = bytes(bytearray(cipher_texts1_192bit[test_index])) test_plain_text = bytes(bytearray(plain_texts1[test_index])) result = pycaes_test_crypt_cbc( pycaes.crypt_modes.DECRYPT, test_key, test_initialization_vector, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False print("Testing AES-CBC 192-bit decryption\t"), result = True for test_index in range(0, 128): test_key = bytes(bytearray(keys[test_index][:24])) test_initialization_vector = bytes(bytearray(initialization_vector)) test_cipher_text = bytes(bytearray(cipher_texts2_192bit[test_index])) test_plain_text = bytes(bytearray(plain_text)) result = pycaes_test_crypt_cbc( pycaes.crypt_modes.DECRYPT, test_key, test_initialization_vector, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False print("Testing AES-CBC 256-bit decryption\t"), result = True for test_index in range(0, 128): test_key = bytes(bytearray(key)) test_initialization_vector = bytes(bytearray(initialization_vector)) test_cipher_text = bytes(bytearray(cipher_texts1_256bit[test_index])) test_plain_text = bytes(bytearray(plain_texts1[test_index])) result = pycaes_test_crypt_cbc( pycaes.crypt_modes.DECRYPT, test_key, test_initialization_vector, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False print("Testing AES-CBC 256-bit decryption\t"), result = True for test_index in range(0, 128): test_key = bytes(bytearray(keys[test_index])) test_initialization_vector = bytes(bytearray(initialization_vector)) test_cipher_text = bytes(bytearray(cipher_texts2_256bit[test_index])) test_plain_text = bytes(bytearray(plain_text)) result = pycaes_test_crypt_cbc( pycaes.crypt_modes.DECRYPT, test_key, test_initialization_vector, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False return True if __name__ == "__main__": if not main(): sys.exit(1) else: sys.exit(0) libcaes-20240413/tests/test_python_module.sh0000755000175000017500000000731014606476433021657 0ustar00lordyestalordyesta#!/usr/bin/env bash # Tests Python module functions and types. # # Version: 20240413 EXIT_SUCCESS=0; EXIT_FAILURE=1; EXIT_IGNORE=77; TEST_FUNCTIONS="support"; TEST_FUNCTIONS_WITH_INPUT=""; OPTION_SETS=(); TEST_TOOL_DIRECTORY="."; INPUT_GLOB="*"; test_python_function() { local TEST_FUNCTION=$1; local TEST_DESCRIPTION="Testing Python-bindings functions: ${TEST_FUNCTION}"; local TEST_SCRIPT="${TEST_TOOL_DIRECTORY}/pycaes_test_${TEST_FUNCTION}.py"; run_test_with_arguments "${TEST_DESCRIPTION}" "${TEST_SCRIPT}"; local RESULT=$?; return ${RESULT}; } test_python_function_with_input() { local TEST_FUNCTION=$1; local TEST_DESCRIPTION="Testing Python-bindings functions: ${TEST_FUNCTION}"; local TEST_SCRIPT="${TEST_TOOL_DIRECTORY}/pycaes_test_${TEST_FUNCTION}.py"; if ! test -d "input"; then echo "Test input directory not found."; return ${EXIT_IGNORE}; fi local RESULT=`ls input/* | tr ' ' '\n' | wc -l`; if test ${RESULT} -eq ${EXIT_SUCCESS}; then echo "No files or directories found in the test input directory"; return ${EXIT_IGNORE}; fi local TEST_PROFILE_DIRECTORY=$(get_test_profile_directory "input" "pycaes"); local IGNORE_LIST=$(read_ignore_list "${TEST_PROFILE_DIRECTORY}"); RESULT=${EXIT_SUCCESS}; for TEST_SET_INPUT_DIRECTORY in input/*; do if ! test -d "${TEST_SET_INPUT_DIRECTORY}"; then continue; fi if check_for_directory_in_ignore_list "${TEST_SET_INPUT_DIRECTORY}" "${IGNORE_LIST}"; then continue; fi local TEST_SET_DIRECTORY=$(get_test_set_directory "${TEST_PROFILE_DIRECTORY}" "${TEST_SET_INPUT_DIRECTORY}"); if test -f "${TEST_SET_DIRECTORY}/files"; then IFS="" read -a INPUT_FILES <<< $(cat ${TEST_SET_DIRECTORY}/files | sed "s?^?${TEST_SET_INPUT_DIRECTORY}/?"); else IFS="" read -a INPUT_FILES <<< $(ls -1d ${TEST_SET_INPUT_DIRECTORY}/${INPUT_GLOB}); fi for INPUT_FILE in "${INPUT_FILES[@]}"; do local TESTED_WITH_OPTIONS=0; for OPTION_SET in ${OPTION_SETS[@]}; do local TEST_DATA_OPTION_FILE=$(get_test_data_option_file "${TEST_SET_DIRECTORY}" "${INPUT_FILE}" "${OPTION_SET}"); if test -f ${TEST_DATA_OPTION_FILE}; then TESTED_WITH_OPTIONS=1; IFS=" " read -a OPTIONS <<< $(read_test_data_option_file "${TEST_SET_DIRECTORY}" "${INPUT_FILE}" "${OPTION_SET}"); run_test_on_input_file "${TEST_SET_DIRECTORY}" "${TEST_DESCRIPTION}" "default" "${OPTION_SET}" "${TEST_SCRIPT}" "${INPUT_FILE}" "${OPTIONS[@]}"; RESULT=$?; if test ${RESULT} -ne ${EXIT_SUCCESS}; then break; fi fi done if test ${TESTED_WITH_OPTIONS} -eq 0; then run_test_on_input_file "${TEST_SET_DIRECTORY}" "${TEST_DESCRIPTION}" "default" "" "${TEST_SCRIPT}" "${INPUT_FILE}"; RESULT=$?; fi if test ${RESULT} -ne ${EXIT_SUCCESS}; then break; fi done if test ${RESULT} -ne ${EXIT_SUCCESS}; then break; fi done return ${RESULT}; } if test -n "${SKIP_PYTHON_TESTS}"; then exit ${EXIT_IGNORE}; fi TEST_DIRECTORY=`dirname $0`; TEST_RUNNER="${TEST_DIRECTORY}/test_runner.sh"; if ! test -f "${TEST_RUNNER}"; then echo "Missing test runner: ${TEST_RUNNER}"; exit ${EXIT_FAILURE}; fi source ${TEST_RUNNER}; RESULT=${EXIT_IGNORE}; for TEST_FUNCTION in ${TEST_FUNCTIONS}; do test_python_function "${TEST_FUNCTION}"; RESULT=$?; if test ${RESULT} -ne ${EXIT_SUCCESS}; then break; fi done if test ${RESULT} -ne ${EXIT_SUCCESS} && test ${RESULT} -ne ${EXIT_IGNORE}; then exit ${RESULT}; fi for TEST_FUNCTION in ${TEST_FUNCTIONS_WITH_INPUT}; do if test -d "input"; then test_python_function_with_input "${TEST_FUNCTION}"; RESULT=$?; else test_python_function "${TEST_FUNCTION}"; RESULT=$?; fi if test ${RESULT} -ne ${EXIT_SUCCESS}; then break; fi done exit ${RESULT}; libcaes-20240413/tests/caes_test_libcaes.h0000644000175000017500000000171514606473413021176 0ustar00lordyestalordyesta/* * The libcaes header wrapper * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _CAES_TEST_LIBCAES_H ) #define _CAES_TEST_LIBCAES_H #include #include #endif /* !defined( _CAES_TEST_LIBCAES_H ) */ libcaes-20240413/tests/pycaes_test_crypt_xts.py0000644000175000017500000102252714606473413022412 0ustar00lordyestalordyesta#!/usr/bin/env python # # Python-bindings AES-XTS de/encryption testing program # # Copyright (C) 2011-2024, Joachim Metz # # Refer to AUTHORS for acknowledgements. # # This software is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This software 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 Lesser General Public License # along with this software. If not, see . # import sys import pycaes def pycaes_test_crypt_xts( mode, key, tweak_key, tweak_value, input_data, expected_output_data): caes_context = pycaes.tweaked_context() caes_context.set_keys(mode, key, tweak_key) output_data = pycaes.crypt_xts(caes_context, mode, tweak_value, input_data) return output_data == expected_output_data def main(): # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" keys1_128bit = [ [ 0xc4, 0x3c, 0xd0, 0xb2, 0x37, 0x98, 0xee, 0x3d, 0xb0, 0x05, 0x3d, 0x1e, 0x4d, 0x18, 0x5e, 0x96, 0x5d, 0x67, 0xfd, 0xda, 0x8c, 0x53, 0x25, 0xcc, 0x70, 0x9f, 0xc3, 0x97, 0x3f, 0x05, 0xcd, 0x17 ], [ 0x9a, 0x13, 0x1b, 0xcb, 0xde, 0xbf, 0x2b, 0xa2, 0xef, 0xc2, 0x51, 0x32, 0x45, 0x20, 0x34, 0x21, 0x31, 0x56, 0x36, 0xac, 0x24, 0xf5, 0x92, 0xe1, 0xd2, 0xb5, 0x95, 0x40, 0x51, 0x16, 0x50, 0xbe ], [ 0xfd, 0x56, 0x22, 0x25, 0x5e, 0x4b, 0x21, 0xe3, 0xee, 0x6c, 0x4f, 0x1f, 0x35, 0x4a, 0x23, 0x77, 0xa6, 0x8b, 0x07, 0x58, 0xbc, 0x3a, 0xca, 0x3f, 0x32, 0xaa, 0x0f, 0xd8, 0x99, 0xd1, 0x6f, 0x11 ], [ 0x4e, 0x31, 0x35, 0xee, 0x51, 0x67, 0xab, 0x65, 0x8b, 0x46, 0x94, 0xfb, 0xb7, 0xb0, 0x21, 0x79, 0x1d, 0xe4, 0x1e, 0xd6, 0x76, 0xc8, 0xc4, 0x08, 0xc5, 0x1e, 0xcf, 0xfb, 0x19, 0x00, 0xc0, 0x7e ], [ 0x23, 0x9b, 0x56, 0x5a, 0xc7, 0x10, 0xfe, 0x74, 0x2c, 0x43, 0xff, 0x15, 0x6f, 0xf9, 0xfa, 0x73, 0x72, 0xef, 0xde, 0xa3, 0x38, 0x03, 0xbd, 0x8b, 0x88, 0x3f, 0x77, 0x81, 0x49, 0x72, 0x69, 0x20 ], [ 0xda, 0x33, 0x73, 0xe2, 0x5d, 0x76, 0xd1, 0x6b, 0x53, 0xe4, 0xdd, 0xa3, 0x68, 0x66, 0x9c, 0xb0, 0xd9, 0xb8, 0x51, 0x75, 0x0b, 0x96, 0x24, 0xc6, 0x5c, 0xd7, 0xd7, 0x93, 0x3c, 0xf4, 0x62, 0xa8 ], [ 0x1d, 0xbb, 0x08, 0x81, 0x54, 0x2c, 0x6d, 0x67, 0x8e, 0x8a, 0x00, 0x40, 0xc2, 0x20, 0x34, 0x0e, 0xd4, 0x88, 0x4e, 0x1a, 0x81, 0xb2, 0x3f, 0x43, 0xd9, 0x67, 0x3b, 0x4a, 0xc5, 0xe2, 0x95, 0xd6 ], [ 0x60, 0xd2, 0xe7, 0x18, 0x98, 0xb3, 0x41, 0x35, 0x7b, 0x91, 0x50, 0xa5, 0x16, 0x3a, 0x2b, 0xe0, 0x56, 0xf5, 0xda, 0x2c, 0xed, 0xc4, 0xac, 0x70, 0x8e, 0xb4, 0x3d, 0x92, 0xba, 0x40, 0xe0, 0x01 ], [ 0xdc, 0xe7, 0xd0, 0x83, 0xc3, 0xad, 0x40, 0x20, 0x29, 0xf1, 0xed, 0x40, 0x07, 0x4f, 0xf2, 0xf4, 0x2e, 0x9e, 0x14, 0x09, 0x1d, 0x09, 0xdd, 0xb6, 0x80, 0x95, 0xeb, 0x94, 0x5b, 0xf3, 0x43, 0xb7 ], [ 0x8f, 0x8e, 0x47, 0x35, 0x64, 0xfa, 0x63, 0x26, 0x84, 0xd0, 0x40, 0x51, 0xca, 0xc1, 0xf1, 0x29, 0xc1, 0xd6, 0x12, 0x9b, 0x64, 0x70, 0x04, 0x29, 0xb8, 0xb1, 0x0c, 0xf3, 0x00, 0x03, 0x36, 0x38 ], [ 0x49, 0x45, 0xeb, 0xf4, 0xde, 0xd6, 0xf4, 0x97, 0xc9, 0xd7, 0x36, 0x1d, 0x87, 0x17, 0x46, 0x43, 0xf9, 0xcf, 0x59, 0x09, 0x29, 0x4f, 0x6a, 0x23, 0xa8, 0x2a, 0x53, 0xbe, 0xfc, 0x6a, 0x58, 0xc6 ], [ 0xb0, 0x89, 0xbc, 0x48, 0xbf, 0xa1, 0x1c, 0x49, 0x36, 0x87, 0x57, 0xf0, 0x2d, 0x30, 0x95, 0x04, 0xa3, 0x0a, 0xfe, 0xd1, 0x2c, 0xe5, 0xc6, 0x3a, 0x18, 0xa3, 0xe2, 0xeb, 0x3c, 0x04, 0x15, 0x3f ], [ 0xb7, 0x09, 0xf1, 0x8e, 0xef, 0x3d, 0x86, 0xd8, 0x54, 0x70, 0x2f, 0x20, 0x07, 0xf9, 0xdd, 0x13, 0x46, 0x3f, 0xda, 0x8f, 0x07, 0x0f, 0xf0, 0x2e, 0xeb, 0x7e, 0x8f, 0xb5, 0x4e, 0x00, 0x9f, 0xf8 ], [ 0x07, 0xfd, 0xe9, 0x47, 0xd9, 0xd0, 0xc0, 0x7b, 0x81, 0xa8, 0x24, 0xd5, 0x3e, 0x33, 0xe2, 0x52, 0x72, 0x65, 0x53, 0xcd, 0x3e, 0xcd, 0xff, 0xaf, 0x02, 0x34, 0xd1, 0x61, 0x84, 0x3c, 0x11, 0x2b ], [ 0x58, 0xf6, 0xe7, 0x13, 0xc6, 0x70, 0xff, 0xfa, 0x62, 0xb2, 0xe7, 0x46, 0x59, 0x24, 0x0f, 0xa8, 0x4c, 0x44, 0x64, 0x46, 0x14, 0xcb, 0xf7, 0xad, 0x33, 0xa9, 0x91, 0x45, 0x7b, 0x90, 0x41, 0xdd ], [ 0xb2, 0xd4, 0x7e, 0x6b, 0xa0, 0x56, 0xb6, 0x7a, 0xff, 0x50, 0x99, 0x39, 0xd3, 0x02, 0x87, 0xe4, 0x89, 0xa7, 0x1b, 0xbd, 0xa6, 0xc3, 0x1b, 0x63, 0x9f, 0x8d, 0xe5, 0xe2, 0x50, 0x8b, 0x8b, 0xe0 ], [ 0x81, 0xb1, 0x9f, 0x35, 0xf4, 0x5b, 0x4e, 0x45, 0x9d, 0x88, 0xe9, 0x5e, 0x3a, 0x49, 0x64, 0x2c, 0x51, 0x27, 0x09, 0x8c, 0xcb, 0xa6, 0xa5, 0x0e, 0xf4, 0xb2, 0xf8, 0x75, 0xed, 0x20, 0xb9, 0xe5 ], [ 0x68, 0xcb, 0xd5, 0xe7, 0xe9, 0xec, 0xfc, 0x60, 0x31, 0xa2, 0xc6, 0x3a, 0xd1, 0xf9, 0x5d, 0xc8, 0xba, 0x5f, 0xaa, 0x3d, 0x3b, 0x7f, 0xba, 0x1b, 0x1e, 0xf2, 0x17, 0x6f, 0x82, 0x65, 0xfb, 0xdb ], [ 0x3b, 0xd5, 0x7d, 0x47, 0xe1, 0x3e, 0xa3, 0x9f, 0x1c, 0xf5, 0xf3, 0x3c, 0x8b, 0xa0, 0x29, 0xfb, 0x20, 0xf0, 0xd3, 0x38, 0x63, 0x90, 0x16, 0xf9, 0x86, 0xb7, 0x79, 0x78, 0x53, 0x37, 0x01, 0xfe ], [ 0xab, 0x46, 0xc3, 0x06, 0xa2, 0x50, 0x3f, 0xcc, 0x94, 0x80, 0xad, 0x96, 0x01, 0x87, 0x91, 0x67, 0x49, 0x70, 0x93, 0x7f, 0x73, 0xac, 0xa9, 0x0a, 0x5f, 0xd0, 0x5d, 0x84, 0x20, 0xe7, 0xbd, 0xc2 ], [ 0x1b, 0x09, 0x12, 0x1d, 0x93, 0x45, 0x82, 0x79, 0x01, 0x3d, 0xf1, 0x2b, 0x26, 0xe7, 0xb2, 0xa1, 0x5c, 0x28, 0xc4, 0x4f, 0x93, 0xf9, 0x7e, 0xa6, 0x38, 0xb0, 0x56, 0x17, 0x7d, 0xea, 0xfa, 0xb0 ], [ 0xd0, 0x23, 0x80, 0xe8, 0x4e, 0x40, 0xf6, 0x89, 0x15, 0xed, 0x27, 0x6c, 0x2e, 0xfa, 0x48, 0x2c, 0x90, 0xb0, 0x98, 0x46, 0x70, 0x27, 0xfc, 0x3f, 0x0a, 0x16, 0xe8, 0xa3, 0x27, 0xb5, 0x23, 0xc9 ], [ 0x22, 0x4d, 0xec, 0xbf, 0x90, 0x01, 0x4e, 0x6f, 0xc9, 0xbc, 0xe6, 0x83, 0x07, 0x2c, 0x9a, 0xce, 0x10, 0x89, 0x33, 0xb9, 0x2e, 0xba, 0xc4, 0x9b, 0xce, 0xea, 0x98, 0x26, 0x17, 0x16, 0xc4, 0xae ], [ 0x67, 0x5f, 0xf2, 0x63, 0x7f, 0xcc, 0xd2, 0x28, 0x90, 0x65, 0xa6, 0x42, 0xdc, 0xfc, 0x54, 0x8d, 0xb7, 0x58, 0x2a, 0x04, 0x0d, 0x3a, 0xb7, 0x09, 0xd5, 0x2b, 0x03, 0x51, 0x2d, 0x5e, 0x6a, 0x08 ], [ 0xbd, 0x0e, 0x95, 0x72, 0x29, 0x8b, 0x6a, 0xf2, 0x0d, 0xdc, 0x07, 0x92, 0xef, 0xa2, 0xa6, 0xc5, 0x0c, 0xb3, 0xe0, 0x8f, 0x75, 0xb5, 0x55, 0x0e, 0x60, 0x73, 0x18, 0xac, 0x18, 0x08, 0xbb, 0x93 ], [ 0x62, 0x78, 0x42, 0xbf, 0xaa, 0xb7, 0xd8, 0xe6, 0xe7, 0x26, 0x81, 0xac, 0x4e, 0x5b, 0xf9, 0x91, 0x5f, 0x82, 0xe8, 0x56, 0x1b, 0x04, 0x0c, 0xca, 0xab, 0xec, 0x9e, 0x70, 0x34, 0x3a, 0x94, 0xe5 ], [ 0x1f, 0x0a, 0xb8, 0xd1, 0xe1, 0x53, 0x65, 0xe3, 0x92, 0x2e, 0xc9, 0x14, 0xe9, 0xad, 0x68, 0x09, 0x7f, 0x39, 0x07, 0xb3, 0x81, 0x2b, 0x90, 0x05, 0x2d, 0x7c, 0x6a, 0x6d, 0xaf, 0x43, 0x9c, 0x61 ], [ 0xe1, 0x97, 0x71, 0x29, 0xe2, 0x9c, 0x76, 0x17, 0x5e, 0x7f, 0xd1, 0x70, 0x71, 0x0f, 0xaf, 0x9f, 0x60, 0xc8, 0xb0, 0x2d, 0x03, 0xb4, 0x0c, 0xe6, 0x8b, 0x0c, 0xae, 0xe8, 0x72, 0x37, 0x7d, 0xe4 ], [ 0xfc, 0xcb, 0x6e, 0x7b, 0x4c, 0x91, 0x2d, 0x41, 0x7d, 0x30, 0x34, 0x7b, 0xae, 0x86, 0xe5, 0x54, 0xec, 0xb2, 0xd0, 0x50, 0x57, 0xb2, 0x7c, 0xc4, 0xf3, 0x82, 0x45, 0x56, 0x7c, 0xd8, 0xaf, 0x9e ], [ 0x1d, 0xc9, 0x48, 0xc4, 0x8d, 0xfe, 0x02, 0x7a, 0x62, 0xbe, 0x79, 0xf1, 0x0b, 0x4b, 0xe2, 0x13, 0xd6, 0x2b, 0xdc, 0x5b, 0x78, 0x45, 0x59, 0x35, 0x6c, 0x9b, 0xc9, 0xc6, 0x59, 0x73, 0xf7, 0xf4 ], [ 0x6c, 0x3b, 0x93, 0x4f, 0x37, 0x78, 0xde, 0xd2, 0x8c, 0x4a, 0x5b, 0xa1, 0xd2, 0x18, 0x56, 0x21, 0xf5, 0xe9, 0x46, 0xc1, 0x09, 0x96, 0x29, 0x59, 0xdc, 0x0b, 0x8f, 0x7a, 0xb4, 0x01, 0x94, 0x4b ], [ 0x51, 0x69, 0x68, 0x79, 0xee, 0x8b, 0x77, 0xf3, 0x72, 0x4c, 0x62, 0x89, 0xf3, 0xa2, 0x73, 0xa3, 0x46, 0xd9, 0xd0, 0x38, 0x07, 0xdc, 0x0b, 0x82, 0x67, 0x0f, 0x3c, 0x2b, 0x37, 0x8a, 0x79, 0x35 ], [ 0x4d, 0x2b, 0x83, 0x55, 0x1a, 0xc5, 0xcb, 0x8c, 0x4b, 0xb4, 0x34, 0x57, 0x7d, 0x36, 0x4d, 0xac, 0x70, 0x3f, 0x7f, 0xe7, 0x5f, 0x74, 0xc7, 0x9f, 0xbf, 0x1a, 0x79, 0x63, 0x71, 0x1f, 0xdd, 0x53 ], [ 0x35, 0xd7, 0xa7, 0x74, 0x84, 0x82, 0x59, 0x76, 0x0d, 0x32, 0xf4, 0x6c, 0x7a, 0x01, 0x3d, 0x79, 0x1b, 0xab, 0xd3, 0xb8, 0x98, 0x31, 0x6d, 0xfb, 0x00, 0xc6, 0x68, 0xc5, 0x52, 0x8b, 0xc3, 0xf3 ], [ 0xe5, 0xd6, 0x08, 0xc5, 0xcb, 0x8c, 0x2c, 0x3d, 0x72, 0x6b, 0xb4, 0xf4, 0xa8, 0x02, 0x38, 0x31, 0xb9, 0x33, 0x5d, 0x00, 0x5c, 0xc2, 0xdf, 0x3b, 0xd7, 0x0d, 0x9f, 0x7e, 0x71, 0x25, 0x0c, 0x6a ], [ 0x0a, 0x18, 0x0b, 0xd9, 0x0b, 0xa2, 0x06, 0xa7, 0xbf, 0x2c, 0xc8, 0x2a, 0x2f, 0x5f, 0xdd, 0xf9, 0x22, 0x40, 0xe0, 0x87, 0x11, 0xba, 0x02, 0xa4, 0x92, 0x5f, 0x90, 0xa0, 0x90, 0xb9, 0xca, 0x68 ], [ 0xa8, 0x87, 0xa0, 0x96, 0x99, 0xa2, 0x68, 0x5d, 0xbe, 0xf3, 0x06, 0xd0, 0x90, 0x15, 0xf8, 0x38, 0x97, 0xa7, 0xf5, 0x99, 0xbd, 0xcb, 0x3b, 0x7f, 0x64, 0xe3, 0x46, 0x45, 0xcb, 0x6f, 0xaf, 0xcf ], [ 0xef, 0xe9, 0x34, 0xcb, 0x1a, 0x60, 0xb2, 0x92, 0x8b, 0xf4, 0xdc, 0xa8, 0x43, 0x64, 0x95, 0x8d, 0x6a, 0x2b, 0x5b, 0x69, 0x86, 0xdb, 0x3e, 0x63, 0x16, 0x2a, 0x65, 0xd3, 0x77, 0xbe, 0xca, 0xcc ], [ 0x43, 0x22, 0x8d, 0xdf, 0x51, 0x8e, 0xa7, 0x67, 0x5d, 0x9c, 0xa6, 0x39, 0x4f, 0x3e, 0x89, 0x44, 0x42, 0x2f, 0xa3, 0x44, 0x9e, 0x8f, 0xa8, 0x04, 0xfb, 0x42, 0x22, 0x8f, 0x55, 0xb9, 0x7b, 0xc2 ], [ 0xb1, 0x3e, 0x6a, 0xf1, 0xd5, 0x9e, 0x3d, 0x82, 0x84, 0x27, 0x03, 0xd1, 0x03, 0xc1, 0x03, 0x8d, 0x3d, 0x05, 0x2a, 0xee, 0x03, 0x47, 0xa9, 0x71, 0x67, 0xb8, 0x78, 0x6a, 0xaa, 0xf0, 0xb8, 0xfe ], [ 0xd4, 0xda, 0xc4, 0xb8, 0x8c, 0x97, 0x8d, 0x82, 0xf0, 0xd8, 0xd0, 0xd8, 0xb4, 0x4f, 0x69, 0xc9, 0x1e, 0xee, 0x87, 0x35, 0xf1, 0x2f, 0x0a, 0xb5, 0xa9, 0x74, 0x58, 0xab, 0x72, 0xe4, 0x62, 0x68 ], [ 0x2b, 0xfa, 0xfb, 0x74, 0xd1, 0x92, 0xd5, 0x06, 0xa5, 0x0c, 0xf8, 0xce, 0x28, 0xb7, 0x9c, 0x15, 0x5a, 0x35, 0x59, 0x0b, 0x92, 0x5d, 0x79, 0x51, 0x02, 0xb7, 0xa1, 0x85, 0x08, 0x0e, 0x0a, 0x3f ], [ 0x3f, 0xe0, 0x24, 0xe9, 0xb4, 0x6c, 0x0a, 0x72, 0x62, 0xce, 0x04, 0x31, 0xe8, 0x11, 0x42, 0x44, 0x3a, 0x4e, 0xb0, 0x1f, 0xb8, 0x2d, 0x30, 0x1e, 0x9b, 0x8b, 0x5f, 0x7e, 0xbf, 0xe2, 0xcf, 0x4c ], [ 0x89, 0x0d, 0x5c, 0xbb, 0x10, 0xd8, 0xc7, 0xf6, 0x5e, 0x7a, 0x95, 0x81, 0xc2, 0xc0, 0xa4, 0x59, 0xa8, 0x4e, 0x2e, 0x80, 0xee, 0x90, 0xd4, 0x64, 0x99, 0x58, 0x1c, 0x5b, 0x8a, 0xb2, 0x74, 0x6c ], [ 0x9a, 0x41, 0x78, 0x4e, 0x49, 0x53, 0x1d, 0xc4, 0x75, 0xb7, 0x6d, 0x96, 0x9a, 0x42, 0x96, 0x51, 0x0f, 0x88, 0xaf, 0x19, 0x25, 0xc8, 0x32, 0x3c, 0x38, 0xf6, 0xe8, 0xe1, 0x1a, 0x9b, 0x0a, 0x33 ], [ 0x98, 0x85, 0xc0, 0x35, 0xf7, 0x14, 0x56, 0x32, 0x75, 0x9b, 0x5d, 0xf6, 0xc1, 0x1f, 0xab, 0x9a, 0x2b, 0x8d, 0xa8, 0x5a, 0x8e, 0xfa, 0x7a, 0x9b, 0xc9, 0x12, 0x1a, 0x59, 0xe4, 0x54, 0xda, 0x94 ], [ 0x25, 0x94, 0xe2, 0xd7, 0x25, 0x5a, 0x6c, 0x99, 0xae, 0x3b, 0xe1, 0x20, 0xf7, 0xcc, 0x6c, 0xa1, 0x83, 0x5b, 0x56, 0x43, 0xfc, 0x28, 0xc1, 0x24, 0x5e, 0x2d, 0x88, 0x13, 0x73, 0x08, 0xe9, 0xac ], [ 0x48, 0xe4, 0xa7, 0x71, 0x86, 0xbd, 0xf2, 0x95, 0xbf, 0x1c, 0xaf, 0x07, 0x65, 0x95, 0xb3, 0x49, 0x7a, 0x6d, 0x6d, 0x6d, 0x91, 0x82, 0x04, 0x52, 0xce, 0xfd, 0xfa, 0x2d, 0x22, 0x1a, 0xf5, 0xaa ], [ 0xe6, 0xc1, 0x5e, 0x17, 0x79, 0x3d, 0xe5, 0x4e, 0xdc, 0x96, 0xec, 0x29, 0x42, 0xc2, 0x69, 0x34, 0x27, 0x80, 0x09, 0x2b, 0x70, 0x97, 0x7b, 0xf5, 0x25, 0x61, 0x6d, 0x80, 0xe6, 0xad, 0xa3, 0x6b ], [ 0x23, 0xf9, 0x8e, 0x3a, 0xac, 0xb0, 0xc5, 0x9f, 0x85, 0x32, 0xdc, 0x09, 0xb4, 0xcd, 0xa9, 0xbc, 0x69, 0x25, 0x48, 0x1a, 0x14, 0x0c, 0x98, 0xbe, 0x78, 0xab, 0x34, 0x24, 0x2d, 0xd6, 0x7b, 0xfe ], [ 0xa0, 0x68, 0xe2, 0x24, 0x5d, 0xed, 0xdb, 0x8f, 0x42, 0x2d, 0x1a, 0xbe, 0x3f, 0x34, 0x7a, 0x7e, 0xe4, 0x55, 0x63, 0xce, 0x97, 0x84, 0xfd, 0xb5, 0xda, 0x64, 0x52, 0xd4, 0x18, 0x59, 0x6c, 0x18 ], [ 0xd6, 0xcd, 0x85, 0x83, 0x64, 0xf4, 0x72, 0x39, 0x57, 0x26, 0xf5, 0x59, 0x96, 0x11, 0x47, 0x55, 0xf3, 0xfc, 0xa7, 0x39, 0x20, 0x15, 0xba, 0xc5, 0x8f, 0x0e, 0x60, 0x65, 0xda, 0x32, 0xeb, 0x94 ], [ 0x94, 0x6b, 0x38, 0x8e, 0xfb, 0xf5, 0x94, 0x68, 0x02, 0xb0, 0xc5, 0x57, 0x20, 0x91, 0x0a, 0x2a, 0x71, 0xf7, 0x50, 0x85, 0xa5, 0x65, 0x47, 0x2f, 0x2f, 0xca, 0x09, 0x1e, 0xec, 0x6c, 0x4e, 0x9c ], [ 0x2e, 0xd1, 0x16, 0x61, 0x24, 0x99, 0x1c, 0xe6, 0xd3, 0xc0, 0x92, 0x1a, 0x25, 0xf5, 0x0a, 0x4c, 0x99, 0x00, 0x8c, 0x26, 0x98, 0xe8, 0x01, 0x28, 0x68, 0xdb, 0x6a, 0x30, 0x71, 0xe1, 0x53, 0xc7 ], [ 0x64, 0xec, 0x33, 0xf6, 0xf5, 0x81, 0x14, 0x31, 0x8c, 0xf8, 0x8f, 0x2c, 0x86, 0xf6, 0x9e, 0xa5, 0xa7, 0x85, 0x94, 0xf9, 0x54, 0x75, 0x88, 0x44, 0x04, 0xad, 0xd2, 0x61, 0x07, 0x40, 0xcf, 0x49 ], [ 0xba, 0x0f, 0x08, 0x8a, 0x69, 0x7a, 0xd3, 0x78, 0x29, 0xe2, 0x0c, 0xdc, 0xd5, 0x35, 0xca, 0x3a, 0x17, 0x80, 0xa1, 0x20, 0xd0, 0x7a, 0xd8, 0x8c, 0x7a, 0x23, 0x69, 0xec, 0xe3, 0x7d, 0x42, 0x51 ], [ 0x02, 0x66, 0x9a, 0x84, 0x4e, 0x5d, 0x4f, 0xdd, 0x66, 0x28, 0x7c, 0xd8, 0xb2, 0xe1, 0x16, 0xa3, 0xeb, 0x47, 0xf3, 0x39, 0x1a, 0x1c, 0xaf, 0x3a, 0x58, 0xfd, 0xbf, 0xab, 0xbe, 0x34, 0x70, 0x8d ], [ 0x31, 0xff, 0x2c, 0x6e, 0x5c, 0xc7, 0xda, 0xb6, 0x6e, 0xe7, 0x81, 0x1c, 0xcf, 0xb3, 0x6d, 0x95, 0x46, 0xd8, 0x1a, 0xc0, 0xb8, 0x57, 0x55, 0x0c, 0xf9, 0x38, 0xb9, 0x45, 0xda, 0x72, 0xa4, 0xe5 ], [ 0x36, 0x7d, 0xd3, 0x17, 0xca, 0x33, 0xaf, 0x76, 0x88, 0x0b, 0x3a, 0x1c, 0x01, 0x94, 0x58, 0x2f, 0xb7, 0x52, 0xc9, 0xdc, 0x4d, 0x5e, 0xdf, 0x98, 0x3e, 0x6a, 0x67, 0xe7, 0xd7, 0x90, 0x28, 0x1e ], [ 0xfd, 0x00, 0xd6, 0x28, 0xc1, 0x12, 0x19, 0x1d, 0xba, 0x79, 0x29, 0x78, 0x0c, 0xfb, 0x5b, 0xe8, 0xdf, 0x9e, 0x0a, 0x99, 0x83, 0x0f, 0x02, 0x82, 0x18, 0x10, 0x8a, 0x58, 0x00, 0xc1, 0x49, 0xbb ], [ 0x02, 0x57, 0x9c, 0x69, 0x1f, 0x09, 0x88, 0x02, 0xd5, 0x94, 0x71, 0x25, 0x23, 0x89, 0x78, 0x9a, 0xc0, 0x49, 0xfc, 0xe8, 0x58, 0x83, 0x9d, 0xeb, 0x68, 0x5f, 0x15, 0xfc, 0x21, 0xe8, 0x2f, 0xa8 ], [ 0x96, 0x85, 0x97, 0xe8, 0x0a, 0x2e, 0x16, 0x2e, 0x4d, 0x43, 0xe6, 0x76, 0xaa, 0xcc, 0x4b, 0xf7, 0x07, 0x57, 0xa3, 0x35, 0xc0, 0x4c, 0xba, 0x26, 0xfd, 0x0f, 0xfb, 0x5f, 0xf0, 0xdb, 0x01, 0x49 ], [ 0xa2, 0xa8, 0xba, 0x81, 0x5d, 0x0b, 0x4c, 0x04, 0xdc, 0x74, 0x20, 0x4e, 0x8a, 0x5a, 0x4b, 0x45, 0x9a, 0x11, 0xc1, 0x1a, 0x2e, 0x3b, 0x59, 0xc0, 0xa6, 0x0e, 0x7b, 0x5a, 0xa5, 0xed, 0x63, 0x16 ], [ 0x08, 0xd8, 0x6e, 0x27, 0xb9, 0x02, 0xaa, 0x49, 0x1a, 0x22, 0xa0, 0xd8, 0xd5, 0x41, 0x04, 0xbf, 0xa2, 0x9b, 0xf4, 0xaf, 0xf2, 0x32, 0x28, 0x59, 0x0b, 0xcb, 0xca, 0x10, 0xaf, 0x64, 0xe5, 0x21 ], [ 0x2e, 0x13, 0x80, 0x7f, 0xf0, 0x45, 0x01, 0xd8, 0x99, 0xe9, 0xd1, 0x95, 0x24, 0x4c, 0x1a, 0x8e, 0xd4, 0xaa, 0x80, 0x22, 0xb9, 0xd6, 0x99, 0x94, 0xc6, 0x5a, 0x65, 0x69, 0xbb, 0x63, 0xff, 0x3f ], [ 0x7a, 0xa1, 0xe6, 0xc2, 0x0f, 0xdd, 0x27, 0x55, 0xe5, 0x0f, 0x55, 0x37, 0x51, 0x5f, 0xa7, 0x49, 0xd0, 0x3a, 0x14, 0xc4, 0x1a, 0xc8, 0x45, 0xd7, 0x2e, 0x59, 0xe1, 0x66, 0xe0, 0x6d, 0x7e, 0x82 ], [ 0xa6, 0xca, 0xad, 0xe6, 0x62, 0xb7, 0x0b, 0xd1, 0x79, 0xd2, 0x95, 0xef, 0xa4, 0xcc, 0x29, 0xc7, 0x5b, 0x24, 0x05, 0x33, 0xc7, 0x7b, 0x1b, 0x54, 0x5c, 0x02, 0x47, 0x7a, 0x16, 0x04, 0x19, 0x15 ], [ 0xb4, 0xc0, 0xae, 0x25, 0xfe, 0x1b, 0xb2, 0x22, 0x81, 0xa2, 0x7f, 0x93, 0x55, 0xc7, 0x91, 0x70, 0x1a, 0xb7, 0x08, 0x64, 0x87, 0xd2, 0x97, 0x1f, 0xbc, 0x00, 0x8a, 0x71, 0xef, 0x49, 0x8c, 0x42 ], [ 0xe9, 0x6f, 0x4f, 0xd8, 0x5c, 0x51, 0x27, 0x64, 0x91, 0x2e, 0x2a, 0x2a, 0xf4, 0xa2, 0xac, 0x23, 0x34, 0x25, 0x9b, 0x79, 0xc8, 0x97, 0x1c, 0x68, 0xf2, 0x8c, 0x4e, 0x6c, 0x4c, 0xdc, 0x8d, 0xfb ], [ 0x2a, 0x5c, 0xa9, 0x93, 0x90, 0x0f, 0x10, 0x8d, 0x83, 0xfe, 0xc3, 0xbc, 0x6a, 0xb4, 0xe7, 0x4f, 0xd5, 0xbc, 0x2a, 0xd9, 0x81, 0x2c, 0x31, 0x15, 0x4b, 0x80, 0xf4, 0x8b, 0x2c, 0x43, 0x72, 0x29 ], [ 0x5b, 0x3e, 0xd2, 0x66, 0xe3, 0x51, 0x31, 0x67, 0x8b, 0x5f, 0xc1, 0xb4, 0xf3, 0x59, 0xbb, 0xa0, 0x1f, 0x15, 0x39, 0xd1, 0x88, 0xb6, 0x63, 0x1e, 0xa6, 0xa7, 0x4d, 0xc8, 0xb5, 0x89, 0x5e, 0x12 ], [ 0x08, 0xfd, 0x05, 0x09, 0xef, 0xb8, 0xd9, 0x17, 0x1e, 0xa3, 0xad, 0x3e, 0xc9, 0xbb, 0xbe, 0xdd, 0x9d, 0xbe, 0xdd, 0xe9, 0x71, 0xcc, 0x75, 0x7a, 0xee, 0x34, 0x9c, 0x9d, 0xb1, 0x81, 0xd5, 0x69 ], [ 0x10, 0x01, 0x57, 0x1a, 0x70, 0xf8, 0xd7, 0xb3, 0x41, 0x48, 0xc1, 0x40, 0x23, 0xe5, 0xf3, 0x07, 0x31, 0xc6, 0x90, 0x3b, 0xd8, 0x7d, 0xe3, 0xac, 0xf5, 0x5a, 0x00, 0x17, 0x52, 0x91, 0xfa, 0xac ], [ 0xeb, 0x52, 0x16, 0x33, 0x26, 0xd2, 0x5b, 0x59, 0x77, 0x28, 0x60, 0x06, 0x5c, 0xc6, 0x8f, 0x0f, 0x5c, 0x05, 0xf5, 0x8a, 0x41, 0xe7, 0x60, 0x8d, 0x92, 0x48, 0xb9, 0x86, 0x5b, 0xcc, 0x6a, 0x54 ], [ 0x45, 0xda, 0x2e, 0xac, 0xe7, 0xd9, 0xb1, 0x5e, 0xfb, 0xed, 0xac, 0x13, 0x73, 0xf4, 0x12, 0x0e, 0xeb, 0x1b, 0x36, 0x1f, 0x2a, 0x5c, 0xf8, 0xf8, 0x28, 0xf0, 0xbe, 0x86, 0xf9, 0x42, 0x17, 0xcc ], [ 0xec, 0x79, 0xdf, 0x9e, 0xb4, 0xb6, 0xae, 0xb8, 0x01, 0x6d, 0x4f, 0x31, 0x6b, 0xe7, 0xfc, 0x6d, 0xb4, 0x2c, 0x22, 0x95, 0x5f, 0x6e, 0x43, 0x27, 0x44, 0xa4, 0x8a, 0x1f, 0x18, 0x16, 0x39, 0x20 ], [ 0x63, 0x2f, 0x8e, 0xab, 0x45, 0xcd, 0x9b, 0x6f, 0x6a, 0x24, 0xb4, 0x67, 0xac, 0x80, 0x4f, 0x4e, 0xc7, 0xdc, 0x65, 0x67, 0x72, 0x5d, 0xf0, 0x2e, 0x40, 0x52, 0x50, 0xf1, 0xda, 0x07, 0x87, 0x95 ], [ 0xdb, 0x6a, 0x32, 0xd2, 0xa0, 0x26, 0x2d, 0x61, 0x52, 0x51, 0xd0, 0xaa, 0x9d, 0x6a, 0x36, 0xd1, 0x54, 0xe9, 0x6d, 0x86, 0x6c, 0x0b, 0xae, 0x2b, 0x2a, 0xbf, 0x89, 0x10, 0xa3, 0x31, 0xd4, 0x9e ], [ 0xc6, 0xad, 0x2c, 0xca, 0x0d, 0x5d, 0xa1, 0x91, 0x80, 0xd1, 0x77, 0xd8, 0x1c, 0x50, 0x2d, 0xa9, 0x4e, 0x3b, 0x9e, 0x89, 0xa5, 0x17, 0x76, 0x8d, 0x8e, 0x1c, 0x5c, 0xcd, 0x8a, 0x39, 0x6f, 0xaa ], [ 0x92, 0x68, 0x83, 0x00, 0xd4, 0x00, 0x1d, 0xa8, 0xaa, 0x8b, 0xc6, 0xfa, 0xbc, 0x63, 0x7a, 0x96, 0x31, 0x5e, 0xe4, 0xec, 0x18, 0xdc, 0xab, 0x01, 0x0c, 0x44, 0xaf, 0x72, 0x12, 0x3a, 0x7e, 0x01 ], [ 0x1a, 0x01, 0xa9, 0x6c, 0x83, 0x2f, 0x38, 0xb1, 0xa0, 0x44, 0x7d, 0x82, 0xc9, 0xbe, 0xc7, 0x60, 0xcc, 0x34, 0x01, 0xf0, 0x15, 0x9c, 0xc0, 0xf6, 0xd4, 0xb6, 0x70, 0x3e, 0xaa, 0x16, 0xf0, 0x7c ], [ 0x47, 0x29, 0xc7, 0xb7, 0xe7, 0xc6, 0x14, 0x56, 0x01, 0x86, 0xfd, 0xd7, 0xba, 0xdb, 0x0a, 0x9a, 0x1f, 0x9a, 0x96, 0x38, 0x93, 0xba, 0x19, 0x1e, 0xf4, 0xac, 0xf5, 0xfe, 0x33, 0xad, 0xf8, 0xaa ], [ 0x4d, 0xda, 0x94, 0x1e, 0x40, 0x08, 0xf5, 0x99, 0x9e, 0x5e, 0x0b, 0x63, 0x99, 0x23, 0x7b, 0xaa, 0xf3, 0x71, 0xb4, 0xf3, 0xfa, 0x97, 0x73, 0x7e, 0x71, 0x4f, 0x46, 0x07, 0x21, 0x82, 0x5d, 0xdc ], [ 0x63, 0xdc, 0xc1, 0x07, 0x5b, 0x20, 0x31, 0x73, 0x00, 0x17, 0xc6, 0x8a, 0x41, 0x28, 0x74, 0xdd, 0x1e, 0x26, 0x59, 0x7b, 0x23, 0xc1, 0xd0, 0x2f, 0x1a, 0x9f, 0x24, 0xbe, 0x3b, 0xa0, 0x21, 0xa4 ], [ 0x10, 0x14, 0xb5, 0xd1, 0xec, 0x8a, 0x23, 0x5b, 0x85, 0x2f, 0x38, 0x66, 0x8a, 0x0a, 0x36, 0x79, 0xbc, 0x68, 0xd2, 0x19, 0xb8, 0x2d, 0x95, 0xea, 0x68, 0xfe, 0x06, 0x50, 0x04, 0x85, 0x1a, 0x77 ], [ 0xea, 0x8b, 0x81, 0x47, 0x56, 0x23, 0x39, 0xe9, 0x00, 0xb0, 0x41, 0x3e, 0x58, 0xd7, 0x58, 0x9e, 0x60, 0xac, 0xb5, 0xa5, 0xa5, 0xd3, 0x12, 0x42, 0xed, 0x01, 0x37, 0x62, 0xb0, 0xc6, 0x87, 0x20 ], [ 0xc9, 0x3d, 0x58, 0x70, 0xfd, 0x5f, 0xc6, 0x06, 0xf9, 0x01, 0xbc, 0x71, 0x55, 0x6c, 0x6e, 0x04, 0xfc, 0x05, 0xd6, 0xa1, 0xbe, 0x0c, 0x78, 0x32, 0x05, 0x74, 0xf4, 0xdf, 0xcb, 0x69, 0x95, 0xa4 ], [ 0x3c, 0x35, 0x59, 0x45, 0xb6, 0x83, 0x49, 0x1d, 0x70, 0xc4, 0x87, 0x12, 0x58, 0x64, 0xe6, 0xb5, 0xd2, 0x94, 0x1b, 0xce, 0xfe, 0xf9, 0xca, 0x11, 0x72, 0xf0, 0x5f, 0xd5, 0xb5, 0xd5, 0x6a, 0x31 ], [ 0xf4, 0x22, 0x91, 0x8b, 0x58, 0x3e, 0xbe, 0x25, 0xae, 0x90, 0x62, 0x62, 0xf8, 0x82, 0x26, 0x6b, 0x8d, 0x5c, 0x68, 0x56, 0xec, 0xff, 0x6d, 0x07, 0x0b, 0xed, 0xf2, 0x18, 0x4b, 0x1c, 0xdb, 0xec ], [ 0x02, 0x58, 0x29, 0xbe, 0x53, 0x4d, 0x9b, 0xd3, 0xb8, 0x36, 0x7d, 0x8b, 0x73, 0x2a, 0x11, 0x11, 0x4b, 0xcb, 0xb0, 0x94, 0x1f, 0x6c, 0xe2, 0x77, 0x13, 0x70, 0xaf, 0x65, 0x4d, 0xed, 0x40, 0xa5 ], [ 0x12, 0x2e, 0x55, 0x0c, 0xe6, 0x02, 0xc9, 0x43, 0x95, 0x1b, 0x4f, 0xc2, 0xea, 0x26, 0x34, 0x17, 0x46, 0x5c, 0x53, 0x90, 0xf0, 0xf9, 0x31, 0x6b, 0x1b, 0x12, 0xff, 0x40, 0x6e, 0xd2, 0x50, 0x75 ], [ 0xfc, 0x58, 0xa8, 0xdf, 0x74, 0xba, 0x83, 0x17, 0xcf, 0xe3, 0x43, 0x22, 0xe8, 0x83, 0x66, 0x4d, 0xf7, 0x66, 0x3f, 0x7f, 0x5a, 0x1a, 0x13, 0x3e, 0x37, 0x5d, 0x41, 0x90, 0x20, 0x0c, 0x48, 0xac ], [ 0x40, 0xf2, 0x58, 0x58, 0x6e, 0xfe, 0xf9, 0xcb, 0x9d, 0xfb, 0xf7, 0x6b, 0x4e, 0x6e, 0xaf, 0xf6, 0x1e, 0x30, 0x32, 0xe8, 0x43, 0x19, 0xcc, 0x97, 0x8e, 0x0d, 0xbf, 0x3c, 0xcd, 0x62, 0xaf, 0xc9 ], [ 0x6e, 0xb9, 0xd0, 0x05, 0x90, 0x99, 0x0a, 0xec, 0x1a, 0xec, 0x6e, 0x19, 0xab, 0x66, 0xec, 0xf3, 0xde, 0x19, 0xeb, 0x4a, 0x32, 0xf7, 0x0d, 0xa4, 0x78, 0xce, 0x4e, 0xd7, 0x44, 0x07, 0xd0, 0xab ], [ 0xd0, 0x1a, 0xb2, 0x51, 0xb0, 0xa7, 0x54, 0x54, 0xde, 0x30, 0x47, 0xce, 0xe9, 0xa4, 0x65, 0x85, 0x0b, 0x57, 0x35, 0x20, 0x4d, 0x7c, 0xef, 0xe0, 0x89, 0x06, 0x94, 0x67, 0x0c, 0xeb, 0x1c, 0xd4 ], [ 0x6a, 0x1a, 0xb8, 0x33, 0x68, 0x78, 0x02, 0x2a, 0xe3, 0x25, 0xdf, 0x5c, 0x64, 0xfd, 0x10, 0xed, 0x32, 0xb8, 0xca, 0xd2, 0x6a, 0xe7, 0xfe, 0xeb, 0x95, 0x32, 0x15, 0x3c, 0x7c, 0x4e, 0x9d, 0x86 ], [ 0xe5, 0x2d, 0x42, 0x59, 0xc4, 0x05, 0x50, 0x89, 0x44, 0xba, 0x59, 0x3b, 0x6c, 0xdc, 0x2b, 0x4b, 0x95, 0x9c, 0xc7, 0xc4, 0xad, 0x05, 0x04, 0xf9, 0x81, 0x9f, 0xe9, 0xdd, 0x98, 0xe8, 0xa9, 0x00 ], [ 0x5b, 0x4b, 0x43, 0xe4, 0xa9, 0xa5, 0x1b, 0x84, 0x62, 0xbe, 0x36, 0x60, 0x52, 0x92, 0xb4, 0x96, 0x54, 0xc9, 0x1b, 0x32, 0x63, 0xdd, 0x4a, 0xeb, 0x4b, 0x38, 0x2c, 0x4f, 0x76, 0x71, 0x7e, 0xa8 ], [ 0x2a, 0x3a, 0x18, 0x09, 0x23, 0x38, 0x7e, 0x99, 0xff, 0x7d, 0x8c, 0xb3, 0xa4, 0x93, 0xe9, 0x4c, 0xee, 0xff, 0x5e, 0x99, 0xf4, 0x00, 0x39, 0xdf, 0x16, 0xb8, 0x64, 0xc9, 0xc7, 0xaf, 0x7d, 0x8d ], [ 0xd1, 0x39, 0x10, 0x81, 0xc8, 0xec, 0x4f, 0x3e, 0xe4, 0xc1, 0xb5, 0xf2, 0x4c, 0x48, 0xd6, 0xa4, 0x7c, 0xab, 0xea, 0x73, 0xfe, 0x49, 0x19, 0xc8, 0xd2, 0x84, 0x90, 0x92, 0x21, 0xe0, 0x51, 0x1a ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" keys2_128bit = [ [ 0x04, 0x42, 0x83, 0x61, 0x6d, 0xfb, 0xe7, 0x55, 0xa7, 0xbf, 0x69, 0xee, 0xc1, 0x8d, 0x79, 0xa0, 0xfb, 0xbd, 0x3e, 0x7a, 0x70, 0x2e, 0xac, 0xc3, 0x26, 0x1b, 0xc4, 0x18, 0xb8, 0x05, 0xe8, 0x85 ], [ 0x5d, 0x24, 0x19, 0xfa, 0xd1, 0xa2, 0x2c, 0x32, 0x2d, 0x92, 0xe7, 0x62, 0x27, 0xed, 0xd3, 0x48, 0x8e, 0x52, 0xe1, 0xe9, 0x8c, 0x67, 0xb5, 0xa2, 0x5f, 0x89, 0x4a, 0x2f, 0x3a, 0x95, 0x47, 0x0b ], [ 0x3a, 0xce, 0x4e, 0x72, 0xa9, 0x7f, 0x75, 0xa5, 0x33, 0x7b, 0xeb, 0x8a, 0xdb, 0xa2, 0x24, 0xb8, 0xec, 0x7d, 0x62, 0x5f, 0x0c, 0xe4, 0x6c, 0xe0, 0x11, 0x4f, 0x53, 0x59, 0x4b, 0x9a, 0xdf, 0x0a ], [ 0xaa, 0x4f, 0x7e, 0x9b, 0x2a, 0x9d, 0x3a, 0xb5, 0xfc, 0x11, 0x88, 0x8d, 0xfd, 0xcf, 0xa1, 0x3b, 0x19, 0xa2, 0x1f, 0xe1, 0x22, 0xfc, 0x18, 0x33, 0x1b, 0x95, 0x48, 0x88, 0x32, 0xdd, 0xe9, 0x73 ], [ 0x02, 0x19, 0xbf, 0xf8, 0xa6, 0x1a, 0x52, 0xff, 0xcb, 0x5a, 0xcb, 0xe1, 0x88, 0xea, 0xb0, 0x95, 0xd2, 0x10, 0xa9, 0xed, 0x0d, 0x18, 0xa4, 0xf7, 0x0f, 0x8e, 0xed, 0x0c, 0x36, 0x90, 0x1e, 0x8a ], [ 0x67, 0x3f, 0x0a, 0x6b, 0x2a, 0x88, 0x9a, 0x8f, 0xb9, 0xfb, 0x1f, 0xde, 0xa1, 0x35, 0xfa, 0x7b, 0x0f, 0xbb, 0x54, 0xd3, 0x93, 0x21, 0xfa, 0xdc, 0xa8, 0x47, 0xe7, 0xce, 0x4d, 0x13, 0x24, 0xc5 ], [ 0xf2, 0xbc, 0xab, 0x3e, 0xad, 0xa0, 0x4a, 0xef, 0x3a, 0x35, 0x2b, 0x2c, 0xd4, 0xbe, 0x83, 0xb2, 0x3c, 0xc5, 0x2c, 0xc8, 0x70, 0x79, 0x8e, 0x31, 0x27, 0x02, 0x5b, 0x2c, 0x88, 0x55, 0x5e, 0x51 ], [ 0xad, 0x05, 0x2d, 0x63, 0x3b, 0xf3, 0xeb, 0xae, 0xf1, 0x9a, 0x32, 0x1f, 0xf9, 0xed, 0x9e, 0x58, 0x21, 0x79, 0x24, 0xc3, 0x9d, 0xc7, 0x3e, 0x74, 0x81, 0x42, 0x0f, 0xa3, 0x60, 0xa8, 0xc3, 0x48 ], [ 0x1b, 0xdb, 0x3c, 0xd4, 0xfe, 0x6a, 0x1b, 0x8c, 0x2f, 0x10, 0x83, 0x7d, 0xe1, 0x65, 0x21, 0x01, 0x70, 0x8d, 0x1a, 0x86, 0x9d, 0x99, 0x51, 0x30, 0x41, 0xfe, 0x64, 0x44, 0xad, 0x06, 0x5e, 0x30 ], [ 0xa5, 0xb7, 0x4d, 0x3b, 0xb5, 0x8c, 0xa8, 0x39, 0xf6, 0x20, 0xb5, 0x50, 0x4a, 0xe9, 0x2a, 0xa9, 0x9a, 0x40, 0x65, 0xd8, 0x1a, 0x49, 0x63, 0x57, 0x34, 0x06, 0x17, 0x08, 0xef, 0x5a, 0x2c, 0x56 ], [ 0xb1, 0xeb, 0xc8, 0xc5, 0xbd, 0xc0, 0x18, 0xef, 0x3d, 0x12, 0xc1, 0x5f, 0xfd, 0x4b, 0x5e, 0x1d, 0xd6, 0x51, 0x2c, 0xbe, 0x42, 0xbb, 0x13, 0x52, 0x8d, 0xd0, 0xc7, 0x54, 0x39, 0x76, 0x41, 0xd0 ], [ 0x8e, 0xe4, 0xf0, 0x15, 0x0c, 0x23, 0xeb, 0xac, 0xa1, 0x27, 0xbd, 0x6c, 0x52, 0xca, 0x3d, 0x53, 0xda, 0xf6, 0xf9, 0x13, 0x5b, 0x32, 0x3b, 0xcb, 0x86, 0xf5, 0xde, 0x2f, 0xc4, 0xed, 0xd8, 0xbe ], [ 0xfd, 0xd4, 0xf1, 0x69, 0xb4, 0x84, 0x17, 0x7d, 0xce, 0xe1, 0xf4, 0xf1, 0x39, 0x98, 0x0a, 0x52, 0x26, 0xd1, 0xad, 0x77, 0x8f, 0xdc, 0x59, 0x1b, 0x6d, 0x56, 0xd0, 0xe4, 0x56, 0xd9, 0xeb, 0x8a ], [ 0x9d, 0x87, 0x3c, 0x9d, 0x56, 0x1c, 0x1b, 0x45, 0x6b, 0x23, 0x25, 0xe7, 0xf7, 0x39, 0x68, 0x0d, 0xc8, 0x80, 0x9a, 0x99, 0x59, 0x75, 0x34, 0x94, 0x1f, 0xcc, 0xc0, 0x74, 0x9d, 0xb4, 0x76, 0x37 ], [ 0xb9, 0x34, 0x85, 0xc5, 0x41, 0x9f, 0xb4, 0x06, 0x5b, 0x1e, 0xb1, 0xcd, 0x66, 0xd3, 0x5b, 0x40, 0xc4, 0x59, 0xcd, 0x80, 0xff, 0x63, 0x63, 0x64, 0x3b, 0x9a, 0x7d, 0x11, 0x9f, 0x86, 0xdb, 0x35 ], [ 0x4b, 0xf3, 0x86, 0x53, 0xc1, 0x38, 0x4a, 0xdd, 0xa2, 0xaf, 0xa5, 0x60, 0x06, 0x4e, 0x84, 0xb7, 0xd2, 0x20, 0x8d, 0xe9, 0x69, 0xa0, 0x66, 0x83, 0xcb, 0xfc, 0x3d, 0xd6, 0x18, 0xa0, 0x7e, 0xba ], [ 0xd2, 0x37, 0x3c, 0x8c, 0x62, 0x66, 0xb1, 0x14, 0xfd, 0x42, 0xe4, 0x38, 0xe8, 0x36, 0x03, 0xcf, 0xdb, 0x73, 0x16, 0x0e, 0x4a, 0xbd, 0x42, 0xf2, 0x1b, 0x31, 0x03, 0x9d, 0x39, 0x43, 0x7d, 0x5e ], [ 0x45, 0x16, 0xf9, 0xb1, 0x56, 0x92, 0x3a, 0x70, 0x18, 0xb8, 0x49, 0x09, 0x44, 0xb7, 0xf5, 0x9f, 0x07, 0x30, 0x78, 0x7e, 0xe7, 0x7f, 0xed, 0x4a, 0xa5, 0x42, 0x80, 0x24, 0xd5, 0xb2, 0x3c, 0x61 ], [ 0x19, 0xb0, 0x9b, 0xc8, 0xcd, 0x5d, 0xed, 0x96, 0xb9, 0xd4, 0xa6, 0x8f, 0xb5, 0x95, 0xf6, 0x95, 0x2e, 0x68, 0x3b, 0x6a, 0x96, 0x29, 0x7f, 0xb3, 0x2f, 0xfe, 0xc0, 0x6e, 0x2b, 0xba, 0x1f, 0xf1 ], [ 0x2c, 0x07, 0xd8, 0xb8, 0x4e, 0xc3, 0x48, 0x53, 0x28, 0x3f, 0xde, 0xcf, 0x6a, 0x77, 0xd4, 0xa9, 0x3a, 0x53, 0xd3, 0x64, 0x87, 0x32, 0x26, 0x35, 0x2b, 0x57, 0x04, 0x37, 0xf8, 0x61, 0xd2, 0x90 ], [ 0x2c, 0x3b, 0x55, 0x2d, 0x43, 0xf0, 0x1f, 0x1d, 0xc8, 0x2e, 0xad, 0x0c, 0xb0, 0xd4, 0x3f, 0xa7, 0x46, 0xd1, 0xb8, 0x3e, 0x10, 0x04, 0x47, 0x74, 0xcc, 0x0e, 0xa0, 0xc9, 0xe8, 0x83, 0x0d, 0xe3 ], [ 0xc1, 0x4a, 0x66, 0xb3, 0x27, 0xb4, 0x55, 0x4e, 0xc0, 0xf2, 0x85, 0xc6, 0xd7, 0x10, 0x0e, 0x72, 0xdd, 0x8a, 0xff, 0x50, 0xe7, 0x7f, 0xc6, 0x74, 0xda, 0x88, 0xf8, 0xb8, 0x09, 0x2e, 0xc5, 0x66 ], [ 0x2e, 0xd8, 0x89, 0x3a, 0xde, 0x98, 0xf9, 0xaf, 0xd2, 0x91, 0x16, 0x17, 0xad, 0x34, 0x6d, 0x6f, 0xd5, 0xd2, 0x58, 0xce, 0x1b, 0x6f, 0x37, 0xd3, 0x2c, 0xc5, 0x81, 0x53, 0x81, 0x03, 0x36, 0x01 ], [ 0x9e, 0xe3, 0x08, 0x03, 0x54, 0x0c, 0x35, 0x38, 0x8c, 0xf0, 0x44, 0x78, 0xe4, 0x80, 0x90, 0x18, 0x3c, 0x1a, 0x0f, 0x1b, 0x7e, 0x8c, 0x1c, 0x9b, 0x2a, 0x67, 0x4d, 0x65, 0xf4, 0x8b, 0xca, 0x8d ], [ 0x67, 0x4f, 0xa1, 0x16, 0x62, 0xf1, 0xf2, 0x20, 0xc1, 0xbd, 0x6b, 0x59, 0x52, 0x3d, 0x84, 0xfa, 0x72, 0x41, 0xf9, 0xda, 0xbf, 0x37, 0x82, 0x7e, 0x82, 0x70, 0x19, 0x83, 0x43, 0x12, 0x19, 0x7c ], [ 0x39, 0x25, 0x79, 0x05, 0xdf, 0xcc, 0x77, 0x76, 0x6c, 0x87, 0x0a, 0x80, 0x6a, 0x60, 0xe3, 0xc0, 0x93, 0xd1, 0x2a, 0xcf, 0xcb, 0x51, 0x42, 0xfa, 0x09, 0x69, 0x89, 0x62, 0x5b, 0x60, 0xdb, 0x16 ], [ 0xe6, 0xe8, 0x72, 0x8f, 0x52, 0x0a, 0xff, 0xb5, 0xc5, 0xb2, 0xc6, 0x5e, 0x58, 0x9d, 0xf2, 0x5e, 0xd0, 0x00, 0x68, 0xb7, 0x18, 0xbb, 0xb0, 0x0a, 0x79, 0xd4, 0xec, 0x05, 0x5e, 0x1c, 0xc3, 0x2a ], [ 0xe1, 0x6a, 0x2f, 0xb3, 0x8a, 0x83, 0xcb, 0xb5, 0x0b, 0x9b, 0x73, 0xbf, 0xf9, 0x79, 0x87, 0x86, 0x7b, 0xb2, 0xc5, 0xdd, 0xe2, 0x0e, 0xe6, 0x6e, 0x8b, 0xc1, 0x93, 0xbb, 0x20, 0x30, 0x30, 0x44 ], [ 0x05, 0x4f, 0xa8, 0x05, 0xcd, 0x6e, 0xd4, 0xd7, 0x2c, 0x6c, 0xf5, 0x17, 0x5b, 0x07, 0x2c, 0x94, 0x6b, 0x52, 0x71, 0xe3, 0x62, 0x6d, 0x2e, 0xce, 0x43, 0x08, 0x18, 0x5b, 0x2a, 0x41, 0x3a, 0xc7 ], [ 0x26, 0x95, 0xe7, 0xeb, 0x00, 0x09, 0x27, 0x7f, 0x24, 0x63, 0xa6, 0xda, 0x8a, 0x57, 0xcc, 0xbb, 0xb2, 0x44, 0xb2, 0xbd, 0x09, 0xab, 0xe5, 0xf2, 0xda, 0x53, 0x80, 0x25, 0xc7, 0x51, 0x6b, 0x80 ], [ 0x85, 0x57, 0xca, 0x8c, 0x4e, 0x7a, 0x95, 0x60, 0xf7, 0x5d, 0x2c, 0x41, 0xea, 0xaa, 0x2a, 0x4e, 0xcf, 0x7b, 0x4b, 0xc5, 0x02, 0x12, 0x7f, 0x7e, 0x71, 0x7f, 0x01, 0x8d, 0xe1, 0x61, 0x65, 0x28 ], [ 0x35, 0x04, 0xf8, 0x16, 0x72, 0x15, 0x0d, 0xb2, 0x4a, 0x61, 0x56, 0xa8, 0x99, 0x51, 0x12, 0x48, 0x63, 0xba, 0xa3, 0x05, 0x58, 0xe2, 0xf1, 0xa0, 0xf5, 0x1c, 0x3c, 0x6c, 0xf8, 0x09, 0x03, 0xa2 ], [ 0x49, 0x92, 0x63, 0xa6, 0x3c, 0x49, 0x17, 0xf4, 0xb4, 0x4f, 0x6a, 0xdb, 0x00, 0x8b, 0xf1, 0x99, 0x74, 0xb2, 0x9c, 0x2c, 0x9e, 0x02, 0x18, 0x6c, 0xfc, 0x9c, 0xd0, 0xa8, 0xa0, 0x5e, 0xc7, 0x31 ], [ 0x06, 0x9f, 0x57, 0x77, 0xde, 0x49, 0x63, 0x2b, 0x67, 0xce, 0xf4, 0x12, 0x14, 0x19, 0x48, 0xfa, 0x68, 0xd4, 0xc5, 0x46, 0x5c, 0xd3, 0xb8, 0xbe, 0x59, 0x65, 0x9c, 0x29, 0xb7, 0x6f, 0x53, 0x15 ], [ 0x08, 0x96, 0x81, 0x8d, 0x81, 0xfb, 0xb8, 0x4c, 0xeb, 0x0b, 0xea, 0x5a, 0xc9, 0x3c, 0x09, 0xca, 0xec, 0xfa, 0x92, 0xce, 0x0a, 0xfd, 0x0b, 0xed, 0xfe, 0xac, 0x9c, 0xec, 0xb8, 0xba, 0x8c, 0x55 ], [ 0xa2, 0x59, 0x38, 0x9b, 0xe3, 0x6d, 0x64, 0x56, 0x8c, 0x05, 0x3c, 0x63, 0x94, 0x67, 0xbe, 0x0e, 0x26, 0xd3, 0xc0, 0xeb, 0x62, 0x82, 0x79, 0x03, 0xd4, 0x82, 0x6e, 0xfa, 0x53, 0x17, 0x16, 0x16 ], [ 0x73, 0x3e, 0xb1, 0x25, 0x41, 0x3c, 0x57, 0x0b, 0x9a, 0xdb, 0xda, 0xec, 0xbd, 0x9b, 0xda, 0x1c, 0x13, 0xa1, 0xbc, 0x28, 0x60, 0x81, 0x04, 0x1a, 0xa0, 0x69, 0xe5, 0x2b, 0xb7, 0x22, 0x91, 0x4f ], [ 0x07, 0xe4, 0x37, 0x8b, 0xf7, 0xe5, 0x14, 0xe2, 0x87, 0x50, 0x86, 0xff, 0x56, 0x7f, 0xee, 0x96, 0x21, 0xc4, 0x5f, 0x6f, 0xf3, 0x6d, 0xb4, 0x5f, 0x1c, 0x0f, 0x70, 0x6b, 0x1a, 0x9e, 0x02, 0x8b ], [ 0x0e, 0x17, 0x1e, 0x22, 0x5c, 0xbd, 0xe4, 0x08, 0x73, 0xdb, 0xf6, 0x86, 0xb2, 0x97, 0xb2, 0xb6, 0xd4, 0xed, 0x08, 0x47, 0x6d, 0xd6, 0x92, 0x36, 0x22, 0x4f, 0x0e, 0xe1, 0xbf, 0x30, 0x43, 0x82 ], [ 0xe8, 0x56, 0x11, 0x7e, 0xc0, 0x53, 0x86, 0x43, 0xe8, 0x27, 0x69, 0x19, 0x7e, 0x4a, 0x4c, 0x0a, 0x26, 0xae, 0x60, 0xf3, 0xf8, 0xde, 0x16, 0x50, 0x02, 0xba, 0x34, 0x74, 0x44, 0xcb, 0xa0, 0x6f ], [ 0xc5, 0xb4, 0x9e, 0x5f, 0xca, 0xc9, 0x23, 0x6c, 0xaf, 0x72, 0x42, 0x16, 0x05, 0xbe, 0x6d, 0xc5, 0x31, 0x77, 0x40, 0x0f, 0x8d, 0x3e, 0xe3, 0xe8, 0x77, 0xfa, 0x55, 0x59, 0x2c, 0xcf, 0x2a, 0x83 ], [ 0xd2, 0x9c, 0xeb, 0x27, 0x4a, 0x3f, 0xe2, 0x0b, 0x9c, 0xd3, 0x72, 0xc3, 0xef, 0x26, 0x4d, 0xf3, 0x69, 0x90, 0xd6, 0xd2, 0x0e, 0xde, 0x69, 0x91, 0x50, 0xbc, 0x8a, 0x01, 0x3a, 0x16, 0x7a, 0x4b ], [ 0xcc, 0xd3, 0x76, 0x2a, 0x06, 0x16, 0xcd, 0xa5, 0xc4, 0xa4, 0x70, 0xf6, 0xfa, 0x81, 0xa9, 0xaf, 0x77, 0x7b, 0xa5, 0x9e, 0xe8, 0x78, 0x8b, 0xd7, 0xea, 0x9e, 0xc1, 0x17, 0xf2, 0x5a, 0x75, 0xc4 ], [ 0xb9, 0xfa, 0x2f, 0xc6, 0x03, 0x70, 0x0e, 0x6f, 0xe7, 0x88, 0xf7, 0x1f, 0xa0, 0x06, 0x4f, 0x4c, 0x5a, 0x84, 0x61, 0x88, 0xfe, 0x6d, 0xa4, 0x62, 0xf0, 0x9b, 0x9a, 0x8f, 0x15, 0xcf, 0xd7, 0x09 ], [ 0xed, 0xe7, 0x35, 0xce, 0x9a, 0x45, 0x6b, 0xd7, 0x95, 0xab, 0xbd, 0x65, 0x67, 0x1e, 0x64, 0xf6, 0x21, 0xec, 0xe0, 0x65, 0x20, 0xc2, 0xb6, 0x32, 0xa4, 0xaa, 0x87, 0x53, 0xe6, 0xaf, 0xe7, 0x4b ], [ 0xf6, 0x9b, 0xd6, 0x71, 0x6c, 0xce, 0xee, 0x47, 0xa1, 0x8c, 0x1b, 0xa9, 0x18, 0xce, 0x1c, 0xe5, 0x94, 0x56, 0x8a, 0xcb, 0x1c, 0xd5, 0x96, 0xc1, 0x49, 0x64, 0xfb, 0xf7, 0xcb, 0xf8, 0x38, 0x12 ], [ 0x02, 0x55, 0xdf, 0x03, 0x39, 0x93, 0x6b, 0x44, 0xe3, 0xf0, 0xce, 0x4f, 0x13, 0x0f, 0x52, 0x02, 0xe1, 0x9d, 0x2f, 0x18, 0x17, 0xbb, 0x0c, 0x94, 0xc4, 0x40, 0x48, 0x34, 0x19, 0xfd, 0x4e, 0xd9 ], [ 0xcc, 0x36, 0xbc, 0x7d, 0xa2, 0x27, 0x4c, 0x36, 0x3d, 0x45, 0x6e, 0x6e, 0x81, 0x8c, 0x55, 0x73, 0x36, 0xe5, 0x30, 0x23, 0x92, 0xa2, 0x31, 0xb7, 0xfd, 0xf5, 0xed, 0x6c, 0x38, 0xd9, 0xdc, 0x90 ], [ 0xac, 0x58, 0x7d, 0xc5, 0x88, 0xd4, 0x39, 0x22, 0x30, 0xa8, 0x1e, 0xfd, 0xcb, 0x4b, 0xa8, 0xe0, 0x15, 0xea, 0xe3, 0x61, 0xfa, 0x5c, 0x56, 0x69, 0xe8, 0x9c, 0xea, 0xe7, 0x74, 0x2c, 0x5e, 0x6e ], [ 0xe8, 0xc7, 0xbc, 0x3c, 0xf6, 0x4b, 0x16, 0x34, 0x94, 0x36, 0xfd, 0x72, 0x8b, 0x48, 0xd8, 0xfd, 0x84, 0xd7, 0xf2, 0x35, 0xda, 0xb6, 0x21, 0xb1, 0xcc, 0x93, 0xb4, 0xa5, 0xf0, 0x66, 0x69, 0x8c ], [ 0x8f, 0x71, 0x7c, 0xbd, 0x0d, 0x82, 0x73, 0xf3, 0x14, 0x43, 0x71, 0xf1, 0xe5, 0xa0, 0x32, 0x84, 0x30, 0xca, 0xa8, 0xd2, 0x68, 0x31, 0xf0, 0x3f, 0xe0, 0x39, 0xfe, 0x11, 0x33, 0x15, 0x6a, 0x0b ], [ 0xeb, 0x0a, 0x46, 0x3b, 0xb2, 0x14, 0x83, 0x17, 0x54, 0xad, 0xd0, 0x39, 0x88, 0xaa, 0xe7, 0x34, 0xd5, 0x8d, 0xe3, 0x28, 0xb0, 0x7e, 0x6f, 0x13, 0x51, 0x90, 0x5a, 0x37, 0x62, 0xfe, 0xeb, 0xe0 ], [ 0x66, 0x93, 0x47, 0xef, 0xc2, 0xc9, 0x11, 0x1b, 0xbc, 0xe1, 0xd4, 0x97, 0x25, 0x60, 0xec, 0x21, 0xae, 0x71, 0x53, 0x27, 0xc1, 0x32, 0x57, 0x15, 0x18, 0xa0, 0xd0, 0xff, 0x69, 0x7a, 0x07, 0xcd ], [ 0xc9, 0x9e, 0x3e, 0xf1, 0x45, 0x5e, 0x28, 0x56, 0xf5, 0xef, 0x07, 0xd6, 0x22, 0x7b, 0x1a, 0x37, 0xed, 0xa6, 0x52, 0xdb, 0x8f, 0x50, 0xea, 0x4b, 0xcb, 0x95, 0x25, 0x02, 0x76, 0xee, 0x3b, 0x0e ], [ 0x48, 0x68, 0x3f, 0xf1, 0x93, 0x9b, 0x4e, 0x78, 0x17, 0x9b, 0x18, 0xd8, 0x1d, 0xab, 0x05, 0xe7, 0xdc, 0x46, 0xd8, 0x5e, 0xb3, 0x56, 0x59, 0xb4, 0xf7, 0x14, 0x5b, 0xc3, 0x38, 0x19, 0x90, 0x11 ], [ 0x92, 0xd3, 0x39, 0xd3, 0x78, 0x85, 0x5a, 0x78, 0xb3, 0xaa, 0x7b, 0xe9, 0x6e, 0xf3, 0x66, 0xb8, 0x72, 0x03, 0x1b, 0x09, 0x93, 0xae, 0x15, 0xf3, 0x5b, 0xc7, 0xd4, 0x8e, 0x88, 0xf2, 0xdb, 0x69 ], [ 0x38, 0xde, 0xa4, 0x2a, 0x9f, 0x43, 0x83, 0x3b, 0xc6, 0x31, 0x28, 0x42, 0xe3, 0xa3, 0xcb, 0x4b, 0x6f, 0xb4, 0xb2, 0xfa, 0x96, 0xd4, 0x62, 0x32, 0x85, 0xb5, 0xa1, 0x36, 0x7c, 0xa8, 0xea, 0x11 ], [ 0x6c, 0xe0, 0x00, 0x8f, 0xb8, 0x8d, 0xe2, 0xb5, 0x60, 0xec, 0x42, 0x6a, 0xce, 0x1f, 0xd7, 0xce, 0x40, 0xf9, 0x5d, 0xf7, 0x5e, 0xcd, 0x3b, 0x59, 0xa1, 0xa0, 0xb4, 0x32, 0x6b, 0x30, 0xce, 0x3e ], [ 0x0f, 0x5e, 0x51, 0xd3, 0x7c, 0xbc, 0x39, 0x25, 0x5c, 0xe0, 0x50, 0x23, 0x5e, 0x15, 0x22, 0xcc, 0x17, 0x5a, 0xbf, 0xf1, 0xb2, 0x2f, 0x3b, 0x21, 0x1c, 0x2f, 0xb6, 0x52, 0xd7, 0x5d, 0x52, 0x0d ], [ 0xba, 0x03, 0x41, 0xba, 0x66, 0xb3, 0x9d, 0x26, 0x94, 0xfb, 0xdd, 0x9b, 0xfc, 0xa9, 0xa7, 0x98, 0x52, 0x45, 0x02, 0x6a, 0xb3, 0xe5, 0xac, 0xfb, 0x6d, 0x2a, 0xf4, 0xb2, 0x7e, 0x3b, 0x4a, 0x80 ], [ 0x35, 0x92, 0xcf, 0xcc, 0xbd, 0xb2, 0x6a, 0x95, 0x73, 0xec, 0x93, 0xc6, 0x71, 0xa6, 0x9c, 0x95, 0xea, 0x9c, 0x9e, 0x8a, 0x1c, 0x10, 0xbd, 0x73, 0x9d, 0x26, 0x74, 0xdb, 0x5b, 0x91, 0xd0, 0x39 ], [ 0x51, 0xf0, 0x4e, 0x84, 0xa1, 0x77, 0x1e, 0x27, 0xbb, 0x2c, 0xea, 0x89, 0xed, 0x4c, 0x6d, 0x2e, 0x51, 0xfa, 0x1b, 0xb4, 0xa1, 0xa1, 0x92, 0xf4, 0x7e, 0x30, 0x6c, 0x61, 0xda, 0xc4, 0x5c, 0x3c ], [ 0x42, 0xdc, 0x66, 0x44, 0xc1, 0xa5, 0x63, 0x9b, 0x50, 0xc0, 0x77, 0x8a, 0xd8, 0xc9, 0x8b, 0x5e, 0xb6, 0xaa, 0x9b, 0xd3, 0x47, 0x92, 0xcb, 0x06, 0x56, 0x7e, 0x15, 0xcc, 0x50, 0xe0, 0x36, 0x0c ], [ 0xb6, 0x07, 0x96, 0x31, 0xdc, 0x85, 0xa7, 0xa6, 0xde, 0x4d, 0x35, 0x79, 0xbb, 0xc6, 0x25, 0xe4, 0x92, 0x8c, 0x35, 0x0f, 0x13, 0x13, 0xa9, 0x9e, 0x9b, 0xa4, 0x3c, 0x2e, 0xf8, 0x61, 0x40, 0x16 ], [ 0xaf, 0xab, 0x45, 0x64, 0x69, 0x7d, 0xa7, 0x50, 0x9a, 0xa0, 0x44, 0x96, 0x1a, 0xa1, 0xd7, 0x91, 0x03, 0x4d, 0xc6, 0x3a, 0x2f, 0xa4, 0x12, 0x89, 0x02, 0x6d, 0x99, 0xd4, 0x5f, 0xae, 0xcb, 0xa1 ], [ 0x26, 0x7e, 0x66, 0x7f, 0x3d, 0x98, 0x43, 0x41, 0x0d, 0xc5, 0x55, 0x87, 0x20, 0xc4, 0xed, 0x46, 0x06, 0x10, 0x20, 0x21, 0x2f, 0x36, 0x64, 0xd2, 0x7d, 0x8d, 0x00, 0xd4, 0x05, 0x89, 0x5e, 0x25 ], [ 0x44, 0xe1, 0x94, 0xe2, 0xdf, 0x43, 0xa8, 0x31, 0xd7, 0x1f, 0xd8, 0xb4, 0x78, 0x30, 0x7d, 0xe7, 0xe5, 0x9f, 0x1c, 0xd2, 0x79, 0x43, 0xf8, 0x9d, 0x97, 0x0c, 0xaf, 0x8a, 0x9a, 0x7c, 0x2c, 0x90 ], [ 0x79, 0xa4, 0x11, 0x74, 0x8c, 0xde, 0x56, 0x27, 0x41, 0x17, 0xc3, 0xbb, 0xa3, 0x2b, 0x51, 0x73, 0x11, 0xb2, 0x0e, 0x00, 0xbf, 0x42, 0x6e, 0xf0, 0x37, 0x7c, 0x56, 0x66, 0xfe, 0xbc, 0x7a, 0xe4 ], [ 0x1e, 0xdd, 0x1d, 0xee, 0x26, 0xed, 0xa2, 0x49, 0x80, 0x1b, 0xc7, 0xe3, 0x64, 0xe3, 0xba, 0x7c, 0x4b, 0xd6, 0x45, 0xd9, 0x39, 0x0a, 0x23, 0x06, 0xa1, 0x29, 0x0c, 0x9f, 0x6e, 0xcb, 0xfa, 0xc9 ], [ 0x4b, 0x23, 0x64, 0xb8, 0x86, 0x91, 0x89, 0x0e, 0x2c, 0x88, 0x96, 0x89, 0xdb, 0x7c, 0x6e, 0xeb, 0xb8, 0xc5, 0xaf, 0x8e, 0xbb, 0x33, 0x37, 0x2c, 0x0f, 0x16, 0xc8, 0x6a, 0x55, 0xfd, 0xe0, 0xb9 ], [ 0xfe, 0xca, 0x1b, 0x2b, 0xd1, 0xf9, 0xfb, 0x8d, 0xa8, 0x11, 0x43, 0xa8, 0x67, 0xf5, 0x0a, 0xdc, 0xd2, 0x3e, 0x8e, 0x0c, 0x59, 0xf1, 0x69, 0xca, 0xf1, 0xbf, 0x21, 0xff, 0x6c, 0x84, 0xbb, 0xe1 ], [ 0x7d, 0xa8, 0xb2, 0xf6, 0x62, 0x3c, 0x61, 0xd7, 0xf5, 0xb6, 0x64, 0x0b, 0xed, 0x42, 0x13, 0x6d, 0x94, 0x4e, 0xd1, 0x44, 0xdc, 0xea, 0x01, 0xb2, 0x83, 0x0f, 0xe0, 0xcc, 0x55, 0xcf, 0xda, 0x60 ], [ 0x39, 0x1a, 0x7c, 0x85, 0xa1, 0x72, 0x5a, 0xa5, 0xd0, 0x60, 0x49, 0x9d, 0x3a, 0x9e, 0x25, 0x4a, 0x5f, 0x93, 0xec, 0x9d, 0x40, 0x4f, 0x68, 0xc4, 0x32, 0xca, 0xea, 0x3b, 0xd1, 0xbe, 0xc8, 0x36 ], [ 0xfd, 0x13, 0xfa, 0x71, 0x27, 0x80, 0x83, 0xa7, 0x46, 0xc3, 0x9e, 0xff, 0xb7, 0x14, 0x0a, 0x0c, 0x3e, 0x81, 0xa8, 0x1c, 0x0c, 0xbb, 0x49, 0x36, 0x83, 0xbf, 0x7b, 0x58, 0x7c, 0x12, 0xe0, 0xa1 ], [ 0xce, 0xa7, 0x0d, 0xba, 0xa9, 0xc1, 0xd6, 0xad, 0x18, 0x9b, 0x19, 0x94, 0x2e, 0xe2, 0xa6, 0xc8, 0x91, 0x6e, 0x4c, 0x67, 0xdb, 0x31, 0x51, 0xe4, 0xa4, 0x2c, 0x48, 0x97, 0x4f, 0x59, 0x13, 0xc0 ], [ 0xe9, 0x7a, 0xfe, 0x2e, 0xef, 0x68, 0xf9, 0x43, 0x1a, 0x32, 0xc5, 0x4f, 0x5d, 0x29, 0x20, 0xee, 0xc8, 0xee, 0x14, 0x63, 0xf4, 0x82, 0x52, 0xf1, 0x15, 0x1a, 0x27, 0x6d, 0xe9, 0x4c, 0xd0, 0xe8 ], [ 0x63, 0x90, 0xf9, 0x29, 0x10, 0x84, 0xbb, 0x68, 0x64, 0x6d, 0xf4, 0x44, 0x8a, 0xc9, 0x90, 0xd4, 0x9f, 0xe3, 0x12, 0x9a, 0x13, 0x4a, 0x6e, 0xcf, 0x16, 0x2b, 0x27, 0x50, 0xd5, 0x9f, 0x70, 0x92 ], [ 0xdb, 0xe9, 0x07, 0x39, 0xbc, 0xff, 0xe5, 0x49, 0x70, 0x60, 0x5a, 0xaa, 0x4f, 0xf8, 0x7a, 0xa3, 0x47, 0x5f, 0x4b, 0xd8, 0xf8, 0x5d, 0x28, 0x34, 0x96, 0x88, 0x82, 0x35, 0x92, 0x3d, 0x60, 0x88 ], [ 0xe3, 0x1f, 0xff, 0xe3, 0x41, 0x57, 0x6c, 0x3d, 0x89, 0xf9, 0x72, 0x34, 0x34, 0x58, 0x4e, 0xdd, 0x17, 0x32, 0xb5, 0xfc, 0x60, 0xcf, 0x95, 0xe3, 0xcb, 0xf5, 0x00, 0x40, 0x4c, 0xe7, 0x6a, 0x41 ], [ 0x5d, 0x8b, 0x9c, 0x9c, 0x5c, 0x35, 0xf8, 0x46, 0x1c, 0x04, 0x41, 0x4f, 0x57, 0x6b, 0x1c, 0xe9, 0xcf, 0xcb, 0xfd, 0x9b, 0x3e, 0x88, 0xf1, 0x94, 0xa2, 0x25, 0x67, 0x52, 0xe4, 0xdd, 0x21, 0xde ], [ 0x4e, 0x4d, 0xb8, 0xd4, 0x02, 0xc1, 0x29, 0x67, 0x67, 0x94, 0x84, 0xa2, 0x88, 0xb6, 0x40, 0x33, 0x56, 0xc5, 0x4f, 0xfe, 0x4c, 0x3b, 0xae, 0x1b, 0x40, 0xd3, 0xe0, 0x29, 0x27, 0xb2, 0x12, 0xb6 ], [ 0xb1, 0xdc, 0x62, 0xf2, 0xdd, 0x58, 0x96, 0x55, 0x63, 0x16, 0x6b, 0x77, 0x9a, 0xe7, 0xb2, 0x26, 0x6a, 0xce, 0xb8, 0x5b, 0x87, 0x60, 0xa5, 0xd0, 0x9d, 0xd4, 0x50, 0x0b, 0x80, 0x73, 0x90, 0x3a ], [ 0x70, 0xd3, 0xb7, 0x9d, 0x9e, 0x77, 0x81, 0xd3, 0x14, 0x3c, 0x13, 0x49, 0x51, 0xea, 0x21, 0x63, 0xe1, 0x3a, 0x5c, 0x93, 0xb1, 0x5d, 0xf9, 0xeb, 0x01, 0xe3, 0x85, 0x16, 0xc9, 0xea, 0x5f, 0xd6 ], [ 0x6f, 0x5b, 0x8e, 0xec, 0x5c, 0xf9, 0x66, 0x21, 0xbf, 0x91, 0x24, 0xae, 0xee, 0xce, 0x5c, 0x7e, 0x58, 0x4d, 0x00, 0xac, 0x1f, 0x62, 0x2c, 0xdd, 0x60, 0x6c, 0xb4, 0x12, 0x49, 0x2b, 0xe3, 0x15 ], [ 0x08, 0xc5, 0xeb, 0x90, 0x3f, 0x57, 0xbc, 0x70, 0xf6, 0xc7, 0xa1, 0x8f, 0xc8, 0x36, 0x61, 0xab, 0xe9, 0x7d, 0x3e, 0x4b, 0xbd, 0x9a, 0xf8, 0x1c, 0x66, 0xb3, 0x8b, 0x45, 0x02, 0x43, 0x0c, 0xc0 ], [ 0xfe, 0xde, 0xaa, 0x11, 0x2c, 0x4f, 0x1f, 0x69, 0x36, 0x6e, 0xf6, 0x7d, 0xa3, 0x28, 0xd7, 0x82, 0xa2, 0x7a, 0x0e, 0x0a, 0x88, 0xa0, 0xf5, 0xe5, 0x3d, 0x9a, 0x8a, 0xe5, 0x86, 0x91, 0x60, 0x6b ], [ 0xd0, 0xd0, 0x83, 0xd2, 0x86, 0x43, 0xb3, 0xde, 0x9c, 0xd7, 0x8c, 0x99, 0xb0, 0x14, 0xf2, 0x33, 0x39, 0xef, 0x1e, 0x8e, 0xe8, 0x2e, 0xa5, 0x02, 0x65, 0xc9, 0x4c, 0x85, 0xfb, 0x30, 0x8a, 0xd1 ], [ 0x06, 0x14, 0x89, 0xa3, 0x69, 0xf1, 0x64, 0xaa, 0x16, 0xec, 0x74, 0x38, 0xaa, 0x89, 0xe8, 0x0c, 0x3a, 0x0c, 0x29, 0x5b, 0x9b, 0xc4, 0x6f, 0x8c, 0x4d, 0x44, 0x76, 0xe9, 0x4d, 0x57, 0x6a, 0x07 ], [ 0xd9, 0xa8, 0x01, 0x4e, 0xa3, 0xb5, 0x94, 0xa3, 0x32, 0xbc, 0x97, 0x38, 0xfc, 0xae, 0x27, 0x79, 0xe2, 0x60, 0x41, 0x1e, 0x0b, 0x7e, 0x30, 0xad, 0x3e, 0xa4, 0x20, 0x99, 0x2a, 0x3b, 0x1a, 0xa5 ], [ 0x14, 0x37, 0x4d, 0x46, 0xf0, 0xe6, 0xdb, 0x81, 0x9c, 0xeb, 0x4f, 0x56, 0xb7, 0x61, 0xef, 0x88, 0xbb, 0x76, 0xf9, 0x71, 0x42, 0xaa, 0xa6, 0x21, 0xe1, 0x54, 0x65, 0x4a, 0xbb, 0x95, 0xbb, 0x67 ], [ 0xa3, 0x7b, 0x4c, 0x68, 0xb6, 0xd5, 0x66, 0xac, 0x64, 0x61, 0xe8, 0x63, 0xbf, 0x6d, 0x78, 0x08, 0xd7, 0xb7, 0x34, 0x25, 0xa3, 0x5a, 0xb5, 0x32, 0x57, 0x68, 0xf7, 0x94, 0x87, 0xc2, 0x96, 0x69 ], [ 0xe1, 0x1c, 0xd1, 0xda, 0x19, 0x6b, 0x4d, 0x8c, 0xfe, 0x0b, 0xf3, 0x51, 0xaa, 0x31, 0x17, 0x93, 0xa4, 0x3c, 0x47, 0x26, 0xee, 0x14, 0xee, 0x86, 0x14, 0x09, 0x41, 0x1f, 0xf1, 0x4c, 0xd4, 0xf0 ], [ 0xe3, 0x69, 0x88, 0x83, 0xf9, 0x71, 0x5f, 0x9f, 0xcb, 0xef, 0xeb, 0x78, 0x33, 0x90, 0x37, 0xf3, 0x5f, 0xf1, 0x43, 0xec, 0x0a, 0x4b, 0x95, 0xa0, 0x63, 0x77, 0x34, 0xa4, 0xd1, 0xb8, 0x56, 0x5c ], [ 0x91, 0xec, 0x4e, 0x0d, 0x3f, 0x41, 0xdb, 0x57, 0xd5, 0x37, 0x2d, 0xc3, 0x5e, 0xb8, 0x8d, 0xbb, 0x7a, 0x81, 0x12, 0x9f, 0xfe, 0xf6, 0x11, 0x3f, 0xdb, 0x5a, 0x46, 0xab, 0xc4, 0x52, 0x5f, 0x8f ], [ 0xb3, 0x6b, 0xca, 0x6c, 0x55, 0x48, 0xd7, 0x5d, 0xbc, 0xb4, 0x79, 0x02, 0x7f, 0xff, 0x82, 0x9d, 0xd7, 0xe3, 0x90, 0xe2, 0xa7, 0xa5, 0xac, 0xb5, 0x4f, 0xee, 0xb1, 0x69, 0x27, 0x5a, 0x8d, 0xeb ], [ 0x66, 0x59, 0x23, 0xb5, 0x3e, 0xb8, 0x55, 0xcc, 0x0b, 0xfc, 0x7c, 0x7a, 0xac, 0x6a, 0xba, 0xcc, 0x21, 0x0c, 0x2f, 0x23, 0xda, 0x73, 0x64, 0x14, 0x8b, 0x1e, 0xe3, 0x2e, 0xa1, 0x06, 0xb6, 0xa3 ], [ 0xed, 0x47, 0x77, 0xb9, 0x78, 0x54, 0x14, 0xa5, 0xc5, 0x87, 0xec, 0xba, 0x5f, 0xf2, 0x39, 0xf2, 0x1c, 0x33, 0xaa, 0x42, 0x7d, 0xcc, 0x00, 0xae, 0x65, 0x5e, 0x96, 0xc5, 0xff, 0x94, 0x95, 0x75 ], [ 0x7b, 0xe9, 0x2c, 0xfe, 0x49, 0x56, 0xb5, 0x2d, 0x3d, 0xef, 0xbe, 0x52, 0x03, 0xb0, 0x3d, 0xfd, 0x36, 0x56, 0x4e, 0x4d, 0x22, 0xe5, 0x9f, 0xcf, 0xe3, 0x7f, 0x4f, 0xed, 0xa5, 0x82, 0x4e, 0xc5 ], [ 0x05, 0x5c, 0xf1, 0xf3, 0xfb, 0x88, 0x06, 0xbe, 0x29, 0x43, 0x00, 0x26, 0xbb, 0xc5, 0x5f, 0x5b, 0x06, 0x24, 0x9d, 0x75, 0x38, 0x32, 0x21, 0xb5, 0x07, 0x43, 0xac, 0x33, 0xd8, 0xa2, 0x3d, 0x0f ], [ 0x9c, 0x5c, 0x6e, 0x72, 0xcb, 0xb9, 0xff, 0xcb, 0x0c, 0x07, 0x4e, 0x1a, 0xb9, 0x41, 0x33, 0xa2, 0x07, 0xf2, 0x23, 0x1b, 0x55, 0x76, 0xda, 0x2f, 0x7c, 0xaa, 0xc1, 0xb8, 0xba, 0xcf, 0x2f, 0x93 ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" keys3_128bit = [ [ 0xfb, 0xef, 0x31, 0xbf, 0x8a, 0xa7, 0x54, 0x6b, 0x52, 0x68, 0x6b, 0xe2, 0xa6, 0x60, 0x19, 0xa1, 0x5e, 0xa8, 0x38, 0x33, 0x65, 0x49, 0x01, 0xf6, 0xdc, 0x52, 0x60, 0x3a, 0xe6, 0x55, 0x79, 0xea ], [ 0xd8, 0x06, 0xb8, 0x52, 0xed, 0xb2, 0x97, 0x07, 0xf3, 0xe9, 0x4a, 0xc5, 0x2f, 0x43, 0xd3, 0x5a, 0x23, 0xa9, 0xb4, 0xb3, 0xbe, 0x81, 0x71, 0xa4, 0x69, 0x05, 0x16, 0xda, 0x12, 0xb2, 0x04, 0x0a ], [ 0xe4, 0xb9, 0x2f, 0xa6, 0x2c, 0x5f, 0x09, 0x39, 0x49, 0xd1, 0xdf, 0xd4, 0x9d, 0x30, 0x0e, 0x1b, 0x73, 0x41, 0x5a, 0x17, 0x63, 0x15, 0xb9, 0x21, 0xe7, 0x0f, 0xd4, 0x9e, 0x6b, 0xa6, 0x34, 0xe1 ], [ 0xa0, 0x37, 0xca, 0x87, 0xa6, 0x44, 0xb5, 0xd3, 0x09, 0x27, 0xae, 0xff, 0x1b, 0x31, 0xf9, 0x7c, 0x5f, 0x19, 0xe4, 0x28, 0xe9, 0x72, 0xb8, 0xc6, 0x85, 0xc1, 0x9e, 0x17, 0x92, 0x47, 0x44, 0xf4 ], [ 0x40, 0x4d, 0x27, 0x0f, 0x41, 0x5c, 0xfa, 0xba, 0xc6, 0x21, 0x47, 0x0b, 0x35, 0xd8, 0x7a, 0x27, 0xd4, 0x1e, 0x6b, 0x40, 0xbc, 0x5f, 0x4c, 0x4c, 0x9c, 0xba, 0x13, 0x55, 0x80, 0x47, 0xdc, 0x26 ], [ 0xc3, 0x3c, 0x5f, 0x68, 0x88, 0xaf, 0x22, 0x8a, 0xf4, 0x0f, 0xcc, 0x92, 0x7f, 0x7c, 0xcf, 0x54, 0x80, 0xdd, 0xea, 0xc7, 0x91, 0x98, 0x36, 0x3e, 0xc2, 0x7a, 0x06, 0x77, 0x8c, 0x7e, 0x97, 0xd0 ], [ 0xfc, 0xc2, 0x44, 0xbb, 0x1d, 0x01, 0xe3, 0x37, 0x6c, 0xe8, 0xc6, 0x78, 0x37, 0xec, 0x39, 0x26, 0xcb, 0x71, 0xad, 0x57, 0x27, 0x0a, 0xd7, 0x4e, 0xe0, 0x17, 0xa4, 0x3e, 0x44, 0x04, 0x8c, 0x68 ], [ 0xe3, 0x47, 0xaa, 0x19, 0x83, 0x6f, 0xe5, 0x6b, 0x33, 0x3a, 0x1a, 0x3d, 0xcf, 0xcf, 0x38, 0xf9, 0xd3, 0xe6, 0xa8, 0xf6, 0x5e, 0x02, 0xbc, 0x15, 0x4e, 0x4c, 0x6e, 0x6e, 0xa5, 0x7f, 0x1b, 0x4a ], [ 0xa9, 0x2d, 0x85, 0xc2, 0x91, 0x68, 0x73, 0x8c, 0xdc, 0xcc, 0x19, 0xb8, 0x34, 0x3c, 0x24, 0x14, 0x34, 0xd0, 0xe0, 0x05, 0x53, 0xb0, 0xe1, 0x4b, 0xba, 0x86, 0xc6, 0x23, 0x24, 0xd4, 0x3d, 0x61 ], [ 0x2b, 0xbf, 0x7c, 0xdc, 0x0e, 0x46, 0x71, 0x66, 0x03, 0x7b, 0x99, 0x51, 0x01, 0xd6, 0xa4, 0xc2, 0x48, 0xe3, 0x85, 0xa5, 0x9d, 0xc5, 0x60, 0x1c, 0x64, 0x21, 0x2d, 0xff, 0x72, 0x24, 0x35, 0x78 ], [ 0xe8, 0xdf, 0x65, 0xc6, 0x35, 0xda, 0xea, 0x1f, 0x8e, 0x16, 0x34, 0x4b, 0x7c, 0xb7, 0x20, 0xe5, 0x96, 0x26, 0x4e, 0x38, 0x63, 0xc3, 0x58, 0xbf, 0xc7, 0xaa, 0x47, 0xad, 0x99, 0x85, 0x16, 0xa5 ], [ 0x17, 0xbe, 0xb5, 0x10, 0xf6, 0x84, 0xf6, 0x44, 0x84, 0x90, 0x4b, 0x1d, 0xde, 0x68, 0x03, 0x8d, 0xa6, 0xb6, 0xaa, 0xee, 0x61, 0x1b, 0xaf, 0xb4, 0x92, 0xed, 0x1c, 0x60, 0x85, 0x93, 0xb1, 0x18 ], [ 0x6e, 0xfb, 0x57, 0x2d, 0xe4, 0xe6, 0xa5, 0x88, 0xc4, 0x3c, 0x7a, 0xfa, 0x9f, 0xc4, 0xf5, 0x86, 0x50, 0xbe, 0xa1, 0x5d, 0x71, 0x3f, 0x58, 0xfc, 0x27, 0x3c, 0x97, 0xd4, 0x92, 0x17, 0x7f, 0x2c ], [ 0x2e, 0x52, 0xf5, 0x9e, 0xbe, 0xc3, 0x35, 0x06, 0x00, 0x0c, 0x2d, 0x05, 0xaa, 0x3b, 0xc8, 0x04, 0x7f, 0x57, 0x98, 0xfc, 0x07, 0x36, 0x45, 0x6a, 0x0d, 0x3e, 0xd0, 0x9d, 0x86, 0xb9, 0xc3, 0x6a ], [ 0x13, 0xcb, 0xc3, 0xbb, 0xfa, 0x82, 0x16, 0xa7, 0xd9, 0x56, 0xb5, 0xf7, 0x39, 0x1e, 0x0a, 0x9d, 0x82, 0xcf, 0xf5, 0x59, 0x26, 0x3d, 0x3e, 0xc7, 0xe0, 0xd1, 0xe9, 0x8a, 0x5d, 0x0e, 0x3b, 0x94 ], [ 0x93, 0xd5, 0xeb, 0x3e, 0x9b, 0x51, 0x3a, 0x5a, 0x86, 0xcf, 0x7a, 0x84, 0x22, 0xa4, 0x41, 0x1c, 0x16, 0x4d, 0x70, 0xd1, 0x81, 0x4c, 0x27, 0x5c, 0xae, 0x56, 0xde, 0x09, 0x95, 0xe2, 0xc3, 0x96 ], [ 0x9e, 0x29, 0x15, 0x47, 0xfc, 0x0f, 0x7a, 0x31, 0xc6, 0x33, 0x0a, 0x34, 0x87, 0x1c, 0x49, 0xc7, 0x3e, 0xbc, 0x24, 0x5d, 0xdc, 0xb5, 0x0c, 0x07, 0x6c, 0xf5, 0x7a, 0x07, 0x9c, 0x84, 0x5f, 0x9c ], [ 0xb3, 0x92, 0x08, 0xc7, 0xf5, 0x2f, 0x6d, 0xbe, 0x67, 0x81, 0x7d, 0x83, 0xa8, 0xb6, 0xa5, 0x39, 0xbb, 0xaa, 0xea, 0x87, 0x7f, 0x2e, 0xbc, 0xd1, 0x8d, 0x70, 0x21, 0xb3, 0x2f, 0xe7, 0xf6, 0x1e ], [ 0x04, 0x1d, 0xc3, 0xf6, 0xba, 0x6c, 0x6a, 0x2f, 0xfb, 0x55, 0x4c, 0x61, 0xf0, 0xcf, 0x14, 0x52, 0x07, 0x1e, 0x0d, 0x84, 0xad, 0xeb, 0xa3, 0xd1, 0x6c, 0xfc, 0x86, 0x56, 0x4f, 0x47, 0xd0, 0x5f ], [ 0xac, 0x4f, 0xc0, 0xdf, 0xc3, 0x16, 0xcb, 0x26, 0x8a, 0x2f, 0xad, 0xa3, 0x77, 0xb4, 0x33, 0xa6, 0xc4, 0xc1, 0x5d, 0xd2, 0x52, 0x14, 0x76, 0x2c, 0x7d, 0x5f, 0x4b, 0x8f, 0x30, 0x39, 0x70, 0x88 ], [ 0xc8, 0xee, 0xe8, 0x09, 0x91, 0x01, 0x65, 0xfb, 0x5d, 0xd9, 0x7b, 0x96, 0xe8, 0xf7, 0x1e, 0x69, 0x57, 0xb0, 0xe5, 0x2d, 0x1f, 0x73, 0x36, 0x18, 0x57, 0x09, 0x06, 0xd1, 0x4c, 0x40, 0xec, 0x2f ], [ 0x08, 0x8a, 0x93, 0x9d, 0x92, 0x14, 0xf5, 0x6b, 0x5d, 0xed, 0x3c, 0xad, 0xcb, 0x34, 0x5b, 0xbf, 0x83, 0x86, 0xaa, 0xb3, 0x9c, 0x66, 0xd3, 0x6a, 0xe7, 0x49, 0xb2, 0x8e, 0x0d, 0xc0, 0x24, 0x4e ], [ 0xbf, 0xd3, 0x85, 0xf0, 0xc1, 0xf8, 0x2b, 0xee, 0xef, 0xda, 0x68, 0x22, 0x3e, 0x88, 0x66, 0xba, 0xd2, 0xa6, 0x9b, 0xe6, 0x6c, 0x32, 0xdf, 0x1e, 0x80, 0xee, 0x59, 0x85, 0x63, 0xaa, 0x7a, 0x47 ], [ 0xee, 0x74, 0xd7, 0x21, 0xfb, 0x5a, 0xbd, 0x72, 0x37, 0x21, 0x3f, 0xfb, 0x32, 0x59, 0xe6, 0xd6, 0xd3, 0x71, 0xed, 0xd6, 0xbe, 0x98, 0x10, 0x2e, 0x7c, 0xdf, 0x9f, 0x38, 0x6b, 0x2c, 0x3c, 0xe8 ], [ 0x48, 0xd1, 0x3c, 0x82, 0x59, 0xe9, 0x9e, 0xa6, 0x01, 0xb7, 0x8c, 0xbb, 0xc1, 0x03, 0x89, 0x98, 0x5f, 0x49, 0xf1, 0xc8, 0xcf, 0x83, 0x2f, 0xcb, 0xfa, 0x39, 0x85, 0xf8, 0x7b, 0xa8, 0xc0, 0x32 ], [ 0x4e, 0xec, 0xca, 0xd5, 0x7d, 0x35, 0x0e, 0xc0, 0xe7, 0x04, 0x65, 0xa1, 0xcd, 0x7d, 0x8f, 0x1c, 0xd2, 0xbd, 0x71, 0x57, 0xb1, 0xde, 0xab, 0x22, 0x67, 0x5b, 0x60, 0x0c, 0x99, 0xb4, 0xcc, 0xf0 ], [ 0xe7, 0x42, 0x94, 0xe1, 0x71, 0x3e, 0x59, 0x82, 0x21, 0x41, 0x85, 0x3a, 0x5e, 0xf8, 0xe9, 0xff, 0xdf, 0x98, 0xf4, 0xf4, 0x70, 0x64, 0x64, 0xbd, 0xa9, 0xb9, 0x75, 0x78, 0x7b, 0xb7, 0x89, 0xe9 ], [ 0x10, 0x3d, 0xf8, 0x84, 0xb1, 0xcb, 0x8f, 0x24, 0x98, 0xde, 0x1e, 0x7f, 0x68, 0x1c, 0x44, 0x55, 0xdf, 0x56, 0xf7, 0x19, 0xc2, 0x06, 0xdd, 0x25, 0x0f, 0x83, 0xdc, 0x74, 0x50, 0x8c, 0x1a, 0x6a ], [ 0x26, 0x24, 0x7d, 0x33, 0xf2, 0xb7, 0xe9, 0xe0, 0x6a, 0x2e, 0xe4, 0x83, 0x3e, 0x81, 0x4d, 0x99, 0x25, 0x73, 0xa8, 0x34, 0x3f, 0x47, 0x62, 0xe1, 0x45, 0x4b, 0x0b, 0xbb, 0xd1, 0x52, 0x5a, 0xe4 ], [ 0x75, 0x79, 0x9c, 0xb6, 0x75, 0x9a, 0x2e, 0xdd, 0xfe, 0x99, 0x63, 0x97, 0x34, 0x91, 0x10, 0x2e, 0xe9, 0x65, 0x3b, 0xf0, 0x32, 0x0c, 0x1b, 0x32, 0x24, 0xfd, 0x4e, 0x7a, 0x30, 0x80, 0x88, 0xe3 ], [ 0xb5, 0xcc, 0xec, 0xb5, 0x54, 0xfb, 0xa1, 0x09, 0x2b, 0xcc, 0x54, 0x6e, 0x03, 0x35, 0xa7, 0x5b, 0x07, 0xbd, 0xb2, 0x34, 0xc5, 0x52, 0xe4, 0x17, 0x2e, 0x73, 0x33, 0x15, 0x88, 0xd6, 0xa3, 0x14 ], [ 0x9f, 0x94, 0xa3, 0x98, 0xe0, 0x32, 0xc2, 0x60, 0x81, 0x67, 0xad, 0x53, 0x8b, 0x7f, 0xaf, 0x92, 0xd0, 0x1f, 0xba, 0x0c, 0xbc, 0xe9, 0xb1, 0x38, 0x57, 0x36, 0xe3, 0x13, 0x72, 0x38, 0x9e, 0x10 ], [ 0x5d, 0x3f, 0xb4, 0x68, 0xb2, 0x6e, 0xa0, 0x2e, 0x5f, 0xf7, 0x72, 0xb9, 0xdf, 0x6c, 0x6c, 0x98, 0xa7, 0xe2, 0x8c, 0x5e, 0x67, 0xa9, 0xb1, 0x6b, 0x8a, 0x44, 0xd2, 0xc6, 0x8e, 0x43, 0x6f, 0x8a ], [ 0x9b, 0xde, 0x31, 0xa8, 0xf1, 0xa4, 0xa3, 0xb5, 0x46, 0xbb, 0x70, 0xc8, 0xd4, 0x99, 0x11, 0xf9, 0xa3, 0x2b, 0x75, 0x91, 0xb5, 0x51, 0xe5, 0xc9, 0xb8, 0x50, 0x6c, 0x33, 0xb2, 0x15, 0x2b, 0x68 ], [ 0x1e, 0x10, 0x50, 0x65, 0x57, 0xa0, 0xa1, 0xc5, 0x39, 0x7d, 0x14, 0x16, 0xeb, 0x4d, 0x99, 0x4c, 0x90, 0x71, 0x61, 0x70, 0x1f, 0xce, 0x00, 0x15, 0x7a, 0xed, 0xe9, 0xd5, 0xab, 0x38, 0x15, 0x8d ], [ 0x5d, 0x77, 0x3f, 0x41, 0x3d, 0xc5, 0x14, 0xf4, 0xe6, 0x44, 0x41, 0x97, 0x0a, 0x66, 0xac, 0x36, 0xdd, 0xc3, 0x52, 0x92, 0x42, 0x36, 0xc9, 0x48, 0x38, 0x4d, 0xd5, 0x11, 0x6e, 0xa7, 0x3b, 0x0f ], [ 0x49, 0xe4, 0x63, 0x93, 0x10, 0xb6, 0xa2, 0xdd, 0x5e, 0xe9, 0x0b, 0x69, 0xed, 0x4d, 0xcf, 0xd7, 0x68, 0xd5, 0x14, 0x25, 0x4e, 0xeb, 0x7e, 0xd5, 0x59, 0xc8, 0x64, 0xd5, 0x67, 0xa6, 0xd1, 0xa9 ], [ 0xe7, 0xb8, 0x27, 0xbc, 0xd5, 0x0c, 0x71, 0xb1, 0x98, 0x6a, 0x52, 0x67, 0x45, 0x84, 0x72, 0x81, 0xa4, 0xa7, 0xa6, 0x9a, 0x8d, 0x01, 0x90, 0x16, 0x41, 0x2f, 0xe2, 0xba, 0x74, 0xbc, 0xd3, 0xb7 ], [ 0xab, 0x11, 0x93, 0xe2, 0x73, 0x7f, 0x28, 0x2d, 0x6a, 0x0d, 0x29, 0x93, 0x26, 0x00, 0xc4, 0xe4, 0x08, 0xc8, 0xf1, 0x94, 0x90, 0x69, 0x78, 0xfe, 0x2f, 0x9f, 0x56, 0xb2, 0xcb, 0x98, 0xea, 0x83 ], [ 0x82, 0xbe, 0x68, 0x29, 0x8b, 0xde, 0xa7, 0x56, 0x25, 0x47, 0xe6, 0x8b, 0x9f, 0xba, 0xfd, 0x43, 0x06, 0xf5, 0x7d, 0x3d, 0xf9, 0xcd, 0x91, 0xa9, 0x32, 0x5b, 0x54, 0x09, 0x7d, 0x2d, 0x7f, 0x5b ], [ 0xb7, 0xce, 0x95, 0x7c, 0x67, 0xac, 0xc5, 0x23, 0xf9, 0x63, 0xd0, 0x75, 0x32, 0xa9, 0xf8, 0x29, 0xef, 0x15, 0x3b, 0x03, 0x46, 0x26, 0x02, 0xaa, 0x9d, 0x57, 0x36, 0x7c, 0x96, 0xd6, 0x19, 0x41 ], [ 0x44, 0x4b, 0xd7, 0xe1, 0x1e, 0xf0, 0x1e, 0x89, 0x0b, 0x32, 0x76, 0x43, 0x11, 0xd6, 0x45, 0x06, 0xc3, 0x60, 0xfd, 0xf4, 0x10, 0xef, 0x8a, 0x77, 0xf2, 0x67, 0x16, 0xb1, 0xd1, 0xbe, 0x43, 0xe4 ], [ 0x5e, 0xaf, 0xe0, 0x53, 0x62, 0xed, 0xdd, 0x05, 0xef, 0xfc, 0xb2, 0x44, 0x78, 0x96, 0xe7, 0x44, 0x0f, 0x38, 0xc6, 0x55, 0x27, 0x6b, 0x6c, 0x7f, 0xba, 0xe0, 0x03, 0xa3, 0x87, 0xd1, 0x0c, 0x96 ], [ 0x89, 0xda, 0xe9, 0x26, 0x21, 0xba, 0x5a, 0x25, 0x9c, 0x6b, 0xe4, 0xc8, 0x2d, 0x0e, 0xee, 0xb1, 0x18, 0x51, 0xce, 0x00, 0xeb, 0x37, 0xda, 0xdf, 0x77, 0x0f, 0x68, 0xf4, 0x4a, 0x31, 0x0a, 0x9c ], [ 0x1f, 0xb0, 0x4d, 0xac, 0x75, 0xdf, 0x2a, 0x61, 0x6f, 0x49, 0x7f, 0xdd, 0x35, 0xce, 0x59, 0x29, 0xe6, 0x12, 0xf0, 0x51, 0x47, 0xdc, 0xa4, 0x18, 0x3e, 0x47, 0x86, 0xff, 0xd2, 0xae, 0x9b, 0x29 ], [ 0x2f, 0xfe, 0x28, 0x66, 0xd6, 0xfa, 0x82, 0xa7, 0x5d, 0x2f, 0xcf, 0x25, 0x72, 0x57, 0x70, 0x83, 0x36, 0x77, 0x56, 0x84, 0xaa, 0xce, 0x66, 0x25, 0xac, 0xe0, 0xed, 0x4a, 0x8f, 0xd8, 0x9e, 0x67 ], [ 0x77, 0x41, 0xd5, 0xc2, 0x1c, 0x34, 0xaf, 0x08, 0x30, 0x01, 0xdb, 0xde, 0x39, 0x22, 0xe7, 0x87, 0xb3, 0xd6, 0xed, 0x22, 0x42, 0xb8, 0x76, 0xfd, 0xae, 0x62, 0x66, 0xb7, 0xd7, 0xa9, 0x7c, 0x9b ], [ 0xa4, 0x8e, 0x8b, 0x31, 0x88, 0x56, 0x24, 0x0f, 0x5f, 0x70, 0x3a, 0x0d, 0x92, 0xa1, 0x9f, 0x8b, 0x26, 0xb0, 0x60, 0xd1, 0x3d, 0xbd, 0x80, 0xdd, 0xda, 0x54, 0xba, 0xec, 0x71, 0xe9, 0x6e, 0xab ], [ 0xaa, 0x13, 0xec, 0xf0, 0x99, 0xe5, 0x4e, 0x89, 0xa3, 0xac, 0x48, 0x61, 0x32, 0xa4, 0x1f, 0x57, 0x5e, 0x42, 0x22, 0x87, 0x72, 0x62, 0xaa, 0xc4, 0xf1, 0xef, 0xd1, 0x00, 0x55, 0xc8, 0x5e, 0xf2 ], [ 0xe3, 0xcb, 0x68, 0x2b, 0x03, 0x70, 0x8d, 0x53, 0xe2, 0x92, 0x03, 0xf7, 0x22, 0x80, 0x47, 0x89, 0xa6, 0xbb, 0x01, 0xbd, 0x09, 0x75, 0xa9, 0x67, 0x9f, 0x0c, 0x7f, 0x7d, 0x86, 0x84, 0xda, 0x3c ], [ 0x1a, 0xe5, 0x68, 0x06, 0xca, 0x98, 0x6f, 0xee, 0x10, 0x87, 0xce, 0xca, 0x88, 0xfc, 0x49, 0x52, 0x8a, 0xbe, 0x3b, 0x14, 0xdb, 0x9a, 0xc1, 0x08, 0x55, 0x55, 0x55, 0xc7, 0x87, 0x8e, 0xe7, 0xdb ], [ 0x6b, 0x0e, 0x40, 0x79, 0xb7, 0xe5, 0x87, 0xd7, 0x8e, 0x9b, 0x0c, 0x16, 0x01, 0xca, 0x54, 0x03, 0xef, 0x6f, 0xff, 0x52, 0x5e, 0x92, 0x38, 0x13, 0x10, 0x33, 0x20, 0x68, 0x2e, 0x7f, 0x27, 0x51 ], [ 0x67, 0x78, 0xbb, 0x3a, 0x3d, 0xef, 0x8c, 0x9f, 0xcf, 0xd0, 0x19, 0xce, 0x2f, 0x84, 0x02, 0x03, 0x94, 0x14, 0x61, 0xf3, 0xd1, 0x18, 0x91, 0x1e, 0xec, 0x77, 0xc7, 0x98, 0x6b, 0x44, 0x1c, 0xa1 ], [ 0xdb, 0x15, 0xeb, 0xb2, 0xc4, 0x68, 0x37, 0x6a, 0xf9, 0xac, 0x8c, 0xac, 0xac, 0xb7, 0xd2, 0x31, 0x69, 0x20, 0xb1, 0x4b, 0xe7, 0x46, 0x62, 0xdc, 0xea, 0xaa, 0xfc, 0xe0, 0x45, 0x0a, 0xed, 0xca ], [ 0xa0, 0xd2, 0x48, 0x0a, 0x7d, 0xd0, 0xc0, 0x02, 0xbb, 0xfa, 0xe6, 0x70, 0x61, 0x7a, 0x27, 0x73, 0x03, 0x1d, 0xe1, 0x28, 0x1f, 0xff, 0xcf, 0x8e, 0x44, 0x10, 0xe4, 0xf1, 0xc6, 0xce, 0x87, 0x38 ], [ 0x4d, 0x39, 0x5d, 0xea, 0x25, 0xb7, 0x2b, 0x03, 0x4b, 0xd5, 0xc2, 0xba, 0x67, 0x42, 0x5c, 0x84, 0xc1, 0x37, 0x0c, 0x58, 0x72, 0x75, 0xb9, 0x48, 0x55, 0x8d, 0x05, 0xa0, 0xc7, 0x7d, 0x2e, 0x7c ], [ 0xdc, 0x70, 0x60, 0x43, 0xcc, 0x23, 0x20, 0xd2, 0x20, 0x35, 0x79, 0x33, 0x44, 0xae, 0x01, 0xdd, 0x4d, 0x93, 0x67, 0x50, 0x6a, 0x5d, 0x07, 0xb6, 0xf6, 0x62, 0x7d, 0xe6, 0x13, 0xa0, 0xd2, 0x24 ], [ 0x23, 0x3f, 0xa7, 0x76, 0xf0, 0xab, 0x4f, 0x0b, 0xc9, 0x27, 0x7c, 0x72, 0x77, 0x01, 0x74, 0xd1, 0xbe, 0x3c, 0xa3, 0x86, 0x21, 0x58, 0x23, 0xf3, 0x44, 0xcc, 0x51, 0x9b, 0x38, 0x46, 0x85, 0x85 ], [ 0xb2, 0x58, 0x74, 0x64, 0xdb, 0x49, 0x2e, 0xec, 0x3c, 0x33, 0x03, 0x4a, 0x75, 0x4f, 0xc9, 0xcb, 0xd0, 0xb8, 0xff, 0xd4, 0xcd, 0x49, 0xd1, 0xbe, 0x50, 0x24, 0x94, 0x0c, 0xdb, 0xd3, 0x5c, 0x40 ], [ 0x55, 0xc2, 0xa6, 0xe7, 0x16, 0x23, 0xe3, 0x24, 0x46, 0xa2, 0xaf, 0x66, 0xd1, 0x3e, 0xb1, 0x74, 0x35, 0x9f, 0xee, 0x87, 0xdf, 0xa7, 0x9f, 0x0c, 0xfd, 0x0c, 0xea, 0x89, 0xdd, 0x4b, 0x58, 0x2d ], [ 0x62, 0x56, 0xed, 0xe6, 0x7e, 0x32, 0xe2, 0x23, 0x84, 0x5f, 0x10, 0xb8, 0xe1, 0xa0, 0x57, 0x0a, 0x9f, 0xeb, 0xe1, 0x01, 0x6a, 0x0c, 0x5b, 0x26, 0x5b, 0x3a, 0x03, 0x08, 0x20, 0x7d, 0xcc, 0xad ], [ 0x52, 0x04, 0x30, 0xff, 0x9e, 0x70, 0x66, 0x5d, 0xb9, 0x55, 0x21, 0x6d, 0x56, 0x2e, 0x78, 0x8d, 0xc8, 0xb6, 0xcf, 0x6a, 0xd6, 0x4d, 0x17, 0x42, 0x65, 0xea, 0x0d, 0x0f, 0xc7, 0xc4, 0xd8, 0x88 ], [ 0x49, 0x40, 0x4d, 0x86, 0xc6, 0xdf, 0x86, 0x53, 0x98, 0xeb, 0x5e, 0xef, 0xf3, 0xc5, 0x5e, 0x35, 0x3e, 0x7c, 0x61, 0x46, 0xbb, 0xc3, 0xf7, 0x5e, 0x63, 0xe9, 0xdd, 0x96, 0xd5, 0xfd, 0xb3, 0x40 ], [ 0x4a, 0x39, 0xd3, 0x7e, 0x5c, 0xea, 0xd0, 0x02, 0x20, 0x9e, 0x1e, 0xcb, 0x7f, 0xac, 0x5d, 0xfe, 0x20, 0xb0, 0xd5, 0xda, 0xc4, 0x50, 0x52, 0xac, 0x8f, 0x22, 0xf8, 0x7e, 0x46, 0xbf, 0xe2, 0xa4 ], [ 0x31, 0xd7, 0xde, 0x50, 0x4f, 0x3b, 0xc4, 0x41, 0x7a, 0x4d, 0xb9, 0x32, 0x23, 0x1b, 0x35, 0x09, 0x54, 0xa8, 0xe1, 0xec, 0x85, 0xa7, 0x99, 0xac, 0x1b, 0x16, 0x9a, 0x0e, 0xdb, 0xee, 0x24, 0xc8 ], [ 0xa7, 0x83, 0xfc, 0x87, 0xe5, 0x5a, 0x7f, 0xca, 0x96, 0xc2, 0xce, 0x5a, 0xa2, 0x77, 0x36, 0x15, 0x65, 0x58, 0x27, 0x03, 0xdf, 0xd1, 0x8d, 0xc1, 0x5a, 0xfa, 0x98, 0xbb, 0x0b, 0x60, 0x6a, 0xc6 ], [ 0x46, 0x01, 0xaa, 0x2b, 0xa0, 0xfa, 0x7e, 0x99, 0xc9, 0x3e, 0x0c, 0x9d, 0xbd, 0x44, 0x8f, 0xd1, 0xd9, 0x9c, 0xe5, 0x09, 0x8a, 0x6d, 0x1d, 0x8c, 0x9c, 0x21, 0x4d, 0xb6, 0x20, 0x6e, 0xd0, 0x52 ], [ 0xb2, 0x38, 0x06, 0xed, 0x16, 0xe3, 0xb3, 0xa3, 0x5b, 0x30, 0x30, 0xc9, 0x2f, 0xb6, 0x8f, 0x27, 0x54, 0xc4, 0x32, 0xcd, 0x87, 0xfb, 0x1f, 0xc2, 0xb8, 0xa0, 0x9f, 0xd5, 0x2b, 0x89, 0x02, 0x14 ], [ 0xf4, 0x33, 0x51, 0xde, 0x2b, 0x9b, 0xf9, 0x3f, 0x57, 0x35, 0xb1, 0x99, 0xf5, 0x6b, 0x7e, 0x10, 0xeb, 0x6b, 0x7a, 0x82, 0x40, 0xf9, 0x6a, 0xeb, 0x4b, 0x21, 0x34, 0x64, 0x86, 0x32, 0xe2, 0x8a ], [ 0xc2, 0x95, 0x1a, 0x92, 0xb7, 0xbe, 0x8c, 0xda, 0xee, 0xbe, 0x9b, 0xa2, 0x71, 0xbf, 0xf0, 0xcc, 0xcd, 0x1d, 0x5b, 0x13, 0xec, 0xa4, 0x5b, 0x62, 0xcd, 0x69, 0x72, 0x8a, 0xdf, 0x27, 0x23, 0xf4 ], [ 0x7b, 0x92, 0xa2, 0x1b, 0x33, 0x57, 0xbb, 0xcf, 0xa4, 0x2b, 0x33, 0x33, 0x88, 0xa4, 0x64, 0x78, 0xcd, 0x38, 0xef, 0xf6, 0x43, 0xeb, 0x5b, 0x81, 0x86, 0xdb, 0x23, 0x72, 0x82, 0x99, 0xe1, 0x5f ], [ 0x6a, 0x95, 0xd5, 0x32, 0x61, 0xca, 0x62, 0x10, 0xd4, 0xf2, 0x97, 0x3d, 0x20, 0x4f, 0x18, 0x62, 0xa4, 0x78, 0xb9, 0x19, 0xb4, 0x52, 0x0e, 0x30, 0xd4, 0x5f, 0x3a, 0xea, 0xb0, 0xe6, 0xe9, 0x2b ], [ 0x9e, 0x8a, 0xae, 0x70, 0x8a, 0xfd, 0x14, 0x89, 0x31, 0x88, 0x3f, 0xbb, 0xb2, 0x03, 0x60, 0xb5, 0xd4, 0x4a, 0xc7, 0xa3, 0x08, 0x3b, 0xaa, 0x3a, 0xfb, 0x53, 0xa4, 0xac, 0x0f, 0x2f, 0x47, 0x69 ], [ 0x43, 0x84, 0x1b, 0xd9, 0x49, 0xbb, 0x30, 0xeb, 0x9d, 0x52, 0xd1, 0x3e, 0x5c, 0x34, 0x82, 0x03, 0x90, 0xc6, 0x69, 0x18, 0x0a, 0x5f, 0xd4, 0xb3, 0x07, 0x69, 0xac, 0xc6, 0x46, 0x74, 0x4e, 0x2b ], [ 0x77, 0xfa, 0x5f, 0x7b, 0x82, 0xec, 0x32, 0xbe, 0x0b, 0x3d, 0xb9, 0xec, 0xee, 0x9e, 0x67, 0x44, 0x83, 0xed, 0x37, 0x0a, 0x43, 0x61, 0x6f, 0x81, 0xae, 0x19, 0x9c, 0xcb, 0x2f, 0xd2, 0x4c, 0x25 ], [ 0x9d, 0x38, 0x2f, 0x84, 0xfb, 0x27, 0x5f, 0xf8, 0x98, 0x31, 0x12, 0x84, 0xad, 0xcd, 0xc7, 0x9f, 0x2a, 0xe3, 0x63, 0xd1, 0xc3, 0x92, 0xfb, 0xaf, 0x9f, 0x8f, 0x28, 0x6e, 0x7d, 0xd8, 0xf1, 0x46 ], [ 0xc7, 0xe1, 0x2b, 0x52, 0x0a, 0xdf, 0xcd, 0x89, 0x65, 0xd4, 0xf0, 0x91, 0xaf, 0x25, 0x21, 0x7b, 0x31, 0xfb, 0xbb, 0xcc, 0xe7, 0x31, 0x53, 0x72, 0x15, 0xb7, 0x0b, 0xa5, 0x6e, 0x98, 0x3d, 0x50 ], [ 0x14, 0xd2, 0xf7, 0x12, 0xbb, 0x2a, 0xac, 0x8a, 0x77, 0xcf, 0x07, 0x11, 0xa4, 0xb6, 0x4a, 0x72, 0x99, 0x6d, 0x7e, 0x30, 0x9a, 0x11, 0xa3, 0xd9, 0x00, 0xd1, 0x65, 0x8f, 0x63, 0x7d, 0x40, 0xdc ], [ 0xa3, 0x85, 0x66, 0xd8, 0xc5, 0x83, 0xd7, 0xdf, 0x3b, 0x5a, 0x7a, 0x84, 0x68, 0x57, 0x62, 0xe9, 0x98, 0x24, 0x15, 0xfe, 0x31, 0x9d, 0x1d, 0x75, 0x77, 0xd9, 0xba, 0x0c, 0x94, 0x58, 0x46, 0xbb ], [ 0xb3, 0x12, 0x32, 0x4a, 0x75, 0xbc, 0x7b, 0x24, 0xa6, 0xda, 0x68, 0xe3, 0x0e, 0xe0, 0xf4, 0x46, 0x3a, 0x78, 0xbc, 0xd6, 0x92, 0x2e, 0x4a, 0xa0, 0xc8, 0xe7, 0x4b, 0x05, 0x1a, 0xe1, 0xe0, 0xeb ], [ 0x94, 0x40, 0x96, 0x72, 0x2c, 0x2a, 0x3e, 0x52, 0x13, 0xec, 0x70, 0x9f, 0xc5, 0xaa, 0x92, 0x91, 0x8f, 0x3f, 0x49, 0xc0, 0x4e, 0x3c, 0x75, 0x62, 0x3b, 0xb7, 0x88, 0x5f, 0xf6, 0x52, 0x9c, 0x56 ], [ 0x38, 0x5a, 0x07, 0x65, 0x13, 0x62, 0xb5, 0x36, 0x4d, 0x82, 0x6c, 0xd5, 0xae, 0x1e, 0x96, 0xde, 0xb7, 0x54, 0x1c, 0x67, 0xb6, 0xf4, 0x01, 0x6c, 0x59, 0x08, 0x23, 0xbb, 0xe4, 0x2d, 0x01, 0x6b ], [ 0xcd, 0x72, 0x7f, 0x71, 0xf2, 0x1a, 0x53, 0x72, 0x86, 0x0b, 0xe9, 0x71, 0x5a, 0x69, 0x90, 0xfd, 0x5b, 0x67, 0x0b, 0xe8, 0xae, 0x08, 0x31, 0x11, 0x95, 0x06, 0x2a, 0x12, 0x39, 0xe3, 0x20, 0x12 ], [ 0xd0, 0xff, 0x00, 0x59, 0x42, 0x81, 0xc8, 0x08, 0xbb, 0xec, 0x5d, 0x1f, 0xd0, 0xcc, 0xc8, 0xb6, 0x71, 0x36, 0x0b, 0x95, 0x33, 0x84, 0x61, 0x7f, 0xad, 0xee, 0x42, 0xa9, 0xb5, 0xd9, 0x85, 0x7e ], [ 0x55, 0x28, 0xe3, 0xd3, 0xd0, 0x58, 0x5d, 0x3f, 0xee, 0x3f, 0xcd, 0xe6, 0x75, 0xf3, 0x8c, 0x2d, 0x6d, 0x78, 0x91, 0xa9, 0xa8, 0xc4, 0x8e, 0x96, 0x95, 0x98, 0xdb, 0xfd, 0x71, 0x7e, 0x87, 0x49 ], [ 0x96, 0xf1, 0xb3, 0x77, 0x29, 0xd9, 0x20, 0x68, 0xd7, 0xb7, 0xb6, 0x63, 0xed, 0xae, 0x42, 0xbd, 0xfb, 0xc4, 0x3f, 0x58, 0x29, 0xf2, 0x07, 0xa9, 0xdc, 0xaf, 0xe0, 0x02, 0x30, 0x35, 0xca, 0xfd ], [ 0x6b, 0x11, 0x9a, 0x82, 0x4d, 0xf4, 0xe7, 0xea, 0x2a, 0x4b, 0x8f, 0x53, 0x5a, 0x46, 0x76, 0x5b, 0xbb, 0xaf, 0x93, 0xfe, 0x30, 0x4e, 0x78, 0x4c, 0xf4, 0xb8, 0x58, 0x59, 0x71, 0xa6, 0x39, 0x3a ], [ 0xb4, 0x43, 0x49, 0x57, 0xd3, 0xdd, 0x0b, 0x9e, 0x4f, 0x86, 0xbe, 0x93, 0x82, 0xf3, 0x05, 0xb5, 0xd0, 0xf5, 0xc2, 0x31, 0xd9, 0xc7, 0xa9, 0xd7, 0x52, 0xd0, 0x34, 0x15, 0x35, 0xdb, 0x3e, 0x08 ], [ 0xc2, 0xe4, 0xb8, 0xa4, 0x7e, 0xbc, 0x56, 0x86, 0x24, 0x6a, 0xcc, 0x32, 0xbb, 0xe1, 0x4c, 0x9d, 0xf8, 0x5d, 0x9e, 0xc4, 0x10, 0x9d, 0x94, 0xa8, 0xf0, 0x69, 0x7f, 0xc2, 0x6b, 0x65, 0xf4, 0x1e ], [ 0xe0, 0x94, 0xef, 0x60, 0x05, 0x7a, 0x3f, 0xa2, 0x38, 0x5b, 0x00, 0xb4, 0x1f, 0x0f, 0x6f, 0x22, 0xff, 0x6a, 0xd8, 0xdc, 0x2f, 0x75, 0xda, 0xf1, 0x6c, 0x10, 0x95, 0xd6, 0x7d, 0x54, 0xe6, 0xbc ], [ 0xbe, 0xf5, 0x75, 0xe3, 0xd2, 0x99, 0x92, 0x7d, 0x3f, 0x0a, 0x65, 0x6b, 0x29, 0xac, 0xf6, 0x41, 0x2f, 0x92, 0xf8, 0xc8, 0x60, 0x98, 0xba, 0xc1, 0x4d, 0xca, 0x9e, 0xa5, 0x3e, 0x38, 0x65, 0x72 ], [ 0xb0, 0xab, 0xd7, 0x34, 0xd1, 0xfd, 0x91, 0xa7, 0xec, 0x4b, 0x31, 0xf1, 0x5a, 0x10, 0x94, 0x20, 0xd3, 0xdd, 0xfa, 0xef, 0xd5, 0x9f, 0x4c, 0xca, 0x50, 0x50, 0xc4, 0xbb, 0x8a, 0xd9, 0x77, 0xb9 ], [ 0x6a, 0xfc, 0xf8, 0xe9, 0x65, 0x18, 0xc4, 0x8c, 0x7b, 0x40, 0xb1, 0x5e, 0x71, 0x79, 0xbe, 0xeb, 0xd3, 0xcc, 0x81, 0xf4, 0xe0, 0xd3, 0x6d, 0x5b, 0x97, 0x7a, 0xc6, 0x58, 0x74, 0x4e, 0x17, 0x80 ], [ 0xd5, 0xbc, 0xc7, 0x49, 0x81, 0x54, 0x12, 0x5a, 0x4a, 0x12, 0x21, 0x3f, 0xcd, 0x2a, 0x1a, 0x83, 0xaf, 0xd5, 0xaa, 0x6f, 0x60, 0x2a, 0x61, 0x4c, 0xfb, 0xb8, 0xd4, 0xd0, 0xef, 0xd6, 0x1d, 0x33 ], [ 0x54, 0x35, 0x28, 0x59, 0xc2, 0x1f, 0x76, 0x11, 0xae, 0xd8, 0x18, 0x70, 0xfe, 0x6a, 0x67, 0x5a, 0xf6, 0x46, 0x64, 0x3b, 0x2b, 0xe3, 0xeb, 0x4c, 0xf9, 0x4a, 0x19, 0x5e, 0xbe, 0x24, 0x96, 0x8b ], [ 0x49, 0xa2, 0x0f, 0x03, 0xd5, 0x82, 0x63, 0x48, 0x2e, 0x28, 0xc4, 0x45, 0x0c, 0x85, 0xb0, 0xb2, 0x33, 0x22, 0xee, 0x47, 0x24, 0x3a, 0xaa, 0xfa, 0x45, 0x8d, 0x1b, 0x7d, 0x3e, 0xb5, 0x0b, 0xaf ], [ 0x53, 0xc3, 0xe2, 0x0d, 0x72, 0xae, 0x95, 0xdd, 0x76, 0x68, 0xcd, 0xe4, 0xb4, 0x01, 0x06, 0x4b, 0x2e, 0x5c, 0xdc, 0xba, 0x84, 0xa5, 0x9e, 0x5e, 0x48, 0x0f, 0xc3, 0x42, 0x47, 0xeb, 0xeb, 0x2d ], [ 0xea, 0x41, 0xd6, 0xe9, 0x12, 0x53, 0xb0, 0xae, 0xfc, 0x47, 0x6c, 0x87, 0xdc, 0xc7, 0x75, 0xc1, 0x40, 0x82, 0x9f, 0x71, 0x8f, 0xb3, 0x3a, 0x67, 0xf1, 0x7c, 0x29, 0x3a, 0x9f, 0x8d, 0x04, 0xcc ], [ 0x99, 0x5c, 0xb6, 0xf4, 0x9a, 0x8b, 0xa5, 0x7a, 0x84, 0x1e, 0x0a, 0xa3, 0xc5, 0xbb, 0x04, 0xce, 0xf0, 0x1b, 0xd2, 0x8c, 0x3e, 0xc0, 0x7f, 0x0f, 0x6a, 0x9e, 0x86, 0xcc, 0xf0, 0x0e, 0x7d, 0x9f ], [ 0x6b, 0xae, 0x70, 0x93, 0x48, 0x6c, 0xa9, 0xc4, 0x0f, 0xe0, 0x63, 0xf0, 0x1a, 0x66, 0x59, 0x20, 0xdc, 0x13, 0xac, 0xa9, 0x02, 0x98, 0x6e, 0x64, 0x10, 0xd1, 0x24, 0xec, 0x01, 0xe8, 0x70, 0x6a ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" keys4_128bit = [ [ 0x66, 0xc2, 0x1c, 0x85, 0x9d, 0x40, 0xbc, 0x38, 0x47, 0x25, 0x62, 0x6c, 0x79, 0x3f, 0xe8, 0x82, 0xb0, 0xf1, 0x1a, 0x39, 0x7c, 0x63, 0xaa, 0xc2, 0x02, 0x6c, 0xc8, 0xda, 0x89, 0x16, 0xfb, 0xad ], [ 0x6c, 0x92, 0x1b, 0x4a, 0x18, 0xcc, 0x84, 0xab, 0xca, 0xfc, 0xd9, 0x82, 0x56, 0x65, 0xc7, 0xa0, 0xfe, 0x5f, 0x36, 0x51, 0xd5, 0x10, 0x99, 0xd1, 0x68, 0x07, 0x6c, 0x43, 0x4b, 0x49, 0x5f, 0x9c ], [ 0xb0, 0xcd, 0x92, 0x7d, 0xc5, 0x78, 0x48, 0x1b, 0x39, 0x17, 0x86, 0x38, 0xde, 0x7c, 0x87, 0x7a, 0xf7, 0xfe, 0x87, 0xa0, 0x4f, 0xfe, 0x7b, 0xfb, 0xcb, 0xf3, 0x31, 0xd1, 0x4f, 0x81, 0x7c, 0xa8 ], [ 0xe7, 0x82, 0x4f, 0x44, 0x6f, 0xbd, 0x4d, 0xd4, 0xe0, 0xbb, 0x40, 0x24, 0x69, 0x3f, 0x25, 0xd8, 0xba, 0x7a, 0x3e, 0x4b, 0x50, 0x2f, 0x06, 0x1c, 0x4f, 0xed, 0xed, 0x1a, 0x32, 0x8c, 0x49, 0x15 ], [ 0x83, 0xa2, 0x30, 0x39, 0xae, 0x08, 0xa9, 0xe1, 0x7b, 0x59, 0x63, 0xce, 0x9a, 0x90, 0x01, 0x54, 0xd5, 0xb0, 0x3f, 0xff, 0x19, 0xd0, 0xcb, 0xd9, 0x67, 0xe4, 0xe1, 0x47, 0xd5, 0x32, 0x16, 0x63 ], [ 0xf9, 0x82, 0x5b, 0xfc, 0x9c, 0xee, 0xa1, 0x13, 0xce, 0x39, 0x94, 0x86, 0x29, 0xde, 0x52, 0xa4, 0xfb, 0x49, 0x4a, 0xd1, 0x13, 0xdf, 0x94, 0x54, 0xb2, 0x9d, 0xba, 0x67, 0xb9, 0xf2, 0x6f, 0x7e ], [ 0x49, 0x34, 0xd6, 0xcc, 0xa2, 0x11, 0x80, 0x97, 0xa3, 0x84, 0xbf, 0x7f, 0x5f, 0x6b, 0x04, 0x5f, 0x02, 0x46, 0x77, 0x22, 0x37, 0x3a, 0x8c, 0x22, 0xb2, 0xed, 0x1c, 0xff, 0x0c, 0x4e, 0x3d, 0x04 ], [ 0x2e, 0x6f, 0x04, 0x49, 0x67, 0x8d, 0x5a, 0xb6, 0x36, 0x2e, 0xc3, 0x91, 0xc4, 0x5e, 0xc5, 0x66, 0x7a, 0xd1, 0x44, 0x0a, 0xd6, 0x58, 0xee, 0x1e, 0x81, 0x33, 0xd1, 0xf1, 0x60, 0x0a, 0xb1, 0xea ], [ 0x27, 0xea, 0x50, 0x14, 0x70, 0xb1, 0x97, 0x1e, 0xa9, 0x05, 0x8c, 0xb8, 0xf1, 0x0f, 0x81, 0x7c, 0xe0, 0xe5, 0xed, 0x13, 0x3a, 0x04, 0xbd, 0xa1, 0xd6, 0x22, 0xea, 0x23, 0x95, 0x90, 0xa2, 0xd5 ], [ 0x30, 0x23, 0x33, 0xa6, 0x72, 0x4a, 0xc6, 0x20, 0xa7, 0xdd, 0x30, 0x83, 0x56, 0x32, 0xbc, 0x5f, 0xcf, 0xf2, 0x27, 0x7a, 0x1f, 0x24, 0x37, 0x5d, 0x55, 0x92, 0x2b, 0x36, 0x78, 0x0c, 0xf7, 0x09 ], [ 0x88, 0xb1, 0x07, 0xde, 0xe1, 0x24, 0x93, 0x37, 0x9a, 0x03, 0x3b, 0xe0, 0xa4, 0x0f, 0xbe, 0xf0, 0x77, 0x51, 0x1a, 0xce, 0xf2, 0xc8, 0x53, 0x28, 0xe4, 0x09, 0x78, 0x67, 0xeb, 0xd2, 0xd9, 0x40 ], [ 0xa8, 0xe3, 0xf1, 0x47, 0x5a, 0xb7, 0xa6, 0x2b, 0x4c, 0xbe, 0xca, 0x78, 0x2a, 0xf4, 0xbd, 0xf8, 0x24, 0x6c, 0x00, 0xfb, 0xde, 0xd3, 0x54, 0x82, 0x6f, 0x6b, 0x16, 0xff, 0xf4, 0xf1, 0x6d, 0x10 ], [ 0xd3, 0x54, 0x63, 0xbd, 0x6e, 0xca, 0xd0, 0x3e, 0xad, 0x9a, 0x36, 0x63, 0x81, 0x7d, 0x62, 0x66, 0xa0, 0xdc, 0xf2, 0x4b, 0x2a, 0x17, 0x2e, 0x03, 0xa6, 0x1f, 0xd8, 0x65, 0x10, 0x4e, 0xef, 0xb8 ], [ 0x29, 0xed, 0x68, 0x97, 0x59, 0x11, 0xf8, 0xe4, 0x19, 0x69, 0x4f, 0xdf, 0x95, 0xb6, 0x28, 0xba, 0xc4, 0xb9, 0xc3, 0x26, 0xd7, 0xbc, 0x1a, 0x39, 0x8d, 0x32, 0x29, 0xe5, 0xa6, 0x32, 0x00, 0x05 ], [ 0xb3, 0xdc, 0xeb, 0x73, 0x2e, 0x60, 0x67, 0x05, 0x8e, 0x83, 0xe3, 0xc1, 0x5f, 0x8b, 0x15, 0x75, 0xaa, 0x1b, 0xf6, 0xce, 0x7b, 0xf4, 0x5e, 0x98, 0xf8, 0x19, 0x33, 0xeb, 0xb7, 0x15, 0xfb, 0x5d ], [ 0x68, 0xae, 0x99, 0x72, 0xfc, 0xa9, 0xdf, 0x71, 0x52, 0x3d, 0xbf, 0xe2, 0x5b, 0xca, 0x93, 0x5d, 0x0e, 0x50, 0x51, 0x67, 0xca, 0x93, 0x09, 0x14, 0xba, 0xb2, 0x2e, 0x94, 0xe7, 0xdd, 0xe5, 0x07 ], [ 0xce, 0x98, 0xcf, 0x88, 0xbd, 0xcf, 0x3f, 0x46, 0xe2, 0x33, 0x22, 0x24, 0x88, 0xcf, 0x76, 0x45, 0x7f, 0xff, 0x23, 0x4f, 0x9d, 0x3e, 0x81, 0xbb, 0xf4, 0xb3, 0x2c, 0x86, 0x23, 0x23, 0x37, 0x7e ], [ 0x71, 0xeb, 0x59, 0x75, 0xe7, 0x1f, 0xd9, 0xe6, 0x0a, 0xc9, 0x8c, 0xc2, 0x4c, 0x51, 0xaa, 0x7d, 0x5c, 0xd3, 0x54, 0x81, 0xec, 0xe1, 0x20, 0x8b, 0x82, 0xf6, 0x40, 0x06, 0xfd, 0x6c, 0xa3, 0x0b ], [ 0x45, 0x8b, 0x60, 0x27, 0x13, 0xba, 0x0a, 0x0e, 0x77, 0xb5, 0x80, 0xf0, 0x34, 0x7a, 0xd1, 0x77, 0xf9, 0xda, 0x3e, 0x02, 0xea, 0xbf, 0xc3, 0xfc, 0x25, 0x9c, 0x1e, 0x0e, 0xcc, 0xb7, 0x0e, 0xc1 ], [ 0xe7, 0xc5, 0x92, 0x65, 0x97, 0x1f, 0x52, 0xce, 0xb4, 0x24, 0x19, 0xd1, 0x1d, 0xcd, 0x3c, 0xa4, 0x26, 0x00, 0x7e, 0x00, 0x90, 0x85, 0x54, 0xed, 0x0a, 0x4f, 0x66, 0x4f, 0x8b, 0x57, 0xb9, 0xd3 ], [ 0xdc, 0x6e, 0x16, 0x0d, 0x75, 0x07, 0x70, 0x74, 0xc0, 0x29, 0xa0, 0x85, 0x0b, 0x19, 0xf1, 0x55, 0x74, 0x3b, 0x29, 0x54, 0x58, 0x4e, 0xfa, 0xca, 0x1f, 0x3f, 0x87, 0xa5, 0xe0, 0xbb, 0x2c, 0x40 ], [ 0x18, 0x65, 0xff, 0x2c, 0x5a, 0xa7, 0x5a, 0x2a, 0xb4, 0x1c, 0x75, 0x25, 0x18, 0xb9, 0xcb, 0x19, 0x34, 0x0d, 0xd3, 0x78, 0x5c, 0xc7, 0x26, 0xc6, 0xb6, 0x49, 0xf2, 0x8e, 0xe6, 0x19, 0xc8, 0x7a ], [ 0xde, 0x5c, 0xd9, 0xbe, 0x60, 0x43, 0x52, 0x01, 0x83, 0x81, 0x7e, 0xed, 0xfa, 0x97, 0x03, 0xa9, 0xdb, 0xba, 0x13, 0xfc, 0x08, 0xca, 0x63, 0x76, 0xb0, 0xbc, 0x60, 0x1a, 0x8f, 0x2d, 0x12, 0x87 ], [ 0x55, 0x8f, 0x8c, 0xd8, 0x31, 0x44, 0xe5, 0x43, 0x98, 0xab, 0xad, 0xbc, 0xa6, 0xbb, 0x38, 0x60, 0xca, 0x21, 0xc1, 0x2c, 0x7b, 0xaf, 0x0e, 0xd3, 0xcb, 0x7f, 0xa7, 0xff, 0xf8, 0x82, 0xc4, 0x64 ], [ 0x97, 0x51, 0x7a, 0xe1, 0xc7, 0x80, 0x09, 0x0b, 0x39, 0x3e, 0xd4, 0x89, 0x80, 0xb9, 0xde, 0x5a, 0xc6, 0xf2, 0xfa, 0x82, 0x21, 0x0f, 0xdd, 0x1c, 0xde, 0xeb, 0xfd, 0xd8, 0x7e, 0xf4, 0x98, 0x6b ], [ 0xf6, 0x96, 0x8f, 0x71, 0x19, 0x68, 0x2d, 0xda, 0x3a, 0xf9, 0x45, 0xe5, 0xbc, 0x4c, 0x88, 0xdc, 0x3e, 0x38, 0xa2, 0x06, 0x93, 0x80, 0x9f, 0x08, 0x1d, 0x43, 0x65, 0xc3, 0xdc, 0x92, 0x20, 0xcb ], [ 0xb9, 0xb9, 0xb7, 0x72, 0x4b, 0x42, 0xab, 0xed, 0xf2, 0x1a, 0x1a, 0xa5, 0x0c, 0xf9, 0x9d, 0xe0, 0xb2, 0x50, 0x22, 0xcc, 0x55, 0xe5, 0x41, 0x89, 0xf1, 0xf4, 0xb0, 0x98, 0x2c, 0x21, 0x2a, 0xf1 ], [ 0xff, 0xe2, 0x9c, 0x15, 0x31, 0xde, 0x9f, 0x1e, 0x53, 0xf8, 0x02, 0xb4, 0x38, 0x66, 0x34, 0x46, 0x0c, 0xdd, 0x10, 0x77, 0xb8, 0x30, 0x18, 0xa3, 0xf2, 0x83, 0x4e, 0x9e, 0x55, 0x95, 0x81, 0x33 ], [ 0x01, 0x7f, 0x16, 0xff, 0xce, 0x63, 0x2b, 0xf3, 0xef, 0x31, 0xde, 0x37, 0x31, 0xc1, 0xfc, 0x66, 0x9a, 0x01, 0x46, 0xe9, 0x39, 0x4a, 0xf5, 0x64, 0xe4, 0x20, 0x01, 0x59, 0x29, 0x9e, 0x87, 0xc3 ], [ 0x82, 0x51, 0xf4, 0xa5, 0x4e, 0x02, 0x66, 0x81, 0x9c, 0x65, 0x38, 0xe8, 0xad, 0xc2, 0xb0, 0xb4, 0x95, 0x90, 0x69, 0xd5, 0x7e, 0x7f, 0xb1, 0x21, 0x78, 0xa2, 0x21, 0xd2, 0x34, 0xad, 0x69, 0xdc ], [ 0xb6, 0xcb, 0xdd, 0x64, 0xd6, 0x19, 0x13, 0xf9, 0x05, 0x40, 0x2b, 0xf5, 0x9e, 0x7c, 0x24, 0x38, 0x37, 0x3c, 0xca, 0xf6, 0x97, 0xc7, 0xaf, 0x93, 0x45, 0x80, 0x85, 0x7a, 0x9d, 0x3b, 0x86, 0xf3 ], [ 0xa2, 0x9a, 0xcc, 0x4a, 0x74, 0xef, 0x70, 0x44, 0xf5, 0x25, 0xa1, 0x61, 0xe4, 0x3f, 0xa9, 0x6c, 0x30, 0x19, 0x96, 0xc3, 0xd6, 0x56, 0xac, 0x50, 0xe2, 0xff, 0x69, 0x07, 0xf0, 0x54, 0x8c, 0xc9 ], [ 0x3b, 0xec, 0x22, 0x04, 0x0d, 0x78, 0xe4, 0xeb, 0x50, 0xfe, 0x12, 0x12, 0x03, 0x2b, 0xb5, 0x52, 0x52, 0x29, 0x7a, 0xc6, 0x7d, 0xc0, 0x26, 0x4c, 0x13, 0x24, 0x58, 0xb5, 0x76, 0x18, 0xa8, 0x5d ], [ 0x0b, 0x8e, 0x6a, 0x32, 0xa9, 0x70, 0x9b, 0x77, 0xea, 0xd7, 0x82, 0xeb, 0x1a, 0x5f, 0x09, 0x6d, 0x53, 0x15, 0xe3, 0xae, 0xe9, 0xe2, 0xa7, 0x2a, 0x1b, 0x55, 0x2a, 0x77, 0x19, 0xa1, 0x32, 0xef ], [ 0xd8, 0x6e, 0x38, 0xf2, 0xf2, 0xac, 0x28, 0xf5, 0xd2, 0x1d, 0xe9, 0x8d, 0xeb, 0x90, 0x8a, 0xff, 0xac, 0xd6, 0x02, 0x45, 0x6a, 0x1c, 0x06, 0xe6, 0x4c, 0x1f, 0x7a, 0x00, 0xdf, 0x1f, 0x62, 0xfe ], [ 0x57, 0x02, 0x7d, 0xde, 0x15, 0x77, 0x2e, 0x4e, 0x8d, 0xe7, 0x31, 0xd4, 0x1c, 0xa4, 0xc6, 0xbd, 0xb5, 0x8b, 0xf8, 0x20, 0x6f, 0x5d, 0xd1, 0x8e, 0xf8, 0xff, 0x0c, 0x7c, 0xfe, 0xa0, 0xfa, 0x2c ], [ 0x9b, 0x59, 0x60, 0x6f, 0xf3, 0x63, 0x74, 0x86, 0x6a, 0xc6, 0x69, 0xde, 0x69, 0x33, 0xd3, 0x9b, 0xaf, 0x3c, 0x36, 0xba, 0x46, 0xda, 0xf2, 0xdb, 0xdb, 0x58, 0x48, 0x70, 0x44, 0xec, 0x70, 0xc0 ], [ 0xb2, 0x9f, 0xa8, 0xfd, 0xe6, 0xef, 0xc2, 0xf6, 0x6d, 0xf9, 0xe5, 0xe5, 0x91, 0xba, 0x81, 0x8c, 0x15, 0xa8, 0x23, 0x58, 0xd6, 0x36, 0x5c, 0x4f, 0x58, 0xfd, 0x2f, 0x31, 0xf2, 0x54, 0xbc, 0xd9 ], [ 0x80, 0x59, 0x38, 0x64, 0x1a, 0xb6, 0xdb, 0xb6, 0x8e, 0xd1, 0x5c, 0xb0, 0x89, 0x6f, 0x29, 0x01, 0x09, 0x06, 0x4e, 0xec, 0x64, 0x17, 0xfc, 0x0b, 0xa8, 0xdc, 0xb4, 0x83, 0x43, 0xa1, 0xa8, 0xe7 ], [ 0x91, 0x63, 0x9e, 0xf6, 0x65, 0x1a, 0x2d, 0xbb, 0x25, 0x0b, 0x81, 0xc8, 0x65, 0x01, 0x0a, 0xc8, 0xf2, 0x11, 0x62, 0xfe, 0x56, 0x8d, 0x0d, 0x63, 0x3d, 0x0e, 0x92, 0xa4, 0xd5, 0x56, 0x5e, 0x29 ], [ 0x15, 0x13, 0x49, 0x76, 0x5b, 0x21, 0x1a, 0xa4, 0x1a, 0xbf, 0x33, 0x42, 0x20, 0xa2, 0xc6, 0xcc, 0x8d, 0x04, 0xa4, 0x52, 0xa3, 0x5e, 0x4f, 0x3f, 0x69, 0x96, 0x46, 0x58, 0x44, 0x56, 0x8e, 0x89 ], [ 0xb4, 0xb0, 0xdc, 0x42, 0xb4, 0x21, 0x78, 0x9a, 0x68, 0xb4, 0xc8, 0x49, 0x1d, 0xda, 0x3c, 0x21, 0xe1, 0x3e, 0x0b, 0x5a, 0x1b, 0xa6, 0xd1, 0x52, 0x35, 0x96, 0x9b, 0x14, 0xeb, 0x3c, 0x47, 0x8e ], [ 0x76, 0x8c, 0x72, 0xe3, 0xe8, 0x6e, 0xec, 0x02, 0x11, 0x0d, 0xb6, 0xc7, 0x1a, 0x2b, 0xf0, 0xdc, 0x9b, 0xaf, 0xa0, 0x05, 0x39, 0x26, 0x4b, 0xd8, 0x76, 0x41, 0x0e, 0x56, 0x10, 0xd2, 0xfc, 0xea ], [ 0x4a, 0x59, 0xa6, 0x12, 0x08, 0xa6, 0x2a, 0xa7, 0x56, 0x1c, 0x01, 0xec, 0xef, 0x00, 0xf1, 0x50, 0x03, 0xa8, 0xa5, 0x5a, 0x9c, 0x1c, 0xed, 0x6c, 0x54, 0x94, 0x6c, 0x1a, 0xc4, 0x70, 0x22, 0x94 ], [ 0x3f, 0xd8, 0x1a, 0x57, 0x4f, 0xc6, 0x8a, 0x8a, 0x1e, 0x4a, 0xe7, 0x32, 0xf6, 0xb8, 0x17, 0x8f, 0x42, 0x6c, 0x98, 0x11, 0x40, 0xa9, 0xbf, 0x5f, 0x0b, 0x04, 0x4b, 0x84, 0x8f, 0xb5, 0x9f, 0xc2 ], [ 0xfa, 0x7c, 0x43, 0x4a, 0x32, 0x16, 0xe9, 0x05, 0x5f, 0xbb, 0x38, 0x24, 0x12, 0x37, 0x88, 0x51, 0x16, 0xa9, 0xf1, 0x2e, 0xbf, 0xe1, 0x94, 0x4a, 0x3d, 0x92, 0x7b, 0xb8, 0x80, 0xbe, 0x92, 0x80 ], [ 0x30, 0x11, 0xd3, 0x36, 0x2d, 0xbd, 0xa3, 0x76, 0x84, 0x49, 0x12, 0x82, 0xfd, 0xa9, 0xa3, 0x23, 0x85, 0xcb, 0xc9, 0x45, 0x22, 0xb7, 0x24, 0x24, 0xf4, 0xb2, 0xbe, 0x81, 0x71, 0x4c, 0x6c, 0x80 ], [ 0x87, 0x71, 0x49, 0x40, 0xa5, 0x1d, 0xfc, 0x50, 0x8e, 0x5c, 0x27, 0x23, 0xbe, 0x59, 0xd0, 0x08, 0xc7, 0xa3, 0xed, 0x32, 0xe1, 0x1b, 0xca, 0xb7, 0x0a, 0xca, 0x32, 0x44, 0x0d, 0x40, 0x1f, 0x5f ], [ 0x91, 0x65, 0x26, 0x88, 0xae, 0x04, 0x9f, 0x61, 0xe7, 0x42, 0x07, 0x5a, 0xb7, 0x7d, 0x16, 0xa8, 0xb3, 0xcb, 0x10, 0x43, 0xc1, 0x57, 0xef, 0x35, 0x77, 0xc3, 0x18, 0x91, 0x71, 0x30, 0x58, 0x9b ], [ 0x53, 0xc6, 0x94, 0x9a, 0xc9, 0xaa, 0x4a, 0x6f, 0x0a, 0x9b, 0x8a, 0xe3, 0xe9, 0xf5, 0x0f, 0x95, 0xb9, 0xe2, 0x0c, 0x72, 0xbe, 0x61, 0x7f, 0x89, 0x5a, 0x4b, 0x0a, 0x13, 0x2d, 0x77, 0x21, 0xd0 ], [ 0xc9, 0x99, 0x2c, 0xe9, 0x80, 0x71, 0xa5, 0xfe, 0x5a, 0x8a, 0xa6, 0xd1, 0x01, 0xc9, 0xcb, 0x18, 0xea, 0x7b, 0x1f, 0xfd, 0x00, 0xbc, 0x65, 0xf8, 0xbe, 0xa7, 0xbc, 0x8e, 0x08, 0xe7, 0xda, 0x03 ], [ 0xcb, 0xb0, 0xc1, 0x89, 0x73, 0x90, 0xf7, 0x27, 0x30, 0x3e, 0x3d, 0xc7, 0xfe, 0xef, 0xd1, 0x7c, 0x5e, 0x34, 0x34, 0x62, 0xc5, 0x45, 0x66, 0x21, 0xe2, 0x87, 0x21, 0x84, 0xd9, 0x2d, 0x78, 0xbe ], [ 0xae, 0x85, 0xc9, 0x23, 0x7a, 0xff, 0xeb, 0xe6, 0x5f, 0xb8, 0x8c, 0xdd, 0x98, 0x37, 0x90, 0xb1, 0x92, 0x84, 0x17, 0x87, 0xb5, 0xf7, 0x53, 0x6d, 0x3f, 0x27, 0x77, 0xee, 0x7b, 0x9a, 0xdf, 0x01 ], [ 0x9c, 0x18, 0xfd, 0x6d, 0x4b, 0x35, 0xad, 0x0b, 0x17, 0x94, 0x81, 0xd3, 0x09, 0xf1, 0xcb, 0xd0, 0xd0, 0x31, 0xf4, 0x8b, 0xa8, 0x46, 0x97, 0x16, 0x5f, 0x2b, 0xd9, 0xdc, 0xa5, 0xb8, 0x36, 0x77 ], [ 0x12, 0x09, 0x1a, 0x52, 0xac, 0x13, 0x70, 0x30, 0x67, 0x33, 0xe5, 0x8e, 0xc4, 0x24, 0x14, 0x27, 0x7e, 0x78, 0x38, 0xdd, 0x16, 0x18, 0x44, 0x50, 0x47, 0x5a, 0x6c, 0xc4, 0x4a, 0x6e, 0x84, 0xac ], [ 0x0d, 0x3c, 0x11, 0x8c, 0x02, 0x5b, 0xed, 0x7f, 0x73, 0xea, 0xd5, 0x1c, 0xe8, 0xa2, 0x33, 0xda, 0xb5, 0x9b, 0xfb, 0xc9, 0x16, 0xd0, 0x78, 0xa2, 0x0c, 0x8f, 0x76, 0x8b, 0x05, 0x4d, 0xef, 0xbb ], [ 0xe1, 0xf0, 0x1b, 0xc4, 0x5a, 0xd8, 0x77, 0x17, 0xd8, 0x9b, 0xbf, 0xde, 0x15, 0x5d, 0xaa, 0x3e, 0xdd, 0x8f, 0x66, 0x79, 0x3a, 0xe2, 0x05, 0xcb, 0x79, 0xf6, 0xab, 0xc5, 0x8f, 0x90, 0xe4, 0x18 ], [ 0xcb, 0x33, 0x43, 0xbf, 0x74, 0x9f, 0xfe, 0x1f, 0x18, 0x29, 0x19, 0x56, 0xb2, 0x2e, 0x7f, 0x2e, 0xe5, 0x8e, 0x7f, 0x1b, 0x3c, 0x35, 0x1a, 0x33, 0x61, 0xb3, 0x26, 0xef, 0x73, 0xd5, 0xd2, 0x63 ], [ 0xe2, 0xa0, 0xff, 0x54, 0x17, 0x9e, 0x85, 0xa0, 0xdb, 0x18, 0xa4, 0x21, 0xf8, 0xc6, 0x0e, 0x57, 0xdb, 0x39, 0x03, 0xc0, 0x9e, 0x47, 0x62, 0x28, 0xc1, 0xb5, 0x8e, 0xd1, 0x5c, 0xe3, 0xfc, 0xa8 ], [ 0xba, 0xfd, 0x1d, 0x16, 0x99, 0x37, 0x45, 0x67, 0xb0, 0x88, 0xc3, 0xd9, 0x76, 0x31, 0x5b, 0x75, 0x16, 0x1a, 0x57, 0x38, 0xff, 0x53, 0x7a, 0x86, 0x8a, 0x3f, 0xfd, 0x88, 0x01, 0x68, 0x73, 0xd3 ], [ 0x9c, 0xc0, 0x6d, 0x59, 0x2c, 0x3d, 0xf5, 0x30, 0x97, 0xff, 0xcd, 0x75, 0x55, 0xd4, 0xf2, 0x8d, 0xec, 0x1b, 0x56, 0xe4, 0xd6, 0xbd, 0x70, 0xcb, 0xea, 0x85, 0x40, 0x6e, 0xbe, 0x87, 0x7d, 0xf0 ], [ 0xc4, 0x79, 0x95, 0x56, 0xed, 0xf5, 0x23, 0x1e, 0x46, 0xf6, 0x48, 0x18, 0x2b, 0x38, 0x66, 0xe9, 0x25, 0x7c, 0xd1, 0x66, 0x10, 0x01, 0x31, 0xa0, 0x79, 0x6b, 0x4c, 0x20, 0x4c, 0x96, 0xaa, 0x15 ], [ 0x1a, 0x67, 0x43, 0x9e, 0xb0, 0x5b, 0xef, 0x08, 0x6b, 0x57, 0xdf, 0xf8, 0xf7, 0x9a, 0x09, 0xcb, 0xac, 0x98, 0x2d, 0xaa, 0xfa, 0x8f, 0x69, 0x7d, 0x25, 0x0c, 0x5a, 0xff, 0xc4, 0x3f, 0x44, 0x66 ], [ 0xbd, 0x63, 0xa6, 0x71, 0x80, 0xa0, 0x25, 0xaa, 0xc2, 0x5c, 0x73, 0x81, 0xea, 0xb4, 0xd6, 0x77, 0xa5, 0x9b, 0x6c, 0x22, 0x3d, 0xc8, 0x56, 0x88, 0x47, 0x17, 0x9d, 0xcb, 0x49, 0x16, 0x93, 0xdf ], [ 0xa7, 0x3f, 0xaf, 0x2a, 0x96, 0x8b, 0xc0, 0x87, 0x45, 0x98, 0x8a, 0x54, 0xc9, 0x46, 0x49, 0xcc, 0xb1, 0x49, 0xde, 0x0e, 0x52, 0x2e, 0x31, 0x6a, 0x0b, 0x04, 0x6b, 0xed, 0x45, 0x3d, 0xd5, 0xcf ], [ 0xb0, 0x24, 0x35, 0xad, 0x97, 0xba, 0x36, 0xea, 0x88, 0x55, 0x38, 0x32, 0xe7, 0x6b, 0xc2, 0xfc, 0xa7, 0x54, 0xb9, 0x86, 0x9f, 0xb5, 0x13, 0x91, 0x15, 0xff, 0xbc, 0x02, 0xeb, 0x57, 0xf2, 0x83 ], [ 0x1d, 0xc8, 0x36, 0x90, 0xaa, 0xf4, 0x30, 0x46, 0x6c, 0xe0, 0xb1, 0xda, 0x4b, 0x1a, 0x7c, 0x45, 0xdb, 0xb6, 0x98, 0x70, 0xc2, 0x00, 0x66, 0x20, 0xb5, 0x2c, 0x7a, 0xe9, 0x0d, 0x56, 0xca, 0xab ], [ 0x0b, 0xde, 0x61, 0xa2, 0x5c, 0x97, 0x12, 0x71, 0x88, 0xfc, 0x41, 0xbc, 0x2f, 0xe1, 0x34, 0xea, 0x90, 0x4c, 0x48, 0xb2, 0xc3, 0x50, 0xf9, 0x5a, 0x75, 0x24, 0xd2, 0x2b, 0x5c, 0xed, 0x1a, 0x1a ], [ 0x8c, 0x8a, 0x18, 0xeb, 0x06, 0xc5, 0xa6, 0x7a, 0xf2, 0x8d, 0x7c, 0x93, 0x54, 0x14, 0x32, 0x42, 0x64, 0xa9, 0x52, 0xba, 0xd1, 0x95, 0xc8, 0x28, 0x1d, 0x7c, 0x5a, 0xf2, 0xa4, 0x2f, 0x3b, 0xc1 ], [ 0x78, 0x7d, 0x59, 0xd0, 0xaa, 0x52, 0x85, 0x51, 0x75, 0xb4, 0xe8, 0x55, 0xef, 0x72, 0xea, 0x33, 0x1d, 0x79, 0xe1, 0x9f, 0xe3, 0xfa, 0x8d, 0x4b, 0xd8, 0xba, 0x2c, 0x0b, 0x8a, 0x47, 0x34, 0x4d ], [ 0x00, 0x27, 0x9a, 0x16, 0x17, 0x4d, 0x2a, 0x2f, 0x34, 0x38, 0x8a, 0x9e, 0x68, 0x5c, 0xf0, 0xc7, 0x94, 0x95, 0xab, 0x57, 0xed, 0x7c, 0x6f, 0x33, 0xda, 0xa1, 0x77, 0x37, 0xd8, 0x7e, 0x5d, 0xa0 ], [ 0x0c, 0xdb, 0x4d, 0xa7, 0x2e, 0x0c, 0x99, 0xca, 0xb4, 0xd8, 0x20, 0x3c, 0x48, 0xf7, 0x4f, 0xec, 0x64, 0x41, 0xcf, 0xf0, 0x20, 0x77, 0x0f, 0xfe, 0x3e, 0xeb, 0x91, 0x39, 0x40, 0x6e, 0x29, 0x4c ], [ 0x85, 0xe0, 0x08, 0xce, 0x75, 0xb9, 0x04, 0x3a, 0x20, 0x67, 0x92, 0x6b, 0xfe, 0xb6, 0x36, 0xcd, 0xe9, 0x01, 0x90, 0x09, 0x2a, 0xef, 0x04, 0xc1, 0x9b, 0x3f, 0x00, 0x91, 0x83, 0x9e, 0xe9, 0x74 ], [ 0xe1, 0xd1, 0x3a, 0x25, 0x25, 0x4f, 0x02, 0x58, 0xb7, 0x7d, 0xe2, 0x56, 0xb3, 0x32, 0x83, 0x67, 0x62, 0xf3, 0x6e, 0xa9, 0xbc, 0x5b, 0x95, 0x3f, 0x7c, 0xee, 0xa8, 0x9e, 0x3b, 0xf3, 0x69, 0xd1 ], [ 0xa6, 0xb5, 0x39, 0x28, 0x36, 0x4a, 0xbd, 0x3e, 0x57, 0x2f, 0x53, 0x4c, 0xb5, 0x0e, 0x7c, 0x3e, 0xb8, 0x7a, 0x56, 0x02, 0xe1, 0xcf, 0xda, 0xbb, 0x59, 0x45, 0x37, 0xb8, 0x07, 0xb4, 0x18, 0x54 ], [ 0x83, 0x14, 0xa8, 0xb3, 0x3c, 0xde, 0xb8, 0x9c, 0xeb, 0xc2, 0x98, 0xd3, 0x05, 0x1c, 0xa8, 0xb7, 0xf9, 0xf7, 0x43, 0x67, 0x67, 0xfa, 0xa1, 0x95, 0xfc, 0xbf, 0xef, 0x26, 0x34, 0x1d, 0x4e, 0x79 ], [ 0xdc, 0x90, 0x7c, 0xbd, 0x96, 0x3b, 0x7a, 0x71, 0xe4, 0xe4, 0xf9, 0x77, 0x08, 0x36, 0xb5, 0xdc, 0xa0, 0x05, 0xc8, 0x85, 0x0d, 0xf0, 0x35, 0xb3, 0xdb, 0x83, 0x96, 0xd3, 0x73, 0xf4, 0x9e, 0xdc ], [ 0x71, 0x48, 0x7f, 0x76, 0xa3, 0xdd, 0x10, 0xfd, 0xda, 0xa5, 0x48, 0xe8, 0xb0, 0x40, 0x08, 0x84, 0xd4, 0x7e, 0x12, 0x1d, 0xe4, 0xc8, 0x01, 0xc1, 0x84, 0x37, 0x8d, 0x2a, 0xed, 0x6d, 0xce, 0x2b ], [ 0x00, 0xeb, 0x1b, 0xd4, 0x69, 0xc8, 0x75, 0x76, 0x4f, 0xea, 0x1b, 0xe8, 0x7f, 0x1b, 0x8f, 0xc6, 0xfe, 0xf1, 0x02, 0x38, 0xd0, 0x72, 0x68, 0xcc, 0x3e, 0xff, 0x5b, 0xab, 0x54, 0x25, 0x88, 0x4c ], [ 0x79, 0xd4, 0x42, 0x77, 0xee, 0x9d, 0x9c, 0xf7, 0x5b, 0x5a, 0x6b, 0x5b, 0x4d, 0xe2, 0xb4, 0x0f, 0x37, 0xf9, 0xdc, 0x69, 0x73, 0x75, 0x69, 0xb5, 0x0c, 0x69, 0x70, 0xa5, 0x7e, 0x25, 0x15, 0x0e ], [ 0x3b, 0xb8, 0x24, 0xa6, 0x05, 0xeb, 0x8a, 0x86, 0xc7, 0x6d, 0xd1, 0xfe, 0xec, 0x68, 0x7d, 0xfa, 0x76, 0x2d, 0x8c, 0xee, 0xd8, 0xd8, 0xf7, 0x55, 0x55, 0x47, 0x91, 0xee, 0x72, 0xa1, 0xfa, 0xd7 ], [ 0xc0, 0x7f, 0x4e, 0xf1, 0x09, 0x7c, 0xdf, 0xc0, 0x80, 0x40, 0xf9, 0x23, 0xb4, 0x96, 0x57, 0x51, 0xbd, 0x1f, 0xdc, 0xab, 0x7f, 0x75, 0x81, 0x44, 0xf6, 0x5c, 0x9c, 0xbb, 0x42, 0x41, 0xc7, 0x82 ], [ 0x7c, 0x41, 0x87, 0x9b, 0xc7, 0x21, 0xd9, 0x5f, 0x30, 0xd1, 0x04, 0x95, 0x79, 0xd4, 0xa4, 0xc5, 0x47, 0xd7, 0x55, 0xea, 0x5b, 0xbc, 0x56, 0xad, 0x06, 0x35, 0xba, 0x6f, 0x2a, 0xe9, 0xd8, 0xdb ], [ 0x9f, 0x8f, 0x6a, 0x66, 0xcc, 0x63, 0x57, 0x62, 0xab, 0x9f, 0x4e, 0xc6, 0xda, 0x60, 0x46, 0x22, 0xca, 0x44, 0xc7, 0x46, 0x37, 0xa3, 0xd8, 0x5e, 0x21, 0x8a, 0x59, 0x85, 0x12, 0x21, 0xfc, 0xd0 ], [ 0x2b, 0x11, 0x4d, 0x9e, 0xae, 0xd8, 0xc0, 0x0f, 0x40, 0xaa, 0x00, 0x0a, 0x75, 0x13, 0x99, 0xb8, 0xde, 0x58, 0x0b, 0x46, 0x74, 0xf3, 0xfd, 0xb5, 0x74, 0xc1, 0x80, 0xfc, 0x7e, 0x38, 0xed, 0x31 ], [ 0x40, 0x73, 0xc0, 0x03, 0xc7, 0xfd, 0x55, 0x8b, 0x26, 0x27, 0xc9, 0xd0, 0x91, 0xdb, 0x85, 0x13, 0x16, 0xd7, 0x43, 0xb9, 0x19, 0x1b, 0xa9, 0x70, 0x05, 0x33, 0x47, 0x57, 0x0f, 0xa2, 0xbb, 0xa0 ], [ 0xbf, 0xda, 0xeb, 0xb9, 0x88, 0x70, 0x23, 0xd3, 0x89, 0xc9, 0x04, 0x3d, 0x3a, 0x37, 0x09, 0x3a, 0xc3, 0x88, 0xb7, 0x1d, 0x25, 0x58, 0xdd, 0x2f, 0x28, 0xb6, 0x5f, 0x08, 0xd6, 0x21, 0x09, 0xcb ], [ 0x39, 0x4d, 0xeb, 0x25, 0x2b, 0x48, 0x82, 0xae, 0x84, 0x74, 0x13, 0xa0, 0x47, 0xbf, 0x2b, 0xe0, 0x29, 0xc5, 0x75, 0x77, 0x8f, 0xbf, 0x1f, 0x16, 0x2d, 0x2e, 0xe2, 0xa6, 0x95, 0x0b, 0xf1, 0x05 ], [ 0xe9, 0x6f, 0x5b, 0xb4, 0x37, 0x00, 0x1f, 0xe2, 0x4e, 0xa6, 0x1e, 0xdb, 0x54, 0xc5, 0x8f, 0x0c, 0xff, 0xe9, 0x26, 0x2a, 0x6a, 0xcf, 0x10, 0x4a, 0xf6, 0xb6, 0xab, 0x57, 0x9f, 0x7c, 0x93, 0x53 ], [ 0xd1, 0x42, 0x9d, 0x81, 0xef, 0x10, 0x84, 0xf7, 0xe8, 0x97, 0x4a, 0x07, 0x0f, 0xb5, 0x1d, 0xea, 0xfe, 0x08, 0x84, 0x62, 0x31, 0x32, 0xb6, 0xe1, 0x3d, 0x3e, 0x0e, 0x0a, 0x93, 0xb6, 0x66, 0xe3 ], [ 0x1c, 0x20, 0x02, 0x2a, 0x80, 0xe9, 0x7c, 0xc3, 0x86, 0xe1, 0xc2, 0x71, 0x70, 0x3f, 0x92, 0x70, 0x2e, 0xe8, 0xdf, 0x21, 0x48, 0x9f, 0xdc, 0x41, 0x0f, 0xf6, 0x12, 0xd6, 0x7c, 0x9d, 0x9d, 0x1e ], [ 0x7f, 0x2c, 0x19, 0x02, 0xbd, 0xda, 0x3d, 0xf6, 0x99, 0x41, 0x5f, 0x6a, 0x9f, 0xb2, 0x19, 0x4a, 0x18, 0x6b, 0x93, 0xa9, 0x94, 0x18, 0xbd, 0x99, 0x45, 0xc1, 0xca, 0x6b, 0x35, 0x60, 0x25, 0xec ], [ 0x6c, 0xd6, 0x80, 0xb7, 0x7d, 0x32, 0x44, 0x51, 0x4f, 0xa3, 0x1c, 0x3a, 0x9b, 0xb7, 0x70, 0x8c, 0x45, 0xd0, 0x6f, 0x44, 0xb4, 0x57, 0x15, 0xdc, 0x2e, 0xd7, 0xc7, 0x4c, 0x70, 0xce, 0xcc, 0x04 ], [ 0x8e, 0xaa, 0x33, 0xfb, 0x8f, 0x4d, 0xbf, 0x3f, 0x6b, 0x3c, 0x9d, 0x36, 0x0b, 0xdf, 0xfb, 0x6b, 0xbc, 0x48, 0xf3, 0xb3, 0x96, 0x02, 0x8f, 0x12, 0x2d, 0x07, 0xdc, 0xb5, 0x0f, 0x90, 0x89, 0x32 ], [ 0x38, 0xbb, 0x05, 0xb1, 0x11, 0xbf, 0x21, 0x97, 0x54, 0x14, 0x5a, 0x63, 0xec, 0x43, 0x99, 0x6f, 0x25, 0x32, 0xfe, 0x9d, 0x82, 0xd8, 0x09, 0xce, 0x40, 0xbd, 0x5f, 0x11, 0x77, 0x87, 0x57, 0x82 ], [ 0xfd, 0x53, 0xc1, 0xba, 0x88, 0xb8, 0x54, 0x52, 0xc3, 0x4d, 0x92, 0xd1, 0xcb, 0xaa, 0xad, 0xa1, 0x33, 0x43, 0x1b, 0xc6, 0xd8, 0xd6, 0x58, 0xdc, 0x86, 0x0f, 0x88, 0xd5, 0x27, 0x59, 0x0d, 0x9f ], [ 0x16, 0xd6, 0x78, 0xac, 0xc1, 0x01, 0x0c, 0x87, 0xfe, 0x10, 0x4a, 0xbf, 0x88, 0xef, 0x4e, 0xc9, 0x81, 0x93, 0x78, 0x03, 0xeb, 0x85, 0x04, 0x61, 0x78, 0xf4, 0x5d, 0x3a, 0x9b, 0xf3, 0xff, 0xe6 ], [ 0x1c, 0x30, 0xbe, 0xe1, 0xed, 0x70, 0xb7, 0x7a, 0x87, 0x13, 0x1e, 0x46, 0x30, 0x89, 0x75, 0xbf, 0xa2, 0x7a, 0x1e, 0xcb, 0xa8, 0xa0, 0x7c, 0x28, 0x6b, 0x11, 0xee, 0x29, 0x2e, 0x5f, 0x43, 0x71 ], [ 0xa4, 0xba, 0x40, 0xd9, 0x8b, 0x83, 0x97, 0xe5, 0x25, 0xeb, 0x76, 0x81, 0xf5, 0xc5, 0x45, 0xda, 0x43, 0x26, 0x19, 0xe2, 0x3a, 0x06, 0x74, 0x21, 0x17, 0x1d, 0x95, 0x1e, 0xd0, 0x18, 0xd1, 0x0e ], [ 0xbf, 0x14, 0xb2, 0x98, 0xe9, 0xc7, 0x2c, 0xa7, 0x36, 0x76, 0x91, 0x5a, 0x80, 0xfa, 0x2f, 0xac, 0x4f, 0xe2, 0xb5, 0x6e, 0xbc, 0x4d, 0xf5, 0x7e, 0x30, 0x28, 0xfd, 0x4a, 0x41, 0xac, 0x9e, 0x1c ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" tweak_value1_128bit = [ [ 0x79, 0x00, 0x43, 0x2e, 0x60, 0x21, 0xbc, 0x0e, 0x62, 0x7c, 0x7b, 0x96, 0xca, 0x08, 0xb4, 0xd0 ], [ 0x8c, 0xfb, 0x87, 0xd6, 0x1f, 0x9c, 0x41, 0xad, 0x3c, 0xbe, 0x38, 0xcf, 0x81, 0xd4, 0xa3, 0xea ], [ 0xd6, 0xa2, 0x7b, 0x8d, 0xde, 0x6d, 0xff, 0xfa, 0x7d, 0x4c, 0xa4, 0x36, 0x44, 0x19, 0x78, 0xb0 ], [ 0x7d, 0x68, 0xf0, 0xf5, 0x3d, 0x3c, 0xe0, 0x15, 0xef, 0x8f, 0x44, 0x2b, 0x40, 0x9d, 0x82, 0xb1 ], [ 0xba, 0x15, 0x46, 0xff, 0xa9, 0xbf, 0x8e, 0x19, 0x4c, 0x99, 0x21, 0x1a, 0x3d, 0x62, 0x0a, 0x92 ], [ 0x8d, 0x24, 0xb5, 0x79, 0xf0, 0x44, 0x83, 0x36, 0x55, 0x0d, 0x37, 0x2c, 0x72, 0x28, 0xfa, 0x1b ], [ 0xd0, 0x97, 0x87, 0x71, 0x7b, 0x3c, 0xb4, 0x1a, 0x68, 0x89, 0x88, 0x23, 0xb6, 0x15, 0xa7, 0x5a ], [ 0x0a, 0xda, 0xa6, 0xe0, 0xff, 0x4b, 0x0a, 0x04, 0xdf, 0xbf, 0x22, 0x47, 0xf6, 0x4a, 0x26, 0x08 ], [ 0xca, 0xa8, 0x83, 0xe2, 0x75, 0x97, 0x66, 0x1d, 0x8e, 0x72, 0x58, 0x2e, 0xd3, 0x46, 0x24, 0xa4 ], [ 0x39, 0x1b, 0x14, 0xe2, 0xf8, 0xcc, 0x21, 0x11, 0xbb, 0x01, 0x47, 0xa3, 0xba, 0xa0, 0x40, 0xe8 ], [ 0x29, 0x76, 0xc2, 0xe8, 0x25, 0xc6, 0x1b, 0x83, 0x60, 0x40, 0x2b, 0xe3, 0x99, 0xfb, 0xea, 0x20 ], [ 0xb7, 0x9e, 0x31, 0x47, 0xe9, 0x48, 0xa8, 0x44, 0x13, 0xf5, 0x45, 0x6e, 0xf0, 0x1b, 0x7f, 0xb6 ], [ 0x47, 0x9c, 0xd8, 0xe9, 0xae, 0xfa, 0x5c, 0xfe, 0xc1, 0x25, 0xa1, 0x10, 0xf1, 0x1d, 0xfe, 0xcf ], [ 0x42, 0x1a, 0x91, 0x2b, 0x68, 0x5a, 0xb7, 0x6b, 0x80, 0x0e, 0x9c, 0xf1, 0x56, 0xf2, 0x33, 0xb5 ], [ 0xb2, 0x20, 0xa3, 0xd0, 0x90, 0x7e, 0xc1, 0xb5, 0x6f, 0x36, 0xb3, 0x8b, 0x0f, 0xdb, 0x51, 0xa6 ], [ 0x4e, 0xd7, 0xea, 0x04, 0x03, 0x2c, 0x82, 0xf6, 0x12, 0xad, 0x0b, 0x26, 0x54, 0xcc, 0x9b, 0x7e ], [ 0x40, 0x27, 0xcf, 0x67, 0x80, 0xa3, 0xaf, 0xc3, 0xd9, 0x9c, 0x3d, 0x2f, 0xe4, 0x6c, 0x57, 0x51 ], [ 0x8a, 0x0e, 0xfa, 0xaf, 0xf0, 0x9c, 0x3a, 0xb2, 0xa3, 0xb2, 0x02, 0xa7, 0xcb, 0x67, 0x36, 0x79 ], [ 0x7d, 0x9e, 0x26, 0x6a, 0xba, 0x87, 0xee, 0x2a, 0xf4, 0xab, 0x7a, 0x22, 0x75, 0x74, 0x21, 0x89 ], [ 0x92, 0xe8, 0x29, 0x56, 0x31, 0xbd, 0x60, 0x8c, 0x0a, 0x53, 0xa3, 0xf2, 0x6f, 0x90, 0x7a, 0x7a ], [ 0xbf, 0x96, 0x2d, 0x31, 0xbd, 0x58, 0xa1, 0xf8, 0x9e, 0x3d, 0xb4, 0x57, 0x2c, 0xfc, 0xd8, 0xdd ], [ 0x6d, 0x1b, 0xaf, 0x4e, 0x86, 0xbb, 0xd5, 0xdf, 0xd8, 0xcf, 0xa3, 0x4b, 0x16, 0x96, 0x68, 0x20 ], [ 0xf1, 0x7f, 0x43, 0x40, 0xdf, 0x27, 0x1f, 0xa5, 0xea, 0x5f, 0xec, 0xec, 0x58, 0xf9, 0x90, 0xbe ], [ 0x05, 0xf1, 0x5b, 0x65, 0x4a, 0x7c, 0x3c, 0x8b, 0x71, 0x68, 0xab, 0xa1, 0xab, 0xef, 0xd3, 0x8a ], [ 0x8f, 0xf4, 0x26, 0xa0, 0x47, 0x1d, 0x85, 0x46, 0xd5, 0x71, 0x15, 0x44, 0xa6, 0x54, 0x0b, 0x0b ], [ 0x7a, 0x9f, 0x9a, 0x41, 0x82, 0xbd, 0xf2, 0x8e, 0x4d, 0x36, 0x4d, 0xb9, 0xb6, 0x7a, 0x8b, 0x0b ], [ 0x88, 0xfd, 0x39, 0x1a, 0xa1, 0xf3, 0xbb, 0x6b, 0x7c, 0xee, 0x85, 0xb5, 0x37, 0x68, 0xfc, 0x76 ], [ 0x57, 0xcb, 0xc8, 0xbd, 0x44, 0x06, 0x53, 0x20, 0x23, 0x19, 0xf7, 0xc9, 0x32, 0xcb, 0x95, 0x89 ], [ 0x40, 0x2b, 0xe8, 0xfb, 0x1c, 0x78, 0xc0, 0x19, 0x4d, 0xe0, 0xf0, 0xbe, 0xb9, 0x0c, 0xcc, 0x98 ], [ 0xad, 0x52, 0x91, 0xd8, 0x68, 0x0e, 0x2d, 0x60, 0x3c, 0xa2, 0x7d, 0xa0, 0x84, 0xd5, 0x6a, 0x78 ], [ 0x92, 0x0b, 0xa4, 0x67, 0x00, 0x42, 0x87, 0x32, 0x19, 0x43, 0xcb, 0xd1, 0x32, 0x16, 0x6c, 0x20 ], [ 0x93, 0x52, 0x32, 0x95, 0x8b, 0x22, 0x36, 0x95, 0xc4, 0x86, 0x5c, 0x8c, 0x09, 0x76, 0x77, 0xe7 ], [ 0xfc, 0x69, 0x6d, 0x41, 0x90, 0xa3, 0xfc, 0x62, 0x73, 0xca, 0xa1, 0xa0, 0x70, 0xe5, 0xbb, 0xfc ], [ 0xf1, 0x54, 0x0d, 0xcc, 0x89, 0x7f, 0x03, 0xb8, 0xa7, 0x0d, 0x7b, 0xa4, 0x50, 0x6a, 0x11, 0x15 ], [ 0x14, 0xd8, 0x30, 0xf7, 0x1e, 0x15, 0xe8, 0x94, 0x53, 0x80, 0xa6, 0xe7, 0xf5, 0x33, 0xa5, 0x32 ], [ 0xe7, 0xcf, 0x2a, 0x79, 0xfa, 0xb3, 0x0a, 0x2d, 0x0e, 0x46, 0x1f, 0xbb, 0x64, 0x7d, 0xde, 0xe3 ], [ 0x13, 0xc3, 0x83, 0x75, 0x4d, 0x39, 0x41, 0x19, 0x43, 0x57, 0x6e, 0x45, 0xdf, 0xb7, 0x77, 0x63 ], [ 0x70, 0xa0, 0x6d, 0xcf, 0x80, 0x44, 0xb9, 0x08, 0x8c, 0x00, 0xf9, 0xbb, 0x91, 0x01, 0x4c, 0x89 ], [ 0x20, 0x2f, 0x6f, 0x09, 0x0d, 0x29, 0x5e, 0x11, 0x8d, 0x1c, 0xe5, 0x01, 0xad, 0xd6, 0x9e, 0xe8 ], [ 0xfa, 0x02, 0xf1, 0xdf, 0x19, 0x56, 0xfb, 0x9b, 0x11, 0xac, 0x59, 0x93, 0x3d, 0xfc, 0x0e, 0x67 ], [ 0x51, 0x5e, 0xc6, 0x65, 0x7d, 0x39, 0x23, 0xc5, 0x68, 0xa3, 0xf7, 0x50, 0x3f, 0x46, 0x16, 0x63 ], [ 0x4b, 0x5f, 0x1b, 0x93, 0x8b, 0xd9, 0x14, 0x5c, 0x5a, 0x0c, 0x27, 0xd5, 0x51, 0xa0, 0xd8, 0xb2 ], [ 0xa4, 0xa5, 0x90, 0x5f, 0xa0, 0xb1, 0x06, 0x5a, 0xf6, 0xbf, 0xbe, 0xea, 0xc9, 0x57, 0x83, 0x79 ], [ 0x00, 0xf9, 0x9c, 0xfd, 0xea, 0x2b, 0x04, 0x5c, 0x5b, 0x8e, 0x29, 0xae, 0x80, 0x13, 0x68, 0xcc ], [ 0x84, 0x2d, 0x10, 0x8a, 0x3c, 0xd4, 0x48, 0xbf, 0x50, 0x5c, 0xda, 0x8b, 0x37, 0x56, 0x26, 0xec ], [ 0x93, 0x5d, 0xb9, 0x5d, 0x74, 0xd2, 0x04, 0x46, 0x34, 0xa4, 0x26, 0x53, 0x3a, 0x3f, 0x19, 0x1d ], [ 0x3f, 0x0a, 0xef, 0x56, 0x62, 0xd5, 0xf2, 0xe4, 0x0d, 0x33, 0xf1, 0x71, 0x2a, 0xea, 0x39, 0x2a ], [ 0xab, 0xff, 0x43, 0xaa, 0x43, 0xc2, 0xbe, 0x70, 0xae, 0xd5, 0xc9, 0x11, 0xf5, 0x36, 0x1d, 0xe1 ], [ 0x89, 0x84, 0x93, 0xe8, 0xce, 0x34, 0x3b, 0x40, 0x0e, 0x4e, 0x2a, 0xb9, 0xc6, 0x5d, 0x45, 0xc0 ], [ 0xd5, 0xa8, 0xb6, 0xd4, 0xb5, 0x1b, 0xac, 0xa7, 0x49, 0x5e, 0xce, 0x35, 0xb9, 0x11, 0xc3, 0x61 ], [ 0xde, 0x75, 0x4c, 0x60, 0x85, 0xaf, 0xf2, 0xe6, 0xd7, 0x59, 0xcb, 0xb5, 0x21, 0x4e, 0xbc, 0x8a ], [ 0x96, 0x78, 0xbf, 0x96, 0x46, 0xf9, 0x1f, 0xf5, 0xbe, 0x8e, 0x5c, 0xe7, 0xd5, 0xb9, 0x79, 0xaf ], [ 0x34, 0x19, 0x22, 0x27, 0x36, 0x16, 0x56, 0xb6, 0xfb, 0xf9, 0x86, 0xd1, 0x05, 0x0c, 0x33, 0xa1 ], [ 0x5b, 0x8b, 0x3b, 0x04, 0x0d, 0x78, 0xf5, 0xcf, 0x32, 0x75, 0x08, 0xe1, 0x80, 0xed, 0xc1, 0x52 ], [ 0x1f, 0xb5, 0xf8, 0xe0, 0x5c, 0x76, 0x30, 0x2a, 0x24, 0x61, 0x2c, 0xb3, 0xe5, 0x85, 0xc8, 0xf0 ], [ 0x6b, 0xf9, 0xa3, 0xe6, 0x4b, 0x2f, 0x89, 0x3a, 0x40, 0xd0, 0x12, 0x65, 0x1d, 0x2b, 0xd7, 0xf1 ], [ 0x70, 0x2c, 0xc1, 0xb2, 0x51, 0x55, 0x9b, 0xa3, 0x6c, 0x97, 0xff, 0x62, 0xff, 0xbf, 0xd5, 0x10 ], [ 0x10, 0x0a, 0xec, 0x34, 0x7f, 0x62, 0xe5, 0xbf, 0x01, 0xa8, 0xd4, 0xf2, 0x79, 0xbd, 0x57, 0x40 ], [ 0x15, 0xb8, 0xb4, 0x71, 0x97, 0x9e, 0xb2, 0x20, 0x86, 0xf2, 0xc3, 0x4f, 0xba, 0x7a, 0x0c, 0x71 ], [ 0xe6, 0xea, 0xb2, 0x57, 0x34, 0x12, 0xad, 0xc1, 0xa8, 0x51, 0x7d, 0x57, 0xbb, 0x6c, 0x99, 0x3c ], [ 0x72, 0x09, 0x48, 0xa8, 0x4a, 0x9c, 0x52, 0xbe, 0xff, 0x58, 0x4a, 0xf9, 0xac, 0xe6, 0xee, 0x9e ], [ 0xdc, 0x7c, 0x32, 0xc7, 0x12, 0xf5, 0xea, 0x13, 0x63, 0xb8, 0x04, 0xa4, 0xfa, 0xa9, 0xc6, 0xee ], [ 0xe1, 0x61, 0x80, 0x26, 0x35, 0x53, 0xad, 0x75, 0x9c, 0xce, 0xe4, 0x51, 0xe3, 0x2a, 0x9b, 0x25 ], [ 0x67, 0xc0, 0x5b, 0xeb, 0x83, 0x78, 0x76, 0x0d, 0xe1, 0x2f, 0xb2, 0x2c, 0x1a, 0xb6, 0x68, 0x39 ], [ 0x03, 0x7f, 0xd7, 0x82, 0x31, 0xd2, 0x7b, 0x3a, 0x3b, 0xc4, 0x19, 0xdd, 0xfd, 0x04, 0x68, 0x3d ], [ 0x58, 0x9d, 0xd4, 0x83, 0xfe, 0xda, 0x2c, 0x6d, 0x49, 0xd3, 0xd9, 0xdd, 0x68, 0x38, 0xb2, 0xc5 ], [ 0x0e, 0x3c, 0xd2, 0x60, 0x86, 0xd7, 0xde, 0xeb, 0x3f, 0xde, 0x71, 0xb2, 0xf8, 0xbd, 0xf5, 0x2b ], [ 0x0b, 0x24, 0x98, 0x65, 0xb5, 0xe1, 0x47, 0xcd, 0x40, 0xe6, 0x53, 0x12, 0x99, 0xda, 0x33, 0xc5 ], [ 0xb6, 0xb5, 0x7c, 0x53, 0xf0, 0x5d, 0xcc, 0x76, 0x68, 0x07, 0x8b, 0x0d, 0x9d, 0x3e, 0x45, 0x35 ], [ 0x36, 0x88, 0x54, 0xa6, 0x93, 0x93, 0x00, 0x29, 0x29, 0xac, 0x54, 0xe1, 0xfa, 0xb7, 0xfb, 0x60 ], [ 0x77, 0x95, 0x25, 0xbd, 0x7e, 0x5c, 0x47, 0xd6, 0x04, 0xda, 0x70, 0x9e, 0x76, 0x70, 0x57, 0x16 ], [ 0x06, 0x07, 0xeb, 0x14, 0x3a, 0x6f, 0x1a, 0x29, 0x4b, 0x6b, 0xd3, 0x51, 0x7c, 0x75, 0x8a, 0xe5 ], [ 0x00, 0xdd, 0x2e, 0x50, 0x13, 0xb0, 0x3a, 0x90, 0x01, 0xc9, 0xa2, 0x24, 0x09, 0x91, 0xcf, 0xe1 ], [ 0xa2, 0xa7, 0x2f, 0xf8, 0x71, 0xe9, 0xa9, 0x01, 0x1e, 0xc2, 0xdc, 0x4b, 0x79, 0xc3, 0x63, 0x22 ], [ 0xaa, 0xcb, 0xb6, 0x0c, 0xa2, 0x6f, 0x89, 0xce, 0xd0, 0x75, 0xe9, 0x7c, 0x73, 0x25, 0x76, 0xab ], [ 0xf8, 0x43, 0x86, 0x8e, 0xfe, 0xef, 0xf8, 0x6f, 0x35, 0x8d, 0xba, 0xab, 0x04, 0x44, 0xa8, 0x00 ], [ 0xf5, 0x48, 0xa3, 0x34, 0xc9, 0x18, 0xb1, 0xa2, 0xe3, 0xf1, 0x18, 0x1c, 0x1a, 0x7e, 0x26, 0x3c ], [ 0xa2, 0x0d, 0x33, 0xc2, 0xdb, 0x13, 0x2a, 0x5f, 0xea, 0x42, 0x87, 0xf4, 0x71, 0xef, 0x94, 0xdf ], [ 0x03, 0x25, 0xd5, 0xca, 0xb4, 0x85, 0x11, 0x0f, 0x23, 0x70, 0x3a, 0xb1, 0x85, 0xc9, 0x8a, 0xf3 ], [ 0x53, 0xc4, 0xd4, 0x10, 0x1a, 0x49, 0x75, 0x86, 0x3f, 0xfc, 0xb8, 0x57, 0xfb, 0x5c, 0x12, 0xf2 ], [ 0xe9, 0xae, 0x4c, 0x86, 0x4f, 0xb0, 0x5b, 0xe2, 0x60, 0x60, 0x35, 0xc0, 0xae, 0xbb, 0x85, 0x80 ], [ 0xd1, 0x7b, 0x19, 0x0f, 0xb3, 0xe1, 0x29, 0xbc, 0x4f, 0x44, 0x48, 0xd7, 0xa6, 0xbd, 0x5e, 0x46 ], [ 0x49, 0x1a, 0x76, 0xae, 0xb6, 0x6f, 0xaf, 0x23, 0x28, 0xc9, 0xbb, 0x7e, 0x9c, 0xcd, 0x21, 0x22 ], [ 0x35, 0x6e, 0x3e, 0xa6, 0xf1, 0x0a, 0xfa, 0x89, 0x35, 0x84, 0x34, 0x5e, 0x6d, 0x2d, 0x02, 0x82 ], [ 0x98, 0x8d, 0x16, 0x21, 0xa4, 0x68, 0x13, 0x7f, 0x3a, 0x6d, 0x88, 0xe6, 0xc1, 0x98, 0xd0, 0xa9 ], [ 0x3b, 0x26, 0x2c, 0xe6, 0x39, 0xc0, 0x6a, 0x7c, 0x1a, 0x46, 0x29, 0x01, 0x0a, 0xeb, 0xd6, 0x77 ], [ 0x44, 0x0f, 0x5b, 0x3b, 0x83, 0xda, 0x79, 0xd5, 0xc6, 0x0a, 0x23, 0x6a, 0x51, 0xf2, 0x1f, 0xae ], [ 0x74, 0xab, 0xc0, 0x01, 0x8c, 0xd6, 0xb5, 0x22, 0x70, 0x45, 0x42, 0xbc, 0x65, 0xae, 0x54, 0x99 ], [ 0xc3, 0xdf, 0x1b, 0xb1, 0x3b, 0xee, 0x0c, 0x55, 0xc8, 0xc0, 0x6b, 0x61, 0x60, 0xf3, 0x6a, 0xee ], [ 0xcd, 0xd7, 0x33, 0x42, 0x1c, 0x22, 0x5a, 0x98, 0x8a, 0xdc, 0xe4, 0x8e, 0x3b, 0x9f, 0x9b, 0x6c ], [ 0xec, 0x81, 0x29, 0x1a, 0xd8, 0x65, 0xe7, 0x4a, 0xd5, 0x32, 0xb7, 0xba, 0x5f, 0x7f, 0x74, 0x35 ], [ 0x90, 0x35, 0xd4, 0x24, 0x7d, 0xde, 0x48, 0xc8, 0xb9, 0x73, 0xe7, 0x7f, 0x5b, 0x83, 0x66, 0xd0 ], [ 0xbb, 0x81, 0x9e, 0x43, 0xed, 0x93, 0x35, 0xc4, 0x7a, 0xb2, 0xc7, 0x10, 0xee, 0x45, 0x46, 0xed ], [ 0xba, 0x70, 0xeb, 0xb0, 0xd3, 0x88, 0xc8, 0xec, 0x10, 0xa5, 0x79, 0xac, 0xb3, 0xfd, 0x19, 0x30 ], [ 0xa2, 0x48, 0x50, 0xa9, 0xe8, 0xc0, 0xc7, 0x73, 0x36, 0x07, 0xfc, 0x10, 0x43, 0xa7, 0x62, 0xf7 ], [ 0xf8, 0xc5, 0x30, 0xc8, 0x34, 0x44, 0x77, 0x13, 0xf0, 0x41, 0xc1, 0xb7, 0xfa, 0x24, 0x3b, 0xc8 ], [ 0xa1, 0x89, 0xe7, 0xd6, 0x67, 0x8d, 0x41, 0xb0, 0x2d, 0xde, 0x8f, 0xbf, 0xdb, 0x90, 0x18, 0x7f ], [ 0xec, 0x1e, 0x5f, 0xed, 0x86, 0x77, 0x05, 0x60, 0x31, 0x0b, 0x1a, 0x60, 0xbc, 0x78, 0x5c, 0xc4 ], [ 0x4b, 0x5e, 0x84, 0xd6, 0xe3, 0x24, 0x24, 0x08, 0x64, 0x7d, 0x92, 0x4f, 0x71, 0x84, 0x8a, 0x0e ], [ 0x0b, 0x67, 0x91, 0xa9, 0x3c, 0x2e, 0xf8, 0x4a, 0xff, 0x52, 0xb6, 0x3f, 0xe6, 0x2a, 0xb9, 0x77 ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" tweak_value2_128bit = [ [ 0x53, 0x19, 0xfb, 0x90, 0xe1, 0x36, 0xc7, 0xd0, 0x25, 0xe3, 0x76, 0x54, 0x32, 0xe6, 0xd4, 0x13 ], [ 0x57, 0x6c, 0x5c, 0x41, 0x6f, 0x26, 0x7f, 0xa4, 0x61, 0x74, 0x26, 0xdc, 0x71, 0xb6, 0xbe, 0x24 ], [ 0x7d, 0x4b, 0xd1, 0x03, 0x7b, 0xf2, 0x6d, 0x79, 0x3a, 0x09, 0xdc, 0x06, 0x42, 0x06, 0x02, 0x46 ], [ 0x33, 0xb9, 0x15, 0xfc, 0xe7, 0xea, 0x20, 0x53, 0x3f, 0xf0, 0xbe, 0x2d, 0x69, 0x70, 0x64, 0xac ], [ 0x8e, 0xde, 0xb6, 0x5d, 0x5b, 0xe1, 0x9b, 0x19, 0x43, 0x53, 0x87, 0x52, 0xb8, 0x85, 0xe3, 0xf9 ], [ 0x32, 0x1c, 0x76, 0xa9, 0x1a, 0x1b, 0x19, 0x08, 0xc5, 0x21, 0xd8, 0x68, 0xb2, 0x91, 0x4e, 0xef ], [ 0xbe, 0x79, 0x5b, 0xa1, 0x4b, 0xa6, 0x61, 0x52, 0x47, 0x92, 0xe3, 0xca, 0xbd, 0xb8, 0xf9, 0x7a ], [ 0x0e, 0xed, 0x58, 0xf5, 0xc2, 0x7f, 0xb9, 0x14, 0x19, 0xea, 0x3b, 0x23, 0xff, 0x87, 0xb1, 0x62 ], [ 0x76, 0x9b, 0x82, 0x3a, 0x46, 0x0a, 0x08, 0xd3, 0xa3, 0x5a, 0x0a, 0x8b, 0x98, 0x31, 0x63, 0xe7 ], [ 0xfa, 0xe3, 0xd8, 0x3c, 0x2e, 0xe4, 0x9c, 0x12, 0x2c, 0x1d, 0x58, 0x86, 0xaf, 0x4f, 0xc3, 0x64 ], [ 0x02, 0x57, 0xc5, 0xa4, 0x77, 0x8e, 0xca, 0xc7, 0x25, 0x33, 0xab, 0xbc, 0x51, 0x3e, 0xfd, 0x92 ], [ 0xc2, 0xc8, 0xef, 0xef, 0x4b, 0x98, 0x05, 0x5c, 0x04, 0x65, 0x78, 0x15, 0xfd, 0x26, 0x3a, 0x94 ], [ 0x14, 0xc2, 0x6a, 0xed, 0xba, 0xa6, 0x30, 0x9e, 0xde, 0x93, 0xdc, 0x6f, 0x96, 0xaf, 0xa5, 0x4e ], [ 0x1d, 0x25, 0x2f, 0xe6, 0x7b, 0xc7, 0xa5, 0x40, 0x44, 0xcf, 0xa6, 0xb9, 0xdb, 0x14, 0x14, 0x9f ], [ 0x92, 0x2e, 0x9a, 0x6e, 0x66, 0x9b, 0xb3, 0x2e, 0xda, 0xf3, 0xe4, 0x5c, 0x44, 0x2e, 0x07, 0xbc ], [ 0x4e, 0x05, 0xee, 0xa6, 0xbe, 0x3b, 0x3e, 0xe6, 0xbb, 0x5b, 0x0e, 0x8f, 0x86, 0xa4, 0xab, 0x12 ], [ 0xd6, 0xc9, 0x9f, 0x58, 0x9a, 0x7c, 0x9e, 0x09, 0xe7, 0x6c, 0x0c, 0xbe, 0xe9, 0x3f, 0xdc, 0x97 ], [ 0x4c, 0x0b, 0xc7, 0xaf, 0xae, 0x44, 0xf2, 0xb0, 0x23, 0xdc, 0x33, 0x7c, 0xec, 0xe4, 0x79, 0xd1 ], [ 0xd0, 0xd7, 0x1e, 0x9b, 0x46, 0x4f, 0x6a, 0x55, 0x1a, 0x27, 0x50, 0xb0, 0x37, 0xfb, 0x7e, 0x82 ], [ 0x32, 0xda, 0xce, 0x1c, 0x2c, 0xb2, 0x82, 0xb7, 0xe8, 0x33, 0x49, 0xca, 0x0a, 0xa3, 0xb0, 0x2e ], [ 0x5f, 0x61, 0x9d, 0xa3, 0x2f, 0x6a, 0x83, 0xc6, 0xe2, 0x71, 0x6d, 0xda, 0xf5, 0x28, 0x2d, 0x94 ], [ 0x72, 0x06, 0x6f, 0x46, 0x27, 0x97, 0x8f, 0xfb, 0xc2, 0xef, 0xc3, 0xf4, 0x1f, 0x62, 0x80, 0x0d ], [ 0x0d, 0xe9, 0x33, 0xe4, 0x36, 0x42, 0xc5, 0x78, 0x8c, 0x77, 0x0a, 0x48, 0x6a, 0x2e, 0xcc, 0xc6 ], [ 0xfa, 0xd0, 0x2f, 0x96, 0x04, 0xc1, 0x6e, 0x3b, 0x7e, 0xee, 0x1d, 0xb6, 0xf5, 0x46, 0x60, 0x96 ], [ 0x9c, 0x02, 0x7a, 0x2a, 0xc9, 0x13, 0xa0, 0xa8, 0xb0, 0xb0, 0xa4, 0x8c, 0x6b, 0x13, 0xbf, 0xd2 ], [ 0x5c, 0xf7, 0x9d, 0xb6, 0xc5, 0xcd, 0x99, 0x1a, 0x1c, 0x78, 0x81, 0x42, 0x24, 0x95, 0x1e, 0x84 ], [ 0xa1, 0x15, 0x9c, 0xfc, 0xfa, 0x67, 0x81, 0xe1, 0x61, 0x7f, 0xc1, 0xf8, 0xf6, 0x11, 0x0e, 0xea ], [ 0x34, 0x23, 0x2e, 0x6b, 0x98, 0x30, 0xa0, 0x3c, 0x97, 0x0b, 0xc7, 0xc8, 0x78, 0x4f, 0x6f, 0x99 ], [ 0x2a, 0x7f, 0x2d, 0xba, 0x78, 0x60, 0x5b, 0x7d, 0x44, 0x6d, 0xa4, 0x48, 0x4b, 0xe7, 0xdb, 0x25 ], [ 0x45, 0x8c, 0x11, 0x97, 0x21, 0x5f, 0x3e, 0x52, 0xc3, 0x45, 0xba, 0xc4, 0x8d, 0xed, 0x0c, 0x89 ], [ 0x25, 0x4b, 0x67, 0x26, 0xfd, 0x24, 0x76, 0x9f, 0xc7, 0xda, 0x30, 0xa3, 0xfe, 0xc8, 0x23, 0xd7 ], [ 0x4f, 0x54, 0xf2, 0x05, 0xd6, 0x1a, 0x71, 0xfa, 0x94, 0x29, 0x37, 0x98, 0x52, 0xee, 0x05, 0xa3 ], [ 0xc5, 0x68, 0x00, 0xac, 0x94, 0xf5, 0x72, 0x05, 0x8c, 0xd0, 0xa6, 0x3c, 0x7e, 0x9e, 0xa4, 0x5e ], [ 0x1a, 0x0d, 0xa4, 0x1c, 0xd4, 0x78, 0xb5, 0xbb, 0xd5, 0xc2, 0x41, 0xb5, 0x6b, 0xc3, 0x58, 0x5c ], [ 0x9b, 0x70, 0xa5, 0x20, 0x6d, 0xbc, 0xe1, 0xc3, 0xef, 0x42, 0xc0, 0x59, 0x10, 0x35, 0x61, 0x85 ], [ 0xa0, 0xd5, 0x74, 0x60, 0xa4, 0x38, 0x8e, 0xf3, 0x98, 0x80, 0xce, 0xa4, 0x35, 0x09, 0x5e, 0xe7 ], [ 0xbe, 0x9f, 0x2c, 0xda, 0x02, 0xf1, 0xe3, 0x5b, 0x15, 0x5f, 0xc0, 0x4a, 0x7f, 0x3e, 0x95, 0x57 ], [ 0x86, 0x46, 0xc5, 0x3c, 0x9e, 0x2e, 0x47, 0xb2, 0x98, 0x48, 0x6e, 0xb9, 0x2a, 0xb7, 0x4c, 0x30 ], [ 0x14, 0xed, 0xbb, 0x75, 0x5a, 0xb9, 0xdf, 0xe2, 0xe3, 0x70, 0x54, 0x6a, 0x1d, 0xa9, 0xe6, 0xf6 ], [ 0xcb, 0x38, 0xd1, 0xa1, 0xdd, 0x9c, 0x57, 0xaa, 0x06, 0x73, 0x08, 0xee, 0x91, 0xe9, 0x04, 0x19 ], [ 0x8b, 0x66, 0x0f, 0xe9, 0xa5, 0xe3, 0xd3, 0x9e, 0x5f, 0x82, 0x0a, 0xdb, 0x2f, 0x21, 0xd8, 0x3a ], [ 0x51, 0xaf, 0xad, 0xac, 0xe8, 0x42, 0x0b, 0x51, 0x6c, 0xf5, 0xe8, 0xce, 0x06, 0x36, 0x83, 0x93 ], [ 0x42, 0x5a, 0x4b, 0x30, 0xa4, 0xcd, 0x0b, 0xad, 0x3c, 0x75, 0xc7, 0xda, 0xf0, 0xb3, 0x1a, 0xc8 ], [ 0x6b, 0x2f, 0xd2, 0xd2, 0x5d, 0x6a, 0x68, 0x0a, 0xbe, 0xaa, 0x4e, 0xdb, 0x22, 0x96, 0xff, 0x3d ], [ 0xa4, 0x2c, 0x61, 0x92, 0xf0, 0x6d, 0x2d, 0xdc, 0x9a, 0x55, 0x1b, 0xc9, 0x09, 0x8d, 0xfe, 0x12 ], [ 0x3f, 0x99, 0xde, 0x81, 0x3e, 0xed, 0x13, 0x8e, 0x02, 0x9a, 0xcd, 0x2d, 0xe7, 0x59, 0x3c, 0x28 ], [ 0x7f, 0x35, 0x73, 0xb7, 0xb1, 0x47, 0xcf, 0x47, 0x33, 0x36, 0x57, 0xc8, 0x73, 0xaf, 0xff, 0xf5 ], [ 0x29, 0x15, 0xe3, 0x7a, 0xbd, 0x33, 0x46, 0x24, 0x34, 0x96, 0x4d, 0x38, 0x01, 0xe0, 0x0a, 0x34 ], [ 0x74, 0xd0, 0x1c, 0xc8, 0xcf, 0xc0, 0x95, 0xfd, 0xd6, 0x69, 0xf3, 0xe4, 0x20, 0x1d, 0x77, 0x74 ], [ 0x71, 0x50, 0x0c, 0xe1, 0x00, 0xb1, 0xc6, 0x62, 0x68, 0x41, 0x57, 0x11, 0x7c, 0xe1, 0x6e, 0x53 ], [ 0x0e, 0x54, 0x45, 0xe0, 0x60, 0x62, 0x85, 0x75, 0xae, 0xf9, 0xbf, 0xfd, 0x99, 0xd9, 0x06, 0x72 ], [ 0x9c, 0xde, 0x2a, 0x35, 0xad, 0x64, 0x40, 0xc4, 0xbc, 0x14, 0x8c, 0xa0, 0xc7, 0x8b, 0x05, 0x6a ], [ 0xe0, 0xf6, 0x1c, 0xb7, 0xf2, 0x36, 0xee, 0x8b, 0x44, 0x41, 0xa6, 0xa5, 0xfa, 0xa6, 0x43, 0x9b ], [ 0x00, 0x6f, 0xd6, 0xa7, 0x44, 0xe0, 0x59, 0x8f, 0x85, 0x69, 0xfe, 0x19, 0x31, 0x7b, 0xab, 0xc4 ], [ 0x5d, 0x43, 0xb9, 0x7d, 0xc5, 0xc4, 0x4c, 0x61, 0xc7, 0xe9, 0xc6, 0xa6, 0x21, 0x4a, 0x97, 0x0a ], [ 0x48, 0xe0, 0xf7, 0xba, 0xf7, 0x67, 0x67, 0xea, 0x56, 0xc1, 0xf9, 0xe1, 0x4c, 0xab, 0x12, 0x0f ], [ 0x4e, 0x25, 0x74, 0xd3, 0x1f, 0x9b, 0x60, 0x2c, 0xdf, 0xe6, 0x3d, 0x45, 0xc1, 0x05, 0x7d, 0x31 ], [ 0xcf, 0xe0, 0x86, 0x2c, 0x45, 0xfc, 0x27, 0x50, 0x74, 0xd4, 0x14, 0xdf, 0x2b, 0xf8, 0x7c, 0x74 ], [ 0xda, 0x68, 0x78, 0x7d, 0x75, 0xdf, 0xbb, 0x4b, 0xe1, 0x4a, 0x39, 0x07, 0x0f, 0xb5, 0x39, 0x23 ], [ 0xde, 0x23, 0x46, 0x8a, 0xc5, 0xa8, 0xaf, 0x13, 0x58, 0x3e, 0x04, 0x24, 0xb3, 0x37, 0x02, 0x14 ], [ 0x67, 0x07, 0x37, 0x6c, 0xee, 0x14, 0xfa, 0xf5, 0x0f, 0xe9, 0x8c, 0x15, 0x3b, 0x11, 0x2e, 0xb8 ], [ 0xd5, 0x14, 0x3c, 0x2f, 0x1c, 0xc1, 0xfd, 0x05, 0x2d, 0x86, 0xa6, 0xb3, 0x40, 0x49, 0x44, 0xab ], [ 0xe0, 0x9c, 0xb4, 0x39, 0xd7, 0x0d, 0x9e, 0x55, 0xc7, 0x4b, 0x51, 0x3f, 0x95, 0x40, 0x93, 0xb2 ], [ 0x12, 0x3e, 0xee, 0x6c, 0xbd, 0x27, 0x36, 0xf9, 0x06, 0xaf, 0xb8, 0x71, 0x10, 0x30, 0xac, 0x18 ], [ 0x23, 0xb9, 0x2f, 0x2e, 0xc6, 0x2b, 0x87, 0x58, 0xad, 0x67, 0xff, 0x77, 0xc3, 0x3a, 0x92, 0xfe ], [ 0x9b, 0xcb, 0xd6, 0xca, 0x75, 0xe2, 0x9a, 0x74, 0xd3, 0x70, 0x7a, 0xb4, 0x07, 0x48, 0x12, 0x73 ], [ 0xfd, 0xeb, 0x2c, 0x91, 0x81, 0x45, 0x04, 0x56, 0x3d, 0xe7, 0xbb, 0x0b, 0x25, 0xa8, 0xbe, 0xb6 ], [ 0x7b, 0x45, 0x88, 0x42, 0x8f, 0x97, 0xa0, 0x74, 0xc8, 0x31, 0x70, 0x3e, 0xf6, 0x7a, 0xae, 0x48 ], [ 0xc6, 0x51, 0x51, 0x7a, 0x45, 0x5f, 0x01, 0xef, 0xd5, 0x10, 0x51, 0x9c, 0xbc, 0xac, 0x8f, 0x10 ], [ 0x9f, 0x1d, 0x3d, 0x84, 0x4b, 0x60, 0xbf, 0x8d, 0x5c, 0xee, 0x7f, 0xae, 0x53, 0x2c, 0x5a, 0x5f ], [ 0x55, 0xbe, 0x12, 0xa0, 0x1a, 0x7b, 0xaf, 0xf9, 0x37, 0x93, 0x77, 0xe9, 0xc9, 0x59, 0x57, 0x46 ], [ 0xa2, 0x39, 0xe1, 0xf6, 0xf0, 0x9c, 0x90, 0x07, 0x73, 0x0b, 0xcd, 0x43, 0x8c, 0x68, 0x1b, 0xab ], [ 0x96, 0x16, 0xb7, 0x7c, 0x5e, 0xae, 0x8b, 0xfa, 0x6b, 0x2a, 0x8c, 0x0c, 0x66, 0x26, 0xc6, 0x85 ], [ 0x7d, 0xd6, 0xb0, 0x34, 0x1e, 0xc1, 0x0f, 0xbe, 0x22, 0xac, 0x77, 0x84, 0x01, 0x66, 0x66, 0x54 ], [ 0x0c, 0x0b, 0xc9, 0xf5, 0xed, 0xbc, 0x4d, 0xf9, 0x04, 0x3b, 0x4c, 0x0e, 0x4c, 0x7e, 0x7d, 0x07 ], [ 0xb7, 0x95, 0xe4, 0x03, 0x75, 0xa1, 0x5c, 0xcd, 0xe2, 0x1b, 0xa8, 0x70, 0xa9, 0xe4, 0xe2, 0x2e ], [ 0xd6, 0xc4, 0x6b, 0x9c, 0x5e, 0x08, 0x5a, 0x18, 0x92, 0x9a, 0xce, 0xca, 0x53, 0xe5, 0xa9, 0xc7 ], [ 0xd4, 0x8c, 0xfa, 0xc7, 0x6b, 0xae, 0xa7, 0xca, 0x5d, 0x31, 0xbd, 0x2b, 0x6f, 0x90, 0x8a, 0x2a ], [ 0xb5, 0xec, 0xf5, 0xae, 0xdd, 0x2f, 0xbe, 0x0f, 0x47, 0x66, 0x1f, 0xb0, 0xe2, 0x12, 0x7e, 0x74 ], [ 0xb2, 0xdc, 0x9f, 0x62, 0x6c, 0x36, 0xd4, 0xf0, 0xe3, 0x26, 0xb5, 0xda, 0x36, 0xe7, 0xf4, 0x1e ], [ 0xcc, 0xa7, 0x7f, 0xc7, 0xc6, 0x89, 0x1b, 0x7c, 0x4f, 0xcc, 0x4f, 0x46, 0x62, 0x15, 0xaf, 0xe6 ], [ 0x79, 0xa8, 0x14, 0x0a, 0xd7, 0x1f, 0xbc, 0xbe, 0xc1, 0x9d, 0x90, 0x2b, 0x81, 0xf0, 0x96, 0x8f ], [ 0xd4, 0xa9, 0x98, 0x5b, 0x87, 0x5f, 0xe4, 0x80, 0x0e, 0x95, 0xd1, 0x98, 0x8f, 0x6c, 0xa9, 0xe1 ], [ 0x32, 0x04, 0x40, 0x4a, 0x2d, 0xc6, 0x51, 0x5f, 0x2d, 0x80, 0x4d, 0x77, 0xb1, 0x39, 0xbb, 0x1c ], [ 0xb5, 0x12, 0x45, 0x80, 0x16, 0xc1, 0x06, 0xb6, 0x04, 0x77, 0xff, 0xb0, 0xe6, 0xe5, 0x77, 0xe9 ], [ 0x67, 0x96, 0x64, 0x42, 0x34, 0x21, 0xfc, 0xbf, 0x13, 0x6a, 0x84, 0x67, 0x7c, 0xc7, 0xcc, 0x26 ], [ 0x4e, 0xae, 0x7e, 0xb0, 0x66, 0xb9, 0x09, 0xb0, 0xdf, 0xc3, 0xd9, 0x7c, 0x64, 0x89, 0x84, 0xc3 ], [ 0xe6, 0x08, 0xed, 0x8d, 0x0e, 0x42, 0x90, 0xdd, 0x8c, 0xea, 0xc0, 0x4c, 0xad, 0x45, 0xe3, 0x0d ], [ 0x20, 0xbd, 0x32, 0x2a, 0x26, 0xff, 0x06, 0x5f, 0x0f, 0xd1, 0xe3, 0x98, 0x53, 0xb0, 0x4b, 0x2e ], [ 0x3e, 0xee, 0xb4, 0x38, 0x1a, 0x36, 0x46, 0x36, 0x5b, 0x58, 0x09, 0xa7, 0xe3, 0x92, 0xd2, 0xec ], [ 0x88, 0xeb, 0x8e, 0xf0, 0x50, 0xea, 0xd3, 0x88, 0x60, 0x26, 0x49, 0x8b, 0xf0, 0xcf, 0x31, 0x20 ], [ 0xbc, 0xee, 0x9c, 0xe6, 0x8b, 0x99, 0xcc, 0x1a, 0xa0, 0xf4, 0xcd, 0x3f, 0xeb, 0x76, 0x87, 0x92 ], [ 0xc8, 0xde, 0xa6, 0x2b, 0x20, 0x96, 0x7f, 0xbf, 0xd0, 0x05, 0xcb, 0x44, 0xdc, 0x2d, 0x2c, 0x29 ], [ 0x41, 0x9e, 0x25, 0x07, 0x47, 0xf5, 0xc6, 0x49, 0xf3, 0x3c, 0xe8, 0xc1, 0x4e, 0xf4, 0x09, 0x1f ], [ 0x75, 0x34, 0xb3, 0xa4, 0x99, 0x02, 0xc6, 0x77, 0x19, 0x6c, 0xa8, 0xf2, 0x77, 0x59, 0x79, 0x10 ], [ 0xcf, 0x5c, 0xa0, 0xf7, 0xaf, 0x99, 0x53, 0x6f, 0xc4, 0x01, 0x88, 0x3e, 0x5d, 0xf6, 0x05, 0x04 ], [ 0x7c, 0x85, 0x34, 0x54, 0x91, 0xf8, 0x75, 0x9e, 0x08, 0x5e, 0xfd, 0xfe, 0xbd, 0x67, 0xb7, 0x0d ], [ 0xe0, 0x68, 0x63, 0x50, 0x89, 0x66, 0x40, 0x9d, 0x63, 0xdc, 0xf0, 0x91, 0x2f, 0x0c, 0xc6, 0x08 ], [ 0xb3, 0x8a, 0x84, 0xe3, 0xbe, 0x18, 0xf1, 0xc7, 0xce, 0xb8, 0x25, 0x57, 0xbb, 0xf3, 0x36, 0x61 ], [ 0xdc, 0xf7, 0x21, 0xca, 0xc1, 0xce, 0x6b, 0xb3, 0xaf, 0x57, 0x9d, 0xf8, 0x8a, 0x12, 0x52, 0x95 ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" tweak_value3_128bit = [ [ 0x23, 0x79, 0xd5, 0xa6, 0x85, 0x0e, 0xc7, 0x4e, 0x74, 0x57, 0xf5, 0xa3, 0xad, 0x43, 0xaf, 0x40 ], [ 0x9f, 0xa4, 0x1b, 0x79, 0xea, 0x18, 0xdc, 0xd6, 0xdd, 0x2c, 0x1d, 0x8c, 0xb0, 0x00, 0x6d, 0x28 ], [ 0x9d, 0x85, 0xe0, 0xc9, 0xe1, 0xac, 0x1e, 0xec, 0xd0, 0x12, 0xd3, 0x02, 0xc7, 0xda, 0x2e, 0x3d ], [ 0xef, 0xb1, 0x61, 0x41, 0x0b, 0x02, 0x13, 0x84, 0x67, 0x4f, 0xf1, 0xf5, 0x0b, 0x29, 0x87, 0xc4 ], [ 0x38, 0x19, 0x3d, 0x9a, 0xb8, 0x94, 0x57, 0xe1, 0x17, 0x38, 0xe9, 0x40, 0xbd, 0x08, 0xf1, 0x1b ], [ 0x3a, 0xce, 0x69, 0x70, 0x1c, 0x34, 0x0d, 0xf5, 0x8f, 0x49, 0xca, 0x0b, 0xa8, 0xca, 0x7a, 0x9a ], [ 0xe5, 0x8e, 0x13, 0x58, 0x20, 0x3b, 0x92, 0x98, 0x99, 0x81, 0x43, 0xfb, 0xfe, 0x61, 0xaf, 0x7e ], [ 0x82, 0x2e, 0xe7, 0x5f, 0x22, 0x3b, 0xe8, 0xbd, 0x7c, 0x1b, 0xb5, 0x15, 0xe4, 0x1c, 0x87, 0x23 ], [ 0x7e, 0x1b, 0x80, 0xb3, 0xb5, 0x65, 0xd9, 0xb1, 0xd0, 0xb7, 0xfe, 0x9f, 0x24, 0xd5, 0x2f, 0x82 ], [ 0xe6, 0x28, 0x44, 0x9b, 0x7f, 0x63, 0x17, 0x89, 0x9a, 0x8f, 0x87, 0xf8, 0x70, 0xef, 0x59, 0x3b ], [ 0x2f, 0xca, 0xdf, 0x36, 0x15, 0xe6, 0x3e, 0x8a, 0xee, 0x82, 0x2b, 0x03, 0x9a, 0xfb, 0x19, 0x8d ], [ 0x07, 0x82, 0x5d, 0xee, 0xd3, 0xb0, 0x28, 0x42, 0x5d, 0xf2, 0xc8, 0x8e, 0xad, 0x6a, 0x33, 0x0a ], [ 0x92, 0x44, 0xfd, 0xf8, 0xb6, 0xf8, 0x3f, 0xb4, 0x25, 0xe5, 0x06, 0x6d, 0x5a, 0xbe, 0x38, 0x62 ], [ 0x1e, 0x30, 0x22, 0xee, 0xb3, 0xa8, 0x32, 0x90, 0x9b, 0xee, 0xcf, 0x9a, 0xe6, 0x32, 0xa1, 0x3f ], [ 0xb1, 0xfe, 0xdd, 0x54, 0x0d, 0x12, 0xdb, 0x05, 0xfc, 0xa0, 0x3e, 0x69, 0x71, 0xcd, 0x93, 0xb0 ], [ 0x01, 0x12, 0x09, 0x1c, 0xa7, 0xb7, 0x75, 0x46, 0x12, 0x99, 0x8d, 0xda, 0x5a, 0xde, 0x48, 0x82 ], [ 0xd0, 0xae, 0x20, 0x89, 0x50, 0x52, 0xd6, 0xb6, 0xfd, 0x53, 0x50, 0x8c, 0xd6, 0x87, 0xc6, 0x42 ], [ 0x6f, 0x38, 0x1a, 0x59, 0x55, 0x94, 0xfa, 0x45, 0x3e, 0x95, 0x3f, 0xf7, 0xb4, 0x90, 0x34, 0x82 ], [ 0x6e, 0x2c, 0x3a, 0xa1, 0xdd, 0x00, 0xfa, 0x16, 0xd8, 0x83, 0x1d, 0x26, 0x39, 0x32, 0xae, 0xb8 ], [ 0xba, 0x1a, 0x0d, 0xdc, 0x15, 0x2f, 0x49, 0x19, 0xb2, 0x17, 0xdf, 0x37, 0x73, 0x03, 0x16, 0x94 ], [ 0x5c, 0x22, 0x40, 0x10, 0xc5, 0x4f, 0x12, 0x8a, 0x54, 0x53, 0x0b, 0xaa, 0xfb, 0x5c, 0x30, 0x44 ], [ 0x82, 0xe5, 0x5b, 0xdc, 0x60, 0x2a, 0x52, 0x28, 0x0c, 0x52, 0x19, 0x0f, 0x69, 0x36, 0x62, 0xef ], [ 0x26, 0x18, 0xb0, 0x1f, 0xb8, 0xf6, 0xc8, 0x23, 0xf4, 0x5a, 0xb0, 0x75, 0x51, 0xe5, 0xed, 0x17 ], [ 0xb8, 0xb6, 0xd1, 0xd6, 0x40, 0x93, 0x42, 0x97, 0x1d, 0x1b, 0x62, 0xd9, 0xb2, 0x2c, 0x1b, 0xc9 ], [ 0xa5, 0xd1, 0xba, 0xd7, 0xb4, 0x46, 0xb9, 0x7a, 0xb2, 0xa3, 0xc8, 0xba, 0xa3, 0xaa, 0xbb, 0x48 ], [ 0x17, 0x28, 0xd6, 0x22, 0x93, 0xe7, 0x61, 0xd1, 0x48, 0x0a, 0x01, 0xf4, 0x59, 0x6b, 0x0e, 0x32 ], [ 0x9e, 0x1f, 0xd8, 0xb5, 0x05, 0x93, 0x2b, 0x26, 0x8f, 0x79, 0x2b, 0x83, 0x16, 0x93, 0x69, 0xa5 ], [ 0xac, 0x7b, 0xf8, 0x39, 0x53, 0xd8, 0xfd, 0x93, 0x8e, 0x12, 0x92, 0x6c, 0xe1, 0xe2, 0xe7, 0x88 ], [ 0xcf, 0xf4, 0xf8, 0x42, 0x25, 0xd0, 0xbb, 0xaa, 0x75, 0x03, 0xa4, 0xd6, 0x61, 0x7e, 0x75, 0x66 ], [ 0x30, 0x00, 0xf2, 0xef, 0x64, 0x20, 0x65, 0x77, 0x55, 0x5a, 0x1f, 0xe4, 0x86, 0xf6, 0xb6, 0x09 ], [ 0x35, 0x6a, 0x7b, 0xb2, 0xa2, 0xbd, 0x57, 0x12, 0x8b, 0x2b, 0x79, 0x38, 0xbc, 0xb0, 0x20, 0xcd ], [ 0xcc, 0x40, 0xc7, 0xb1, 0xc0, 0x9e, 0xdf, 0x02, 0x17, 0xe0, 0x1e, 0x09, 0xc1, 0x07, 0xea, 0x7c ], [ 0x83, 0xe6, 0xca, 0x85, 0xfe, 0x7e, 0xc0, 0x93, 0x79, 0x4f, 0x90, 0x2d, 0x45, 0xe0, 0xf2, 0x10 ], [ 0x28, 0x0d, 0xcf, 0xd9, 0x09, 0x1f, 0x01, 0x3f, 0xa5, 0x4f, 0x68, 0x25, 0x22, 0x92, 0x35, 0xb4 ], [ 0x2d, 0xdd, 0x0e, 0xf0, 0x0f, 0x8d, 0x0c, 0x45, 0x15, 0x55, 0xca, 0x4a, 0x6f, 0xe4, 0xad, 0x2c ], [ 0x25, 0xb3, 0xae, 0x87, 0x79, 0xb8, 0x39, 0x90, 0x97, 0xa3, 0xea, 0xd7, 0xc4, 0xa4, 0xb7, 0xc1 ], [ 0x4b, 0x19, 0xdf, 0x03, 0x74, 0x0b, 0x52, 0xd3, 0x7c, 0x98, 0xfe, 0xdf, 0x26, 0xcf, 0x0b, 0xff ], [ 0xc0, 0xf6, 0x6b, 0xf0, 0xbd, 0x3f, 0x3d, 0x3f, 0x63, 0x0e, 0x15, 0xcc, 0x5e, 0xf4, 0xbc, 0xce ], [ 0xfd, 0x7d, 0x92, 0x1b, 0xae, 0xc3, 0x62, 0x23, 0x9e, 0xb3, 0xcf, 0xa1, 0x91, 0x64, 0xd0, 0x71 ], [ 0x9b, 0x6e, 0xb0, 0xc0, 0x0c, 0xd6, 0xb1, 0x32, 0x64, 0xc0, 0x69, 0xd7, 0x42, 0xd2, 0x95, 0x83 ], [ 0xcb, 0x5c, 0xe7, 0xc0, 0x66, 0xb8, 0x94, 0x58, 0x1f, 0x11, 0x36, 0xa1, 0xa0, 0x0f, 0x50, 0xf8 ], [ 0x41, 0xda, 0x2c, 0x52, 0xd2, 0xbe, 0x94, 0xff, 0x35, 0x92, 0xae, 0x05, 0x4e, 0x2d, 0xac, 0x3c ], [ 0x21, 0x9d, 0xf9, 0xc3, 0xfe, 0xce, 0xa9, 0x11, 0x48, 0x4e, 0x9b, 0x15, 0x25, 0x8d, 0x76, 0xac ], [ 0xcc, 0xe0, 0xab, 0x67, 0x78, 0xb1, 0x9d, 0xfb, 0x7f, 0x3d, 0xe4, 0x5d, 0x97, 0xca, 0xab, 0x65 ], [ 0xd4, 0xfd, 0x5c, 0x75, 0x80, 0xb1, 0x06, 0x8a, 0xb0, 0xdf, 0xd9, 0x0f, 0x79, 0x73, 0x3f, 0xf2 ], [ 0xb5, 0x42, 0x95, 0x85, 0xdf, 0xcd, 0x80, 0xf8, 0xe1, 0x4b, 0x48, 0xc8, 0x6f, 0x11, 0xd1, 0xd9 ], [ 0x3c, 0xc1, 0xd2, 0x68, 0xfe, 0x62, 0x1c, 0x5d, 0x40, 0x52, 0x91, 0x9b, 0xf6, 0xf3, 0x07, 0xdb ], [ 0x10, 0x8b, 0x6e, 0x49, 0x06, 0x24, 0xf9, 0x9e, 0x92, 0xf8, 0x65, 0x2f, 0xac, 0x05, 0x69, 0x06 ], [ 0x12, 0x75, 0x91, 0xc1, 0x0b, 0x0f, 0x2a, 0x88, 0xf7, 0x26, 0x13, 0x2b, 0xa1, 0x0f, 0x80, 0xc9 ], [ 0xec, 0xc2, 0xed, 0xf7, 0xec, 0x7b, 0x0f, 0xf5, 0x29, 0x3c, 0xf6, 0x36, 0x85, 0x22, 0x20, 0xf2 ], [ 0x77, 0xac, 0xdd, 0xd8, 0x4b, 0x31, 0xae, 0xd0, 0xf9, 0x08, 0x17, 0x75, 0x1d, 0x02, 0x37, 0x30 ], [ 0x44, 0xb0, 0xa0, 0x05, 0x19, 0xa4, 0x71, 0x2a, 0xaa, 0xbd, 0xf6, 0x6d, 0xc1, 0x33, 0xa5, 0x1c ], [ 0x8b, 0x09, 0x7e, 0x2f, 0x87, 0x1a, 0x28, 0x90, 0x78, 0x5d, 0x3b, 0x6d, 0x74, 0x03, 0x75, 0x16 ], [ 0x14, 0x7a, 0x13, 0x9b, 0x50, 0xee, 0xd6, 0x6d, 0x77, 0x4e, 0xdc, 0xdf, 0xde, 0x8b, 0x17, 0x18 ], [ 0x12, 0x16, 0x1a, 0xc7, 0x07, 0xeb, 0x8b, 0xd6, 0x29, 0x09, 0x12, 0x99, 0x83, 0x12, 0x1a, 0x54 ], [ 0x69, 0xb1, 0x2f, 0x9f, 0xcf, 0x71, 0x61, 0x19, 0xe4, 0xa4, 0x27, 0x2e, 0x3b, 0x17, 0x42, 0xe8 ], [ 0x53, 0x50, 0xa5, 0xc6, 0x9e, 0x4f, 0xf9, 0x6a, 0xfd, 0x98, 0xea, 0x14, 0x62, 0xd2, 0x5e, 0xd9 ], [ 0xdd, 0x37, 0x69, 0x10, 0xb7, 0x9b, 0x3e, 0x9c, 0x30, 0xb6, 0x2f, 0xbf, 0x5d, 0x5c, 0xed, 0x26 ], [ 0x52, 0x2e, 0x83, 0xe7, 0xab, 0xa5, 0x7e, 0xe4, 0x7c, 0x43, 0xcc, 0x04, 0x05, 0xd6, 0xc1, 0xff ], [ 0xb0, 0x4b, 0xdb, 0x4a, 0xab, 0xf4, 0x2b, 0x0b, 0xad, 0x6a, 0xed, 0xb8, 0x16, 0x52, 0x85, 0x26 ], [ 0x93, 0x13, 0xfc, 0xad, 0x3d, 0x37, 0x71, 0x18, 0x63, 0x3c, 0xb6, 0xe4, 0xff, 0x9c, 0x7c, 0xab ], [ 0x08, 0x68, 0x40, 0x71, 0x08, 0xc1, 0x08, 0x69, 0xf0, 0x43, 0xbb, 0x01, 0xcc, 0xf5, 0x37, 0xe7 ], [ 0x22, 0xf6, 0x3a, 0x00, 0x72, 0x9d, 0xd9, 0xc6, 0x43, 0x6b, 0xc5, 0x1b, 0x25, 0x28, 0x3b, 0x1d ], [ 0xe9, 0xaa, 0x23, 0x8c, 0xb9, 0x22, 0x33, 0x7e, 0x4e, 0x5d, 0x16, 0x8f, 0x8a, 0x79, 0x7e, 0x77 ], [ 0xe3, 0x1c, 0x3d, 0xee, 0x11, 0xb9, 0xd5, 0x26, 0xeb, 0xa8, 0x65, 0x74, 0x2e, 0x82, 0x5b, 0x65 ], [ 0xd2, 0x55, 0xa5, 0xd7, 0xe6, 0xc9, 0x59, 0x06, 0x06, 0x1d, 0xe6, 0x54, 0xd1, 0x9e, 0xdc, 0x79 ], [ 0x55, 0x5b, 0x0a, 0x07, 0x58, 0xbe, 0x0b, 0x3e, 0xa2, 0xd6, 0x7a, 0x86, 0xe2, 0x84, 0xee, 0x04 ], [ 0x64, 0xf6, 0xdb, 0xde, 0xc3, 0xf9, 0x64, 0x26, 0xaf, 0x25, 0x2c, 0xe1, 0xba, 0x81, 0x9f, 0xd0 ], [ 0x65, 0xa0, 0x34, 0x35, 0x83, 0xb5, 0x80, 0x9c, 0xcc, 0xc5, 0x88, 0x76, 0xf2, 0x12, 0x00, 0x16 ], [ 0xce, 0x0e, 0x30, 0xed, 0xca, 0x64, 0x7a, 0x60, 0xe6, 0x7b, 0xec, 0x3e, 0x23, 0x6c, 0x09, 0xaf ], [ 0x86, 0xc7, 0x44, 0x09, 0x22, 0xe7, 0x62, 0x0e, 0xb5, 0xab, 0x5c, 0xe5, 0x25, 0xdf, 0x9b, 0x08 ], [ 0x2a, 0x55, 0x7c, 0x02, 0x14, 0x3c, 0x00, 0xeb, 0xc9, 0x27, 0x32, 0x51, 0x6c, 0x54, 0x52, 0xf7 ], [ 0xd9, 0xbc, 0x4f, 0xc7, 0xfd, 0x21, 0x77, 0x3b, 0xe0, 0x35, 0x2a, 0xaf, 0x99, 0xe2, 0xd3, 0x82 ], [ 0xfd, 0xae, 0x2f, 0xf6, 0x40, 0x8e, 0x09, 0x5e, 0xf4, 0xf3, 0xcf, 0xaf, 0xb8, 0x4f, 0xa9, 0x93 ], [ 0x9d, 0xbb, 0x74, 0xad, 0x0a, 0x77, 0x5f, 0x94, 0x0e, 0xa3, 0xee, 0xe5, 0x19, 0x0a, 0x26, 0xab ], [ 0xaf, 0xf1, 0x21, 0xd2, 0xd8, 0x5c, 0x12, 0x0b, 0xe9, 0x71, 0x8d, 0x30, 0x34, 0xce, 0xe8, 0x23 ], [ 0xb9, 0x03, 0x65, 0x36, 0xb9, 0xf8, 0xbc, 0xf4, 0xf8, 0xdf, 0xf5, 0xed, 0x19, 0x40, 0x6f, 0x8b ], [ 0x2a, 0x29, 0xb9, 0x39, 0xc7, 0xb6, 0x12, 0x79, 0x6c, 0xca, 0x4e, 0xbc, 0x1f, 0xf0, 0x3e, 0x45 ], [ 0xe5, 0xfa, 0x93, 0x9d, 0x81, 0x20, 0x78, 0x4e, 0xb5, 0x1f, 0xae, 0xbe, 0x29, 0xb4, 0x05, 0xb4 ], [ 0xb3, 0x25, 0xc5, 0x37, 0x8a, 0xde, 0xc8, 0xee, 0x71, 0xd1, 0xd3, 0x10, 0x95, 0x66, 0x9b, 0x1a ], [ 0x98, 0x3e, 0xbc, 0xb9, 0xac, 0x2b, 0x2e, 0x4e, 0x95, 0x5f, 0x61, 0x3a, 0x42, 0x4f, 0xe8, 0x0a ], [ 0xc3, 0x34, 0x11, 0xa2, 0x2a, 0xc9, 0xc0, 0xd3, 0x98, 0x6e, 0x9a, 0x51, 0xfc, 0x32, 0x5d, 0x6b ], [ 0x59, 0xdc, 0x13, 0x9d, 0x7b, 0xce, 0x49, 0x7c, 0xe4, 0x91, 0x95, 0xd1, 0x6e, 0x59, 0xf4, 0xf7 ], [ 0x42, 0x5e, 0x7c, 0x32, 0x23, 0x8b, 0xe5, 0xc1, 0x99, 0xa1, 0x55, 0xde, 0x00, 0x78, 0x46, 0x3d ], [ 0x73, 0x4c, 0xdf, 0xc6, 0x2f, 0xd7, 0x19, 0x76, 0xed, 0xc8, 0x2e, 0xb7, 0xf3, 0x3d, 0x37, 0x00 ], [ 0xdf, 0xd6, 0x67, 0x3b, 0x7a, 0xf5, 0x34, 0xa4, 0xcd, 0x80, 0xf5, 0x5f, 0xfb, 0x57, 0x7a, 0x9b ], [ 0x33, 0x9c, 0xe2, 0xa6, 0xfe, 0x1a, 0x6e, 0xa7, 0x41, 0xc7, 0xaa, 0xed, 0x4e, 0xba, 0xd4, 0xe1 ], [ 0x4c, 0xa5, 0xd1, 0x58, 0x64, 0x50, 0xa4, 0xc5, 0x00, 0xa5, 0x57, 0xfa, 0x78, 0x37, 0xd5, 0xe8 ], [ 0x8d, 0x9a, 0x4e, 0x5c, 0xc9, 0x20, 0x10, 0x77, 0x1a, 0xae, 0xa2, 0x1a, 0x08, 0xe8, 0x3a, 0x52 ], [ 0x87, 0x4d, 0x2e, 0xc0, 0x2b, 0x41, 0xa0, 0x38, 0x8f, 0x35, 0x0a, 0x07, 0x89, 0x64, 0xc1, 0x1f ], [ 0xeb, 0x12, 0xfd, 0xe7, 0xd3, 0xf6, 0x33, 0x82, 0xfc, 0xec, 0x95, 0xaf, 0x1e, 0x33, 0x31, 0xd6 ], [ 0x49, 0xfe, 0x95, 0x76, 0x34, 0xc5, 0xa5, 0x84, 0x1c, 0x51, 0x49, 0x6e, 0x7b, 0x6b, 0x66, 0x5c ], [ 0xab, 0x36, 0x01, 0x29, 0x1e, 0xac, 0xb1, 0x9e, 0xff, 0x20, 0x72, 0x29, 0x7d, 0x35, 0x34, 0xe2 ], [ 0x0c, 0x73, 0x75, 0x22, 0xda, 0x7f, 0x9e, 0x04, 0x2c, 0xdc, 0x46, 0x18, 0xd5, 0x0a, 0x5c, 0x40 ], [ 0x70, 0x38, 0x62, 0x4c, 0x1f, 0x4e, 0xd2, 0x35, 0x1d, 0x25, 0x98, 0x23, 0xe3, 0xca, 0x3f, 0xda ], [ 0x9c, 0xf5, 0x69, 0x07, 0xb8, 0xc4, 0x76, 0x14, 0xf9, 0x13, 0xb9, 0x97, 0xaf, 0xa6, 0x0d, 0x9f ], [ 0x53, 0x83, 0x76, 0xda, 0x07, 0x2b, 0x5c, 0x7c, 0x1e, 0x6d, 0x66, 0x2e, 0xac, 0x0e, 0xc3, 0xdb ], [ 0xe1, 0x58, 0x58, 0x63, 0xe7, 0x55, 0x06, 0x7b, 0xc2, 0x66, 0x5e, 0xaf, 0x8a, 0x52, 0xf1, 0x75 ], [ 0x19, 0x2b, 0xcd, 0x4d, 0xa7, 0x8c, 0xf5, 0x97, 0x12, 0x01, 0xc0, 0x6c, 0x43, 0x67, 0x50, 0xed ], [ 0x2f, 0xa8, 0x41, 0xc5, 0x62, 0xe7, 0x70, 0xad, 0xe4, 0x39, 0xd6, 0xab, 0x93, 0x6e, 0xda, 0xf8 ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" tweak_value4_128bit = [ [ 0x68, 0x86, 0xce, 0x72, 0x37, 0x03, 0x1d, 0x39, 0x63, 0xaf, 0x24, 0xef, 0x3d, 0x20, 0xf7, 0xed ], [ 0xa4, 0x6f, 0xad, 0xbd, 0x1e, 0x92, 0x40, 0x6c, 0x42, 0x2d, 0x7f, 0x02, 0xeb, 0x28, 0x10, 0xff ], [ 0x5e, 0x04, 0xca, 0x16, 0xe6, 0x75, 0x88, 0x2b, 0x3d, 0x38, 0x6c, 0x99, 0xd2, 0xf5, 0x08, 0x63 ], [ 0x3d, 0xdd, 0xff, 0x05, 0x58, 0x66, 0xae, 0x70, 0xf3, 0x18, 0x38, 0x4c, 0x04, 0x8f, 0xcf, 0x94 ], [ 0x0d, 0x05, 0xcf, 0x88, 0xef, 0x98, 0x84, 0xf6, 0x4a, 0xd0, 0x67, 0x00, 0xc9, 0x06, 0xe7, 0x60 ], [ 0xb6, 0xef, 0x5f, 0x57, 0x76, 0xc7, 0x93, 0x62, 0x2f, 0xd1, 0x90, 0x77, 0xa2, 0xa1, 0x73, 0x22 ], [ 0x94, 0x4c, 0x4b, 0x8f, 0x03, 0xf5, 0x0e, 0x83, 0x31, 0xd3, 0x83, 0xc1, 0x0d, 0x89, 0xf0, 0x14 ], [ 0x0a, 0xce, 0xa6, 0xf4, 0x5d, 0x6b, 0x40, 0xc7, 0x58, 0x93, 0x7c, 0x37, 0x1e, 0x04, 0x7c, 0xc5 ], [ 0xef, 0x06, 0x32, 0x61, 0xc4, 0xbe, 0x4c, 0x9b, 0xde, 0x14, 0xd8, 0xe4, 0x35, 0xdf, 0x29, 0x52 ], [ 0x98, 0x26, 0x24, 0x18, 0x30, 0x6e, 0x22, 0xf8, 0x64, 0x63, 0x4c, 0x57, 0xe9, 0xb5, 0xa8, 0x15 ], [ 0xda, 0xb4, 0x84, 0xb0, 0xe9, 0x42, 0x74, 0xb3, 0x6b, 0xef, 0x33, 0x9e, 0x5f, 0x2e, 0x20, 0x92 ], [ 0xd9, 0x45, 0xed, 0x0e, 0x1c, 0x80, 0x54, 0x4f, 0x3e, 0xff, 0xd5, 0x32, 0x16, 0x25, 0xce, 0x48 ], [ 0x71, 0x67, 0xec, 0x38, 0xb3, 0xdc, 0x39, 0xe6, 0x05, 0x5c, 0x00, 0x88, 0x17, 0x23, 0xdc, 0xcf ], [ 0xed, 0x93, 0xd3, 0xdb, 0xc5, 0x74, 0x22, 0xdd, 0x13, 0x22, 0x5d, 0xd7, 0x88, 0x6d, 0xea, 0x41 ], [ 0xce, 0xdc, 0x28, 0xa1, 0xea, 0x5a, 0x3e, 0x12, 0xf8, 0x73, 0x6d, 0x46, 0x50, 0x66, 0x79, 0xbd ], [ 0x85, 0xbd, 0xc6, 0x03, 0xaf, 0x4d, 0x82, 0x07, 0x13, 0xbc, 0xe0, 0x69, 0x64, 0x7b, 0x12, 0xc7 ], [ 0x86, 0xad, 0x8c, 0xb7, 0x0c, 0x4f, 0x91, 0xae, 0x2f, 0x6e, 0x47, 0xc3, 0xb2, 0xc1, 0x0f, 0xd1 ], [ 0x36, 0x16, 0x6a, 0x67, 0x9d, 0x1a, 0xe9, 0x56, 0x4b, 0x68, 0x50, 0x26, 0x7a, 0x11, 0x73, 0x79 ], [ 0x8e, 0xb0, 0x80, 0xe7, 0x1a, 0xfa, 0xa2, 0x83, 0x63, 0xdc, 0xeb, 0x57, 0xc5, 0xff, 0xb3, 0x45 ], [ 0xb0, 0x23, 0x10, 0xbc, 0x11, 0xea, 0xb0, 0xe5, 0xf3, 0xb3, 0x3a, 0x4b, 0xa4, 0xc3, 0xc3, 0x56 ], [ 0x99, 0x89, 0x21, 0xc5, 0x14, 0x66, 0xe4, 0xc6, 0xa0, 0x1f, 0x65, 0xb6, 0x84, 0xaa, 0xeb, 0xef ], [ 0xfa, 0x7c, 0x95, 0xde, 0xce, 0xfd, 0xad, 0x91, 0x2b, 0xa3, 0xc6, 0x47, 0x48, 0xde, 0x87, 0x0e ], [ 0x6d, 0x52, 0xee, 0xa3, 0xe1, 0x17, 0x4d, 0x24, 0x5a, 0x91, 0x24, 0x3e, 0x16, 0x5d, 0x4f, 0xdf ], [ 0xe2, 0x78, 0x5b, 0x96, 0x76, 0x50, 0xc0, 0xde, 0x9d, 0x38, 0xfb, 0x90, 0x9d, 0x2d, 0xdf, 0x0e ], [ 0xe1, 0x41, 0x11, 0x44, 0x14, 0x51, 0xd4, 0x7f, 0x95, 0x34, 0x08, 0xf8, 0x2c, 0x93, 0xa7, 0x1b ], [ 0x56, 0xcd, 0x77, 0x2e, 0x83, 0x6b, 0xde, 0x44, 0xf2, 0xb9, 0x04, 0x0e, 0x0a, 0x58, 0x34, 0xc1 ], [ 0x57, 0xb6, 0xc7, 0x66, 0x9d, 0xfe, 0x3f, 0xb8, 0x64, 0xe0, 0x17, 0x0b, 0x36, 0x08, 0x2a, 0x25 ], [ 0x25, 0xca, 0x3d, 0x3e, 0x9d, 0x24, 0xfb, 0xfa, 0x50, 0xa9, 0x38, 0xf4, 0xcd, 0xa8, 0x60, 0xb1 ], [ 0x2a, 0x82, 0xce, 0xdf, 0x4e, 0x5b, 0x65, 0xde, 0x34, 0x04, 0x78, 0x34, 0xb1, 0x33, 0xba, 0xd7 ], [ 0xc6, 0x65, 0x99, 0x53, 0xc7, 0x29, 0xc0, 0x23, 0x80, 0x92, 0xa5, 0x81, 0xaa, 0x02, 0x13, 0x86 ], [ 0xe7, 0x1f, 0x0b, 0x94, 0x41, 0x94, 0x94, 0x0c, 0x30, 0xa3, 0x39, 0xc6, 0x44, 0xd5, 0xcf, 0x69 ], [ 0xf9, 0xb0, 0x4d, 0x5d, 0x03, 0xc8, 0x87, 0x54, 0x62, 0xf8, 0x52, 0xfc, 0x1a, 0x43, 0x8f, 0x9d ], [ 0xf8, 0x9f, 0x80, 0x54, 0x56, 0xb6, 0x42, 0x05, 0x9e, 0x28, 0xf7, 0xde, 0xcb, 0x20, 0x2f, 0xaa ], [ 0xc0, 0x15, 0x71, 0x01, 0x3e, 0xdc, 0xe1, 0xc9, 0xd4, 0x8a, 0x54, 0x31, 0xb6, 0xbd, 0x79, 0x76 ], [ 0x1b, 0x47, 0xfb, 0x74, 0x16, 0xd8, 0x6f, 0xee, 0x2d, 0xda, 0xcb, 0x82, 0x94, 0x06, 0xf0, 0xf3 ], [ 0x17, 0xf3, 0x8c, 0x8f, 0x98, 0x66, 0x57, 0x90, 0x4c, 0x3b, 0x2f, 0x1d, 0x6c, 0x93, 0x40, 0x7b ], [ 0xc7, 0xfb, 0x5c, 0x36, 0x83, 0x08, 0x2d, 0x5d, 0x69, 0xf8, 0x36, 0x1e, 0xc0, 0x54, 0xef, 0x04 ], [ 0xf9, 0xb1, 0x5d, 0x6f, 0xae, 0x9a, 0x53, 0x38, 0xb8, 0x4c, 0xba, 0xe0, 0x5f, 0xac, 0xec, 0x40 ], [ 0x8c, 0x72, 0xc6, 0x06, 0xde, 0xbf, 0xf5, 0x6d, 0x89, 0xc9, 0x68, 0xad, 0xae, 0xc4, 0xb0, 0xf8 ], [ 0xaa, 0xaf, 0xec, 0xa1, 0xf2, 0x5a, 0x6b, 0x82, 0xf8, 0xaa, 0x68, 0xc3, 0x09, 0x19, 0x3e, 0x60 ], [ 0x67, 0x4f, 0xdd, 0x74, 0x4b, 0x17, 0x13, 0x61, 0xa1, 0x91, 0xd5, 0xbc, 0x87, 0xb1, 0xa7, 0xd3 ], [ 0xcf, 0xee, 0x85, 0x7e, 0x13, 0xba, 0x52, 0xc8, 0xea, 0x86, 0xed, 0x88, 0x36, 0xe4, 0xeb, 0x93 ], [ 0xc6, 0xdb, 0x3e, 0xbd, 0xb4, 0xa7, 0xfa, 0xb9, 0x7b, 0x95, 0xf3, 0xc2, 0x3e, 0xa3, 0x12, 0x2c ], [ 0x3d, 0x90, 0xc3, 0x70, 0xdf, 0x4c, 0x4a, 0x4a, 0x72, 0x5c, 0x9b, 0x6c, 0xf6, 0xb2, 0x78, 0xe0 ], [ 0xe4, 0x79, 0xb1, 0xe4, 0x21, 0xcf, 0x93, 0x5a, 0x7c, 0x95, 0x08, 0x51, 0xf3, 0xec, 0x5b, 0x35 ], [ 0x76, 0xe4, 0xf0, 0x01, 0xc6, 0x61, 0x9c, 0x76, 0xfb, 0x2b, 0x3b, 0x19, 0x1a, 0xed, 0x57, 0xe2 ], [ 0x83, 0xbb, 0xb1, 0x8b, 0xdf, 0xbe, 0x44, 0x60, 0xa5, 0x79, 0xff, 0xbc, 0xf9, 0x7b, 0x0e, 0xe8 ], [ 0x41, 0x81, 0x95, 0xd8, 0x83, 0xd1, 0xe2, 0x4c, 0xe9, 0x0c, 0x06, 0xea, 0xb3, 0x25, 0xa2, 0x33 ], [ 0x86, 0x6f, 0x8c, 0xf3, 0x99, 0xec, 0x7b, 0x00, 0x63, 0x75, 0x4f, 0x27, 0x52, 0x8b, 0x64, 0x01 ], [ 0x0e, 0x76, 0xcd, 0x3d, 0x76, 0xd5, 0xc9, 0xf7, 0xc2, 0x84, 0x28, 0x8d, 0x51, 0x95, 0x5b, 0x30 ], [ 0x67, 0x86, 0xea, 0xcd, 0x8f, 0xf9, 0x54, 0xfd, 0x9c, 0x74, 0xe9, 0x21, 0x3b, 0x00, 0x8b, 0x20 ], [ 0x72, 0xd9, 0xe2, 0x22, 0x13, 0x35, 0xcb, 0x69, 0x31, 0xc7, 0x7c, 0x08, 0xf9, 0xce, 0xa6, 0x26 ], [ 0xc8, 0x9d, 0xb2, 0xc8, 0x61, 0x81, 0x49, 0x79, 0x5f, 0x19, 0xb7, 0xa4, 0x1f, 0x74, 0x86, 0xbd ], [ 0x72, 0x84, 0xd5, 0x17, 0x18, 0x76, 0xb6, 0xb7, 0x12, 0x08, 0xda, 0x30, 0xce, 0x7b, 0xe0, 0x15 ], [ 0x7c, 0x29, 0x52, 0xc9, 0xeb, 0x9c, 0xa4, 0x54, 0x6b, 0xfd, 0x2d, 0x12, 0x76, 0xf9, 0x85, 0xd4 ], [ 0x28, 0x05, 0x5b, 0x96, 0x0d, 0xe4, 0x78, 0xc8, 0xc7, 0x46, 0xaa, 0xbe, 0x2d, 0xe0, 0xd9, 0x62 ], [ 0x2f, 0x28, 0x31, 0xd0, 0xfd, 0x73, 0x19, 0x18, 0xbd, 0xe6, 0xcb, 0x0f, 0x35, 0x69, 0x7e, 0x16 ], [ 0xce, 0x0b, 0x8c, 0xba, 0x0c, 0x91, 0x87, 0xe8, 0xdd, 0x1f, 0xa4, 0x19, 0x65, 0x45, 0xd6, 0x52 ], [ 0xe6, 0x38, 0x0d, 0xea, 0xb6, 0x33, 0x1d, 0xb9, 0x8a, 0x8a, 0x2e, 0xc2, 0x15, 0xd1, 0x8a, 0x8d ], [ 0xa6, 0xcc, 0xbb, 0xd3, 0x9f, 0x0f, 0x0f, 0x34, 0xe0, 0xfa, 0xd7, 0xf4, 0x59, 0x96, 0x76, 0xe4 ], [ 0xe3, 0x8a, 0x80, 0xe5, 0x71, 0xe0, 0x0c, 0xcd, 0xb2, 0x28, 0x4e, 0x8c, 0xcf, 0x56, 0xb9, 0x5e ], [ 0xe1, 0xcb, 0xea, 0x55, 0x94, 0x8c, 0x7c, 0xcb, 0x0d, 0x51, 0x91, 0x05, 0xc3, 0xa9, 0x9e, 0xb2 ], [ 0x6c, 0xe3, 0x03, 0x8d, 0x2f, 0xf7, 0xbd, 0xbd, 0xa2, 0x47, 0xc8, 0x36, 0x4b, 0xc9, 0x21, 0xe5 ], [ 0xde, 0xd0, 0x7c, 0xf0, 0x30, 0xdd, 0xd2, 0x35, 0xef, 0x71, 0x82, 0x03, 0x2f, 0xe7, 0x4d, 0x4b ], [ 0xd5, 0x0c, 0x76, 0xe0, 0xb7, 0x32, 0x3b, 0x4e, 0xe4, 0xb9, 0x45, 0xa0, 0xd8, 0xcd, 0x4b, 0x50 ], [ 0xd4, 0xd7, 0x95, 0x13, 0x03, 0x9a, 0x96, 0xba, 0xd0, 0x6f, 0xa8, 0xa7, 0x53, 0x1e, 0xcd, 0xa3 ], [ 0x9c, 0xbd, 0x4b, 0xef, 0xc3, 0xbe, 0xb8, 0xf9, 0x62, 0x82, 0x57, 0x85, 0xa2, 0x88, 0xba, 0x84 ], [ 0x3e, 0x64, 0x3c, 0x25, 0x94, 0xc8, 0xd9, 0x6e, 0xce, 0x8b, 0xca, 0x2e, 0xb8, 0xe1, 0x2a, 0x97 ], [ 0x57, 0xed, 0x57, 0x50, 0xb9, 0x7f, 0x13, 0x19, 0x49, 0x4d, 0x38, 0xb1, 0x62, 0xdb, 0x5a, 0x90 ], [ 0xb4, 0x14, 0x28, 0x76, 0x6d, 0x95, 0x00, 0x00, 0x1a, 0xd3, 0x43, 0x9f, 0x82, 0x3b, 0x41, 0x20 ], [ 0xcf, 0xde, 0xb1, 0xdd, 0x87, 0x5d, 0xf2, 0x63, 0xc6, 0x78, 0xb2, 0x1e, 0xe2, 0x38, 0x2a, 0xf2 ], [ 0x05, 0x70, 0xd4, 0xfd, 0x8d, 0x25, 0x36, 0xb5, 0x8f, 0xdb, 0xef, 0xfc, 0x49, 0xd6, 0x3c, 0x60 ], [ 0x11, 0x85, 0xbf, 0xf8, 0x6b, 0x66, 0xe0, 0xef, 0xfa, 0x7d, 0x28, 0x44, 0x7f, 0xaf, 0x2d, 0x51 ], [ 0x39, 0x60, 0x1d, 0x5e, 0x21, 0x8d, 0x7f, 0x5f, 0x3c, 0xe7, 0xfc, 0x45, 0xf0, 0x57, 0x6f, 0x3d ], [ 0x11, 0xa9, 0x1c, 0xe8, 0x3d, 0x32, 0x4a, 0x10, 0x37, 0x7f, 0x70, 0xac, 0x37, 0x5f, 0x01, 0xdf ], [ 0xaa, 0xf0, 0xd6, 0xb1, 0x9c, 0x4e, 0x42, 0xa9, 0x8c, 0xc8, 0x84, 0x70, 0x99, 0x81, 0xd0, 0x8b ], [ 0x6d, 0x9b, 0x0f, 0xce, 0x7d, 0x9c, 0x3a, 0x9c, 0x64, 0x17, 0xcc, 0x66, 0x7d, 0xed, 0x90, 0x11 ], [ 0x48, 0x34, 0x6e, 0x22, 0xe3, 0x4f, 0x56, 0xcb, 0x47, 0xe8, 0x4e, 0x5d, 0xf1, 0xc4, 0x90, 0xa8 ], [ 0x24, 0x54, 0xb1, 0x8d, 0x3a, 0x4d, 0x16, 0x0c, 0x4b, 0xd4, 0xa0, 0x85, 0x5a, 0x32, 0x38, 0xf6 ], [ 0x5c, 0x65, 0x35, 0xb1, 0x25, 0xd1, 0x2d, 0xbc, 0xee, 0x40, 0x1f, 0x77, 0x23, 0x9d, 0x6c, 0x38 ], [ 0xd3, 0x3b, 0x97, 0xc4, 0x32, 0x80, 0xbe, 0xf9, 0xee, 0x27, 0x64, 0x4c, 0x5f, 0xc9, 0x19, 0x78 ], [ 0x6c, 0x90, 0xe5, 0x7c, 0x76, 0x7e, 0xab, 0x9f, 0x74, 0x7e, 0xb8, 0x08, 0x62, 0xea, 0x0e, 0x0e ], [ 0xee, 0x12, 0xa5, 0x59, 0x8d, 0x2c, 0x28, 0xe3, 0x21, 0xc4, 0xd4, 0xa2, 0x13, 0x03, 0x90, 0x9b ], [ 0x69, 0x07, 0x73, 0xe0, 0x98, 0xb7, 0xba, 0xeb, 0xf9, 0xa2, 0x3a, 0x49, 0xf2, 0x94, 0x43, 0x3e ], [ 0xf5, 0xdd, 0xfe, 0x7d, 0x66, 0xda, 0xb5, 0x2b, 0x9f, 0x52, 0xa5, 0x35, 0xc6, 0x5a, 0xe3, 0x24 ], [ 0x2d, 0x8b, 0xd1, 0xe6, 0x81, 0x5b, 0x89, 0xc5, 0x3e, 0xbd, 0x31, 0xc3, 0x98, 0x3d, 0x3f, 0xf4 ], [ 0xee, 0x36, 0x2d, 0x96, 0xde, 0xad, 0x91, 0x52, 0xfc, 0x26, 0x84, 0x64, 0x2e, 0xd8, 0x81, 0x56 ], [ 0x39, 0x53, 0x48, 0x57, 0x87, 0x2f, 0xb9, 0x5b, 0xcf, 0x23, 0x36, 0x07, 0x03, 0x04, 0xeb, 0xf5 ], [ 0x7e, 0xa8, 0xd0, 0x1b, 0x59, 0x4f, 0x82, 0x3a, 0x53, 0xc2, 0x13, 0x8a, 0xd1, 0x37, 0x9f, 0x75 ], [ 0xb3, 0x22, 0xe8, 0x43, 0x69, 0x67, 0xeb, 0xb3, 0x11, 0xfb, 0x59, 0x61, 0xab, 0xcc, 0x98, 0xdd ], [ 0xe4, 0xb6, 0xcc, 0x44, 0xc0, 0x51, 0xec, 0x11, 0x4b, 0xc3, 0x3e, 0xe7, 0xeb, 0x12, 0xa0, 0xcc ], [ 0x0c, 0xb8, 0x5a, 0x0d, 0x33, 0xc6, 0xb8, 0xe0, 0xc1, 0x9b, 0x8c, 0x21, 0x52, 0xaa, 0x00, 0x38 ], [ 0x78, 0x19, 0xb6, 0x00, 0xb9, 0xca, 0x2a, 0x3a, 0x72, 0x9b, 0x12, 0x5b, 0x66, 0x2c, 0x01, 0x53 ], [ 0x04, 0x35, 0xf9, 0x62, 0x9b, 0x44, 0x0c, 0xd7, 0x57, 0xc2, 0x6c, 0x2c, 0x5d, 0x6c, 0x57, 0x2a ], [ 0xcb, 0x38, 0x5e, 0x13, 0xc3, 0xae, 0xd7, 0x2d, 0xa6, 0x23, 0xed, 0x71, 0x7e, 0xa5, 0xc1, 0xd8 ], [ 0x22, 0xf3, 0xfe, 0xab, 0xf8, 0xf5, 0xab, 0x7a, 0x6b, 0xa3, 0x0b, 0x4c, 0x48, 0x45, 0x4c, 0xdb ], [ 0xb5, 0xd6, 0x25, 0xb0, 0x2f, 0x05, 0xb7, 0xc0, 0x67, 0x08, 0x59, 0xa8, 0xf7, 0x1d, 0xf5, 0xf0 ], [ 0x6f, 0xf7, 0xbc, 0xf3, 0x3b, 0x6f, 0xf7, 0x7b, 0x11, 0x66, 0x10, 0xfd, 0x39, 0xf4, 0xf6, 0xae ], [ 0xdd, 0xbf, 0xcc, 0x25, 0xe2, 0x1a, 0xd7, 0xbd, 0xf6, 0x6a, 0x1b, 0x35, 0x13, 0xa0, 0x30, 0x18 ], [ 0x5e, 0x49, 0x26, 0x3e, 0xfa, 0xc5, 0x45, 0x1e, 0xe3, 0x95, 0x08, 0x3c, 0x25, 0xde, 0x2c, 0x13 ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" cipher_texts1_128bit = [ [ 0x34, 0x54, 0xf7, 0xd3, 0x4c, 0x0c, 0xaf, 0xfa, 0x12, 0xe9, 0xd2, 0x85, 0x0b, 0x03, 0x7f, 0xff ], [ 0x10, 0x70, 0xb7, 0xc1, 0x7d, 0x34, 0x74, 0x28, 0x1a, 0xd0, 0x1f, 0xc0, 0xad, 0x89, 0xcd, 0x8b ], [ 0x2f, 0xb9, 0x7e, 0x97, 0x9f, 0xb1, 0x07, 0xbc, 0xc1, 0x3b, 0x57, 0x7f, 0x0f, 0x1e, 0xa2, 0x03 ], [ 0xcf, 0xf1, 0x5a, 0x80, 0x92, 0x20, 0xb4, 0x06, 0x7c, 0x7c, 0x02, 0x66, 0xbb, 0xcb, 0x32, 0x48 ], [ 0x83, 0x72, 0x5e, 0xec, 0xbc, 0xdf, 0xa8, 0xeb, 0xde, 0xc2, 0xf4, 0x0b, 0xa4, 0xb1, 0x57, 0xed ], [ 0xa7, 0x93, 0x1f, 0xf1, 0x18, 0xdb, 0x06, 0xcb, 0x44, 0x09, 0x7b, 0xca, 0xc1, 0xfa, 0xd1, 0xaf ], [ 0x33, 0x19, 0x60, 0xc2, 0x50, 0xeb, 0x49, 0x88, 0xc7, 0x5c, 0x0d, 0x53, 0x2e, 0x20, 0x6e, 0x5c ], [ 0x36, 0x9a, 0xd5, 0xf8, 0xfb, 0x83, 0xa0, 0xdf, 0x64, 0x9c, 0x89, 0x9b, 0x49, 0xef, 0x74, 0x59 ], [ 0x4a, 0xe7, 0xa4, 0xac, 0x80, 0x02, 0x34, 0x05, 0xac, 0x25, 0xbc, 0x49, 0x7d, 0x65, 0x41, 0xfb ], [ 0xc0, 0xf6, 0xf4, 0x4c, 0x03, 0xd1, 0xcb, 0xe6, 0x68, 0xc0, 0x34, 0x56, 0x2e, 0xa3, 0xd8, 0x04 ], [ 0xdc, 0xff, 0x3e, 0x38, 0xdf, 0xea, 0x1d, 0x3e, 0xb7, 0x81, 0x82, 0x32, 0x6d, 0x7d, 0x68, 0xab ], [ 0x26, 0x33, 0x94, 0x12, 0xd7, 0xac, 0x11, 0x3b, 0x31, 0x90, 0x88, 0x15, 0x3e, 0x13, 0xe1, 0xac ], [ 0x29, 0xc3, 0x61, 0x67, 0x14, 0xbf, 0x80, 0x76, 0xab, 0x19, 0x5e, 0x5e, 0x0d, 0x6c, 0xc0, 0xd7 ], [ 0x88, 0x50, 0xa5, 0xb5, 0x01, 0x1c, 0x0b, 0x49, 0xb4, 0x44, 0xda, 0xa5, 0xcb, 0xd0, 0x4a, 0xba ], [ 0x2f, 0xba, 0xad, 0xd1, 0xb4, 0x7f, 0x72, 0x6d, 0xce, 0x3f, 0x7d, 0x4c, 0x03, 0x58, 0xfd, 0x99 ], [ 0x6d, 0xf4, 0xbe, 0xeb, 0xbe, 0x92, 0xec, 0x8a, 0x42, 0x73, 0x36, 0xb0, 0xca, 0xec, 0x1e, 0xc6 ], [ 0x94, 0x58, 0x64, 0xf9, 0x19, 0x0e, 0xa8, 0xc1, 0x19, 0x43, 0xdf, 0x25, 0x10, 0xf9, 0x44, 0x21 ], [ 0xa8, 0x56, 0x59, 0x41, 0x79, 0x84, 0x5a, 0x87, 0x85, 0x5e, 0xa1, 0x6d, 0xd0, 0x39, 0x16, 0xbe ], [ 0xd1, 0x3a, 0xb1, 0x1d, 0x38, 0x34, 0xd7, 0x33, 0xea, 0x5d, 0xd6, 0xdb, 0xf7, 0x9a, 0xc9, 0x2b ], [ 0x51, 0xb9, 0xc9, 0x27, 0xea, 0xd5, 0xfa, 0xda, 0xd5, 0x6c, 0x3e, 0xb1, 0xa2, 0x20, 0xee, 0xc7 ], [ 0xd8, 0x3d, 0xdc, 0x00, 0x6d, 0xee, 0xee, 0x4c, 0xc2, 0xb4, 0xc4, 0x95, 0x83, 0x0d, 0xdd, 0xc3 ], [ 0x6d, 0x24, 0x6f, 0x57, 0xb5, 0xd6, 0x92, 0x20, 0x5f, 0x2b, 0x97, 0x0d, 0xcf, 0x8e, 0xd6, 0xf8 ], [ 0xa8, 0xb8, 0x32, 0x6c, 0xc5, 0x12, 0x6a, 0x92, 0x6c, 0xf4, 0x14, 0xb4, 0x71, 0xab, 0xd1, 0xb2 ], [ 0x47, 0xb7, 0x51, 0xad, 0xee, 0xcc, 0xd4, 0x47, 0x51, 0x63, 0x23, 0x96, 0x10, 0x79, 0x7d, 0x4b ], [ 0xe8, 0xc6, 0x47, 0xee, 0x74, 0x88, 0xad, 0xc4, 0x09, 0x0e, 0x08, 0xa9, 0x69, 0x65, 0xcc, 0xed ], [ 0x1c, 0x98, 0x0f, 0xd7, 0x98, 0xb9, 0x16, 0x32, 0x6c, 0x52, 0x56, 0x32, 0xe2, 0x15, 0xc4, 0xec ], [ 0x90, 0xf3, 0xc9, 0x99, 0xcb, 0x07, 0x45, 0x87, 0xf8, 0x75, 0x56, 0x1d, 0x04, 0x16, 0x0c, 0x6c ], [ 0xcf, 0xa1, 0xf3, 0xa9, 0xa1, 0x52, 0xc4, 0x87, 0x51, 0x00, 0xad, 0x48, 0x07, 0xb3, 0xb0, 0x9c ], [ 0xb0, 0x4e, 0xa8, 0xcd, 0x83, 0xae, 0xa2, 0x58, 0x93, 0xac, 0x2a, 0x62, 0x18, 0x79, 0xa4, 0xcd ], [ 0xb1, 0xac, 0x6e, 0xca, 0x72, 0x17, 0x09, 0xa5, 0x27, 0x59, 0x8d, 0x1d, 0xc7, 0xfa, 0x36, 0x5e ], [ 0x98, 0xf2, 0x14, 0x26, 0xb7, 0x14, 0x80, 0x82, 0xb4, 0xee, 0x4a, 0x80, 0x74, 0x67, 0x2a, 0x10 ], [ 0x22, 0xf8, 0xc0, 0x63, 0x73, 0x27, 0xb1, 0x12, 0x30, 0x67, 0xe7, 0x30, 0xc3, 0xbe, 0x4a, 0x01 ], [ 0x87, 0x04, 0x55, 0x2b, 0x90, 0x00, 0x9e, 0xc3, 0x32, 0x4a, 0xdb, 0xf2, 0x84, 0xdb, 0xd5, 0x1e ], [ 0xc5, 0xf6, 0x67, 0x3c, 0xbc, 0xea, 0xe8, 0x23, 0x6f, 0xa2, 0x36, 0x79, 0x82, 0x61, 0xee, 0xc1 ], [ 0x91, 0xee, 0xcd, 0x8b, 0xbd, 0x0f, 0xf7, 0xcf, 0xe4, 0xb3, 0x3d, 0x8e, 0x99, 0x92, 0x43, 0x68 ], [ 0x86, 0xd6, 0xbf, 0x32, 0x4b, 0xcc, 0x29, 0x10, 0x81, 0x6a, 0xbb, 0xf5, 0x5f, 0x3b, 0xa4, 0x5d ], [ 0x5b, 0x0a, 0x85, 0xe3, 0x76, 0xa6, 0x36, 0xd1, 0x13, 0x36, 0x6e, 0xc8, 0x2a, 0x2c, 0x03, 0xf8 ], [ 0x9b, 0x3a, 0x03, 0x64, 0x36, 0xa2, 0x46, 0x36, 0x29, 0x0c, 0x96, 0x9e, 0x9d, 0x97, 0xcf, 0x8b ], [ 0xf5, 0x15, 0xb3, 0xd5, 0x0e, 0x99, 0x1d, 0x55, 0xa3, 0xe0, 0xfc, 0xb0, 0x93, 0x08, 0x5a, 0x10 ], [ 0x4b, 0x20, 0xfc, 0xe1, 0xff, 0xac, 0xc7, 0x55, 0x3a, 0xfa, 0x3a, 0x6a, 0xc9, 0x4e, 0x59, 0x66 ], [ 0xca, 0xed, 0x5c, 0x73, 0x8a, 0x8d, 0xc3, 0x01, 0x55, 0x52, 0x28, 0x64, 0xf9, 0x28, 0x9e, 0x61 ], [ 0x63, 0xa8, 0x81, 0x84, 0x18, 0x6f, 0xa7, 0x97, 0xd2, 0x64, 0xa0, 0x52, 0x8f, 0x39, 0x70, 0x9f ], [ 0xba, 0xa4, 0x95, 0xce, 0x83, 0x09, 0xa6, 0xc8, 0x8a, 0xd8, 0x55, 0xf9, 0x7a, 0x77, 0x41, 0x13 ], [ 0x68, 0xc5, 0x29, 0x58, 0x64, 0x35, 0x37, 0x4c, 0xfb, 0xad, 0xb1, 0x7b, 0x9b, 0x89, 0x5a, 0x4d ], [ 0x71, 0xf0, 0x51, 0x9b, 0x7a, 0x6a, 0xee, 0x11, 0x6d, 0x48, 0x1f, 0x31, 0xb9, 0x65, 0xfc, 0x2d ], [ 0xe9, 0xc6, 0x80, 0x83, 0x84, 0x84, 0x71, 0x4f, 0x38, 0xc5, 0x9f, 0xdb, 0xfa, 0xf4, 0x9a, 0x5e ], [ 0xac, 0xa4, 0x3e, 0x27, 0xd8, 0xcf, 0xfc, 0x6d, 0x27, 0x3a, 0x90, 0xf3, 0x43, 0xc9, 0xac, 0xce ], [ 0x8f, 0xd8, 0x6c, 0x04, 0x89, 0x94, 0x4d, 0x43, 0x50, 0xb2, 0x23, 0x29, 0x58, 0x01, 0x66, 0x68 ], [ 0x3f, 0x06, 0x9d, 0x49, 0x97, 0xa1, 0xdd, 0x7e, 0xa4, 0x21, 0x5c, 0xf1, 0xd9, 0x56, 0x83, 0x95 ], [ 0xb7, 0x97, 0x2c, 0x5f, 0x6a, 0x48, 0x8d, 0xce, 0x95, 0xeb, 0x46, 0xa8, 0x55, 0xa1, 0x05, 0xa5 ], [ 0x80, 0x47, 0x95, 0xbc, 0x58, 0x8a, 0xa0, 0x48, 0x89, 0x4a, 0x18, 0x4c, 0x60, 0x0a, 0xc7, 0x5f ], [ 0x4d, 0xcd, 0xab, 0xef, 0xbf, 0x99, 0xb4, 0xf4, 0x94, 0xfa, 0x83, 0xb9, 0x1f, 0x0e, 0x97, 0xa7 ], [ 0xa4, 0x32, 0x14, 0x72, 0xfc, 0xa0, 0x2d, 0x86, 0x94, 0x32, 0x58, 0x5a, 0x43, 0x80, 0xbe, 0x30 ], [ 0x62, 0x54, 0x38, 0x70, 0x0a, 0x4d, 0x15, 0x38, 0x11, 0xdc, 0x26, 0xf6, 0x88, 0xb1, 0xf8, 0x2e ], [ 0x56, 0x5f, 0xa6, 0x39, 0x0a, 0x7a, 0x37, 0x7b, 0x90, 0x33, 0x0b, 0xa0, 0x93, 0x91, 0xa7, 0xd6 ], [ 0x7d, 0x18, 0x0b, 0x8a, 0xe1, 0x43, 0x61, 0x73, 0x69, 0x23, 0x9a, 0x60, 0x6c, 0x69, 0x3d, 0x1f ], [ 0xe5, 0x67, 0xf6, 0xd2, 0x72, 0x76, 0x22, 0x27, 0x8b, 0x93, 0x10, 0xe9, 0x1e, 0xce, 0x01, 0x65 ], [ 0x5c, 0xe1, 0x56, 0x2f, 0x45, 0xda, 0x9d, 0xad, 0x24, 0x8b, 0xb7, 0xac, 0x2a, 0xab, 0xe2, 0xb4 ], [ 0x97, 0x74, 0xeb, 0xd7, 0xb0, 0x8c, 0xc8, 0x7f, 0xdf, 0x70, 0xc9, 0xd4, 0xf7, 0x46, 0xf2, 0xf4 ], [ 0xe7, 0x27, 0x46, 0xc7, 0x43, 0xf8, 0x4e, 0x32, 0xee, 0xd8, 0x1b, 0x8d, 0xd5, 0x1b, 0x6f, 0xea ], [ 0x48, 0x21, 0x0d, 0xf8, 0x64, 0x1e, 0x31, 0x03, 0x9d, 0x06, 0xf0, 0xe7, 0xdc, 0x1a, 0xd9, 0x7f ], [ 0x94, 0x4f, 0x66, 0xbb, 0x9c, 0xb9, 0xc0, 0xda, 0x59, 0x11, 0x18, 0x75, 0xbd, 0x8a, 0x83, 0xed ], [ 0x6b, 0x62, 0x95, 0xca, 0x7b, 0x81, 0xd5, 0x21, 0x6c, 0xc2, 0x51, 0xea, 0xd4, 0x6c, 0x70, 0xbb ], [ 0x09, 0xbe, 0xa3, 0xcc, 0xa2, 0x0b, 0x8f, 0x95, 0x44, 0xe6, 0x24, 0x30, 0x81, 0x9d, 0x90, 0xcc ], [ 0xae, 0x58, 0xfb, 0xd4, 0x10, 0x58, 0xbd, 0x60, 0xb5, 0x46, 0x37, 0x9c, 0x83, 0x6a, 0xda, 0x28 ], [ 0x2c, 0x11, 0xe9, 0x97, 0x30, 0x68, 0xab, 0xcf, 0xf0, 0xb7, 0x5c, 0xb1, 0xb0, 0x02, 0x25, 0x21 ], [ 0x6f, 0xfd, 0xbb, 0x7b, 0x11, 0xbc, 0x41, 0xa6, 0x8b, 0xb4, 0x39, 0x80, 0xb4, 0xd5, 0x04, 0x5a ], [ 0x55, 0xbc, 0x20, 0x96, 0x21, 0x9a, 0x93, 0x0b, 0x9a, 0x12, 0xe2, 0x21, 0x4c, 0x51, 0x47, 0xef ], [ 0xeb, 0x68, 0xe4, 0x75, 0xbf, 0xf2, 0xbd, 0xf3, 0xa1, 0x51, 0xb0, 0x7e, 0x38, 0x86, 0x0d, 0x03 ], [ 0xd4, 0x47, 0x5d, 0xa4, 0x8f, 0x24, 0xba, 0x75, 0x95, 0x31, 0xbf, 0x30, 0xa5, 0xbc, 0xd4, 0x30 ], [ 0xd1, 0x4d, 0x7b, 0x02, 0x62, 0x73, 0xdf, 0xf3, 0x3b, 0x09, 0xe7, 0x0d, 0xb4, 0x5d, 0x31, 0x40 ], [ 0x93, 0xf3, 0x95, 0x26, 0x56, 0xb4, 0x3f, 0x66, 0x3e, 0x02, 0x28, 0xed, 0x74, 0xcb, 0xab, 0x0f ], [ 0x98, 0x7d, 0x38, 0xaf, 0xcf, 0xbc, 0x37, 0xb2, 0x54, 0xef, 0x41, 0xb6, 0x28, 0x38, 0x13, 0xe5 ], [ 0xbc, 0x0b, 0xbd, 0x16, 0xa2, 0x1b, 0xaf, 0xca, 0x60, 0x58, 0x8e, 0x3f, 0x67, 0x0f, 0xff, 0xb9 ], [ 0x60, 0x69, 0x8b, 0x82, 0x3b, 0xeb, 0x2d, 0x9d, 0x08, 0x3d, 0xbe, 0x2e, 0x7d, 0x1a, 0xd2, 0x43 ], [ 0xa3, 0xed, 0x3b, 0x90, 0x52, 0xe7, 0x63, 0xb7, 0x49, 0x13, 0xcb, 0xdf, 0x1f, 0x71, 0xfa, 0xfd ], [ 0x5d, 0x8b, 0x27, 0xda, 0x95, 0xb0, 0x73, 0xb9, 0x3f, 0xb1, 0x55, 0xed, 0xd2, 0xc8, 0x8f, 0xea ], [ 0xb5, 0x45, 0x8a, 0xfa, 0x62, 0x68, 0xd1, 0x47, 0x4a, 0x93, 0x6d, 0xdf, 0x84, 0xb6, 0x3b, 0x05 ], [ 0xb0, 0x40, 0x45, 0x86, 0xc6, 0x31, 0x3e, 0xf7, 0x7e, 0x24, 0x65, 0x0f, 0xa4, 0x8d, 0xa1, 0x31 ], [ 0x61, 0xeb, 0xad, 0x87, 0xdf, 0x8c, 0x35, 0xe4, 0x59, 0xeb, 0x31, 0x5e, 0x27, 0xbc, 0x47, 0xf3 ], [ 0xf1, 0x13, 0x01, 0x6f, 0x74, 0x69, 0x8d, 0x5f, 0x1e, 0x68, 0x07, 0x88, 0xdd, 0xcb, 0x56, 0xd0 ], [ 0xfd, 0x8f, 0x5f, 0xa1, 0x62, 0x82, 0x05, 0x85, 0xf7, 0x7b, 0x25, 0x0e, 0xfb, 0xb5, 0x0f, 0x1c ], [ 0x65, 0x51, 0xd6, 0x91, 0x0a, 0xe9, 0xe2, 0x97, 0x7f, 0x09, 0xbd, 0x29, 0x64, 0xd0, 0xfa, 0x2b ], [ 0xca, 0xf9, 0x6f, 0x61, 0xfa, 0x32, 0xef, 0x7c, 0x5d, 0xf6, 0x61, 0x03, 0xaf, 0xac, 0x84, 0x95 ], [ 0x35, 0x18, 0x77, 0x87, 0x06, 0xa0, 0xa0, 0xb1, 0xba, 0xac, 0x40, 0xdf, 0xd8, 0x18, 0x16, 0x1d ], [ 0x69, 0x20, 0xc0, 0xc3, 0xa8, 0xe2, 0x3b, 0xbe, 0xb8, 0x5b, 0x52, 0x58, 0x8a, 0xbd, 0x97, 0xb6 ], [ 0x69, 0xcc, 0x1f, 0x1d, 0x1c, 0xcb, 0x57, 0xdf, 0x6a, 0xde, 0x53, 0x02, 0x95, 0x9b, 0x17, 0x46 ], [ 0x70, 0x30, 0xb6, 0x12, 0x2c, 0x32, 0x29, 0xaf, 0xc6, 0xd1, 0x2d, 0x8e, 0xb2, 0xc2, 0x9b, 0x99 ], [ 0xc9, 0xac, 0x91, 0x09, 0x5d, 0xbc, 0xea, 0x52, 0xd5, 0xfc, 0xb5, 0x8b, 0x57, 0x87, 0x14, 0x41 ], [ 0xee, 0x28, 0x6b, 0x71, 0x48, 0x4a, 0x9d, 0x05, 0x56, 0xe1, 0xc0, 0x42, 0xd8, 0x86, 0x6d, 0x8f ], [ 0xfe, 0x89, 0xcc, 0xbb, 0x39, 0x97, 0xf4, 0x75, 0xe4, 0x7d, 0x55, 0x24, 0x82, 0x88, 0xa3, 0x24 ], [ 0xc3, 0xc7, 0xd4, 0x9f, 0x3c, 0x42, 0xa8, 0x4e, 0x28, 0x3e, 0xcb, 0xd8, 0xb2, 0xbe, 0x81, 0xd2 ], [ 0x7a, 0x70, 0xfd, 0x4d, 0xed, 0x65, 0xcd, 0x2c, 0xfc, 0xf1, 0x5e, 0xc3, 0x8b, 0x2e, 0x87, 0x9b ], [ 0x97, 0x5e, 0xa3, 0x66, 0xab, 0x8e, 0xc3, 0xcd, 0x35, 0xfd, 0xda, 0x91, 0xdf, 0xb1, 0xaf, 0xd6 ], [ 0x46, 0x0c, 0x04, 0x6e, 0x6e, 0x3b, 0x97, 0xe2, 0x35, 0x65, 0xbc, 0xe7, 0xb9, 0x22, 0x4e, 0x97 ], [ 0xef, 0xcc, 0xaa, 0xae, 0x45, 0x81, 0x7c, 0xbc, 0x61, 0x25, 0xc6, 0x20, 0x84, 0xc7, 0x05, 0xec ], [ 0xb0, 0x23, 0x8d, 0x6d, 0x1f, 0x37, 0x95, 0x3e, 0x70, 0xd3, 0xdc, 0xf3, 0xcd, 0xd3, 0x28, 0xa1 ], [ 0x7e, 0xd0, 0xd2, 0x5f, 0x0d, 0x1d, 0x1b, 0x7e, 0x62, 0xfa, 0xcf, 0xe3, 0x6e, 0x46, 0x8c, 0x5d ], [ 0x00, 0xe8, 0x40, 0x63, 0x07, 0xb7, 0x98, 0xd4, 0x3f, 0xdf, 0xf7, 0x77, 0x25, 0x65, 0xd5, 0xf9 ], [ 0xec, 0xc0, 0x38, 0x12, 0x5f, 0xdb, 0x26, 0x76, 0x62, 0xa5, 0x7d, 0xc9, 0xac, 0xc0, 0x64, 0x39 ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" cipher_texts2_128bit = [ [ 0x78, 0x96, 0xce, 0x48, 0x49, 0xa6, 0x03, 0xdc, 0xf0, 0x1e, 0x62, 0x2d, 0x68, 0x20, 0xf4, 0x25, 0xe7, 0xde, 0x24, 0x85, 0xd2, 0x47, 0x21, 0x05, 0xbb, 0xf5, 0xf1, 0x1c, 0x5d, 0xc5, 0x8e, 0xe1 ], [ 0x7c, 0xf2, 0x51, 0x99, 0xfc, 0xec, 0xb9, 0x7e, 0xf2, 0xa6, 0xb8, 0x41, 0x66, 0x77, 0xc1, 0xad, 0x15, 0xf4, 0xa6, 0xcf, 0x78, 0xf0, 0x2b, 0x42, 0x0b, 0xb8, 0xce, 0x95, 0xbd, 0x5c, 0xdb, 0xb5 ], [ 0x4c, 0xc9, 0x66, 0xf4, 0x22, 0x77, 0xf1, 0xcc, 0xcc, 0x68, 0xa8, 0x86, 0xfb, 0x14, 0x9b, 0xb4, 0x57, 0xdc, 0xa7, 0x13, 0xe6, 0x5b, 0x51, 0xc3, 0x15, 0x6a, 0x12, 0xd4, 0x70, 0x9b, 0x0f, 0x76 ], [ 0x26, 0xfa, 0xdd, 0x2d, 0x11, 0xfb, 0x2a, 0x1f, 0x98, 0x3d, 0x41, 0x99, 0x59, 0xf8, 0xa0, 0x35, 0x27, 0x35, 0x16, 0x03, 0x28, 0xe0, 0xfd, 0xb3, 0x7b, 0x80, 0x0f, 0xa2, 0x2e, 0x3f, 0x51, 0xf5 ], [ 0xe3, 0x3e, 0x93, 0x6b, 0x3f, 0xfe, 0x75, 0xd5, 0x6e, 0x00, 0xa4, 0xc7, 0x57, 0x77, 0x51, 0x75, 0x09, 0xe6, 0xd2, 0xfb, 0xb0, 0x46, 0xbf, 0x4b, 0x7f, 0xb6, 0xb8, 0x7b, 0x40, 0x32, 0x11, 0x2d ], [ 0x1a, 0x1a, 0x46, 0xee, 0x17, 0x73, 0xc9, 0xce, 0xf9, 0x27, 0x49, 0xc4, 0xef, 0x3b, 0x55, 0x2f, 0xe2, 0xe0, 0x46, 0x58, 0x29, 0x3a, 0x5a, 0x60, 0xc6, 0x0c, 0x2e, 0x35, 0x0b, 0x37, 0x23, 0xc3 ], [ 0xb2, 0x93, 0x7e, 0x87, 0x99, 0x98, 0x78, 0x4c, 0x74, 0xcc, 0x6a, 0x48, 0x79, 0x02, 0xd1, 0x96, 0xd6, 0xa3, 0x28, 0xf0, 0x7a, 0xfe, 0x23, 0x81, 0x32, 0x4c, 0xf2, 0x73, 0x01, 0x31, 0xf0, 0xb5 ], [ 0xd0, 0x9e, 0xbe, 0x78, 0x35, 0x1e, 0x03, 0x20, 0x1a, 0xed, 0x53, 0xba, 0x22, 0x15, 0x7a, 0xf7, 0x75, 0x2c, 0x45, 0xf9, 0x4e, 0xe2, 0x83, 0x38, 0x20, 0x22, 0x91, 0x20, 0xa6, 0x0e, 0x05, 0x94 ], [ 0xe4, 0x0f, 0x5f, 0x03, 0x2a, 0xe2, 0x0a, 0x1d, 0x06, 0xb8, 0x17, 0xd5, 0x01, 0x6e, 0x2a, 0x35, 0xfb, 0x25, 0x9c, 0x87, 0x99, 0x77, 0xb8, 0x99, 0xc9, 0x95, 0x0d, 0xd2, 0x12, 0xd7, 0xb5, 0x33 ], [ 0x09, 0x25, 0x17, 0xad, 0xac, 0x8b, 0xef, 0x1a, 0x33, 0xcc, 0x31, 0x08, 0x42, 0x07, 0x51, 0x98, 0x38, 0xf3, 0x14, 0x82, 0xa6, 0x0e, 0x8c, 0xbe, 0xaf, 0x86, 0xd0, 0xba, 0xe6, 0x17, 0xa8, 0x72 ], [ 0x69, 0x46, 0xdf, 0xdf, 0x79, 0x15, 0x1e, 0x6e, 0x2c, 0xfc, 0xc5, 0x4e, 0x0b, 0x52, 0xaf, 0x6d, 0xe1, 0x78, 0x40, 0xf8, 0x34, 0x66, 0x25, 0x70, 0x22, 0x0a, 0xd8, 0x49, 0x87, 0x5c, 0xe7, 0xa5 ], [ 0x7a, 0x51, 0xb3, 0x39, 0x66, 0x25, 0x5e, 0x2c, 0xa3, 0x25, 0xbe, 0xa9, 0xde, 0x4a, 0xaa, 0xcb, 0x22, 0xe9, 0x35, 0x9b, 0x82, 0xff, 0x0c, 0xa3, 0x4b, 0x5b, 0x39, 0xf8, 0x08, 0x05, 0xa6, 0xb7 ], [ 0x30, 0x6b, 0xf2, 0xc4, 0xcc, 0x85, 0xa7, 0xec, 0x8f, 0xe6, 0xc6, 0x69, 0xbc, 0x10, 0x0c, 0x4f, 0xa9, 0x2a, 0xf9, 0x93, 0x42, 0x8f, 0x80, 0xe2, 0x24, 0x25, 0xa9, 0xe6, 0x30, 0xc2, 0x29, 0x50 ], [ 0x80, 0x98, 0xed, 0x2f, 0x12, 0x90, 0xf3, 0xd6, 0xbb, 0x21, 0x68, 0xa9, 0xda, 0x96, 0xf0, 0x81, 0xd1, 0x84, 0xc7, 0x22, 0xec, 0xe4, 0xbb, 0xed, 0x52, 0x8a, 0x8f, 0x00, 0x39, 0x2a, 0x3c, 0x03 ], [ 0xa3, 0xb6, 0xba, 0x39, 0x51, 0xba, 0x20, 0x3a, 0x59, 0x82, 0x7c, 0xb5, 0x97, 0x62, 0xd4, 0x0a, 0x3c, 0x5a, 0x91, 0xd5, 0xd5, 0xbf, 0x86, 0x2a, 0x38, 0xb7, 0x5f, 0xc3, 0x5d, 0x4f, 0xb2, 0xde ], [ 0x22, 0x96, 0x65, 0xa0, 0xc4, 0x40, 0xe4, 0x6d, 0x7d, 0x79, 0x09, 0x1f, 0xf9, 0xf0, 0x0d, 0xcf, 0x60, 0x48, 0x2b, 0xdd, 0x1c, 0x98, 0x82, 0x19, 0x72, 0x1f, 0x73, 0x89, 0xf1, 0x29, 0xc0, 0xa4 ], [ 0xca, 0xfe, 0x8b, 0x63, 0x42, 0x69, 0x9f, 0x00, 0x1e, 0x81, 0x68, 0x8d, 0xd8, 0xfa, 0x5c, 0x52, 0x03, 0x8d, 0xee, 0xa6, 0xd3, 0xf5, 0xa2, 0xde, 0xb3, 0xb4, 0xe5, 0x2c, 0xdf, 0x1c, 0x2f, 0xcb ], [ 0x3e, 0x6c, 0xe9, 0x34, 0x3e, 0xd6, 0xcc, 0x3f, 0x50, 0x09, 0xb9, 0x79, 0x4a, 0x48, 0xd7, 0x9b, 0x05, 0xb9, 0x34, 0x26, 0xbc, 0xf6, 0x24, 0xd0, 0x62, 0x98, 0x74, 0x1a, 0xb7, 0xaf, 0x4b, 0xa1 ], [ 0x63, 0x94, 0x75, 0xe5, 0x68, 0x6c, 0x8c, 0x30, 0x0e, 0x6d, 0x21, 0xe3, 0x6c, 0x82, 0xd2, 0x4f, 0xab, 0xc2, 0x1c, 0x8a, 0x74, 0xe3, 0xea, 0xd0, 0x2a, 0x91, 0xae, 0xc4, 0x64, 0x11, 0x96, 0x8d ], [ 0x02, 0x2f, 0x0f, 0xe4, 0x81, 0xa8, 0xe7, 0x02, 0xc3, 0x31, 0xbd, 0x11, 0x95, 0x9d, 0xd2, 0x5e, 0x14, 0x9f, 0xde, 0x8e, 0x3b, 0xc4, 0xb3, 0x39, 0x20, 0x52, 0xa7, 0xfa, 0x04, 0x38, 0x7a, 0x26 ], [ 0x11, 0x9a, 0xd8, 0x70, 0xe6, 0x39, 0x97, 0xb0, 0xa7, 0x58, 0x52, 0x4a, 0xa8, 0x96, 0xa6, 0x5f, 0x40, 0x29, 0x9b, 0x01, 0xb8, 0x41, 0x81, 0xf5, 0x27, 0x30, 0x13, 0x4a, 0xac, 0x0d, 0x22, 0xd6 ], [ 0x19, 0x35, 0x41, 0x24, 0x54, 0x91, 0x35, 0xa5, 0x13, 0xfb, 0x92, 0xbc, 0x94, 0xc5, 0x52, 0xd0, 0x4a, 0x83, 0x60, 0xdf, 0x74, 0xe3, 0x4c, 0x7e, 0x9c, 0x61, 0x6f, 0xe5, 0x9c, 0x5e, 0xa6, 0x83 ], [ 0xf5, 0x89, 0xaa, 0xe6, 0xaf, 0x88, 0x5a, 0xd0, 0x1b, 0xe8, 0x32, 0xaf, 0xab, 0xf6, 0x5d, 0xde, 0xe4, 0xb6, 0xed, 0xa3, 0x36, 0xa1, 0x9c, 0xa3, 0x0e, 0x26, 0x46, 0xac, 0x3a, 0x85, 0x64, 0x19 ], [ 0x37, 0x1d, 0xfd, 0xac, 0x45, 0x3c, 0x96, 0x0f, 0xc7, 0xd5, 0x30, 0x75, 0xad, 0x57, 0xe2, 0xda, 0x81, 0x1c, 0x0d, 0x7a, 0xc0, 0xb6, 0x0c, 0xe0, 0x4e, 0x6a, 0xf6, 0x8b, 0x9a, 0xaf, 0x72, 0x41 ], [ 0xd9, 0xf8, 0x1d, 0xa9, 0x96, 0xb9, 0x58, 0xa2, 0xce, 0xf8, 0x77, 0x6d, 0x0d, 0xd4, 0x76, 0x30, 0xa1, 0x35, 0x5e, 0x95, 0xee, 0x26, 0x7c, 0xb8, 0xb8, 0x41, 0x33, 0x1c, 0xbb, 0x3c, 0x0f, 0x3e ], [ 0xd6, 0xbe, 0x04, 0x6d, 0x41, 0xf2, 0x3b, 0x5e, 0xd7, 0x0b, 0x6b, 0x3d, 0x5c, 0x8e, 0x66, 0x23, 0x2b, 0xe6, 0xb8, 0x07, 0xd4, 0xdc, 0xc6, 0x0e, 0xff, 0x8d, 0xbc, 0x1d, 0x9f, 0x7f, 0xc8, 0x22 ], [ 0x1e, 0x98, 0x04, 0x73, 0xc2, 0x3d, 0x1e, 0x6d, 0xb5, 0xb8, 0x3a, 0x34, 0x88, 0x73, 0x0e, 0xe6, 0x44, 0x4f, 0x6a, 0x7d, 0x3d, 0xb0, 0x75, 0x15, 0x83, 0xfb, 0x4b, 0x07, 0x38, 0x47, 0x32, 0x22 ], [ 0xcb, 0x89, 0x00, 0x9d, 0x41, 0x49, 0xe2, 0xd5, 0xbc, 0x90, 0x55, 0x39, 0x55, 0x90, 0xb9, 0xa4, 0x17, 0xc9, 0x95, 0xfb, 0xa3, 0x01, 0xdc, 0x5c, 0x61, 0x82, 0x82, 0x63, 0x71, 0x67, 0xd9, 0x05 ], [ 0x86, 0x91, 0xb8, 0x3a, 0xfc, 0xe5, 0x8b, 0x52, 0xa6, 0x57, 0x56, 0x18, 0xb7, 0xf8, 0xb6, 0x8a, 0x40, 0x8a, 0xcc, 0x86, 0x63, 0x76, 0xad, 0xad, 0x22, 0xc7, 0xb7, 0x49, 0x45, 0x28, 0x3d, 0x1e ], [ 0xce, 0xd6, 0x42, 0x91, 0x6a, 0xf8, 0xc5, 0x8d, 0xb8, 0x57, 0xf8, 0x8f, 0x1b, 0x8c, 0x8a, 0x47, 0x87, 0x60, 0xdf, 0x75, 0x83, 0x4f, 0x8b, 0x77, 0xce, 0x2f, 0x1d, 0x31, 0x20, 0x54, 0xf7, 0x6a ], [ 0x0c, 0xaf, 0x12, 0xff, 0x57, 0x84, 0xff, 0x49, 0xdc, 0x88, 0xea, 0xf0, 0xee, 0x96, 0x09, 0x7f, 0x6b, 0xd1, 0xa0, 0x05, 0xad, 0xe1, 0x8b, 0x9e, 0xa7, 0x3b, 0x6e, 0xad, 0xd0, 0x5b, 0xc5, 0x49 ], [ 0xff, 0x49, 0xaa, 0x42, 0x37, 0x87, 0x1f, 0x91, 0xd5, 0x4a, 0xe1, 0x87, 0x7a, 0x27, 0xd8, 0xda, 0x87, 0x7e, 0x98, 0x67, 0xcb, 0x2f, 0x69, 0x33, 0x0d, 0x22, 0xe9, 0xc2, 0x73, 0xa4, 0x49, 0xd9 ], [ 0xc1, 0xcb, 0x16, 0x89, 0x1d, 0x30, 0xff, 0x0e, 0x05, 0xe2, 0x4b, 0x95, 0x7d, 0x57, 0xc3, 0xe4, 0x0d, 0xad, 0xfa, 0x2c, 0x7c, 0x27, 0x37, 0x8c, 0xbe, 0x8a, 0x16, 0x76, 0xf1, 0x12, 0x86, 0x15 ], [ 0x15, 0xc9, 0xd8, 0xdd, 0x95, 0x6d, 0x73, 0x9a, 0xac, 0x35, 0x41, 0xa4, 0xe2, 0x91, 0x2e, 0xd4, 0x7d, 0xf5, 0xd1, 0x93, 0xc0, 0xbf, 0xc7, 0xeb, 0x24, 0x36, 0xef, 0x75, 0x6e, 0x3b, 0x82, 0xe8 ], [ 0xa5, 0x51, 0xce, 0xe3, 0x57, 0x2d, 0xc8, 0x53, 0xd9, 0x0b, 0x21, 0x57, 0x60, 0xda, 0x63, 0x22, 0x06, 0xe3, 0x69, 0xa3, 0x56, 0x42, 0x33, 0x46, 0xc7, 0xc4, 0x92, 0x4d, 0x57, 0xd0, 0xa9, 0x42 ], [ 0x9d, 0x27, 0x17, 0xab, 0x39, 0xb9, 0xcb, 0xd4, 0xb6, 0x2a, 0xcd, 0xf7, 0xf5, 0x6a, 0x8a, 0xe2, 0x34, 0xf8, 0xd2, 0x32, 0x32, 0xbb, 0x71, 0x34, 0x8c, 0xa0, 0x39, 0xa8, 0x83, 0x98, 0xbf, 0xab ], [ 0x93, 0x32, 0xc3, 0xfa, 0xcd, 0x20, 0xf6, 0xad, 0x6e, 0xbc, 0x02, 0xb9, 0x44, 0xe8, 0x18, 0x9e, 0x10, 0xb1, 0x2b, 0xe7, 0x4a, 0x74, 0x29, 0x81, 0x00, 0x01, 0x5c, 0x88, 0xd1, 0x5b, 0x2b, 0xc4 ], [ 0xd0, 0x8a, 0x0d, 0x05, 0x2f, 0x00, 0xc4, 0x46, 0x04, 0xed, 0x31, 0x34, 0x8c, 0xdf, 0xa8, 0x6e, 0x4d, 0xbc, 0xe7, 0x1b, 0xad, 0x4d, 0xb8, 0x8d, 0xb9, 0xcc, 0x27, 0xce, 0xa5, 0x0d, 0x7f, 0xde ], [ 0xf0, 0x81, 0x3a, 0x6d, 0x4c, 0xeb, 0x96, 0xaf, 0x1a, 0x92, 0x0f, 0x8a, 0x06, 0x6c, 0x96, 0xd8, 0x79, 0x9a, 0x34, 0x33, 0x8a, 0xc8, 0xd4, 0x6d, 0xeb, 0x6a, 0x65, 0x1a, 0xd9, 0x27, 0xd5, 0x3f ], [ 0x69, 0x81, 0x55, 0x0e, 0x1c, 0x53, 0x5e, 0x10, 0x21, 0x8e, 0x61, 0x20, 0xce, 0xe3, 0xb1, 0x59, 0xf5, 0x6b, 0x1b, 0xb4, 0x92, 0xc6, 0xbf, 0x18, 0x1b, 0x69, 0x4c, 0x24, 0x96, 0xf7, 0x1f, 0xb8 ], [ 0xf6, 0xa2, 0x66, 0xdd, 0xd6, 0x84, 0xf0, 0x24, 0xeb, 0x08, 0x0c, 0x9b, 0x58, 0xf8, 0x17, 0xae, 0x2d, 0x24, 0xf3, 0x14, 0x33, 0x50, 0xb4, 0xd3, 0xe2, 0x7a, 0x13, 0x09, 0xcd, 0xf1, 0xa3, 0xe0 ], [ 0xa6, 0x23, 0x56, 0x93, 0xbb, 0x98, 0xa4, 0x7a, 0xbf, 0x6d, 0xd7, 0xef, 0xc2, 0x0e, 0xd8, 0x71, 0x8e, 0xb9, 0x6d, 0x46, 0xe8, 0xed, 0x53, 0xbb, 0xc6, 0xae, 0xf2, 0x62, 0x03, 0x91, 0xaa, 0x78 ], [ 0xc2, 0x9e, 0x8e, 0xe3, 0x47, 0x52, 0x8d, 0x3d, 0x16, 0x0d, 0x28, 0xae, 0xd9, 0xb5, 0xcb, 0x13, 0x09, 0xd7, 0xb0, 0xb7, 0x06, 0xa0, 0x1a, 0x2e, 0x2a, 0xef, 0xdd, 0x94, 0x53, 0xd3, 0xd1, 0x3f ], [ 0x6d, 0x59, 0x8f, 0x53, 0xdf, 0x02, 0x28, 0x53, 0xe0, 0x5f, 0xe7, 0x04, 0xef, 0x8f, 0x1f, 0x6c, 0xf5, 0xdd, 0x6e, 0x88, 0xda, 0x57, 0xd3, 0xf2, 0x9c, 0xe7, 0xee, 0x39, 0x2f, 0x01, 0xde, 0x2a ], [ 0x8d, 0x31, 0x6d, 0x02, 0x01, 0x76, 0xd5, 0x1b, 0x42, 0xf6, 0xc2, 0xa5, 0xcc, 0x58, 0x11, 0x58, 0xeb, 0x67, 0x4d, 0x99, 0x10, 0xf4, 0x6e, 0x20, 0xb7, 0x56, 0x79, 0x0d, 0x64, 0x91, 0xf7, 0xab ], [ 0xcc, 0x58, 0xb6, 0x71, 0x80, 0xa3, 0xbb, 0xea, 0x94, 0x4c, 0xba, 0xaa, 0x66, 0xe8, 0xe3, 0x7e, 0xe2, 0x58, 0xf8, 0xf2, 0x74, 0xcd, 0xd6, 0x20, 0x28, 0x15, 0x36, 0x8e, 0x3b, 0xf1, 0xcf, 0xcb ], [ 0xa0, 0x31, 0x58, 0x6a, 0xba, 0x1f, 0x82, 0x33, 0xfc, 0x30, 0x3c, 0x1c, 0x5e, 0xef, 0x63, 0x98, 0xb5, 0x97, 0x9f, 0x54, 0x09, 0xa4, 0x55, 0x3a, 0x32, 0x82, 0xa2, 0xe8, 0x13, 0xa6, 0x09, 0x44 ], [ 0x41, 0x49, 0x96, 0xef, 0x10, 0x18, 0x5f, 0xc3, 0x5a, 0xa9, 0x50, 0x3c, 0xe7, 0xbf, 0x56, 0xf6, 0xad, 0xcb, 0x82, 0x10, 0xe9, 0xde, 0xd0, 0x26, 0xb9, 0x3a, 0x24, 0xee, 0x48, 0x4d, 0x7c, 0xd8 ], [ 0xd0, 0x25, 0x33, 0x76, 0x5e, 0x11, 0xe7, 0x1d, 0xda, 0xf2, 0xeb, 0x26, 0x33, 0x33, 0x91, 0xbe, 0x17, 0x1f, 0x49, 0x2c, 0xf8, 0x8e, 0x3a, 0x48, 0x02, 0xa9, 0x66, 0xe9, 0x2b, 0x03, 0x23, 0x1b ], [ 0xfd, 0xfa, 0x02, 0x07, 0x42, 0x91, 0x86, 0x6f, 0xf7, 0xf6, 0xd3, 0xfc, 0x9b, 0x16, 0xa2, 0x2a, 0x74, 0x38, 0xe8, 0xd6, 0x9a, 0x24, 0x68, 0x95, 0x18, 0xac, 0x96, 0x80, 0x76, 0x8e, 0x95, 0xa6 ], [ 0xf8, 0xd4, 0x23, 0x66, 0x2e, 0x31, 0x5b, 0xe3, 0xee, 0x5c, 0xfc, 0x7f, 0x0b, 0x50, 0x9d, 0xf2, 0xe6, 0x4f, 0x57, 0xb1, 0xf2, 0xc1, 0xf4, 0xa8, 0xcd, 0xab, 0x5e, 0xcf, 0x95, 0xa7, 0x63, 0xfd ], [ 0x2a, 0x3d, 0x5d, 0x94, 0xb3, 0xd4, 0xe3, 0x62, 0xcc, 0x9c, 0xa1, 0xd4, 0x3d, 0xb1, 0xc2, 0x7e, 0xa6, 0xab, 0xf5, 0xd4, 0x20, 0x84, 0xe7, 0x8c, 0xc8, 0xfb, 0xd9, 0x09, 0x62, 0x76, 0x93, 0x70 ], [ 0x5f, 0xf9, 0x65, 0x2b, 0x49, 0x5f, 0x76, 0x66, 0xb7, 0x2f, 0xe9, 0x0d, 0x2e, 0x60, 0xfa, 0xf6, 0xc7, 0xf6, 0xb5, 0x27, 0x24, 0x1f, 0x2e, 0x7a, 0x25, 0xe7, 0x69, 0x5c, 0x14, 0x0b, 0x12, 0x9a ], [ 0xa8, 0x89, 0xc2, 0xcb, 0x9e, 0x79, 0x69, 0x8a, 0xbe, 0x34, 0x86, 0xd0, 0xc0, 0x9d, 0xa3, 0x95, 0x24, 0xdc, 0xee, 0x74, 0xc2, 0x14, 0x08, 0x94, 0x5a, 0x25, 0x3e, 0x0a, 0x8b, 0x41, 0x83, 0x5c ], [ 0xfe, 0x6c, 0x08, 0xf4, 0x7b, 0xb5, 0x81, 0xac, 0xde, 0x23, 0x0f, 0x9c, 0x74, 0xdd, 0x70, 0x98, 0x31, 0x17, 0xeb, 0x3e, 0xb1, 0x16, 0xd1, 0x92, 0xe7, 0x1c, 0x97, 0x44, 0xc8, 0xa5, 0xab, 0x09 ], [ 0x48, 0xc1, 0x7f, 0x35, 0xb4, 0x8f, 0x78, 0x45, 0x6b, 0xb3, 0x6b, 0xe8, 0xb6, 0x08, 0x0e, 0x4d, 0x41, 0x9a, 0x53, 0xaa, 0x94, 0x23, 0x20, 0x24, 0xa8, 0xa8, 0xdb, 0xcd, 0x88, 0x0b, 0x4c, 0x8f ], [ 0x9c, 0x11, 0x8b, 0x07, 0x22, 0xeb, 0x85, 0xbe, 0xd7, 0xeb, 0x7e, 0xb0, 0x0f, 0x2f, 0x76, 0x35, 0x26, 0x39, 0x57, 0xaa, 0x65, 0x4c, 0x2d, 0x38, 0x24, 0x41, 0xf8, 0xb4, 0x2a, 0x25, 0x19, 0x16 ], [ 0xaf, 0x99, 0x29, 0xef, 0x02, 0xd9, 0x04, 0x0d, 0xb0, 0x1d, 0x29, 0xbc, 0x14, 0x6b, 0x10, 0xd5, 0xe2, 0xf3, 0xba, 0x40, 0x1f, 0x0a, 0x5e, 0xc5, 0x27, 0x4f, 0x94, 0x2e, 0x52, 0x2b, 0xea, 0xfa ], [ 0x35, 0x77, 0x9b, 0x9b, 0x79, 0x34, 0xc8, 0x59, 0xf4, 0xec, 0x75, 0x66, 0x86, 0xaa, 0x52, 0xe7, 0x1f, 0x62, 0x00, 0x44, 0x01, 0x1e, 0x34, 0x60, 0x67, 0x3a, 0xdc, 0x98, 0xaf, 0xb9, 0xdd, 0x12 ], [ 0x5f, 0x89, 0x52, 0x12, 0xb2, 0x1d, 0x1b, 0x10, 0x96, 0x02, 0xc0, 0x38, 0x8b, 0xcd, 0x61, 0x41, 0x59, 0x95, 0x82, 0x57, 0xdd, 0x07, 0xe2, 0x12, 0xe5, 0x56, 0x01, 0x24, 0xbd, 0x12, 0x5a, 0x7d ], [ 0x63, 0xb8, 0xd5, 0x8c, 0x7a, 0x99, 0x34, 0x4b, 0xd2, 0xd2, 0x4e, 0x88, 0x4e, 0x46, 0x71, 0x2e, 0xd4, 0xd7, 0xca, 0xeb, 0x4b, 0x7c, 0xed, 0x6f, 0xe7, 0x27, 0x8f, 0xe1, 0xee, 0x3e, 0xf5, 0x8b ], [ 0xa0, 0xff, 0x0b, 0x77, 0x93, 0x6d, 0xbb, 0xef, 0x98, 0xd7, 0x4c, 0x4b, 0x90, 0x92, 0x6c, 0x9d, 0x0e, 0x2c, 0x34, 0xf7, 0x8e, 0x5a, 0x41, 0x01, 0xe6, 0x04, 0x69, 0x3e, 0x0f, 0x81, 0x0b, 0xb8 ], [ 0xe7, 0x57, 0x3b, 0x16, 0xbd, 0xd6, 0x0e, 0xc9, 0x7e, 0xa4, 0x16, 0x67, 0x9b, 0x53, 0x97, 0xc8, 0x2b, 0xa5, 0x18, 0xaa, 0x4f, 0x57, 0xc3, 0x53, 0x02, 0x6f, 0x42, 0x46, 0x4e, 0xda, 0x87, 0x69 ], [ 0x90, 0xaa, 0x84, 0x71, 0x68, 0x26, 0x34, 0x3d, 0x1b, 0x1a, 0x0d, 0xa5, 0x39, 0xaa, 0x2b, 0x95, 0xee, 0x9d, 0xd9, 0x2a, 0x94, 0xd1, 0xa8, 0x67, 0xe3, 0xcf, 0x58, 0x22, 0xf0, 0xc5, 0xe5, 0x2a ], [ 0x5b, 0x3c, 0x9d, 0xbe, 0xe7, 0xde, 0x68, 0x50, 0x68, 0xfd, 0xc2, 0x33, 0x36, 0xaf, 0x6b, 0xb0, 0x91, 0xf4, 0xb6, 0x5c, 0x14, 0x2c, 0x17, 0xfa, 0x46, 0x8b, 0xdd, 0x05, 0x68, 0x0a, 0x30, 0x4b ], [ 0x25, 0xb5, 0xcb, 0xc2, 0x36, 0x0b, 0x95, 0x02, 0xf4, 0x52, 0x1b, 0x6a, 0x76, 0xc1, 0x39, 0x70, 0xa9, 0x9d, 0x30, 0x61, 0xa6, 0xf3, 0x98, 0xcf, 0xb5, 0x7b, 0x0b, 0x7c, 0x92, 0xe9, 0x80, 0x93 ], [ 0x45, 0x14, 0x40, 0x40, 0x1c, 0x3d, 0x12, 0x1d, 0x7d, 0xa7, 0x3c, 0xef, 0x54, 0xf3, 0xd0, 0x21, 0x14, 0x74, 0x55, 0x39, 0x0e, 0x93, 0xc7, 0xe2, 0xf1, 0x6e, 0x5d, 0xe6, 0x51, 0xdc, 0x34, 0x3c ], [ 0x52, 0x99, 0x85, 0x24, 0xd9, 0x67, 0xb2, 0x8c, 0x64, 0x6b, 0xa6, 0x25, 0xfb, 0x3f, 0x9a, 0x8d, 0x1b, 0xe8, 0x65, 0x29, 0xd3, 0x85, 0x70, 0x2a, 0x2e, 0x67, 0x6c, 0xfe, 0xa2, 0x6d, 0x88, 0xe5 ], [ 0x8d, 0x1a, 0x06, 0x6f, 0xb0, 0x6e, 0xec, 0x35, 0x82, 0x5a, 0x1d, 0x50, 0x4c, 0x38, 0x15, 0x71, 0xaa, 0x3d, 0x6c, 0x65, 0xbb, 0x58, 0x4f, 0xc4, 0x44, 0x87, 0x37, 0x0e, 0x29, 0x87, 0x2e, 0x96 ], [ 0xba, 0x1d, 0x0c, 0x4b, 0x89, 0x51, 0xc4, 0xd3, 0x6a, 0x1e, 0x8f, 0x75, 0x48, 0xab, 0x37, 0x03, 0xd3, 0xdc, 0x07, 0x72, 0xe0, 0xc7, 0x52, 0xe9, 0x6d, 0xd5, 0xd1, 0x92, 0x6f, 0x33, 0x9e, 0xfb ], [ 0x2c, 0x3d, 0xa3, 0x16, 0x66, 0xf7, 0x78, 0x51, 0xef, 0x74, 0xcd, 0x4c, 0x3a, 0x9c, 0xb4, 0x7b, 0xa6, 0xf0, 0x6a, 0x8c, 0x0f, 0x7f, 0x9b, 0xd4, 0xc6, 0xa8, 0x5c, 0xd8, 0x65, 0x91, 0x0d, 0x70 ], [ 0xb2, 0xc4, 0x5d, 0xd6, 0x1e, 0xae, 0x5a, 0x19, 0x5e, 0x51, 0xcf, 0xe1, 0xa9, 0x43, 0xe7, 0x57, 0x7f, 0x97, 0x15, 0xf9, 0x31, 0x08, 0x61, 0xb7, 0x32, 0x0b, 0x60, 0xee, 0x46, 0x96, 0x48, 0xb5 ], [ 0x4d, 0xe5, 0x23, 0x6f, 0xa0, 0xe2, 0x29, 0x1d, 0x5b, 0xc2, 0xc0, 0xa5, 0x36, 0x8d, 0xfe, 0xe2, 0x87, 0xc0, 0x89, 0x69, 0xd0, 0x51, 0xf8, 0xe0, 0x61, 0xb5, 0x1a, 0x1a, 0xd4, 0x27, 0x99, 0x2a ], [ 0xe6, 0xb6, 0x4a, 0xf6, 0x64, 0x66, 0xc2, 0xb4, 0x0b, 0x53, 0xc7, 0x85, 0x9b, 0x32, 0x06, 0x11, 0x07, 0x88, 0xa7, 0x71, 0x7e, 0xe1, 0xb1, 0x62, 0x8c, 0xa8, 0x43, 0x33, 0x68, 0xdb, 0xaf, 0xa9 ], [ 0x78, 0x4b, 0x11, 0xe1, 0x2f, 0x9e, 0xb1, 0x4c, 0x6a, 0x1b, 0xb4, 0x48, 0x71, 0xa6, 0x8a, 0x03, 0x09, 0x0d, 0xbd, 0x1c, 0x85, 0x8b, 0x51, 0x6c, 0xd8, 0x17, 0xf0, 0xc5, 0xdb, 0x07, 0x05, 0xde ], [ 0x3b, 0xf8, 0xe4, 0xc8, 0x7d, 0x6e, 0x92, 0x38, 0xdc, 0x2c, 0x9a, 0xd8, 0x0d, 0xd8, 0xb4, 0x56, 0xf0, 0x19, 0x46, 0xb9, 0xde, 0x87, 0xbd, 0x3c, 0x7f, 0xef, 0x47, 0x30, 0x36, 0x90, 0xa5, 0x68 ], [ 0x7d, 0xc2, 0x3f, 0x89, 0xc3, 0xf7, 0x40, 0x10, 0x3e, 0xdd, 0x77, 0xc8, 0x3f, 0x33, 0x02, 0xc9, 0x12, 0x56, 0x48, 0x63, 0x63, 0xed, 0xbe, 0x33, 0x1b, 0x97, 0x94, 0x64, 0x09, 0xa8, 0x27, 0xd2 ], [ 0x68, 0xfb, 0x3c, 0x4f, 0x6e, 0x30, 0xa9, 0xe8, 0xb6, 0xca, 0xe6, 0xb4, 0x91, 0x30, 0xc4, 0x33, 0xef, 0x5f, 0x9a, 0xf0, 0x12, 0xd0, 0x02, 0x1a, 0xce, 0x4a, 0xd8, 0x4a, 0x3e, 0x53, 0x29, 0x26 ], [ 0xa9, 0x2a, 0xdc, 0x72, 0xcf, 0xce, 0x95, 0xb3, 0x49, 0x65, 0xb5, 0x29, 0x30, 0x28, 0x66, 0x6c, 0x2f, 0x2b, 0x9f, 0x6a, 0x8e, 0xc1, 0x3f, 0x90, 0x00, 0x77, 0xb1, 0x01, 0x8b, 0x4b, 0x0e, 0x7b ], [ 0xed, 0xfc, 0xe1, 0xf8, 0xb6, 0x01, 0x6c, 0x79, 0xb5, 0x98, 0x53, 0xb5, 0x47, 0x18, 0x03, 0xd6, 0x22, 0x24, 0xf1, 0xfa, 0x37, 0xaa, 0x5c, 0xbf, 0xf2, 0x87, 0x47, 0xa0, 0x66, 0x68, 0x9d, 0x5b ], [ 0x55, 0xa0, 0x0c, 0x1f, 0x81, 0x4b, 0xdf, 0x1e, 0xeb, 0x2c, 0xe0, 0xff, 0x0c, 0x60, 0xeb, 0xf7, 0xb5, 0xdd, 0x7a, 0xcf, 0x63, 0xce, 0x44, 0x17, 0xf2, 0xba, 0x14, 0x3a, 0x7d, 0x51, 0x06, 0x6e ], [ 0x24, 0x07, 0x54, 0x11, 0x41, 0x57, 0xc3, 0xb7, 0x9d, 0x0a, 0xbe, 0x9b, 0xfc, 0x22, 0xa9, 0x19, 0x84, 0x46, 0x2e, 0xb9, 0x2f, 0x98, 0x30, 0xb5, 0x52, 0x5b, 0x3f, 0x7e, 0x19, 0xb3, 0xfb, 0x55 ], [ 0x51, 0xd8, 0x24, 0x17, 0x6a, 0x47, 0xda, 0x46, 0x8b, 0xe7, 0x5f, 0x6b, 0xf1, 0x9a, 0x09, 0x1a, 0x55, 0x5b, 0x9a, 0xf8, 0xf4, 0xbf, 0xb0, 0xe0, 0x44, 0x8c, 0xc2, 0x3c, 0x99, 0x33, 0x1f, 0x05 ], [ 0xdc, 0x41, 0x0f, 0x8b, 0xcc, 0x92, 0x2e, 0x96, 0x63, 0x4d, 0xb1, 0x23, 0xd5, 0xe2, 0xf4, 0x66, 0x15, 0x0d, 0x08, 0xdc, 0x0b, 0x2d, 0xa1, 0x9a, 0x8c, 0x6b, 0x1b, 0x3a, 0x39, 0x5b, 0xab, 0xad ], [ 0xb4, 0xff, 0xa1, 0x15, 0x54, 0x41, 0x29, 0x16, 0xbb, 0xe8, 0x45, 0x88, 0xd4, 0x98, 0xff, 0xb7, 0x56, 0x17, 0xae, 0xda, 0x49, 0x61, 0x8f, 0x27, 0x91, 0xdc, 0xe4, 0xff, 0x22, 0xbc, 0x0a, 0xcf ], [ 0x8b, 0xd8, 0xb5, 0x47, 0x0d, 0x36, 0x46, 0xfd, 0xe2, 0x94, 0xf0, 0x48, 0xf2, 0xe8, 0xa0, 0xf0, 0x12, 0x9b, 0x74, 0x5c, 0x53, 0xf5, 0xe8, 0x98, 0xf8, 0x0f, 0x14, 0x62, 0xad, 0x79, 0x89, 0x38 ], [ 0xa3, 0x85, 0xdc, 0x6e, 0x2c, 0xec, 0x08, 0xae, 0xdd, 0x4f, 0xed, 0xb7, 0x53, 0x6a, 0xe7, 0xf4, 0xbb, 0x77, 0xf1, 0x39, 0x69, 0xce, 0x59, 0x5d, 0x3e, 0x36, 0x7c, 0xd8, 0x3b, 0x6b, 0xe4, 0xc4 ], [ 0x30, 0x03, 0xfb, 0xe4, 0x97, 0x7e, 0xb6, 0x3a, 0x3c, 0x58, 0x98, 0x1d, 0x1f, 0xb4, 0xea, 0xc2, 0xba, 0xc3, 0x82, 0xe8, 0xbc, 0xf9, 0x38, 0x9e, 0xcb, 0x5a, 0x37, 0x2f, 0x13, 0x49, 0xb8, 0x84 ], [ 0xd0, 0x4e, 0xcf, 0x6b, 0x79, 0x21, 0x00, 0x02, 0xa7, 0x78, 0xad, 0x2a, 0x33, 0x14, 0xd9, 0x0f, 0xb2, 0x70, 0x7c, 0xe3, 0xcd, 0x91, 0x3e, 0x58, 0x13, 0x47, 0xdb, 0x2c, 0xdf, 0x61, 0xd6, 0x98 ], [ 0xd5, 0xe1, 0xfa, 0x40, 0xb4, 0x76, 0x45, 0xe5, 0x92, 0x47, 0x17, 0xb5, 0x3b, 0xfb, 0x62, 0x90, 0x38, 0xc6, 0x6e, 0x06, 0x5f, 0x71, 0x06, 0xb6, 0xb6, 0xc6, 0x42, 0x6e, 0x5d, 0x5c, 0xba, 0x19 ], [ 0xad, 0x64, 0x77, 0xdd, 0x9d, 0x9c, 0x3a, 0xa4, 0x0c, 0x28, 0xe4, 0x55, 0xf1, 0xbd, 0x16, 0x93, 0x24, 0xe5, 0x15, 0xb5, 0xd1, 0x63, 0x94, 0x70, 0x2e, 0x7a, 0x19, 0x37, 0xee, 0x29, 0xfe, 0xe7 ], [ 0xe6, 0x1c, 0x7b, 0xa1, 0xcf, 0xd2, 0x29, 0x12, 0x07, 0xa0, 0xda, 0x83, 0x6a, 0xa8, 0xca, 0x91, 0x25, 0x49, 0x83, 0xd1, 0xa7, 0xee, 0xa6, 0x9d, 0x1e, 0x25, 0x28, 0xde, 0x1c, 0xd3, 0x38, 0x9f ], [ 0x55, 0x91, 0xdc, 0x08, 0xa6, 0x33, 0x64, 0xdd, 0xfc, 0xb1, 0x82, 0x39, 0x0a, 0xfc, 0x85, 0xb2, 0xb2, 0x75, 0x9f, 0xeb, 0xc4, 0x94, 0x81, 0x27, 0x39, 0xac, 0x8b, 0x44, 0x47, 0xc6, 0xc8, 0x92 ], [ 0xfd, 0x29, 0x6a, 0x1d, 0x64, 0x85, 0x98, 0x14, 0x3d, 0xc4, 0xc1, 0x05, 0x51, 0xb6, 0x9e, 0xab, 0x17, 0xde, 0x74, 0xfa, 0xcf, 0x01, 0x59, 0xd5, 0xa5, 0x39, 0xc3, 0x4a, 0x92, 0x17, 0x45, 0x95 ], [ 0xdc, 0x17, 0xca, 0xcd, 0x5e, 0x10, 0xd1, 0x3c, 0x03, 0x24, 0xbf, 0xe8, 0x0f, 0x00, 0x06, 0x6a, 0x78, 0x2a, 0x2b, 0xfb, 0x28, 0x40, 0x41, 0x31, 0x62, 0x86, 0xbc, 0x85, 0xba, 0xc2, 0x84, 0x79 ], [ 0x05, 0x99, 0x08, 0xc4, 0xd5, 0x31, 0x3c, 0xfd, 0x84, 0x7c, 0xd2, 0xb1, 0xfb, 0x5d, 0x85, 0x70, 0xea, 0x65, 0x92, 0x8f, 0x0b, 0x31, 0x8e, 0x5a, 0x2c, 0x48, 0xc3, 0x82, 0x7b, 0xee, 0xd8, 0x60 ], [ 0x2e, 0x12, 0x55, 0xdb, 0x34, 0xa1, 0x37, 0xdb, 0xf6, 0xda, 0x59, 0x41, 0x37, 0xa0, 0x3b, 0xfa, 0xe6, 0x76, 0xb5, 0xe9, 0x43, 0xa0, 0xc1, 0xbe, 0xf1, 0xcf, 0x28, 0x47, 0xdf, 0xa2, 0xb1, 0x72 ], [ 0x14, 0xf7, 0xb4, 0x1f, 0x7d, 0xca, 0x28, 0xec, 0xda, 0xd8, 0xa8, 0x0a, 0xab, 0xe1, 0xa2, 0x62, 0x23, 0xce, 0x3a, 0x3d, 0x58, 0x3d, 0xb3, 0xb1, 0x43, 0xfd, 0x94, 0xf2, 0xf2, 0x10, 0xe4, 0x1e ], [ 0xd4, 0x91, 0x5d, 0x2f, 0xa9, 0xe2, 0x19, 0x10, 0x54, 0xad, 0xdb, 0x63, 0xb8, 0x16, 0xbe, 0x05, 0xc0, 0xdc, 0x0e, 0x65, 0x51, 0x5f, 0xa0, 0x5c, 0xb9, 0x5c, 0x1a, 0xb8, 0xdf, 0xf3, 0x56, 0xab ], [ 0x59, 0x3c, 0xb7, 0x36, 0xf6, 0x4c, 0x9e, 0x83, 0x8f, 0x0a, 0x88, 0x02, 0x29, 0xa7, 0x24, 0x50, 0x2d, 0x16, 0xa4, 0xaa, 0x3b, 0xa8, 0x0b, 0x2a, 0x35, 0x15, 0x54, 0x2d, 0x3a, 0xce, 0x49, 0x9c ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" cipher_texts3_128bit = [ [ 0x23, 0xd5, 0x6c, 0x45, 0xe6, 0xca, 0x04, 0xbc, 0x1f, 0xea, 0x40, 0x24, 0xf8, 0xf1, 0x13, 0xfa, 0x3f, 0x63, 0x4f, 0xc3, 0xe5, 0x0d, 0x33, 0x05, 0xe4 ], [ 0x60, 0x29, 0x61, 0x8d, 0x91, 0x2f, 0x8e, 0x54, 0xe5, 0xcf, 0x6b, 0xaa, 0x9c, 0x34, 0x7a, 0x9d, 0x70, 0x64, 0xff, 0x19, 0x5a, 0xa2, 0x26, 0xed, 0x6b ], [ 0xc7, 0x27, 0x3e, 0x5b, 0xbf, 0x32, 0x0c, 0x13, 0x0e, 0xd8, 0xc1, 0x58, 0xa0, 0x75, 0xd3, 0x55, 0x3a, 0x2d, 0xa1, 0x9d, 0xb0, 0xae, 0x3d, 0x11, 0x98 ], [ 0x07, 0xac, 0x68, 0x5b, 0xaa, 0x21, 0x22, 0x72, 0x06, 0x8e, 0xde, 0xbd, 0xd6, 0xa6, 0x2b, 0xdf, 0xc2, 0xfc, 0x0d, 0x71, 0xab, 0x57, 0x39, 0xe3, 0xb3 ], [ 0x58, 0xcc, 0x33, 0x2b, 0x30, 0xa2, 0xc7, 0x50, 0xcc, 0x9c, 0x52, 0xb7, 0x67, 0x0b, 0xb1, 0x5c, 0xb7, 0xe9, 0xcb, 0xde, 0x95, 0x3d, 0xf7, 0x3b, 0xb2 ], [ 0x16, 0x45, 0x01, 0x5b, 0x34, 0x2b, 0x14, 0xaf, 0x82, 0xee, 0xe3, 0xd4, 0x9c, 0xa6, 0x6e, 0xe4, 0xa5, 0x43, 0x46, 0xeb, 0x13, 0xd9, 0x27, 0xe7, 0x36 ], [ 0x2f, 0x08, 0x06, 0x21, 0xa4, 0x0e, 0x74, 0x92, 0x06, 0xaf, 0x07, 0x9d, 0x6e, 0x93, 0x90, 0x3d, 0x4c, 0x2d, 0x40, 0xf6, 0x67, 0xfd, 0xfa, 0x9b, 0x5d ], [ 0x74, 0x49, 0xe3, 0x7f, 0x74, 0x11, 0xd5, 0x61, 0x56, 0xc4, 0x5b, 0x91, 0x61, 0x27, 0xfb, 0x16, 0x3c, 0x2b, 0x09, 0xea, 0x03, 0x87, 0x4d, 0x82, 0x07 ], [ 0x6b, 0x0b, 0x61, 0x28, 0xf7, 0xe3, 0x38, 0x40, 0x08, 0xda, 0x26, 0xb1, 0x75, 0x41, 0x41, 0xfd, 0xf3, 0x41, 0xe8, 0x6e, 0x70, 0x39, 0x6f, 0x5c, 0x3a ], [ 0x86, 0x5a, 0xc2, 0x6b, 0x6a, 0xc1, 0xed, 0x29, 0xff, 0xb3, 0x9f, 0xca, 0xbb, 0x9c, 0xba, 0x74, 0xeb, 0xed, 0xac, 0xfd, 0xb4, 0xc7, 0x03, 0x19, 0x3b ], [ 0x86, 0x33, 0x12, 0x74, 0x3a, 0x00, 0x6c, 0x48, 0x49, 0xb7, 0x11, 0x57, 0xf1, 0xca, 0x10, 0x83, 0xcf, 0xa1, 0xb2, 0x65, 0x4b, 0xa3, 0x7e, 0xa4, 0x4f ], [ 0x37, 0x0d, 0xda, 0x94, 0x47, 0xcb, 0xe2, 0x65, 0xeb, 0x1c, 0x39, 0x1a, 0x89, 0xa1, 0xc8, 0xaa, 0xf7, 0x5d, 0x44, 0x25, 0xab, 0x29, 0x63, 0x0a, 0x7f ], [ 0x25, 0x3c, 0x0d, 0x5c, 0xb7, 0x26, 0x80, 0x54, 0xfe, 0xa1, 0xc8, 0xff, 0xc6, 0x8e, 0xc7, 0xdd, 0xe3, 0x63, 0x62, 0x68, 0xdb, 0x54, 0xce, 0xff, 0x2e ], [ 0x26, 0x71, 0x19, 0xf9, 0x19, 0xb4, 0x90, 0xec, 0x4d, 0x3b, 0xd7, 0x2c, 0xec, 0x3a, 0x71, 0x7f, 0x8e, 0x9e, 0xc7, 0x07, 0xaa, 0xbe, 0x98, 0x4b, 0xd6 ], [ 0xfa, 0x35, 0x4c, 0xbf, 0xce, 0x18, 0x2e, 0xd0, 0x71, 0x0d, 0x60, 0x07, 0xe9, 0x44, 0xd1, 0xa8, 0xb2, 0x99, 0xde, 0x93, 0x20, 0xce, 0x77, 0x5d, 0xb2 ], [ 0xd6, 0x76, 0x93, 0x34, 0xe9, 0x0a, 0x0f, 0xaa, 0x02, 0xe2, 0xf9, 0x52, 0x20, 0x8a, 0xca, 0x06, 0x62, 0x13, 0xdb, 0x8d, 0xca, 0x05, 0x0b, 0x52, 0x8a ], [ 0x3e, 0xcd, 0xef, 0xcf, 0x57, 0xf1, 0xb5, 0xa7, 0xc1, 0xd2, 0x75, 0xaa, 0xc3, 0x31, 0xcc, 0xd2, 0x25, 0x5c, 0x08, 0x9e, 0x54, 0x44, 0xb1, 0x6a, 0x51 ], [ 0x30, 0xb0, 0x6d, 0x11, 0xfe, 0x83, 0xe9, 0xa4, 0x71, 0xb1, 0x20, 0x58, 0x99, 0x06, 0xc0, 0xa8, 0x18, 0xac, 0x3d, 0x9f, 0xf0, 0x3f, 0x62, 0x0f, 0x07 ], [ 0x30, 0x86, 0x46, 0x09, 0x34, 0xd7, 0xa7, 0xed, 0x6b, 0x37, 0x98, 0xc1, 0x22, 0xfc, 0x8c, 0x0e, 0x1e, 0xc6, 0xa3, 0xa0, 0x76, 0x05, 0xfc, 0xd3, 0x27 ], [ 0x37, 0xcd, 0x1b, 0x9b, 0x77, 0x9c, 0xd4, 0x05, 0x1a, 0xf3, 0x97, 0x54, 0xd9, 0x7b, 0xcb, 0x44, 0x80, 0x5d, 0x8c, 0x72, 0x64, 0x50, 0x63, 0x34, 0x7c ], [ 0xea, 0x66, 0x32, 0xf9, 0xd6, 0xd5, 0x52, 0xb4, 0x14, 0xed, 0xe1, 0xa5, 0xd2, 0xa5, 0x54, 0x50, 0x5f, 0x8d, 0x2e, 0x22, 0xff, 0xea, 0x69, 0x2e, 0x53 ], [ 0x8c, 0x7b, 0x4e, 0x51, 0xeb, 0x88, 0xaa, 0xe2, 0x71, 0xe2, 0xd1, 0xfb, 0xe4, 0x52, 0x2f, 0xa9, 0xd1, 0x28, 0xdd, 0x4b, 0xc2, 0xe3, 0x6e, 0xfd, 0xc4 ], [ 0xc8, 0x65, 0x39, 0x64, 0x2f, 0x08, 0xcc, 0x95, 0x9d, 0x90, 0x6d, 0x85, 0x91, 0x03, 0x21, 0x02, 0x9e, 0x14, 0x84, 0xfe, 0xd4, 0x19, 0xda, 0xea, 0x69 ], [ 0xd7, 0x68, 0xba, 0xd0, 0x59, 0xb0, 0xc9, 0x4f, 0xf3, 0xaa, 0x95, 0xe2, 0x74, 0x25, 0x72, 0xbd, 0x44, 0xd7, 0xbf, 0x05, 0xdc, 0x9a, 0x1d, 0x3e, 0x29 ], [ 0x9c, 0x42, 0x64, 0x65, 0xcd, 0x3d, 0x94, 0x58, 0xbf, 0x3f, 0x8e, 0x3f, 0xc2, 0x63, 0x6d, 0xdc, 0xbc, 0x7f, 0xb4, 0xb5, 0x74, 0x28, 0xbd, 0x6e, 0xa2 ], [ 0xc1, 0x5d, 0x7e, 0x9d, 0x1a, 0xc5, 0x79, 0x27, 0x7f, 0x78, 0xf0, 0xa3, 0xae, 0x8d, 0xd9, 0xd2, 0x9e, 0xd5, 0x5b, 0x90, 0xa9, 0x4e, 0x86, 0x50, 0xd0 ], [ 0x55, 0xb1, 0x8c, 0xed, 0x64, 0x08, 0x60, 0xd4, 0x80, 0xf6, 0x30, 0xa6, 0xb7, 0x1f, 0x7f, 0x5a, 0xea, 0x29, 0x26, 0xd5, 0xb4, 0xe4, 0xfb, 0x30, 0x97 ], [ 0xb5, 0xb3, 0x38, 0xfd, 0x3d, 0xc8, 0xe5, 0x65, 0xfb, 0x61, 0x2c, 0xd5, 0xae, 0xf6, 0xaf, 0x4a, 0x80, 0x4d, 0x8c, 0xa0, 0x09, 0x0d, 0xe9, 0xb2, 0x0f ], [ 0xa3, 0xcf, 0x15, 0x8e, 0x19, 0x01, 0x0a, 0x9b, 0x8d, 0xd8, 0x60, 0x5d, 0x5c, 0xff, 0x1b, 0xe2, 0xc5, 0x02, 0xa1, 0xc0, 0xad, 0x32, 0x55, 0x43, 0xb0 ], [ 0xb1, 0x43, 0xb0, 0x59, 0xff, 0x94, 0x5c, 0xc2, 0x8b, 0x3c, 0x1c, 0x32, 0x03, 0xed, 0x7e, 0x7e, 0x7e, 0xbe, 0x33, 0xad, 0x13, 0x45, 0x25, 0x89, 0x63 ], [ 0x8a, 0x0b, 0x4f, 0x8d, 0x62, 0x17, 0x43, 0x4b, 0xfb, 0xe5, 0xcf, 0xd8, 0x0c, 0x08, 0xe7, 0x06, 0x6f, 0xe0, 0xc4, 0x7b, 0xaf, 0x6c, 0x2a, 0x3a, 0x7c ], [ 0xb3, 0x11, 0xba, 0x6e, 0x52, 0x2f, 0x18, 0xca, 0x1d, 0x13, 0xf1, 0xfd, 0x42, 0x69, 0x18, 0xee, 0x83, 0xef, 0xcf, 0xa8, 0x73, 0x90, 0xef, 0xc4, 0x0e ], [ 0xed, 0x47, 0x71, 0x98, 0x47, 0xd7, 0x3e, 0x0e, 0x12, 0x70, 0x7a, 0x27, 0x7e, 0xc4, 0x7a, 0x9c, 0xc8, 0x09, 0x67, 0x91, 0xa8, 0x23, 0x8d, 0xae, 0xbd ], [ 0x23, 0xe7, 0x98, 0x73, 0xe3, 0x26, 0x9f, 0x9d, 0xc4, 0x2b, 0x6d, 0x9b, 0x71, 0x20, 0xcf, 0xb1, 0xc9, 0xe4, 0x5a, 0xe8, 0x0e, 0xbe, 0x16, 0x6c, 0xad ], [ 0xef, 0xe2, 0x40, 0x78, 0xd3, 0x6a, 0x8c, 0xf1, 0x55, 0xdd, 0x95, 0xbd, 0xd5, 0x32, 0x1c, 0x6a, 0xcb, 0x26, 0xff, 0x60, 0x7b, 0x3b, 0x19, 0xbc, 0xa5 ], [ 0x24, 0x5d, 0x25, 0x28, 0xb7, 0xe1, 0x60, 0x8a, 0x18, 0x6f, 0x6e, 0x8d, 0x62, 0x18, 0xee, 0x0b, 0x7a, 0x73, 0xed, 0x97, 0x96, 0x58, 0x24, 0x19, 0xd7 ], [ 0x3e, 0xb3, 0x8e, 0x02, 0xe7, 0x03, 0x72, 0xb2, 0xa4, 0x1f, 0x27, 0xc6, 0x8e, 0x4e, 0xdd, 0x7b, 0x8e, 0xa1, 0x96, 0xa1, 0xa3, 0x8b, 0x28, 0x5f, 0xa3 ], [ 0x1b, 0xdd, 0xe7, 0x4c, 0xaa, 0xbc, 0x38, 0xb3, 0x73, 0x83, 0xb0, 0x72, 0xd2, 0xae, 0xb4, 0x0c, 0xb2, 0x1f, 0xb2, 0x94, 0x01, 0xf1, 0x10, 0xac, 0x0c ], [ 0xec, 0x08, 0xaf, 0xe7, 0xa0, 0xb6, 0x45, 0x03, 0xe0, 0x3a, 0x75, 0x7b, 0xa0, 0xba, 0xa8, 0xcd, 0x28, 0x5c, 0xc3, 0xfe, 0x74, 0xa6, 0x9f, 0x65, 0xa5 ], [ 0xea, 0xd2, 0x9b, 0x33, 0x51, 0x9f, 0xa0, 0x10, 0xe1, 0xb4, 0x57, 0xd3, 0xa5, 0x1b, 0x71, 0x45, 0x2f, 0xb4, 0x86, 0xb1, 0xee, 0x37, 0x99, 0x65, 0x3c ], [ 0x32, 0x1d, 0x47, 0x47, 0x95, 0x37, 0xf2, 0x38, 0x1f, 0x5d, 0x33, 0xec, 0xe6, 0x6c, 0xd1, 0x73, 0x68, 0xbc, 0xab, 0xc2, 0xea, 0x90, 0xf3, 0xbd, 0x2c ], [ 0x34, 0xa0, 0x2a, 0xe1, 0x9d, 0xd3, 0x9e, 0x76, 0xda, 0x25, 0x6d, 0x32, 0x70, 0xaa, 0xa2, 0x57, 0x25, 0xc7, 0x46, 0x11, 0x3b, 0xb2, 0xe5, 0xd9, 0xc4 ], [ 0x0a, 0x6a, 0xaf, 0xd3, 0x37, 0x50, 0x14, 0x4f, 0x38, 0x8b, 0xc7, 0x7c, 0xcd, 0xfa, 0x40, 0xc9, 0x47, 0x11, 0x7c, 0x3a, 0x7e, 0x1f, 0xed, 0x53, 0xbf ], [ 0xce, 0xd7, 0x2e, 0x95, 0x6b, 0xa6, 0x9f, 0xfa, 0x14, 0x4b, 0xf8, 0x1a, 0x2a, 0x99, 0x46, 0x2f, 0x3d, 0x47, 0x4f, 0x62, 0xcc, 0x46, 0xa9, 0xf1, 0xdd ], [ 0x65, 0x99, 0x15, 0xe3, 0x42, 0x74, 0xff, 0x7f, 0x72, 0xc9, 0xfe, 0x55, 0xc3, 0xfa, 0x4e, 0xa5, 0x5c, 0xb9, 0xa0, 0x21, 0xff, 0xcc, 0x9f, 0x13, 0x67 ], [ 0xa3, 0xa0, 0x63, 0x80, 0x05, 0x6b, 0x3f, 0x15, 0x58, 0x92, 0xfb, 0x01, 0x03, 0xaa, 0xc6, 0x66, 0xea, 0x19, 0x20, 0x5f, 0xa3, 0xfa, 0xe9, 0x4f, 0x78 ], [ 0x40, 0xd9, 0xf9, 0xdc, 0x7a, 0xc2, 0x26, 0x24, 0xc0, 0xa4, 0x50, 0xd2, 0x76, 0x89, 0x8f, 0x62, 0x2e, 0xbd, 0x05, 0x86, 0xec, 0x2c, 0x48, 0x37, 0x2b ], [ 0x9b, 0xe5, 0xb4, 0x9d, 0x8e, 0x8b, 0x87, 0x40, 0x16, 0x90, 0xd2, 0x40, 0x47, 0x97, 0xf0, 0x58, 0x4d, 0xe8, 0x88, 0xd0, 0x2b, 0x1f, 0x90, 0xd6, 0x1d ], [ 0xcb, 0x83, 0x3d, 0x27, 0xf1, 0xbc, 0xe1, 0xa6, 0x55, 0x4b, 0x15, 0xdf, 0xa0, 0xae, 0x87, 0x40, 0x2f, 0x5d, 0x9d, 0x2e, 0x0c, 0x52, 0x18, 0xc1, 0xcd ], [ 0x95, 0x46, 0x84, 0xc0, 0xb4, 0x7d, 0xe9, 0x8b, 0xd2, 0xbd, 0xae, 0xad, 0x68, 0x0a, 0x36, 0x81, 0x57, 0x94, 0xd7, 0xac, 0x6d, 0x1e, 0xde, 0x17, 0xc7 ], [ 0x6f, 0x8c, 0xb3, 0x80, 0x86, 0x32, 0x21, 0x61, 0xf6, 0x4a, 0x2c, 0xa4, 0x94, 0x73, 0x8b, 0xbc, 0x0c, 0x89, 0xc8, 0xb7, 0x0c, 0x4f, 0x53, 0x25, 0xc1 ], [ 0x57, 0xb9, 0x22, 0x4a, 0x61, 0xe6, 0x90, 0x4e, 0x5b, 0x4e, 0xb0, 0xf9, 0x81, 0x83, 0xe6, 0x0e, 0xc4, 0x66, 0x8b, 0xd5, 0xe5, 0x35, 0x6b, 0x73, 0xa1 ], [ 0xea, 0xd6, 0xb8, 0x9e, 0x0d, 0x2d, 0x9f, 0xbb, 0xf6, 0x64, 0x92, 0x4b, 0x82, 0xe8, 0x72, 0xf2, 0x28, 0x6d, 0x5f, 0x34, 0x9b, 0x83, 0xc3, 0x39, 0x9f ], [ 0xc9, 0x5d, 0xbd, 0xf3, 0xba, 0x97, 0xd3, 0xc2, 0xa5, 0x95, 0xc5, 0xd6, 0xeb, 0x5f, 0xcc, 0xa1, 0x02, 0x15, 0xc6, 0xb7, 0x8d, 0xde, 0x68, 0xda, 0xe9 ], [ 0x0f, 0x88, 0xaf, 0x95, 0x2d, 0x2e, 0x50, 0x75, 0xba, 0xeb, 0x06, 0xd1, 0x15, 0x13, 0x1b, 0x19, 0x0d, 0xce, 0xc3, 0x8b, 0x98, 0x75, 0xf4, 0x6b, 0x32 ], [ 0xe2, 0x58, 0xfc, 0x02, 0x79, 0x68, 0x7f, 0x49, 0xe4, 0x73, 0xca, 0xa1, 0x39, 0xc8, 0x8e, 0x4d, 0xd1, 0x36, 0xce, 0x4c, 0xc1, 0x37, 0x81, 0xa4, 0xee ], [ 0x56, 0xfe, 0x0a, 0x99, 0x86, 0x75, 0xcc, 0x6e, 0x91, 0xb0, 0x9e, 0x07, 0xc9, 0x4d, 0x56, 0x78, 0x19, 0x65, 0x7d, 0x9c, 0x7b, 0x01, 0xb4, 0x0d, 0x16 ], [ 0xbe, 0xba, 0xbb, 0x62, 0x6e, 0x38, 0x70, 0x06, 0x51, 0xf1, 0xf6, 0x52, 0xdb, 0x7f, 0x35, 0x53, 0xb0, 0xb7, 0x6c, 0xd4, 0x5a, 0xa8, 0xdb, 0xec, 0x28 ], [ 0x03, 0xc3, 0xc3, 0x04, 0xf0, 0x9d, 0xcc, 0x39, 0x72, 0x15, 0xae, 0x2e, 0x0b, 0xf1, 0x90, 0x0e, 0x6b, 0xb0, 0x88, 0xa8, 0xd1, 0x57, 0xe3, 0x74, 0x78 ], [ 0xec, 0x97, 0x5d, 0xb7, 0x3e, 0x5c, 0x47, 0x90, 0x4e, 0x8c, 0x37, 0x18, 0x6f, 0x69, 0x17, 0x1e, 0x2f, 0xf8, 0x7b, 0x17, 0x6c, 0x95, 0x63, 0x3d, 0x7e ], [ 0xf0, 0xec, 0xbc, 0x77, 0x4e, 0x76, 0x9d, 0x3a, 0x35, 0x02, 0x1a, 0x3b, 0x8b, 0x6f, 0x62, 0x31, 0xa7, 0xc2, 0x13, 0x90, 0xfa, 0x95, 0x3d, 0xc8, 0x20 ], [ 0x74, 0x07, 0x35, 0xa8, 0x17, 0x31, 0x6c, 0x7f, 0x02, 0x11, 0xd3, 0x1d, 0xc2, 0xe0, 0x66, 0x8a, 0x4f, 0xa4, 0xe5, 0xca, 0xd1, 0x0d, 0x5a, 0xb0, 0xfc ], [ 0x67, 0xd9, 0x83, 0xa4, 0xd6, 0x99, 0xbd, 0x58, 0x2c, 0xe0, 0x60, 0xb9, 0x80, 0x62, 0xd8, 0x6b, 0xc0, 0xf8, 0x66, 0x72, 0x17, 0x55, 0x79, 0x04, 0x8f ], [ 0x14, 0x44, 0x53, 0x34, 0x8f, 0xd8, 0x94, 0xd8, 0xd9, 0x19, 0x83, 0x2f, 0xb1, 0x8e, 0x6e, 0xc5, 0xcf, 0xd6, 0x7a, 0xff, 0xfd, 0x24, 0x9c, 0xc2, 0x12 ], [ 0x21, 0xd5, 0xab, 0x2f, 0x2b, 0x33, 0x24, 0x2f, 0x25, 0xdd, 0x4f, 0xba, 0x01, 0x67, 0x7f, 0xa1, 0xfd, 0xc0, 0x80, 0x77, 0x3b, 0xcc, 0x17, 0xa5, 0x44 ], [ 0x04, 0xef, 0x8b, 0xf5, 0x56, 0xa2, 0xc0, 0x80, 0x3e, 0x2e, 0x35, 0xe3, 0xe8, 0xdb, 0x03, 0x4f, 0x3a, 0xcc, 0xf3, 0xe3, 0x41, 0x2b, 0xbf, 0xdf, 0xa6 ], [ 0xdf, 0x0a, 0x8a, 0x6f, 0x98, 0xdd, 0x44, 0xb2, 0x53, 0x49, 0x10, 0x79, 0x7f, 0xeb, 0x97, 0x45, 0xe1, 0xd1, 0xae, 0x7b, 0xc7, 0xe6, 0xcb, 0x1e, 0x72 ], [ 0xd1, 0x66, 0x39, 0xeb, 0x84, 0x43, 0x30, 0xa0, 0xa6, 0xed, 0x57, 0x3e, 0xb7, 0xd6, 0x1f, 0x00, 0xdb, 0x66, 0xb1, 0xe1, 0x46, 0x11, 0x73, 0x84, 0xea ], [ 0x2a, 0x67, 0x60, 0x85, 0x47, 0xb9, 0xd9, 0xd9, 0x03, 0xb2, 0xd7, 0xcb, 0x2b, 0x6c, 0x65, 0x48, 0x58, 0xe8, 0x1a, 0xab, 0x2b, 0x1d, 0x9a, 0x72, 0xaa ], [ 0x13, 0x54, 0x02, 0x85, 0x77, 0x76, 0xb8, 0x1a, 0x0d, 0x1e, 0xff, 0x89, 0x1d, 0x58, 0x3b, 0x92, 0x27, 0x6a, 0x9a, 0xbe, 0x7c, 0x51, 0xfa, 0x3f, 0x0a ], [ 0xd6, 0x3c, 0xbd, 0x68, 0x96, 0xae, 0x1a, 0x9d, 0xee, 0x4c, 0x93, 0xa2, 0x83, 0x1b, 0xeb, 0x71, 0xbe, 0xec, 0x5b, 0x37, 0xb0, 0x83, 0xb8, 0x0e, 0x56 ], [ 0x91, 0x93, 0xa9, 0x21, 0xae, 0x6e, 0x83, 0x0d, 0x9c, 0xe7, 0x21, 0xe9, 0x1d, 0x20, 0xed, 0x23, 0x6e, 0x78, 0x09, 0xfa, 0x09, 0x64, 0x0c, 0xb0, 0xfb ], [ 0x6f, 0xab, 0x95, 0x91, 0xcd, 0x07, 0x47, 0x2b, 0x81, 0xf2, 0xd9, 0x06, 0x06, 0x8d, 0xa0, 0x71, 0x89, 0xc9, 0x77, 0xdb, 0x6e, 0x09, 0x23, 0x1c, 0x0c ], [ 0xb5, 0x2b, 0x14, 0x48, 0xbc, 0xf6, 0xd0, 0x13, 0xcc, 0x28, 0xc4, 0x91, 0xe4, 0xd3, 0x78, 0x07, 0xff, 0x8e, 0x88, 0x25, 0xe1, 0xf5, 0xff, 0xde, 0xc6 ], [ 0x94, 0x97, 0x15, 0x3d, 0x73, 0x7a, 0xba, 0xf2, 0xaa, 0x1c, 0xe7, 0xbb, 0xf5, 0x91, 0xff, 0x5a, 0x76, 0x4c, 0xdf, 0x95, 0xe6, 0xbe, 0x9f, 0x28, 0x38 ], [ 0x6b, 0xb7, 0x4f, 0xaf, 0x0b, 0x17, 0x83, 0x3a, 0x3a, 0x1a, 0x95, 0xf6, 0x73, 0x67, 0x5e, 0x23, 0x0c, 0x51, 0x8d, 0xfa, 0x26, 0xfd, 0x98, 0xa5, 0x2a ], [ 0x84, 0xbb, 0x8d, 0x17, 0x72, 0xe9, 0x3f, 0x00, 0xe8, 0x0d, 0xf5, 0xb2, 0x0e, 0x5d, 0x1a, 0x56, 0x02, 0xab, 0x9b, 0x00, 0x1b, 0xad, 0xec, 0x7b, 0x4a ], [ 0x9e, 0x12, 0xe6, 0xb7, 0x0d, 0x6a, 0xa1, 0x68, 0x72, 0x88, 0xa6, 0xe4, 0x9c, 0xd8, 0xb6, 0xd8, 0x61, 0xdb, 0xa0, 0x40, 0x0e, 0x05, 0xaa, 0xf7, 0x52 ], [ 0x37, 0x5f, 0xbc, 0xb5, 0xa0, 0x46, 0x65, 0x5e, 0x2e, 0xed, 0xfa, 0x4f, 0x17, 0x7a, 0x0c, 0xd8, 0xce, 0x3a, 0x7f, 0x62, 0xc8, 0x1c, 0x08, 0x51, 0x88 ], [ 0x6b, 0x4d, 0x11, 0x42, 0x67, 0x9b, 0x32, 0x1c, 0x02, 0x65, 0x21, 0x5b, 0xce, 0xd8, 0x9e, 0x8c, 0xd9, 0xff, 0x1c, 0x73, 0x21, 0x44, 0x75, 0x94, 0xf1 ], [ 0xdd, 0x21, 0x21, 0x43, 0x56, 0x9f, 0x1c, 0x9d, 0x80, 0x02, 0x22, 0x4b, 0xf0, 0x14, 0x9f, 0x33, 0x90, 0x8f, 0xd1, 0xf7, 0x11, 0xfa, 0xa7, 0x7d, 0x38 ], [ 0x8e, 0x81, 0x21, 0x8f, 0x00, 0x69, 0xe1, 0x00, 0x2e, 0x21, 0x8f, 0xee, 0x9b, 0x95, 0x30, 0xb1, 0xc2, 0x29, 0x23, 0x3d, 0xe6, 0x61, 0xaa, 0xa2, 0x8e ], [ 0xa1, 0x1f, 0x8f, 0xd6, 0xa5, 0x71, 0xed, 0x60, 0x1f, 0xbd, 0x52, 0x43, 0x9a, 0x72, 0x7d, 0x47, 0x62, 0x66, 0x77, 0x6b, 0xc8, 0x53, 0xa3, 0xd7, 0xfa ], [ 0x52, 0x0f, 0x01, 0xb9, 0xd8, 0x28, 0x5b, 0xe1, 0xf9, 0x56, 0xdf, 0x7b, 0x76, 0x5d, 0x1c, 0x60, 0x1c, 0x2d, 0xfd, 0x0d, 0x7a, 0x19, 0xf5, 0x0f, 0xec ], [ 0x50, 0x36, 0x02, 0x49, 0x90, 0xb5, 0x8e, 0x01, 0x7a, 0x25, 0x61, 0xf1, 0x26, 0xc1, 0x43, 0xec, 0xfe, 0xf3, 0x43, 0xeb, 0x6b, 0x1f, 0x3f, 0x33, 0x3d ], [ 0x2b, 0xa0, 0x7a, 0xaf, 0x5b, 0xe5, 0x55, 0x0e, 0xd7, 0xb4, 0x4e, 0x28, 0x07, 0x04, 0x14, 0xf1, 0x54, 0xaa, 0xf3, 0x0e, 0xc8, 0x90, 0x4e, 0x82, 0x52 ], [ 0x57, 0x09, 0xfb, 0xb5, 0x09, 0xac, 0x67, 0x76, 0x79, 0x74, 0x23, 0xbc, 0x64, 0xf3, 0x01, 0x40, 0xd5, 0x7d, 0xa9, 0xf5, 0xde, 0xca, 0xed, 0xe0, 0x8f ], [ 0xdc, 0x79, 0xb0, 0x9e, 0xde, 0xaa, 0x45, 0xff, 0x81, 0x39, 0x53, 0xaf, 0x1b, 0x00, 0x61, 0x51, 0x24, 0xca, 0x66, 0x0a, 0xbf, 0x00, 0xfc, 0x92, 0xdc ], [ 0x8d, 0x1a, 0x41, 0x99, 0xa2, 0x97, 0x14, 0x81, 0xed, 0x29, 0x3b, 0x98, 0x43, 0xf0, 0x71, 0x4b, 0x5e, 0x67, 0x01, 0x46, 0x18, 0x8c, 0x1c, 0x65, 0x06 ], [ 0x82, 0x33, 0x1c, 0xf0, 0x5a, 0x8e, 0xb9, 0x91, 0x2d, 0x44, 0x72, 0x3c, 0x8d, 0xda, 0x59, 0x5a, 0x2f, 0xa2, 0x70, 0x6c, 0x10, 0xe8, 0x13, 0x79, 0xe4 ], [ 0xd4, 0xa6, 0x30, 0x9e, 0x57, 0x49, 0xeb, 0x50, 0x6f, 0x25, 0xb5, 0x7c, 0xc3, 0x13, 0xab, 0x50, 0xdc, 0x37, 0x3f, 0xe7, 0x09, 0xef, 0x44, 0x11, 0x4c ], [ 0x7c, 0x92, 0x8f, 0x21, 0x0f, 0x98, 0x31, 0x25, 0xee, 0x6c, 0xb1, 0x21, 0x7b, 0x6e, 0x55, 0x64, 0x3a, 0x32, 0x63, 0x23, 0x4c, 0x21, 0x92, 0xfe, 0x5f ], [ 0xc2, 0x01, 0x1f, 0x95, 0x9c, 0x7e, 0x80, 0x9c, 0x89, 0x76, 0xdb, 0x6b, 0xa7, 0x83, 0x03, 0x4b, 0xbb, 0x2a, 0xd1, 0x58, 0x97, 0x30, 0xff, 0x0a, 0x1e ], [ 0xa6, 0xb9, 0xbe, 0x98, 0xf5, 0xe1, 0xfe, 0x54, 0x59, 0xe2, 0x39, 0x47, 0x4d, 0xc4, 0x1b, 0x34, 0xa3, 0xdc, 0xcc, 0x38, 0x95, 0xce, 0x11, 0x21, 0xd3 ], [ 0x5f, 0x5a, 0x7a, 0x30, 0xcf, 0x1d, 0xa7, 0xe9, 0x79, 0xd0, 0x06, 0xd7, 0x68, 0x90, 0xdd, 0xb9, 0x75, 0xae, 0x17, 0x17, 0x41, 0xb9, 0x03, 0xba, 0x88 ], [ 0xd6, 0x5a, 0x3c, 0xbb, 0xbc, 0x2a, 0x42, 0xf1, 0x40, 0xe4, 0x6c, 0xf4, 0x01, 0x1c, 0x4e, 0x68, 0x6b, 0xe6, 0xf4, 0xa9, 0x80, 0x4e, 0x9f, 0x63, 0x1b ], [ 0x45, 0xe1, 0xdd, 0xae, 0x35, 0xc6, 0x7c, 0x99, 0xb8, 0x25, 0x18, 0xbc, 0xf7, 0xe6, 0xb3, 0xd1, 0xcf, 0x5f, 0x30, 0xe4, 0x8c, 0x30, 0x91, 0x04, 0xcd ], [ 0xb8, 0x2c, 0x5c, 0x5a, 0x21, 0x60, 0xea, 0xec, 0x98, 0x9a, 0xe7, 0x02, 0x66, 0xb9, 0xe3, 0x46, 0xcd, 0x9d, 0xaa, 0x95, 0xde, 0x12, 0x77, 0x88, 0xa1 ], [ 0x2b, 0xe8, 0xb0, 0xc0, 0xfa, 0xeb, 0x45, 0xad, 0x38, 0xc9, 0x0b, 0x4b, 0xf7, 0x03, 0x90, 0x3b, 0x01, 0x5a, 0x87, 0xec, 0x65, 0x24, 0x81, 0x9d, 0xeb ], [ 0x6b, 0x50, 0xdb, 0x3d, 0x29, 0x4c, 0x3f, 0x4a, 0xba, 0x33, 0x59, 0x42, 0xa0, 0x23, 0x40, 0xc7, 0xf6, 0x1e, 0xa4, 0xfe, 0x67, 0x0e, 0x3f, 0x0b, 0xa2 ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" cipher_texts4_128bit = [ [ 0x3c, 0x21, 0x49, 0x04, 0x07, 0x2f, 0xc4, 0xac, 0x45, 0xa2, 0x24, 0x53, 0x41, 0xf7, 0x8b, 0x78, 0x73, 0xf0, 0x5d, 0x32, 0x55, 0xd3, 0x40, 0x11, 0x5a, 0x92, 0x0d, 0x0b, 0xf2, 0xab, 0xf6, 0x71 ], [ 0xd9, 0x6b, 0xdb, 0xbf, 0xdc, 0xe8, 0xd8, 0x98, 0xd5, 0x10, 0x81, 0xc4, 0x6d, 0x95, 0x78, 0xe2, 0x9b, 0x3f, 0x59, 0x87, 0x57, 0xe8, 0x3c, 0xec, 0x92, 0xab, 0x92, 0x1a, 0x41, 0xe4, 0x59, 0xef ], [ 0xa1, 0xe2, 0xd8, 0xbc, 0x5a, 0x24, 0x73, 0x6f, 0xd7, 0x1b, 0x62, 0x4e, 0x7c, 0xde, 0xb9, 0xaf, 0xa9, 0x2e, 0x60, 0x44, 0x92, 0x35, 0x40, 0xde, 0xeb, 0x17, 0xb6, 0xc6, 0x81, 0x29, 0x9e, 0xfa ], [ 0x2b, 0xed, 0x1e, 0xbb, 0x1c, 0x0e, 0x66, 0x5f, 0xcd, 0x05, 0x07, 0x39, 0x39, 0x0c, 0x71, 0xfb, 0x6b, 0x99, 0xc0, 0x00, 0xcc, 0x97, 0x78, 0x0b, 0xda, 0x64, 0xe1, 0x2f, 0x5d, 0xe5, 0xe1, 0xf5 ], [ 0x03, 0x05, 0xe8, 0x09, 0xed, 0xba, 0x6c, 0x0e, 0xd9, 0x99, 0x87, 0xc9, 0xb5, 0xf4, 0x6a, 0x96, 0x59, 0xfb, 0x7e, 0xdb, 0x95, 0x8c, 0xa0, 0xec, 0x2b, 0xc9, 0x2f, 0x0b, 0xf4, 0xa5, 0xea, 0x76 ], [ 0x46, 0x46, 0xde, 0x2e, 0xc0, 0x5b, 0x00, 0xe5, 0x42, 0xbb, 0x00, 0x49, 0x9e, 0xab, 0x1c, 0x7c, 0x00, 0x2e, 0xaf, 0xe9, 0x9a, 0x18, 0x02, 0xec, 0x89, 0xee, 0xa6, 0x73, 0xbd, 0xe9, 0x7f, 0xd0 ], [ 0x8c, 0x79, 0xd7, 0xed, 0xf7, 0x8b, 0xc9, 0x4d, 0x15, 0xfb, 0x51, 0x4e, 0x48, 0xc2, 0x8d, 0x4b, 0xfa, 0xc0, 0xc6, 0x4c, 0xc1, 0xda, 0x7e, 0x09, 0xee, 0x87, 0xb3, 0x4e, 0x83, 0xb3, 0x6d, 0xa5 ], [ 0xe1, 0x98, 0x77, 0xfa, 0x2b, 0xfd, 0x08, 0x58, 0x9d, 0x2f, 0x23, 0xf5, 0xd6, 0x5a, 0xf5, 0x67, 0x49, 0x99, 0x0d, 0x5d, 0x90, 0x8e, 0xa0, 0xf9, 0x29, 0x1f, 0x4c, 0x40, 0x62, 0x93, 0x26, 0xed ], [ 0xd0, 0x31, 0x15, 0x99, 0x66, 0x17, 0xd3, 0x36, 0xf2, 0x2b, 0xfc, 0xd2, 0xa6, 0xbc, 0x99, 0x6e, 0x17, 0x60, 0x34, 0x90, 0x22, 0xb9, 0x3e, 0x5f, 0x50, 0x3e, 0x21, 0x90, 0x1f, 0x99, 0xe9, 0xf5 ], [ 0x6d, 0xc4, 0xf1, 0x43, 0xed, 0x48, 0xd3, 0x97, 0x77, 0xe4, 0x96, 0x01, 0x94, 0xa4, 0x25, 0x1d, 0xc1, 0xf5, 0x00, 0x80, 0xa8, 0x8f, 0x33, 0x9e, 0xda, 0x36, 0xa8, 0x40, 0x26, 0x9a, 0x4d, 0x2a ], [ 0x4c, 0x6c, 0x48, 0x42, 0x07, 0x92, 0x2c, 0xdb, 0x46, 0x09, 0x34, 0x77, 0x77, 0x62, 0xad, 0x0a, 0xe9, 0xb1, 0x19, 0xba, 0xba, 0x71, 0x1a, 0x66, 0x87, 0xfc, 0xc8, 0x82, 0x8d, 0x20, 0x32, 0xef ], [ 0xfb, 0x0d, 0x27, 0xad, 0xd7, 0x00, 0x9d, 0xb0, 0x6d, 0xb5, 0x57, 0xc8, 0x57, 0x10, 0x09, 0x1e, 0xd8, 0xe3, 0xcf, 0xe5, 0xbe, 0x41, 0x8b, 0xe0, 0x61, 0x36, 0x26, 0xb9, 0x50, 0x11, 0x47, 0x55 ], [ 0xba, 0xdf, 0x40, 0x8b, 0xc9, 0xa6, 0xc2, 0xd4, 0x3a, 0x5d, 0xbf, 0xd6, 0x41, 0xc2, 0x24, 0x96, 0x5b, 0xfd, 0x56, 0x0e, 0xac, 0x91, 0x72, 0x91, 0x97, 0xb7, 0x20, 0x54, 0x80, 0x06, 0x74, 0x1c ], [ 0x8b, 0x6a, 0x27, 0x67, 0xa2, 0xd4, 0x76, 0x12, 0x2c, 0xac, 0x5b, 0xfd, 0xcf, 0xf0, 0x44, 0xf3, 0x16, 0xeb, 0x2e, 0x1c, 0xcb, 0x02, 0x66, 0xf5, 0x96, 0xb9, 0x94, 0x79, 0x3c, 0x8c, 0x65, 0x32 ], [ 0x19, 0x1f, 0xf1, 0x78, 0xe8, 0x21, 0x7e, 0xf1, 0x1d, 0x24, 0x57, 0x95, 0xe4, 0x48, 0xdb, 0x51, 0x68, 0xf2, 0xe9, 0xdb, 0x18, 0x4c, 0xbe, 0x09, 0x83, 0xcf, 0x06, 0x6c, 0x40, 0x8f, 0x2c, 0x8e ], [ 0x0c, 0x40, 0xb0, 0xb4, 0xe5, 0x33, 0x7f, 0x8c, 0x6f, 0xed, 0x30, 0x2f, 0x05, 0x18, 0x28, 0xa3, 0x53, 0x11, 0xb6, 0x58, 0x02, 0xbe, 0x92, 0x0e, 0xfa, 0x46, 0x8a, 0x59, 0x8e, 0x18, 0x17, 0x5d ], [ 0x30, 0xee, 0x20, 0x84, 0xaa, 0xda, 0xfe, 0xd9, 0x74, 0xda, 0xda, 0x9b, 0x39, 0x57, 0x78, 0xc4, 0x07, 0xef, 0xd9, 0x90, 0x2c, 0x4c, 0x30, 0xbc, 0x95, 0xe2, 0x86, 0xae, 0x30, 0xea, 0x28, 0x66 ], [ 0x07, 0x00, 0xf9, 0x06, 0x2e, 0xce, 0x9f, 0xc6, 0xfe, 0x38, 0xe4, 0x46, 0x3f, 0x24, 0x8a, 0x41, 0x30, 0xa1, 0x29, 0x21, 0x94, 0x80, 0xf9, 0xca, 0xaf, 0x4e, 0x5a, 0xc0, 0x8f, 0xd4, 0x7e, 0x8f ], [ 0xe5, 0xc8, 0xb5, 0xc9, 0x9a, 0x39, 0x4c, 0x5f, 0xa9, 0x4d, 0x3b, 0xc3, 0xfb, 0x9b, 0x34, 0xe3, 0x3a, 0x95, 0xe1, 0x49, 0x4a, 0x59, 0xf8, 0x2a, 0xf7, 0xf3, 0xdc, 0xaf, 0x8b, 0xe2, 0x69, 0x03 ], [ 0x6a, 0xb0, 0x0f, 0x3f, 0x79, 0x57, 0x7c, 0x1d, 0xa7, 0xa7, 0x66, 0xe0, 0xe5, 0x96, 0x52, 0x09, 0x51, 0x8a, 0xde, 0x87, 0x13, 0x0e, 0x28, 0x8c, 0x78, 0x99, 0xf6, 0x00, 0x3c, 0x8e, 0x25, 0xe0 ], [ 0x4b, 0xaa, 0xe5, 0xa5, 0x19, 0x4e, 0xa7, 0xb0, 0x00, 0xbe, 0x20, 0x94, 0x3b, 0x08, 0xe8, 0xa4, 0x32, 0x74, 0xc6, 0x47, 0x62, 0xf4, 0x86, 0x05, 0x3b, 0x93, 0xfd, 0x2d, 0x53, 0x59, 0x59, 0x61 ], [ 0x56, 0xf7, 0x5a, 0x34, 0x0c, 0xad, 0x8b, 0x53, 0xda, 0xbd, 0xb5, 0xcf, 0xaf, 0x94, 0xd7, 0x83, 0xfa, 0xbc, 0xa1, 0x91, 0x5c, 0x97, 0x20, 0x8c, 0x6a, 0xe0, 0x5c, 0xe5, 0xa1, 0xbe, 0x1c, 0xf9 ], [ 0xf1, 0x81, 0x89, 0x75, 0xf8, 0x1e, 0xfc, 0xc3, 0x0a, 0xf5, 0x8f, 0xbe, 0x01, 0xc2, 0x28, 0x3c, 0x2f, 0xb8, 0x36, 0xf4, 0x1e, 0x9d, 0xb5, 0xdc, 0x66, 0x95, 0xc0, 0x9c, 0xbd, 0x43, 0xdc, 0x01 ], [ 0x51, 0x0f, 0xc8, 0xbf, 0x09, 0x43, 0xa1, 0xe7, 0x09, 0x69, 0xa0, 0x4e, 0xda, 0x28, 0x8e, 0xf9, 0xfc, 0xdb, 0x2a, 0x4b, 0x86, 0x7e, 0xf4, 0x22, 0x31, 0xe4, 0xf5, 0xda, 0xc2, 0x7a, 0xcb, 0x68 ], [ 0x78, 0x65, 0x38, 0xd1, 0x7c, 0x9f, 0x31, 0xc6, 0x54, 0xe2, 0x00, 0x93, 0xa9, 0x44, 0xe2, 0xe7, 0x28, 0x5d, 0x58, 0x3c, 0x56, 0x3c, 0x39, 0x88, 0xe9, 0xa4, 0xcc, 0xe3, 0x9b, 0x18, 0xff, 0x50 ], [ 0x8c, 0x37, 0x7b, 0x5c, 0xdb, 0x03, 0xb6, 0xf4, 0x22, 0xfa, 0x76, 0x1d, 0xd2, 0xe2, 0x1c, 0x69, 0x4a, 0xe7, 0x7d, 0x53, 0x6e, 0xd9, 0x5d, 0x35, 0x46, 0xda, 0x9b, 0x13, 0xbf, 0xac, 0xb1, 0x4e ], [ 0x9e, 0x55, 0x11, 0x21, 0x99, 0x1f, 0x1c, 0x22, 0xf8, 0x16, 0x89, 0xbf, 0x42, 0x69, 0xfd, 0x97, 0xce, 0x5b, 0xce, 0xe7, 0xbd, 0x45, 0x7b, 0x9a, 0x74, 0x45, 0xae, 0x51, 0x73, 0xa0, 0x78, 0x4c ], [ 0x16, 0x64, 0xe8, 0xe2, 0xb9, 0xf1, 0xc2, 0xbf, 0x86, 0x98, 0x7a, 0xae, 0xe4, 0xb3, 0xc3, 0x7a, 0xa4, 0xbb, 0x24, 0x54, 0x24, 0x12, 0x40, 0xa5, 0x80, 0x8d, 0x45, 0x9c, 0x34, 0x2e, 0x5e, 0x67 ], [ 0xa0, 0xb3, 0xed, 0xcf, 0xd2, 0xbc, 0x4b, 0x6d, 0xe6, 0x55, 0x32, 0x93, 0x45, 0x29, 0xd8, 0x15, 0xf7, 0xce, 0xad, 0xdc, 0xb4, 0x64, 0x7f, 0x06, 0x69, 0xac, 0x0f, 0x93, 0xea, 0xab, 0xa4, 0xe1 ], [ 0xa0, 0xc5, 0x4e, 0xba, 0xd2, 0x78, 0xee, 0x52, 0x29, 0xbc, 0xf9, 0x97, 0x26, 0x15, 0x89, 0xef, 0xd7, 0x72, 0x2b, 0xdf, 0xd8, 0x9d, 0xeb, 0x03, 0x1c, 0x11, 0x54, 0xe6, 0x50, 0xee, 0xd0, 0x6c ], [ 0xe6, 0x07, 0xcd, 0x33, 0x36, 0x9b, 0xbf, 0x87, 0x48, 0xa6, 0xa6, 0xfa, 0x93, 0x59, 0xe4, 0x87, 0xe4, 0x16, 0x09, 0x50, 0x45, 0xce, 0x2c, 0xbc, 0xce, 0x46, 0xbb, 0xed, 0xa6, 0x4c, 0xf1, 0xd6 ], [ 0x1f, 0x92, 0x49, 0x68, 0xc0, 0x02, 0x07, 0x93, 0xe5, 0x57, 0x8d, 0x71, 0xb0, 0x76, 0x3c, 0x7e, 0x46, 0x93, 0xd5, 0x64, 0x8e, 0x91, 0x92, 0xaa, 0x21, 0x05, 0x12, 0x47, 0xa9, 0xdf, 0x71, 0x3d ], [ 0x2d, 0x86, 0x57, 0x2c, 0xfb, 0x63, 0xcb, 0x0c, 0x7e, 0x38, 0xe0, 0x31, 0x5a, 0x71, 0x59, 0xd8, 0x98, 0x54, 0x2b, 0x7c, 0x35, 0xd2, 0x09, 0xc2, 0xb7, 0x63, 0xc0, 0xf4, 0x57, 0x7a, 0x85, 0xa4 ], [ 0xa5, 0xcd, 0x1f, 0xbc, 0x64, 0x56, 0x09, 0x54, 0x1c, 0x77, 0x7e, 0xab, 0xdb, 0x14, 0x25, 0xb6, 0x43, 0xe2, 0xac, 0xbe, 0xd1, 0x2f, 0x7e, 0x04, 0xdd, 0x17, 0x87, 0x65, 0xc9, 0x6a, 0x8f, 0xe5 ], [ 0x38, 0x64, 0x33, 0x98, 0x09, 0x3d, 0x79, 0x79, 0xb7, 0x20, 0x21, 0x00, 0x4e, 0x94, 0xeb, 0x92, 0x8a, 0xa8, 0x29, 0x15, 0xf0, 0x52, 0xc5, 0xdc, 0x44, 0xd0, 0x22, 0xf4, 0x98, 0x2b, 0xa0, 0x59 ], [ 0x91, 0x62, 0xa2, 0x10, 0x9d, 0xe3, 0xb6, 0xcc, 0x07, 0xef, 0x8c, 0xa7, 0x51, 0x29, 0xb4, 0x66, 0x03, 0x1b, 0x45, 0xd4, 0xb6, 0x47, 0x6b, 0x79, 0x45, 0xfa, 0x11, 0x29, 0x33, 0x9e, 0xca, 0xb5 ], [ 0xd0, 0x46, 0x6e, 0x1d, 0xa9, 0x46, 0x51, 0x5e, 0x65, 0x72, 0xc3, 0x35, 0x9b, 0x2f, 0x0a, 0xa9, 0x94, 0x21, 0x3d, 0xb1, 0xc8, 0x78, 0xa4, 0x82, 0x8e, 0x08, 0xa8, 0x8f, 0x4b, 0x18, 0xaf, 0xaf ], [ 0x3d, 0x05, 0x5f, 0x21, 0xe3, 0xb3, 0x63, 0xf7, 0x70, 0xe9, 0x51, 0x4b, 0x9b, 0xbe, 0x4f, 0xb5, 0x2a, 0x4c, 0x96, 0x32, 0x19, 0xdc, 0x70, 0x33, 0x3b, 0x24, 0x09, 0x6c, 0x6d, 0x46, 0x43, 0x95 ], [ 0x11, 0x12, 0xb6, 0x9e, 0x11, 0x86, 0x32, 0xf3, 0x48, 0x70, 0x26, 0x5f, 0xec, 0xef, 0xa0, 0xb7, 0xee, 0x0e, 0xec, 0x2b, 0x65, 0x51, 0xff, 0xd3, 0x6a, 0x8e, 0xde, 0x26, 0x9c, 0x1c, 0x2a, 0xb7 ], [ 0xde, 0x0e, 0x7d, 0xf7, 0xee, 0x6a, 0xb1, 0xf1, 0xf4, 0x70, 0x8c, 0x9a, 0x7f, 0x17, 0x95, 0x10, 0x15, 0x7c, 0xa6, 0x20, 0x63, 0x1e, 0x76, 0x2b, 0xa6, 0x9c, 0xbd, 0xfb, 0xf3, 0x50, 0x9a, 0xed ], [ 0x65, 0x2c, 0x40, 0x27, 0x3b, 0x2f, 0xb4, 0xf5, 0xeb, 0x86, 0x81, 0xfc, 0xe6, 0xff, 0x79, 0x59, 0x06, 0x7e, 0xb9, 0xd3, 0xbf, 0x7a, 0x16, 0x71, 0x07, 0x2c, 0x21, 0xc9, 0x52, 0x42, 0x43, 0xd9 ], [ 0x22, 0x49, 0x0f, 0x0c, 0x1f, 0x57, 0x82, 0x68, 0x1e, 0x20, 0x96, 0x86, 0x08, 0x2a, 0x22, 0xea, 0x76, 0xdd, 0x5e, 0x13, 0x46, 0x28, 0x5b, 0x56, 0x58, 0xbf, 0xd7, 0x88, 0xc7, 0xee, 0x0f, 0x4c ], [ 0xe5, 0x7b, 0xad, 0x71, 0x73, 0xc8, 0xe5, 0xcc, 0x7f, 0x43, 0x0a, 0x6b, 0x7e, 0x76, 0x85, 0xb6, 0xa3, 0x62, 0xb8, 0xea, 0x49, 0x79, 0x1d, 0x9d, 0x71, 0x01, 0x78, 0x27, 0x6d, 0x5e, 0x36, 0x95 ], [ 0x1d, 0x69, 0x1f, 0x56, 0xd7, 0xa5, 0x42, 0x55, 0x95, 0x0c, 0x4d, 0xf1, 0xcb, 0xd8, 0x61, 0x1d, 0x2a, 0x45, 0xf9, 0x02, 0x54, 0xba, 0x3f, 0x5d, 0xe8, 0xcc, 0xe7, 0x03, 0xf0, 0xeb, 0x9e, 0xdc ], [ 0x41, 0xa8, 0xff, 0x28, 0x85, 0x86, 0x38, 0x91, 0xc6, 0x11, 0x28, 0xe1, 0x21, 0x5d, 0x3a, 0x19, 0x43, 0x84, 0x81, 0x52, 0x35, 0x0f, 0x6a, 0x88, 0x18, 0x10, 0x58, 0x34, 0x63, 0x11, 0x0b, 0x9e ], [ 0x2c, 0x67, 0x06, 0x35, 0xda, 0x30, 0x41, 0x40, 0xa3, 0xf9, 0xf1, 0xb6, 0x88, 0x40, 0xa4, 0x13, 0xbf, 0xa4, 0xf2, 0xc7, 0x0c, 0x39, 0x26, 0xe7, 0xf3, 0xdc, 0x22, 0x3d, 0x33, 0x41, 0x9a, 0x2d ], [ 0x1f, 0xbd, 0x95, 0xf2, 0x61, 0xe4, 0x50, 0x99, 0xf8, 0xef, 0x7d, 0x98, 0xa3, 0x5b, 0xb7, 0xfa, 0x45, 0x0f, 0x01, 0x05, 0x4a, 0x68, 0x1e, 0x07, 0x72, 0xcb, 0x35, 0x71, 0xd5, 0xb1, 0x64, 0x30 ], [ 0x5b, 0x2a, 0xe9, 0xd5, 0xa8, 0x82, 0x38, 0xb6, 0x1d, 0x09, 0xe0, 0x9b, 0x40, 0x28, 0x8a, 0xd7, 0xe6, 0xd0, 0x4a, 0xb4, 0x8c, 0xe7, 0x33, 0x57, 0x1e, 0x2e, 0x66, 0xd3, 0xac, 0x8b, 0xea, 0xb4 ], [ 0xe1, 0x7e, 0xfd, 0xce, 0xee, 0x7f, 0xee, 0xce, 0x1f, 0x0f, 0x99, 0xc3, 0x6c, 0x2d, 0x40, 0x6d, 0x0f, 0xd3, 0x21, 0x04, 0x25, 0x48, 0xb8, 0xa8, 0xcd, 0x47, 0xc3, 0x08, 0x5e, 0x5e, 0x43, 0x3d ], [ 0x1d, 0xe3, 0x47, 0x05, 0x90, 0x62, 0x95, 0xde, 0xcf, 0x89, 0x03, 0x3d, 0x95, 0xef, 0xb5, 0x1b, 0x97, 0xbb, 0x94, 0xe1, 0xcc, 0xf4, 0xbd, 0x71, 0xd0, 0x55, 0x4f, 0x76, 0x95, 0x27, 0x52, 0x46 ], [ 0x5d, 0x59, 0x9e, 0x39, 0x57, 0xbf, 0x95, 0xed, 0x6a, 0x10, 0xfe, 0x8a, 0x5a, 0x58, 0x5f, 0xd6, 0xe1, 0xfa, 0x89, 0x27, 0xa3, 0x63, 0x92, 0x27, 0xee, 0x47, 0x24, 0xae, 0x68, 0xca, 0x7b, 0x1e ], [ 0x07, 0x63, 0x62, 0xc7, 0xf5, 0x29, 0x3e, 0x9e, 0x8f, 0x42, 0x12, 0xdf, 0xea, 0xdf, 0xdd, 0x5f, 0xd4, 0xb4, 0x34, 0x70, 0xc4, 0x02, 0x91, 0x0a, 0x44, 0x1e, 0x8e, 0x59, 0x68, 0x46, 0x6a, 0x4b ], [ 0x73, 0x56, 0x1f, 0x50, 0x17, 0x2c, 0xf7, 0x49, 0x1d, 0xbf, 0x7e, 0x57, 0x99, 0x02, 0x20, 0x78, 0x31, 0xb7, 0xb4, 0xa0, 0x3e, 0xf8, 0x8a, 0x83, 0x59, 0x7c, 0x73, 0xfc, 0x48, 0x68, 0xec, 0xcd ], [ 0x0f, 0x1d, 0x8d, 0xe3, 0x32, 0x15, 0x29, 0x26, 0x38, 0x72, 0x83, 0x74, 0xe6, 0x40, 0xf0, 0xa3, 0x9a, 0x17, 0x17, 0x21, 0xd4, 0xf1, 0x80, 0x0b, 0x79, 0xca, 0xaa, 0xe9, 0x23, 0xaf, 0x80, 0xff ], [ 0x7e, 0xbf, 0x72, 0x3a, 0x6b, 0xeb, 0xdd, 0xba, 0xbd, 0x9d, 0xe7, 0x15, 0x6f, 0x34, 0x21, 0x25, 0x8e, 0xdb, 0x9c, 0xa5, 0x6e, 0x40, 0x27, 0xb3, 0x7c, 0x95, 0xf5, 0xb9, 0x4a, 0x98, 0x59, 0x3e ], [ 0xe9, 0xbe, 0x27, 0xb1, 0x0c, 0x70, 0x7e, 0x79, 0x4e, 0x8f, 0x8d, 0x0b, 0x74, 0xc5, 0xdd, 0xb0, 0x7c, 0x77, 0x57, 0x1b, 0xd3, 0xe1, 0xd9, 0x59, 0x2e, 0x8e, 0xc7, 0xff, 0xbb, 0x18, 0x64, 0x44 ], [ 0x99, 0x4a, 0xf7, 0x37, 0xb1, 0xd3, 0x07, 0x6e, 0x6d, 0xfc, 0x4c, 0xee, 0x6f, 0x19, 0x77, 0x9b, 0xaf, 0xc7, 0xd4, 0x9b, 0x54, 0x24, 0x34, 0xa5, 0x42, 0x1c, 0x8e, 0xc9, 0xa8, 0xad, 0x78, 0xf9 ], [ 0x77, 0x13, 0xec, 0x1f, 0x80, 0x4d, 0x16, 0x69, 0x03, 0xbd, 0x0b, 0xb7, 0x22, 0xd4, 0x42, 0x14, 0x8d, 0x6f, 0x0d, 0x1e, 0x6a, 0xfd, 0xe7, 0x0c, 0x13, 0x38, 0x9f, 0x14, 0xc6, 0xe6, 0x54, 0x75 ], [ 0xf9, 0x7f, 0xb1, 0xc1, 0xdb, 0x5e, 0x6a, 0x75, 0x01, 0x09, 0x71, 0xd0, 0x2c, 0x45, 0x81, 0x75, 0x98, 0x1d, 0xaa, 0xd7, 0x82, 0xd5, 0x15, 0x2f, 0x09, 0x26, 0x5b, 0x69, 0xa2, 0xa9, 0x27, 0xdc ], [ 0xcb, 0x07, 0x42, 0xe1, 0x1c, 0xbc, 0x49, 0xa1, 0x43, 0x79, 0xc7, 0xd3, 0x4d, 0x0f, 0x18, 0x1e, 0x52, 0xaa, 0x56, 0xfa, 0x3a, 0xed, 0xe8, 0x70, 0xfb, 0x30, 0x7d, 0xb5, 0x50, 0xcd, 0x28, 0x15 ], [ 0x6a, 0x02, 0xdb, 0x70, 0x4d, 0xd9, 0x37, 0x39, 0xc0, 0xa5, 0x36, 0xf1, 0x8f, 0x9a, 0xcc, 0x13, 0x48, 0x15, 0xae, 0xc3, 0x2f, 0x5d, 0x0d, 0x8c, 0x2d, 0xfe, 0xd1, 0x96, 0x8a, 0xfa, 0x1d, 0xd5 ], [ 0x14, 0x29, 0x79, 0xca, 0x70, 0xe1, 0x72, 0x53, 0x22, 0xaf, 0x45, 0x22, 0xca, 0x85, 0xa0, 0x15, 0x8a, 0x57, 0x2c, 0xb3, 0x86, 0xd2, 0x5a, 0x80, 0x22, 0x69, 0x2b, 0x7c, 0xe1, 0xb7, 0x4b, 0xac ], [ 0x33, 0xf2, 0xf5, 0xc1, 0xce, 0xee, 0xbe, 0x60, 0x3a, 0xae, 0xa4, 0x64, 0x0b, 0xcc, 0x0b, 0x4d, 0x49, 0x9c, 0x46, 0x45, 0x8d, 0x6b, 0xab, 0xf5, 0xd2, 0x17, 0x40, 0x89, 0x0f, 0xd0, 0x89, 0x44 ], [ 0xec, 0x7d, 0x3b, 0x09, 0x25, 0x71, 0xc3, 0x05, 0xc6, 0x9c, 0x81, 0xc8, 0x40, 0x40, 0xc5, 0xfc, 0xf3, 0xb0, 0x79, 0xb0, 0x5c, 0x3e, 0xab, 0xde, 0x9d, 0x23, 0x47, 0xc5, 0xb6, 0x92, 0x37, 0x1a ], [ 0x11, 0x7e, 0xf2, 0x41, 0xa4, 0x38, 0x42, 0xab, 0x8a, 0xec, 0x22, 0x25, 0xcd, 0xb7, 0x6a, 0xa5, 0x4c, 0xee, 0x1a, 0xe7, 0x93, 0x39, 0x5d, 0x28, 0xfa, 0x56, 0xf5, 0x97, 0x84, 0xba, 0xd4, 0xf1 ], [ 0x24, 0x48, 0x13, 0x4e, 0x49, 0xbd, 0xef, 0x62, 0x28, 0x63, 0xb2, 0x76, 0xad, 0x08, 0xd3, 0x6e, 0x15, 0x3b, 0xbc, 0xe1, 0xc5, 0xac, 0x68, 0x6d, 0xe0, 0xf6, 0x3e, 0xf8, 0x4c, 0x01, 0x33, 0xed ], [ 0xd4, 0xfc, 0x14, 0xd7, 0x59, 0x60, 0xcf, 0xbd, 0x10, 0xae, 0x1c, 0xb1, 0x73, 0xdd, 0x9f, 0x33, 0x69, 0xc9, 0x60, 0x84, 0x1a, 0x98, 0x8c, 0x9b, 0x2a, 0x5c, 0x07, 0xea, 0x75, 0xb7, 0xc6, 0x1f ], [ 0xd0, 0xab, 0x93, 0x4b, 0x52, 0x35, 0x10, 0xd2, 0x6c, 0x11, 0x91, 0xa7, 0x4a, 0x7b, 0xc4, 0xa0, 0xca, 0x4d, 0x02, 0xab, 0xa7, 0xd1, 0x7e, 0xae, 0xfc, 0x07, 0xe4, 0x2a, 0xac, 0xc7, 0x53, 0x20 ], [ 0xad, 0xe8, 0x2a, 0xec, 0xcf, 0x5c, 0xff, 0x68, 0x50, 0x0b, 0x20, 0xa0, 0x53, 0x6f, 0xcc, 0x3e, 0x44, 0x7d, 0x4c, 0x84, 0x3a, 0xf1, 0x6a, 0x4e, 0xdd, 0x6e, 0x3d, 0xd4, 0x9b, 0xb8, 0xfc, 0x22 ], [ 0x7a, 0xcc, 0xb5, 0xb2, 0x92, 0xa6, 0x1f, 0x15, 0x0e, 0x5c, 0x2e, 0x83, 0x87, 0x88, 0x19, 0xd7, 0xd3, 0xfe, 0xcf, 0x8d, 0xd1, 0xbe, 0x6c, 0x7e, 0xae, 0x42, 0xaa, 0x06, 0x02, 0xbb, 0x1a, 0x34 ], [ 0x49, 0xbe, 0xc7, 0xe7, 0x69, 0x20, 0xb8, 0xa2, 0xa2, 0xc0, 0x75, 0xaa, 0xb3, 0x56, 0x98, 0x6c, 0x84, 0x69, 0x4f, 0x69, 0x6d, 0x5a, 0x07, 0xbd, 0x78, 0x1e, 0x60, 0x5f, 0x00, 0x40, 0x5b, 0xd6 ], [ 0x10, 0x38, 0x41, 0x2a, 0x0a, 0x44, 0xc3, 0xbe, 0x99, 0xfb, 0x4c, 0x19, 0xc2, 0x57, 0x22, 0x5d, 0x27, 0xf6, 0xf3, 0x32, 0x66, 0xf8, 0x7d, 0xc8, 0x01, 0xa2, 0x4c, 0xa6, 0xb8, 0x72, 0xfe, 0x41 ], [ 0x5a, 0xdb, 0x62, 0x28, 0xa0, 0xe5, 0xb1, 0x77, 0xbe, 0x82, 0x8b, 0x4f, 0x9c, 0xc9, 0xca, 0x2e, 0x1b, 0x57, 0x41, 0xe5, 0x32, 0x8b, 0x61, 0x34, 0xda, 0x08, 0x1f, 0xc6, 0xee, 0x0d, 0x3d, 0x4f ], [ 0xd4, 0x33, 0x05, 0x25, 0xcc, 0x89, 0x7e, 0xc4, 0xd6, 0xfa, 0x57, 0xc7, 0x3a, 0x02, 0x81, 0xf9, 0xf9, 0x13, 0xb7, 0x95, 0x94, 0x3c, 0xa6, 0x18, 0xd9, 0x32, 0x7a, 0xf4, 0xef, 0x96, 0x63, 0xee ], [ 0x1e, 0x43, 0x8f, 0x84, 0xd7, 0x89, 0xe1, 0x4a, 0xcf, 0xee, 0x30, 0x31, 0xc8, 0xf4, 0x2c, 0x03, 0x24, 0x5f, 0x66, 0x15, 0x89, 0x52, 0x36, 0x88, 0xe6, 0x81, 0x6a, 0x21, 0x9a, 0x4a, 0xf3, 0xb4 ], [ 0x8c, 0x0d, 0xb6, 0x3b, 0xbd, 0x42, 0x60, 0xb2, 0xba, 0x8b, 0x01, 0x63, 0x42, 0xb3, 0xa3, 0x57, 0x72, 0x97, 0x82, 0x41, 0x02, 0x49, 0xf5, 0xf0, 0x26, 0x5c, 0x60, 0xce, 0xc6, 0x1a, 0xbf, 0xd6 ], [ 0x6f, 0xba, 0xba, 0xb7, 0xb6, 0x68, 0xb2, 0x0b, 0x2f, 0xd1, 0xef, 0xe4, 0xa2, 0x67, 0x31, 0xc9, 0x1b, 0xdf, 0xbc, 0x0e, 0x58, 0xb3, 0x8a, 0xd2, 0x96, 0xd6, 0x8e, 0x7a, 0xd9, 0x51, 0xab, 0x9c ], [ 0x41, 0x58, 0xb9, 0xb1, 0x22, 0xdb, 0x41, 0xc9, 0x62, 0x0d, 0x5c, 0x8b, 0x50, 0xfe, 0x0f, 0x81, 0x30, 0x79, 0x06, 0x2f, 0x68, 0x53, 0x46, 0x7e, 0x5f, 0x75, 0x5e, 0x6b, 0xa9, 0x29, 0xb6, 0xb8 ], [ 0x54, 0x1f, 0x41, 0x34, 0x88, 0x30, 0xe7, 0x53, 0x94, 0x1f, 0xae, 0xed, 0x1e, 0xed, 0x94, 0x21, 0x73, 0xbf, 0xf4, 0xdd, 0x94, 0x15, 0x5e, 0x1c, 0xaf, 0x7a, 0xd8, 0xfc, 0xc2, 0x37, 0x83, 0x38 ], [ 0x7e, 0x1d, 0xa4, 0x18, 0xe5, 0xff, 0x44, 0xeb, 0xe1, 0x86, 0x56, 0xfc, 0x57, 0x1b, 0x57, 0x61, 0x7f, 0x69, 0x12, 0x46, 0xb8, 0x67, 0x4d, 0x0b, 0x06, 0xb0, 0xd2, 0x57, 0x57, 0xd8, 0xd7, 0xd1 ], [ 0x7d, 0x73, 0x00, 0x7f, 0x33, 0x39, 0x72, 0x0f, 0xe1, 0xe7, 0x2c, 0x4c, 0x2e, 0x59, 0xd8, 0x5a, 0x15, 0x18, 0x35, 0x98, 0xc5, 0x91, 0x7f, 0x2a, 0x44, 0x95, 0xbd, 0x9b, 0x2e, 0xdd, 0x5e, 0x0c ], [ 0x61, 0xce, 0xd0, 0x09, 0x8f, 0x96, 0x1b, 0xae, 0x4d, 0x3d, 0xa7, 0x49, 0x24, 0xf2, 0x1c, 0x11, 0x46, 0xd2, 0x74, 0x69, 0x0b, 0x8a, 0x8f, 0xf7, 0xd5, 0xa4, 0xef, 0xc3, 0xeb, 0xd3, 0x66, 0xb0 ], [ 0x17, 0x64, 0x9c, 0x6b, 0xef, 0x80, 0xa4, 0x87, 0xfc, 0x36, 0x84, 0x9d, 0x25, 0x1f, 0x4e, 0xb8, 0x8d, 0x83, 0x23, 0x24, 0x18, 0x55, 0x4f, 0x28, 0x2f, 0x28, 0x91, 0xbd, 0x5f, 0xbc, 0x25, 0x4e ], [ 0x26, 0xfc, 0x5d, 0x9e, 0xaf, 0x3f, 0xe0, 0x7f, 0xa1, 0x21, 0xb2, 0x1b, 0x81, 0x51, 0xce, 0xfc, 0xf8, 0xb6, 0x51, 0x1c, 0xc5, 0xcd, 0xc2, 0x0a, 0xe6, 0xd2, 0xc1, 0xf7, 0x6f, 0x90, 0x99, 0x0b ], [ 0xaa, 0xcf, 0x2b, 0xa4, 0xb0, 0x2d, 0xca, 0xfd, 0xa3, 0x14, 0x35, 0xfc, 0x9a, 0x01, 0xd9, 0x23, 0xd2, 0x29, 0x91, 0x4a, 0xdb, 0x47, 0x92, 0x04, 0x0e, 0xdf, 0xfe, 0x22, 0x37, 0xfa, 0x3e, 0x18 ], [ 0x84, 0xdb, 0x05, 0x92, 0xc3, 0xae, 0xf2, 0xfa, 0x25, 0x17, 0xf3, 0xbb, 0xcc, 0x4f, 0x40, 0xe9, 0xf1, 0xf8, 0x04, 0x40, 0x44, 0x0d, 0xec, 0x26, 0x87, 0x03, 0xbd, 0x41, 0x58, 0x1b, 0xdf, 0x1a ], [ 0xcd, 0xbe, 0x35, 0xd4, 0xbb, 0xfc, 0xbf, 0x06, 0xcf, 0xef, 0xb1, 0x40, 0xbe, 0x14, 0x9a, 0x8b, 0x48, 0x2f, 0x3e, 0xd5, 0x6c, 0x76, 0xc0, 0x56, 0xa2, 0xf9, 0xe7, 0xc3, 0x37, 0x31, 0xfd, 0x64 ], [ 0x2b, 0x08, 0xd7, 0x66, 0x36, 0x53, 0xb0, 0xc8, 0x0a, 0x29, 0xec, 0x44, 0x3a, 0x95, 0x84, 0x1c, 0x93, 0x4f, 0x3d, 0x0f, 0xe6, 0x65, 0xe5, 0x20, 0xee, 0xa2, 0x86, 0xd9, 0xf8, 0x0a, 0x6a, 0xef ], [ 0x46, 0xbb, 0xf8, 0xde, 0x6f, 0x76, 0xf7, 0x7e, 0x38, 0x2e, 0xbb, 0x9e, 0xfe, 0x21, 0xf8, 0x1d, 0xa5, 0xd4, 0x13, 0x93, 0xa8, 0xe8, 0xea, 0xa3, 0xf6, 0x88, 0x51, 0x24, 0xa8, 0x61, 0x79, 0x52 ], [ 0xf0, 0xb0, 0xcf, 0x67, 0x46, 0x2f, 0xe5, 0x3f, 0xf2, 0xed, 0x31, 0x6d, 0x65, 0x42, 0x36, 0xf1, 0xe9, 0x0f, 0x5c, 0x98, 0x6b, 0x30, 0x2d, 0x4f, 0x96, 0xcb, 0x3e, 0x8b, 0xc5, 0x3b, 0x4c, 0x4d ], [ 0xf5, 0x33, 0x26, 0xa1, 0x6c, 0x1c, 0xb4, 0xa0, 0xca, 0x9d, 0x46, 0xa5, 0x07, 0x27, 0xf1, 0xc4, 0x5f, 0x5f, 0xa0, 0xde, 0xe6, 0x1f, 0x2c, 0xd4, 0x90, 0xc1, 0x7d, 0xf9, 0xf9, 0x7c, 0x67, 0x20 ], [ 0x94, 0x3b, 0x05, 0xe2, 0x9e, 0x87, 0xab, 0xec, 0x1d, 0x51, 0xe5, 0x5e, 0x5f, 0x53, 0xc5, 0xa1, 0x02, 0x8f, 0x4e, 0x51, 0x35, 0xad, 0x91, 0x8a, 0xce, 0xd4, 0x3e, 0xe6, 0x06, 0x95, 0xef, 0x7c ], [ 0x2b, 0xd2, 0xc3, 0x07, 0x62, 0x18, 0xf8, 0x52, 0x65, 0x7c, 0xde, 0xc0, 0x0c, 0x17, 0x17, 0xc5, 0x33, 0x3e, 0x4b, 0x6f, 0xf3, 0x3f, 0x2b, 0xcd, 0x24, 0xff, 0xca, 0x33, 0xad, 0xfe, 0x8c, 0x0d ], [ 0x52, 0x78, 0xb5, 0x7d, 0x46, 0xe3, 0x46, 0xed, 0xab, 0xb9, 0x2e, 0x9c, 0x13, 0x62, 0x4b, 0xb9, 0xa6, 0x9f, 0xbd, 0x13, 0x8a, 0x31, 0xb7, 0xb7, 0xc5, 0xd6, 0x7f, 0x91, 0x23, 0x22, 0xeb, 0x39 ], [ 0xc9, 0xdd, 0x00, 0xa2, 0xac, 0x68, 0xdc, 0x3e, 0x61, 0xd5, 0xdc, 0x51, 0xde, 0xed, 0xea, 0xbf, 0x56, 0xb5, 0x77, 0xdd, 0x24, 0x58, 0x03, 0xd5, 0x66, 0xc0, 0xc9, 0x66, 0xd5, 0x3b, 0xa9, 0x98 ], [ 0x1f, 0x38, 0xdb, 0x44, 0x0c, 0x4b, 0xc5, 0xcd, 0x86, 0x6c, 0x29, 0xf6, 0x8f, 0x5b, 0x93, 0x74, 0xdc, 0xe3, 0xca, 0x32, 0xa5, 0xfd, 0x27, 0x1c, 0xd7, 0xab, 0x41, 0x37, 0x70, 0xc1, 0x81, 0xea ], [ 0xc7, 0xc1, 0x54, 0x5a, 0x77, 0x2e, 0x19, 0x6c, 0xd6, 0x95, 0x3c, 0x41, 0x06, 0x56, 0xea, 0x4a, 0x48, 0xbe, 0x54, 0xa4, 0x1b, 0x07, 0x45, 0x6c, 0x1c, 0x89, 0x17, 0xd8, 0x1c, 0xa1, 0xb8, 0x30 ], [ 0xbb, 0x9d, 0xdc, 0xf4, 0x17, 0xaf, 0xc2, 0x57, 0x02, 0xcc, 0x53, 0x39, 0x52, 0xc6, 0x5f, 0xd8, 0xfd, 0xb7, 0xec, 0x85, 0xe7, 0xd3, 0xb4, 0x07, 0xf8, 0x51, 0xb5, 0x1e, 0x5d, 0xc9, 0xa4, 0xfb ], [ 0xe3, 0x3c, 0x52, 0x51, 0x4c, 0xd3, 0x01, 0x53, 0xce, 0xf8, 0xd9, 0x63, 0x65, 0x19, 0xa9, 0xc3, 0x48, 0x17, 0x01, 0x82, 0xe2, 0xa6, 0x47, 0x8d, 0xd4, 0x88, 0x7a, 0x8d, 0x53, 0x6f, 0x0f, 0x45 ], [ 0x63, 0xa9, 0x8f, 0x17, 0x8b, 0xe8, 0x56, 0x88, 0xa8, 0xa5, 0xce, 0x00, 0xb2, 0x5b, 0xf0, 0x8a, 0x97, 0x2d, 0x34, 0xec, 0xe9, 0x5c, 0x69, 0x47, 0x26, 0x0e, 0x6e, 0x44, 0xfd, 0xba, 0xa3, 0x57 ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" plain_texts1_128bit = [ [ 0x07, 0xf2, 0xc2, 0xd4, 0xe6, 0xdb, 0x6e, 0x12, 0x00, 0xbc, 0x16, 0x5d, 0x15, 0x4e, 0x06, 0x98 ], [ 0x32, 0x14, 0x75, 0xac, 0x6a, 0xa0, 0x57, 0x12, 0x55, 0x4d, 0x35, 0xa0, 0xa9, 0x6a, 0x92, 0x65 ], [ 0x6e, 0x0a, 0x78, 0xbc, 0x0d, 0xb2, 0x70, 0x21, 0xf0, 0xf5, 0x97, 0x56, 0xa4, 0x47, 0xe3, 0x13 ], [ 0x18, 0x75, 0x7e, 0xfd, 0x08, 0x05, 0x9a, 0xb7, 0x0b, 0xde, 0x2d, 0xf7, 0x8f, 0x3b, 0xd6, 0xba ], [ 0x7f, 0xec, 0xfc, 0x12, 0x7a, 0x37, 0x62, 0xe3, 0x0e, 0x14, 0x79, 0x11, 0x41, 0xf6, 0x55, 0x85 ], [ 0xc5, 0x80, 0x1e, 0xd8, 0xa3, 0x8a, 0x78, 0x27, 0x7a, 0x45, 0x51, 0x6a, 0x3e, 0x12, 0xb3, 0x10 ], [ 0x25, 0x16, 0x2f, 0x75, 0x11, 0xb5, 0xc3, 0xb2, 0x4a, 0xee, 0x33, 0x9f, 0xfe, 0xb7, 0x94, 0x1c ], [ 0x09, 0xda, 0x2f, 0xc0, 0xed, 0x60, 0x5b, 0x69, 0xd9, 0x5e, 0x0b, 0x77, 0x60, 0x84, 0x0a, 0x99 ], [ 0xd6, 0x67, 0x68, 0x54, 0x2f, 0x49, 0x5d, 0x5c, 0x50, 0xb8, 0x62, 0x3f, 0x31, 0x40, 0x85, 0xf8 ], [ 0xf6, 0xc5, 0x3b, 0xcb, 0x07, 0xcb, 0xb4, 0x47, 0x47, 0xfc, 0x19, 0xa6, 0x60, 0x4e, 0x26, 0xd7 ], [ 0xd2, 0xf5, 0x8a, 0xe0, 0x38, 0x6e, 0x92, 0x30, 0x74, 0x4a, 0x20, 0x56, 0xb7, 0xfd, 0x13, 0x10 ], [ 0xe1, 0xfd, 0x15, 0x56, 0x47, 0xde, 0x15, 0xb9, 0xfe, 0x23, 0x0b, 0xaf, 0x66, 0x8d, 0x23, 0xdb ], [ 0x5f, 0xc7, 0x17, 0xd7, 0x63, 0xa5, 0x6d, 0x76, 0x4a, 0x21, 0x00, 0x9b, 0x51, 0x32, 0xda, 0xb4 ], [ 0xec, 0x53, 0x64, 0xfa, 0x01, 0x84, 0xd8, 0xb9, 0x8e, 0xc0, 0x2c, 0xf9, 0x96, 0x42, 0x8f, 0x38 ], [ 0x95, 0x36, 0x0d, 0x08, 0xaf, 0x99, 0x7e, 0xb3, 0xec, 0x62, 0xe6, 0x41, 0xdd, 0x6b, 0x89, 0x9a ], [ 0xfd, 0xe4, 0xae, 0x88, 0x7d, 0x89, 0x0b, 0x88, 0x35, 0xa5, 0xfc, 0x80, 0xbf, 0xcc, 0xa7, 0x08 ], [ 0xdb, 0x57, 0xd5, 0xb8, 0x19, 0x12, 0x9d, 0x78, 0x96, 0xe2, 0xdf, 0x09, 0x58, 0xa6, 0xf9, 0xf3 ], [ 0xf3, 0x61, 0x43, 0x63, 0x03, 0x77, 0xd4, 0xe4, 0xef, 0xd4, 0x4c, 0x57, 0x16, 0xa8, 0xbd, 0xa1 ], [ 0x8a, 0xab, 0x74, 0x42, 0x87, 0xbf, 0xf6, 0x90, 0x14, 0x41, 0x90, 0x8d, 0xa2, 0x3f, 0x0b, 0x11 ], [ 0xb9, 0xa3, 0x53, 0x3b, 0x48, 0x26, 0x9b, 0x56, 0xf0, 0xdb, 0xb0, 0x57, 0x24, 0x27, 0x2c, 0xe5 ], [ 0xd3, 0x37, 0x77, 0xd7, 0x80, 0xa0, 0x4b, 0xfe, 0x62, 0x5c, 0xae, 0x47, 0x1d, 0x2b, 0x81, 0x69 ], [ 0xa7, 0xf7, 0xe8, 0x0a, 0x06, 0x8e, 0x75, 0x91, 0xae, 0x68, 0x1f, 0xe3, 0xe5, 0xe2, 0x77, 0xa6 ], [ 0xf3, 0x1a, 0xff, 0x86, 0xe5, 0x75, 0x9a, 0x22, 0x43, 0xbf, 0xe9, 0x6f, 0x1c, 0xda, 0xd7, 0xf6 ], [ 0x4f, 0x67, 0x07, 0xb5, 0xe6, 0x5d, 0xa3, 0xee, 0xa9, 0x2b, 0x53, 0x53, 0xc7, 0xbd, 0x95, 0xa2 ], [ 0xd3, 0xaa, 0x65, 0xaf, 0x58, 0x82, 0xd4, 0x32, 0xe8, 0xaf, 0xda, 0xa0, 0xb4, 0xf4, 0x26, 0x40 ], [ 0x87, 0x89, 0xbb, 0x3e, 0x01, 0xc8, 0xd3, 0xe7, 0x68, 0x03, 0x3f, 0x2c, 0x05, 0xff, 0xee, 0x17 ], [ 0x1d, 0x72, 0x76, 0x7f, 0xff, 0xb8, 0xde, 0x3a, 0x2a, 0x42, 0x0c, 0xa4, 0x38, 0x30, 0x87, 0xa6 ], [ 0xfb, 0x8d, 0x8d, 0xb9, 0xcb, 0x86, 0x39, 0xde, 0x83, 0x44, 0x23, 0x8d, 0xc2, 0xc1, 0xf2, 0x55 ], [ 0x90, 0xc0, 0x8a, 0xc7, 0x85, 0xb3, 0xb5, 0xe7, 0xc1, 0x81, 0x54, 0x97, 0xa4, 0x51, 0xa9, 0x6c ], [ 0x03, 0x6c, 0xad, 0x62, 0xc2, 0x42, 0x95, 0xb1, 0x88, 0xc4, 0x7c, 0xdc, 0x24, 0x7e, 0xae, 0x41 ], [ 0x85, 0x76, 0x79, 0xe4, 0x9c, 0xd6, 0x8b, 0xc6, 0x48, 0xc4, 0xab, 0x09, 0x86, 0xaa, 0x59, 0xf8 ], [ 0x5c, 0x93, 0x1a, 0x13, 0x5b, 0x9d, 0x4a, 0x7d, 0x65, 0xc9, 0xa8, 0xd5, 0x53, 0x5c, 0x12, 0x94 ], [ 0xdd, 0x15, 0x57, 0x57, 0xfc, 0xf4, 0x57, 0xd9, 0x0b, 0xb5, 0x71, 0xe8, 0xee, 0xbd, 0x46, 0x30 ], [ 0x56, 0xfd, 0xd9, 0x2d, 0x70, 0xc1, 0x07, 0xb7, 0x70, 0x7c, 0x9a, 0xa1, 0xd3, 0x3a, 0xb0, 0xac ], [ 0xd4, 0x9c, 0xa2, 0xb1, 0xdf, 0xc2, 0x84, 0x81, 0x20, 0xdf, 0xc2, 0xb7, 0x5e, 0x29, 0x2a, 0x0c ], [ 0xda, 0x86, 0x8a, 0xfe, 0xec, 0x48, 0x76, 0x40, 0x91, 0xc5, 0x1f, 0x5e, 0x73, 0x32, 0x33, 0x8d ], [ 0xe8, 0xcb, 0x04, 0x2a, 0x3d, 0x23, 0x97, 0x71, 0xef, 0x10, 0x4b, 0x58, 0x92, 0xbd, 0x10, 0x67 ], [ 0xdf, 0x68, 0x67, 0x69, 0x3d, 0x88, 0x84, 0xcc, 0xa8, 0x19, 0x82, 0x83, 0xbb, 0x2c, 0x3e, 0x16 ], [ 0xf2, 0x24, 0xec, 0x19, 0xa5, 0x8b, 0xbd, 0xe0, 0x3c, 0xb6, 0x92, 0xe0, 0xe4, 0xfc, 0x19, 0xd7 ], [ 0xb8, 0xfa, 0x08, 0x9c, 0xca, 0x83, 0xd2, 0xc9, 0x97, 0x9e, 0x64, 0x2b, 0x9a, 0x24, 0x88, 0x82 ], [ 0x89, 0x69, 0x1c, 0x5d, 0xbc, 0x84, 0xbf, 0x8e, 0x2e, 0x14, 0x54, 0x14, 0x80, 0x49, 0x64, 0x8f ], [ 0xd7, 0xf7, 0xc8, 0xbc, 0xcf, 0x89, 0x68, 0xb9, 0xf1, 0x18, 0xbb, 0xea, 0xd3, 0x53, 0xb6, 0x30 ], [ 0x8b, 0x65, 0x72, 0x48, 0x73, 0x18, 0x16, 0x7d, 0x1b, 0xab, 0xed, 0xf6, 0xa8, 0xce, 0xf7, 0xb2 ], [ 0x53, 0x1d, 0x33, 0x93, 0x77, 0x2d, 0x49, 0xbb, 0xd0, 0xa1, 0xb6, 0xd8, 0x39, 0xde, 0x01, 0x85 ], [ 0x92, 0x6c, 0xfa, 0x1f, 0x56, 0x8b, 0x03, 0xc9, 0x14, 0xb5, 0xa8, 0x28, 0x39, 0x20, 0xbe, 0x26 ], [ 0xb7, 0x90, 0x36, 0x8e, 0x2a, 0xb0, 0x22, 0x7e, 0x5c, 0x08, 0xad, 0xc4, 0xe7, 0x05, 0x7b, 0xaa ], [ 0xc9, 0x4c, 0x62, 0xfd, 0xac, 0x55, 0x0c, 0xf6, 0x2f, 0x3d, 0xbe, 0xc8, 0x9c, 0xb8, 0x61, 0x4c ], [ 0x16, 0x93, 0x8d, 0x35, 0xe7, 0x4a, 0x7a, 0xb0, 0xca, 0xdd, 0xde, 0x53, 0x1c, 0xbb, 0xc3, 0x33 ], [ 0x35, 0xd1, 0x6e, 0x1d, 0x15, 0xcd, 0xad, 0x05, 0x02, 0xe7, 0xef, 0x58, 0xe8, 0x6f, 0x4d, 0x4c ], [ 0x6a, 0xf3, 0x15, 0x2f, 0x97, 0x63, 0xe3, 0x9a, 0x83, 0xb9, 0x4f, 0xe9, 0x60, 0xe0, 0x44, 0x47 ], [ 0xd5, 0xa4, 0xd8, 0xec, 0x68, 0xe5, 0x3c, 0x0a, 0xac, 0x09, 0x4b, 0x95, 0xb8, 0xad, 0xd3, 0xc9 ], [ 0x63, 0x87, 0x89, 0xa3, 0x03, 0x15, 0x4f, 0xb3, 0x64, 0xe5, 0x16, 0x8a, 0xa9, 0x34, 0x08, 0x82 ], [ 0x5f, 0xf7, 0xc0, 0x24, 0x9b, 0xe2, 0xb6, 0x94, 0xad, 0x82, 0xe6, 0x80, 0x23, 0x97, 0x45, 0x33 ], [ 0x44, 0x62, 0xbc, 0x46, 0x9e, 0x79, 0x4f, 0xd7, 0x42, 0x88, 0xf3, 0xf7, 0x75, 0xc0, 0x2c, 0xf9 ], [ 0x3f, 0x29, 0xbf, 0xa0, 0x56, 0x16, 0x50, 0x77, 0x92, 0xce, 0xdc, 0x91, 0xe2, 0x7e, 0x4f, 0xbc ], [ 0x44, 0x79, 0x88, 0x5b, 0x32, 0xed, 0x93, 0xa0, 0x5b, 0xc9, 0x73, 0xd9, 0x25, 0xb3, 0x0a, 0x71 ], [ 0x5f, 0xaa, 0x52, 0x85, 0x56, 0xf7, 0x90, 0x49, 0x11, 0x8c, 0x00, 0x85, 0x2e, 0x02, 0x2d, 0x96 ], [ 0xfa, 0x58, 0xed, 0x4b, 0x55, 0x30, 0xec, 0xb8, 0xad, 0xb5, 0xf4, 0xc1, 0x19, 0xa9, 0xed, 0xda ], [ 0x83, 0xf4, 0x63, 0x9b, 0x4f, 0xa5, 0x4f, 0x5f, 0x65, 0x7c, 0x03, 0xfe, 0x4c, 0x00, 0x98, 0x3e ], [ 0x9c, 0x08, 0x5e, 0xbe, 0x5c, 0xd4, 0x2b, 0x24, 0x88, 0x9b, 0xe0, 0x7f, 0x59, 0xf7, 0x61, 0xb1 ], [ 0x0c, 0xca, 0xac, 0x98, 0xe1, 0xc9, 0x60, 0x9f, 0x40, 0x69, 0x30, 0x61, 0x7f, 0x1e, 0x35, 0xec ], [ 0x1f, 0xb8, 0xa2, 0xd4, 0x99, 0x6b, 0xac, 0xf3, 0x4f, 0x62, 0xca, 0xf1, 0x40, 0x2c, 0xed, 0x12 ], [ 0xab, 0xca, 0xe5, 0x4a, 0xfc, 0xbb, 0x0b, 0x0e, 0xc7, 0x58, 0x84, 0xb1, 0x1a, 0x99, 0x01, 0xff ], [ 0xc9, 0xfe, 0xd3, 0xc2, 0x9c, 0xf7, 0xc2, 0xa2, 0x84, 0x63, 0x68, 0x4f, 0x55, 0x1c, 0x11, 0xcd ], [ 0x55, 0xdd, 0xb8, 0xbc, 0x2b, 0xa1, 0x56, 0xbc, 0xd6, 0x64, 0x83, 0xab, 0x6a, 0x2c, 0xfe, 0x5c ], [ 0x7d, 0x88, 0x58, 0xef, 0xdf, 0x67, 0x84, 0x73, 0xd1, 0x13, 0x89, 0xac, 0xee, 0x8d, 0xed, 0x16 ], [ 0xcb, 0x1e, 0x87, 0x32, 0xf3, 0xa2, 0xdc, 0xd4, 0x5f, 0x4d, 0x05, 0x74, 0x09, 0xeb, 0x4d, 0x06 ], [ 0x44, 0x72, 0x9a, 0x79, 0x75, 0xc2, 0x2a, 0x89, 0xc6, 0x15, 0xd0, 0xf4, 0x8b, 0xcb, 0xad, 0x63 ], [ 0xee, 0xdc, 0x77, 0x72, 0x6b, 0xe4, 0x30, 0x17, 0xfb, 0x49, 0xbc, 0x40, 0x31, 0x42, 0x9e, 0x46 ], [ 0x98, 0x90, 0x0b, 0xbe, 0x2e, 0x11, 0x41, 0xb5, 0x94, 0xc0, 0x5c, 0x93, 0xbd, 0xa6, 0x8c, 0x50 ], [ 0x8c, 0x9c, 0x92, 0x31, 0x73, 0x2b, 0x49, 0xba, 0xa0, 0x7f, 0x99, 0x4a, 0xc9, 0x0c, 0xbb, 0x74 ], [ 0xb4, 0x38, 0xd1, 0x1e, 0x4a, 0xf5, 0x11, 0x07, 0xa4, 0x21, 0x2f, 0x48, 0x44, 0xd8, 0xc6, 0x70 ], [ 0x83, 0xee, 0xe4, 0x5a, 0xba, 0x63, 0x8b, 0xcf, 0x71, 0x26, 0x24, 0x21, 0x77, 0x19, 0x35, 0x63 ], [ 0xe7, 0xe4, 0xdf, 0xf4, 0xb3, 0x6e, 0xe9, 0x69, 0xfd, 0x6d, 0x80, 0xe8, 0xba, 0xec, 0x55, 0xc1 ], [ 0xc3, 0x99, 0x04, 0x09, 0x70, 0x6e, 0xb8, 0xa1, 0xad, 0xcf, 0xe3, 0xba, 0xea, 0x3b, 0x42, 0x1a ], [ 0x47, 0xfe, 0x4c, 0x37, 0x59, 0x75, 0x8e, 0xbe, 0xc5, 0x0f, 0x37, 0x0d, 0x48, 0x3e, 0xbb, 0xb8 ], [ 0x5c, 0x70, 0x9d, 0x12, 0x02, 0x04, 0xee, 0x3e, 0x32, 0xa5, 0x7b, 0x8e, 0xa2, 0x78, 0xe5, 0x84 ], [ 0xfa, 0x81, 0xd0, 0xc1, 0xf6, 0x17, 0x25, 0x7b, 0x43, 0xa7, 0x01, 0x36, 0xae, 0xb5, 0x51, 0x68 ], [ 0x2b, 0xec, 0xd5, 0x0a, 0x3b, 0xeb, 0x5b, 0xa4, 0x1a, 0xef, 0xd8, 0x95, 0x88, 0x41, 0x3c, 0x49 ], [ 0x7c, 0xf6, 0xc0, 0x26, 0x93, 0xcb, 0xb1, 0xf3, 0xfc, 0x82, 0x5e, 0x4a, 0x5c, 0xdb, 0x7f, 0xaf ], [ 0x0d, 0x59, 0xb4, 0x0b, 0xa3, 0xd9, 0x17, 0x4b, 0x58, 0xda, 0x3e, 0xb8, 0x2a, 0xe3, 0x0d, 0xe3 ], [ 0x4a, 0x88, 0x02, 0x1a, 0x53, 0xaf, 0x93, 0x89, 0xe3, 0xab, 0xc1, 0x9a, 0xb6, 0xc2, 0x29, 0xa1 ], [ 0xa8, 0x4d, 0xfd, 0x53, 0x49, 0x2e, 0xc2, 0xe8, 0x0b, 0xda, 0x18, 0x78, 0x92, 0x9d, 0x29, 0x52 ], [ 0xa6, 0x01, 0xc1, 0x69, 0xee, 0x05, 0x9b, 0x8e, 0x1d, 0x0d, 0xce, 0x77, 0xcf, 0x28, 0x62, 0xf3 ], [ 0x85, 0xc9, 0x3e, 0xdc, 0x4e, 0xc4, 0xd3, 0x3d, 0x6c, 0x4e, 0xfd, 0x25, 0x58, 0x18, 0x40, 0x25 ], [ 0x3f, 0x71, 0x52, 0x73, 0xef, 0xe1, 0x95, 0x45, 0x65, 0x66, 0x9a, 0x20, 0x85, 0x04, 0xa7, 0x63 ], [ 0x9d, 0xad, 0x8e, 0x38, 0x5c, 0x80, 0x6d, 0x90, 0xf8, 0x8b, 0xfc, 0xbb, 0x5a, 0x7a, 0x96, 0x86 ], [ 0xa5, 0x93, 0xe8, 0x7b, 0xca, 0x06, 0xf1, 0xba, 0x52, 0x93, 0x17, 0xa7, 0x18, 0x88, 0x3a, 0xbc ], [ 0x89, 0xc0, 0xbb, 0x8f, 0x0f, 0xc6, 0x39, 0x87, 0xcf, 0xd3, 0x5c, 0x72, 0x92, 0xdd, 0xc5, 0x0e ], [ 0xdb, 0x8d, 0x01, 0x9a, 0xb1, 0x2c, 0x98, 0x76, 0x5e, 0xdb, 0x0a, 0x7c, 0xa2, 0x58, 0x92, 0x48 ], [ 0xf8, 0x56, 0x0d, 0x79, 0x95, 0xe8, 0x48, 0xfd, 0x0a, 0xfc, 0x51, 0x8b, 0x6c, 0x7b, 0x62, 0x78 ], [ 0xbb, 0xfe, 0xeb, 0xa2, 0x07, 0x7e, 0x7d, 0x29, 0xc6, 0x7d, 0xaf, 0x70, 0xa1, 0xef, 0x1c, 0xa3 ], [ 0x07, 0x70, 0xf6, 0x40, 0xb1, 0x01, 0x3a, 0x31, 0x48, 0x0c, 0x32, 0x50, 0x88, 0x3b, 0x0b, 0xc7 ], [ 0xd1, 0x61, 0xe0, 0x8e, 0xcf, 0x9c, 0xf2, 0x73, 0x24, 0xff, 0xa8, 0x4a, 0xad, 0xf1, 0x69, 0x41 ], [ 0xa1, 0x38, 0xf2, 0xa1, 0x60, 0x33, 0xe8, 0xc2, 0x24, 0x52, 0x43, 0xda, 0x3a, 0xdc, 0x14, 0x98 ], [ 0x6a, 0xb5, 0xf2, 0xbe, 0x0f, 0xca, 0x76, 0xbc, 0xd8, 0x95, 0xbf, 0x9d, 0x46, 0xde, 0x01, 0xc9 ], [ 0x70, 0x33, 0x05, 0x58, 0xf8, 0x28, 0x8b, 0x74, 0xe8, 0x76, 0x8c, 0xde, 0x82, 0x71, 0x37, 0xc8 ], [ 0xa2, 0x20, 0xba, 0x8c, 0x18, 0x4a, 0x68, 0x26, 0x2b, 0x45, 0x5e, 0x73, 0xc1, 0x3e, 0x6f, 0xfc ], [ 0x66, 0x23, 0x59, 0x74, 0xce, 0x1e, 0x71, 0x8c, 0x12, 0xf7, 0xb8, 0xfd, 0x72, 0x9d, 0xef, 0xe0 ], [ 0xc3, 0x33, 0xdc, 0xc0, 0x14, 0x9f, 0xac, 0x9f, 0x23, 0x37, 0x4f, 0x90, 0x23, 0xfe, 0x92, 0xd0 ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" plain_texts2_128bit = [ [ 0x19, 0x43, 0x90, 0x1f, 0xff, 0x18, 0x17, 0x0a, 0xc5, 0x9c, 0x0b, 0xbb, 0xd6, 0xb7, 0x23, 0x62, 0xdb, 0xb5, 0xc6, 0x50, 0x57, 0xbf, 0x05, 0x53, 0x89, 0xf5, 0x20, 0x75, 0x7a, 0xc2, 0x9d, 0xaf ], [ 0xec, 0xc4, 0x11, 0xf4, 0xac, 0x85, 0x29, 0x2d, 0x40, 0xf4, 0xcf, 0x8b, 0xe6, 0x25, 0x64, 0x57, 0xed, 0xa2, 0xab, 0x5a, 0xa6, 0xd6, 0xef, 0xf1, 0x5b, 0xc4, 0x6d, 0xa8, 0xa5, 0xa8, 0x7c, 0x56 ], [ 0x73, 0x50, 0x53, 0xbd, 0x54, 0x47, 0x06, 0x47, 0xb5, 0x67, 0x4a, 0x12, 0xc5, 0x7a, 0x51, 0xb6, 0xe7, 0xce, 0x80, 0x45, 0x47, 0x0a, 0xfe, 0xf1, 0xc1, 0x2b, 0x69, 0x18, 0xa3, 0xa9, 0x16, 0x11 ], [ 0x29, 0xf7, 0xc9, 0x3b, 0xd3, 0x21, 0xb1, 0x07, 0x68, 0x05, 0xc7, 0xda, 0xfb, 0xcc, 0x35, 0x39, 0x0a, 0xa9, 0x01, 0x4b, 0x60, 0x54, 0x3f, 0x81, 0x6e, 0x08, 0x01, 0x07, 0xc6, 0xc1, 0x4b, 0x9c ], [ 0x3e, 0x02, 0x1d, 0x77, 0xd9, 0x11, 0x26, 0x9e, 0xbf, 0x24, 0xd2, 0xd7, 0xb7, 0xe9, 0xa5, 0x79, 0xd4, 0xee, 0x38, 0xf8, 0x73, 0xb6, 0x7b, 0xff, 0xe3, 0xfa, 0x55, 0xc7, 0x86, 0x04, 0x7f, 0x19 ], [ 0x14, 0xa7, 0xb3, 0x0c, 0x80, 0xd3, 0x41, 0x60, 0x9c, 0x29, 0x16, 0x80, 0xf8, 0xcb, 0xdd, 0x66, 0x28, 0xcf, 0x6d, 0xbb, 0x46, 0x00, 0x4e, 0x52, 0x65, 0x3b, 0x91, 0xcd, 0x9c, 0x18, 0x9d, 0x48 ], [ 0xde, 0xac, 0x6e, 0x7b, 0x9e, 0x06, 0x34, 0xc3, 0x1d, 0xa6, 0xa5, 0xff, 0x71, 0x98, 0x1f, 0x04, 0xc0, 0x86, 0xf4, 0x87, 0x96, 0x32, 0xb3, 0xcd, 0x5a, 0xff, 0x69, 0x6f, 0x94, 0xba, 0x13, 0xe0 ], [ 0xb8, 0x2a, 0x58, 0xa6, 0x4d, 0x81, 0x1c, 0x34, 0x2b, 0x04, 0x20, 0xef, 0xb3, 0x88, 0x6f, 0xd9, 0x9f, 0xd8, 0x5f, 0x59, 0xc5, 0x2d, 0x40, 0xd1, 0x99, 0xfa, 0xa2, 0xd3, 0x60, 0x86, 0x79, 0xe4 ], [ 0x02, 0xf3, 0xaf, 0xf6, 0x9a, 0x08, 0xb6, 0x51, 0x79, 0x30, 0xea, 0xd6, 0x66, 0xaf, 0xda, 0xa2, 0xaf, 0x68, 0x89, 0x88, 0x06, 0xcd, 0x72, 0x3a, 0x50, 0xfb, 0x9b, 0xc0, 0x48, 0x8d, 0x7a, 0x0c ], [ 0x57, 0xc5, 0xef, 0x3e, 0x9f, 0x7e, 0xab, 0x67, 0x6d, 0xe9, 0x59, 0xee, 0xb3, 0x25, 0xf9, 0x54, 0x66, 0xf6, 0xa9, 0xdd, 0xab, 0xd8, 0x4d, 0x7b, 0xd7, 0x5d, 0x26, 0xc4, 0x4f, 0x50, 0x8f, 0x49 ], [ 0x97, 0xaa, 0xb7, 0x62, 0xae, 0x88, 0x3f, 0xf6, 0xa1, 0x08, 0x16, 0xa1, 0x2e, 0xc0, 0x72, 0x35, 0x62, 0xc9, 0x41, 0xfd, 0x09, 0x49, 0x72, 0xb1, 0xb8, 0x5b, 0xf9, 0x14, 0x06, 0xc4, 0xd6, 0xc8 ], [ 0x1c, 0x8d, 0xdd, 0x3f, 0x0c, 0xe1, 0xf8, 0x24, 0xea, 0x03, 0xa9, 0x40, 0x1c, 0x53, 0x89, 0xb0, 0x7e, 0x82, 0xf6, 0x81, 0xf5, 0x76, 0x7f, 0x17, 0xdb, 0xb0, 0x91, 0x03, 0x50, 0x6e, 0xbb, 0x98 ], [ 0x40, 0x51, 0x97, 0x6a, 0x40, 0x3c, 0x91, 0xb1, 0x63, 0x07, 0xda, 0x58, 0x67, 0xf7, 0x3f, 0x40, 0x9f, 0x35, 0xd5, 0x30, 0x4d, 0x88, 0x70, 0x05, 0x18, 0x09, 0x44, 0x54, 0x11, 0x7d, 0x84, 0xc1 ], [ 0x30, 0x81, 0x63, 0x67, 0xfe, 0xff, 0xff, 0x5f, 0xcf, 0x4d, 0x13, 0x08, 0xd8, 0x3c, 0xf6, 0xc1, 0x84, 0x4d, 0x8b, 0xfa, 0xa8, 0x42, 0xb3, 0x1a, 0xe4, 0x44, 0x60, 0xf6, 0x11, 0x47, 0x9f, 0x45 ], [ 0xe5, 0xe8, 0x1f, 0x1c, 0x11, 0x93, 0xad, 0x8d, 0x1e, 0x2e, 0xc1, 0x1a, 0x3c, 0x82, 0xd9, 0x36, 0x1a, 0x80, 0x36, 0x85, 0x2e, 0xf7, 0x78, 0x3e, 0xd0, 0x98, 0xe1, 0xb6, 0x23, 0x45, 0x99, 0xe7 ], [ 0xbb, 0xe7, 0x41, 0x2a, 0x55, 0xba, 0x62, 0x4e, 0xf8, 0x18, 0x55, 0xd6, 0x01, 0x80, 0xee, 0x0a, 0x49, 0x40, 0x94, 0x47, 0xb4, 0x12, 0xb7, 0x63, 0x9d, 0x05, 0x4b, 0x18, 0xfb, 0xa6, 0x6e, 0xc4 ], [ 0x4b, 0x0c, 0x63, 0x08, 0x78, 0x38, 0xff, 0xc7, 0x52, 0x1a, 0xfc, 0xcc, 0x0f, 0x03, 0x1c, 0xc7, 0x7e, 0x3c, 0x6e, 0x8d, 0xcf, 0x8d, 0x63, 0xc4, 0x8b, 0x47, 0x16, 0x5d, 0x65, 0x41, 0x45, 0x90 ], [ 0xae, 0x9b, 0x10, 0xbd, 0xe3, 0x6f, 0x92, 0x5e, 0x82, 0xeb, 0x25, 0x06, 0xd2, 0xf5, 0xfb, 0xfe, 0x07, 0x42, 0x05, 0x3b, 0xbe, 0x82, 0x2f, 0x83, 0x4e, 0xe0, 0x03, 0x9f, 0xa7, 0x1b, 0x1c, 0xb0 ], [ 0x8b, 0x36, 0xcd, 0x24, 0xbe, 0xbf, 0x36, 0x18, 0x83, 0x99, 0x79, 0xf4, 0x0a, 0xb0, 0x1d, 0xd8, 0x3c, 0xe9, 0x56, 0x7d, 0xf7, 0xf4, 0x44, 0xd2, 0xf9, 0x98, 0xd3, 0xb0, 0x76, 0x99, 0xab, 0xb9 ], [ 0xba, 0x5e, 0xf8, 0xbf, 0xe3, 0xc9, 0x56, 0x2c, 0xfe, 0xce, 0x16, 0x8b, 0xd4, 0xe1, 0xad, 0x3b, 0x5f, 0xa5, 0x18, 0xb9, 0x87, 0x91, 0x17, 0x5a, 0xb3, 0x16, 0xed, 0x75, 0x12, 0x95, 0x2e, 0x44 ], [ 0x23, 0xaf, 0x1a, 0x58, 0x91, 0xbc, 0x51, 0xe5, 0x78, 0x89, 0x67, 0xa9, 0xf8, 0x41, 0x9a, 0xeb, 0x71, 0x27, 0x74, 0x4c, 0x2a, 0xc8, 0x62, 0x25, 0xd8, 0x3b, 0x18, 0x01, 0x35, 0xac, 0xdc, 0xda ], [ 0x71, 0x34, 0xee, 0xa5, 0x21, 0x79, 0xc4, 0x7b, 0xa7, 0xcc, 0x1a, 0x7f, 0x0e, 0x15, 0xac, 0x2a, 0x5b, 0x19, 0x93, 0xa6, 0x05, 0x12, 0x77, 0x5f, 0x35, 0x3a, 0x12, 0x88, 0xa7, 0x92, 0x6e, 0x7a ], [ 0x0d, 0x31, 0x11, 0xcf, 0x9e, 0x10, 0x52, 0x17, 0xbf, 0xd2, 0x55, 0x15, 0x2c, 0x28, 0x00, 0x4f, 0x37, 0x28, 0x20, 0x7a, 0x43, 0xc0, 0x6a, 0xab, 0xff, 0x00, 0xb3, 0x8f, 0x3b, 0x2f, 0xb3, 0x89 ], [ 0x4f, 0x61, 0xf2, 0xea, 0x0f, 0x7a, 0xe3, 0xe6, 0x73, 0xa7, 0x09, 0x8e, 0x0a, 0x17, 0x91, 0x91, 0x13, 0x09, 0x43, 0xbc, 0x78, 0xcf, 0x4f, 0x36, 0x1e, 0xbc, 0xe0, 0xb8, 0x48, 0x77, 0xe4, 0xe6 ], [ 0xf2, 0xe0, 0x1a, 0x94, 0xb2, 0x10, 0x13, 0x72, 0xed, 0x33, 0xf6, 0x7e, 0x51, 0xdd, 0xfa, 0x2c, 0x50, 0xdc, 0x2d, 0xfe, 0x7b, 0xd8, 0x81, 0x27, 0x3a, 0x09, 0xae, 0x24, 0x7c, 0xec, 0x9b, 0x63 ], [ 0xbd, 0xc5, 0x46, 0x8f, 0xbc, 0x8d, 0x50, 0xa1, 0x0d, 0x1c, 0x85, 0x7f, 0x79, 0x1c, 0x5c, 0xba, 0xb3, 0x81, 0x0d, 0x0d, 0x73, 0xcf, 0x8f, 0x20, 0x46, 0xb1, 0xd1, 0x9e, 0x7d, 0x5d, 0x8a, 0x56 ], [ 0x10, 0xfe, 0x87, 0xe6, 0xc7, 0x15, 0x57, 0x5e, 0x7e, 0x23, 0x22, 0x0f, 0x38, 0xe9, 0xc5, 0xb9, 0xd4, 0xee, 0x25, 0xb8, 0xcf, 0x74, 0x4e, 0x44, 0x7f, 0x2d, 0x40, 0x56, 0xc9, 0xef, 0xab, 0xc0 ], [ 0xa2, 0xb4, 0x5e, 0xd5, 0xe5, 0x93, 0xa1, 0xfc, 0xbf, 0x9b, 0xcf, 0x3f, 0x40, 0x6b, 0xb7, 0xaf, 0xc5, 0x41, 0x99, 0x7d, 0x45, 0x4c, 0x25, 0x1e, 0xa9, 0x24, 0x80, 0x4c, 0x44, 0xa0, 0x37, 0xbc ], [ 0xe4, 0xa1, 0x9c, 0xdc, 0x4e, 0xab, 0x9f, 0x3a, 0x91, 0xbf, 0x42, 0xa8, 0xb0, 0x84, 0xa2, 0xd7, 0x12, 0x09, 0x5a, 0x64, 0x6a, 0xa0, 0x3a, 0x3c, 0x0b, 0xc9, 0xbf, 0x69, 0x5b, 0x19, 0xc4, 0xbc ], [ 0x91, 0x53, 0x58, 0x47, 0x0c, 0xb9, 0xfa, 0xec, 0x9f, 0x4b, 0xd5, 0x2b, 0x91, 0x5c, 0x9f, 0x1b, 0x30, 0xac, 0x83, 0x77, 0xd3, 0x16, 0xe5, 0xa9, 0x2d, 0x3e, 0xea, 0x87, 0x65, 0x39, 0x46, 0xae ], [ 0x47, 0xa8, 0x33, 0xc7, 0xbd, 0xc5, 0x6e, 0x7e, 0xa9, 0x5f, 0x2d, 0xac, 0xf4, 0x41, 0x58, 0x72, 0x13, 0x1d, 0xd2, 0xc7, 0x6d, 0x6c, 0x2c, 0x9b, 0xe4, 0x9a, 0xd3, 0x07, 0x9c, 0x90, 0xd4, 0x93 ], [ 0x1c, 0xf2, 0x8a, 0x0f, 0x09, 0xa3, 0x1a, 0x0e, 0x84, 0xe0, 0x7b, 0x5f, 0xd6, 0x59, 0xf6, 0x5b, 0x03, 0x3a, 0x6d, 0x51, 0xad, 0x7c, 0x92, 0x90, 0x2e, 0xc6, 0xa4, 0x4c, 0xe9, 0xb3, 0xc3, 0x9e ], [ 0xb7, 0xa0, 0x29, 0x4e, 0x79, 0x8c, 0x9b, 0xa0, 0x85, 0xa3, 0x96, 0x93, 0x81, 0x02, 0x78, 0x39, 0x1e, 0x51, 0x38, 0x1f, 0xfb, 0xfd, 0x9b, 0x49, 0xb8, 0x9e, 0x2e, 0x7f, 0xaa, 0xa9, 0x3a, 0xa0 ], [ 0xc9, 0x45, 0x43, 0xb7, 0x13, 0x10, 0x88, 0x15, 0x74, 0x6c, 0x14, 0xc9, 0x2b, 0x35, 0x16, 0x5f, 0x6c, 0x1d, 0x7a, 0xeb, 0x34, 0xd0, 0x3b, 0xe8, 0x22, 0x31, 0xb1, 0xbf, 0xc2, 0xd9, 0xcc, 0x39 ], [ 0x4e, 0x11, 0x46, 0x66, 0xf7, 0xb6, 0x43, 0xbd, 0x10, 0x30, 0x91, 0xcc, 0xc0, 0x66, 0x05, 0x3d, 0x14, 0x48, 0xc6, 0x0f, 0x4a, 0xde, 0xe1, 0x19, 0x30, 0xdf, 0xd9, 0x89, 0xa8, 0xb8, 0x64, 0x17 ], [ 0x69, 0xa6, 0xea, 0x57, 0x3c, 0xf4, 0xb6, 0xfa, 0xb1, 0xd0, 0x75, 0xbf, 0x18, 0xeb, 0x00, 0x4c, 0xb2, 0xbf, 0x42, 0xdd, 0x7d, 0x8f, 0xbc, 0xd5, 0x73, 0xf7, 0x3a, 0x6c, 0xfb, 0x7d, 0x38, 0xb8 ], [ 0x75, 0x07, 0xfe, 0x91, 0x23, 0xcd, 0x07, 0xef, 0x45, 0xb7, 0x67, 0xa1, 0x9f, 0xa8, 0xc8, 0x52, 0xe6, 0x68, 0x12, 0x44, 0xdf, 0x9e, 0x99, 0xf3, 0x87, 0xce, 0xae, 0x37, 0x3c, 0x64, 0x06, 0xf2 ], [ 0xf8, 0xd1, 0xba, 0xc5, 0x2d, 0x1e, 0x3e, 0xd9, 0x81, 0xe9, 0xad, 0xcc, 0x51, 0x0c, 0x26, 0xda, 0xcc, 0x00, 0xf4, 0x77, 0x8f, 0xb2, 0xb9, 0x2c, 0xec, 0x8a, 0x62, 0xd0, 0xb8, 0x14, 0xe0, 0xdf ], [ 0x2b, 0xa7, 0xa7, 0xc3, 0x94, 0x84, 0x0f, 0xe2, 0xa0, 0x40, 0x18, 0x60, 0x81, 0x5b, 0xe1, 0x1c, 0x40, 0x4d, 0x09, 0xe7, 0x6c, 0xb9, 0x02, 0xa8, 0xc4, 0xed, 0x37, 0x2f, 0xe3, 0x23, 0x13, 0x19 ], [ 0x0a, 0x69, 0xec, 0xda, 0xb9, 0xec, 0xc6, 0x5c, 0x04, 0xb6, 0x7f, 0x77, 0x78, 0x3b, 0xb7, 0x33, 0xc8, 0x69, 0x1b, 0x71, 0xe0, 0x79, 0xdc, 0xa5, 0xa6, 0x29, 0x45, 0xe6, 0x22, 0x49, 0x3e, 0xff ], [ 0x69, 0xb2, 0x79, 0x9e, 0x4a, 0xaf, 0x63, 0x11, 0x14, 0xd1, 0x55, 0x8b, 0x6e, 0xe7, 0x8c, 0x7e, 0xa0, 0x5a, 0x9d, 0xbf, 0x5c, 0xd3, 0x6f, 0x7e, 0xd7, 0xd4, 0xf7, 0x78, 0xdf, 0x77, 0xd9, 0xfe ], [ 0x53, 0x2d, 0x3e, 0x0c, 0xfe, 0x56, 0xe1, 0xb1, 0xe6, 0xbf, 0xf4, 0x3c, 0x48, 0xb6, 0x26, 0x80, 0xaa, 0x79, 0x9f, 0xa5, 0x0b, 0x46, 0x1a, 0x2d, 0x01, 0x8b, 0x89, 0x2d, 0xae, 0x24, 0x00, 0xa9 ], [ 0x93, 0x48, 0xdc, 0x37, 0x1e, 0x73, 0xa0, 0x5c, 0xa8, 0x61, 0x6b, 0xd2, 0xb1, 0x35, 0xfa, 0x30, 0x12, 0x60, 0xa5, 0x4b, 0xd3, 0x96, 0xc4, 0xb0, 0xdb, 0xf1, 0x75, 0x03, 0x7b, 0x08, 0xe8, 0xba ], [ 0x74, 0x62, 0x71, 0x28, 0xb5, 0x29, 0xc5, 0x71, 0xad, 0x25, 0x56, 0x62, 0x37, 0xc1, 0x4f, 0x2f, 0x42, 0x81, 0xbf, 0x36, 0x5a, 0xbd, 0x40, 0xcd, 0x04, 0x8a, 0x3d, 0x5e, 0x42, 0x55, 0x8d, 0x7e ], [ 0x48, 0x0f, 0x82, 0x02, 0x56, 0x61, 0x0b, 0x56, 0x15, 0xd5, 0xad, 0xab, 0x88, 0x8c, 0x71, 0x57, 0xdb, 0x22, 0xd7, 0x60, 0x64, 0xbe, 0x1a, 0xf6, 0xc6, 0x57, 0x9b, 0x52, 0x4a, 0x80, 0xe4, 0x9e ], [ 0xe7, 0xbe, 0x50, 0xcb, 0x36, 0x23, 0x89, 0x51, 0x0a, 0xb1, 0x62, 0x0c, 0xf2, 0x4c, 0xf4, 0x27, 0x69, 0x71, 0xf5, 0xb0, 0x3e, 0xf9, 0x04, 0xa3, 0x54, 0xe1, 0x17, 0xe7, 0xd5, 0xa8, 0xf3, 0x8b ], [ 0xba, 0x11, 0xde, 0x1d, 0xd9, 0x90, 0xdc, 0x60, 0x61, 0x59, 0xd0, 0x5c, 0x99, 0x48, 0xf9, 0x31, 0x85, 0x64, 0x66, 0x0b, 0x68, 0x72, 0x4e, 0x3d, 0x9f, 0xd7, 0x8e, 0x3b, 0xfd, 0xe5, 0x50, 0xc0 ], [ 0xec, 0x08, 0xa6, 0xb0, 0x4e, 0x3a, 0x1c, 0x7d, 0xf5, 0x5e, 0xc7, 0x63, 0x40, 0x19, 0xda, 0x8a, 0x5f, 0xd1, 0xde, 0x89, 0x57, 0xdd, 0xf4, 0x61, 0x06, 0xe3, 0xe2, 0x60, 0x73, 0x96, 0xd1, 0x8b ], [ 0x75, 0x39, 0x70, 0x7e, 0x7f, 0xf1, 0xf4, 0x7c, 0xf6, 0x87, 0x8b, 0x08, 0x9d, 0xff, 0x00, 0xbd, 0x8c, 0x21, 0x2a, 0x89, 0x39, 0xff, 0xcf, 0x9e, 0x2c, 0x22, 0x3e, 0x24, 0x52, 0xdc, 0x1a, 0x12 ], [ 0x99, 0x71, 0xca, 0xa7, 0xb0, 0x1a, 0x25, 0x26, 0xdf, 0xa5, 0xde, 0x8f, 0x71, 0xb0, 0xa6, 0x08, 0x60, 0x13, 0x18, 0x4e, 0xde, 0x8f, 0xa4, 0x6c, 0xbf, 0x9e, 0x9b, 0x2b, 0x4e, 0x57, 0x3a, 0x0c ], [ 0x65, 0x67, 0xad, 0xf8, 0x5f, 0xf4, 0xf8, 0x2c, 0xd1, 0x60, 0x62, 0xf1, 0xaa, 0x78, 0x0d, 0x33, 0xe1, 0x58, 0x26, 0xa8, 0x9b, 0xd3, 0x83, 0x53, 0x5a, 0xa4, 0x2b, 0x7e, 0xf0, 0x03, 0xbc, 0x2e ], [ 0xa3, 0xb0, 0xe1, 0x6f, 0x94, 0xc3, 0xa7, 0x77, 0x96, 0xb4, 0xa3, 0x4b, 0xd5, 0x46, 0xef, 0x54, 0xcf, 0x57, 0x06, 0x2d, 0x0d, 0x80, 0x5a, 0x4c, 0x8c, 0x1b, 0x2b, 0xdf, 0x5c, 0xf7, 0x61, 0xf6 ], [ 0x42, 0xbb, 0x68, 0x95, 0xee, 0x03, 0xcb, 0xe9, 0x59, 0x19, 0x04, 0xf0, 0xe7, 0xc3, 0x06, 0x47, 0x6d, 0xe7, 0x47, 0x08, 0x43, 0x97, 0xc6, 0xa7, 0xfd, 0x6e, 0xb0, 0x3b, 0x10, 0xcb, 0xd5, 0xf7 ], [ 0x2d, 0x86, 0xb8, 0x99, 0xa4, 0x57, 0xc3, 0xcc, 0x2e, 0x77, 0xce, 0xf0, 0x17, 0x60, 0xff, 0x01, 0x18, 0x83, 0x35, 0xbd, 0xe9, 0x3a, 0x7b, 0x23, 0xd8, 0xd6, 0xff, 0x9a, 0xd2, 0xa1, 0x3f, 0xdd ], [ 0x24, 0xda, 0xf4, 0x5f, 0x97, 0xf8, 0x9c, 0x97, 0x1c, 0xab, 0x4e, 0x95, 0xe5, 0x1d, 0x25, 0x7a, 0x12, 0xa3, 0x8f, 0x08, 0xa5, 0xb5, 0x54, 0x24, 0x06, 0x3f, 0x6b, 0x31, 0x7b, 0x5a, 0x12, 0x74 ], [ 0xc3, 0xce, 0x2a, 0x1e, 0x7f, 0xc5, 0xb6, 0xf3, 0xc2, 0xfb, 0x37, 0x62, 0xab, 0x8f, 0x17, 0xdd, 0x14, 0x98, 0xe5, 0x0b, 0xeb, 0x2e, 0xb6, 0x37, 0x2d, 0x81, 0x12, 0xec, 0x42, 0x0a, 0x12, 0xb8 ], [ 0xc7, 0x8c, 0x16, 0x7f, 0xc2, 0x2c, 0xd7, 0xea, 0x26, 0xc7, 0x6b, 0xd3, 0xc3, 0x13, 0x8f, 0xf3, 0xad, 0xee, 0x6d, 0x70, 0xfb, 0x13, 0x4f, 0xeb, 0xe0, 0xb0, 0x51, 0xcd, 0xd2, 0x58, 0x3f, 0x96 ], [ 0x9f, 0x84, 0xdc, 0xa7, 0x8c, 0x13, 0x05, 0x3e, 0x73, 0xb7, 0x91, 0x37, 0xd8, 0xd9, 0xe4, 0x05, 0x77, 0x9c, 0xfc, 0x8e, 0xf3, 0xd4, 0x82, 0x49, 0x97, 0xfb, 0xbc, 0xe1, 0xe9, 0x68, 0x2d, 0xbd ], [ 0x6d, 0x52, 0x5c, 0x54, 0x60, 0x94, 0xc5, 0xdb, 0x76, 0x00, 0x67, 0x8e, 0x84, 0xa0, 0x7d, 0x15, 0x95, 0x46, 0x85, 0x26, 0xc0, 0x2f, 0x90, 0x7b, 0x34, 0xfe, 0x43, 0xef, 0x32, 0x7f, 0x21, 0x24 ], [ 0x8e, 0x9b, 0x5e, 0x02, 0xb0, 0x71, 0xa0, 0xb6, 0x02, 0x31, 0x9e, 0xf3, 0x8a, 0x07, 0x0d, 0x1f, 0xd0, 0x59, 0x06, 0xb8, 0xc3, 0x93, 0x97, 0xb0, 0x0e, 0xb9, 0xbd, 0x0f, 0xd5, 0xc5, 0x28, 0xa2 ], [ 0x57, 0x04, 0x19, 0x0a, 0x0c, 0xbc, 0x48, 0x74, 0x63, 0x76, 0x59, 0xed, 0xb3, 0x44, 0x7e, 0x02, 0xa0, 0x94, 0x16, 0xdd, 0xc5, 0x47, 0x74, 0x01, 0x1e, 0xa1, 0x26, 0x1a, 0x86, 0xff, 0x43, 0x8d ], [ 0xb3, 0xc5, 0xa7, 0xd0, 0x96, 0x05, 0x9d, 0x81, 0x80, 0xd1, 0x48, 0x58, 0xe4, 0xde, 0xfb, 0x54, 0x4f, 0xab, 0x31, 0xe7, 0x6a, 0x62, 0x89, 0xd4, 0x64, 0x92, 0xd3, 0xdb, 0x5b, 0xab, 0xcf, 0xc7 ], [ 0x2d, 0x0b, 0x96, 0xe4, 0x92, 0x10, 0x36, 0x29, 0x54, 0xb0, 0x79, 0x32, 0x00, 0xed, 0x25, 0x2f, 0x7c, 0x4a, 0xb2, 0xc2, 0xa0, 0x39, 0xc7, 0x3b, 0x41, 0x8e, 0x43, 0xa7, 0x81, 0x16, 0xcb, 0xf4 ], [ 0xdc, 0xaa, 0x48, 0x3d, 0x90, 0xa1, 0xb6, 0xf5, 0xcc, 0x0f, 0x7a, 0xba, 0xcc, 0xf2, 0x0b, 0xc9, 0x15, 0x53, 0xe1, 0xd9, 0x88, 0xe0, 0x8e, 0x82, 0xf7, 0x98, 0x27, 0x47, 0x6d, 0x15, 0x7c, 0x7c ], [ 0x31, 0x51, 0xca, 0x41, 0xcb, 0x6c, 0x80, 0x56, 0x56, 0x58, 0x2d, 0x17, 0x24, 0x10, 0x6c, 0x2a, 0x88, 0xe0, 0x9e, 0x62, 0xb6, 0xa4, 0xac, 0xb0, 0x57, 0x32, 0x05, 0x23, 0x4a, 0xaf, 0x0e, 0x5e ], [ 0x16, 0x4e, 0x58, 0x28, 0x28, 0x45, 0xba, 0x15, 0x95, 0xc3, 0xe9, 0x64, 0x62, 0x9f, 0xef, 0x1d, 0x94, 0x3e, 0xb1, 0x34, 0x9a, 0xe9, 0x80, 0x26, 0x2b, 0xb0, 0xef, 0xce, 0xbf, 0x72, 0xcd, 0x8f ], [ 0xe0, 0x16, 0xfe, 0x07, 0x4a, 0x6d, 0xa7, 0x31, 0x97, 0x5b, 0x3d, 0x62, 0xd5, 0xd0, 0x4b, 0x0e, 0xe1, 0x6e, 0x5e, 0xd6, 0xbb, 0xd8, 0xb0, 0xfb, 0xab, 0xb4, 0xc8, 0xd4, 0xb5, 0x18, 0xaf, 0x9e ], [ 0x86, 0x7b, 0x18, 0x5f, 0xd0, 0xb0, 0x9a, 0x09, 0x3b, 0x0f, 0xd6, 0x1a, 0x20, 0x22, 0xfe, 0x82, 0x55, 0x70, 0xfb, 0x31, 0x1c, 0x8c, 0xb7, 0xf0, 0x4e, 0xf3, 0x56, 0x1e, 0x08, 0xc9, 0x92, 0x89 ], [ 0xe7, 0x55, 0x6e, 0x5c, 0xc9, 0x57, 0xab, 0xdb, 0x15, 0x15, 0x88, 0x4c, 0xb3, 0x94, 0x29, 0x52, 0xdc, 0x52, 0x70, 0xe4, 0x31, 0x98, 0xc7, 0x96, 0x13, 0x7e, 0x1d, 0x67, 0x0a, 0xc5, 0x56, 0x17 ], [ 0x61, 0x1b, 0xbf, 0xec, 0x47, 0x9a, 0x56, 0x8e, 0xe4, 0x37, 0x06, 0x25, 0x91, 0xb9, 0xd5, 0x0d, 0x4f, 0x87, 0xcc, 0x84, 0x5c, 0x25, 0xe5, 0xa0, 0x84, 0x5c, 0x38, 0xfe, 0x02, 0xc0, 0x7b, 0x74 ], [ 0xde, 0x4b, 0xb0, 0xa8, 0x9d, 0x35, 0xa0, 0xa5, 0xa3, 0x3a, 0x03, 0x64, 0xda, 0x56, 0xd9, 0xea, 0x1b, 0x54, 0x1f, 0x0a, 0xcb, 0x36, 0x8e, 0x70, 0x6c, 0x9f, 0x76, 0xfa, 0xb4, 0xed, 0xac, 0xa0 ], [ 0x82, 0x28, 0xe1, 0x27, 0x6c, 0x55, 0xe2, 0xc5, 0x15, 0x14, 0xec, 0x67, 0x0a, 0xb8, 0xe9, 0x8d, 0xb0, 0x9b, 0xf1, 0xfa, 0xa5, 0x15, 0x12, 0x00, 0x75, 0xb8, 0xb2, 0x28, 0xbd, 0x32, 0xdc, 0x8e ], [ 0x16, 0x50, 0x35, 0x52, 0x1d, 0x63, 0xa1, 0x51, 0x7d, 0xe3, 0xfc, 0x77, 0xc7, 0x2d, 0x82, 0x1f, 0xe6, 0xa8, 0xa6, 0x24, 0xb2, 0xe1, 0x53, 0x7f, 0xd9, 0xf1, 0x80, 0x62, 0x53, 0x22, 0x7f, 0x6a ], [ 0x0a, 0xf2, 0xbc, 0x0b, 0x0d, 0x3a, 0x64, 0x8e, 0x39, 0x8b, 0x9e, 0x77, 0xc0, 0x51, 0xf8, 0x68, 0xd4, 0xd3, 0x57, 0xf9, 0x63, 0x47, 0x31, 0x57, 0x42, 0xf5, 0x64, 0x8d, 0xaf, 0x48, 0x8a, 0x1a ], [ 0x43, 0xaf, 0xf0, 0x3b, 0x7e, 0x68, 0x76, 0x4f, 0xb5, 0x7b, 0x1e, 0xa8, 0xeb, 0x45, 0x92, 0x8d, 0x75, 0x51, 0x81, 0x9f, 0x7d, 0x3f, 0x07, 0xd8, 0xa3, 0x1c, 0xd4, 0xbb, 0xa8, 0xfc, 0x6a, 0x80 ], [ 0x46, 0xfb, 0x35, 0xfe, 0xc3, 0xb3, 0xdc, 0x30, 0x6b, 0x7e, 0x9e, 0xcf, 0x22, 0x1c, 0x48, 0x59, 0x57, 0x34, 0xde, 0x23, 0x45, 0x06, 0xe9, 0xff, 0x36, 0x62, 0x01, 0x15, 0x8c, 0x19, 0xd6, 0xee ], [ 0xae, 0xe6, 0x24, 0x92, 0xe9, 0x9c, 0x66, 0x0e, 0xda, 0xd4, 0xb9, 0x30, 0xfd, 0xc7, 0xec, 0x63, 0xfe, 0x8a, 0x1f, 0x0f, 0xa1, 0xdf, 0xca, 0xa9, 0x90, 0xea, 0xbb, 0xa7, 0x65, 0xcb, 0xc9, 0x41 ], [ 0xed, 0x49, 0x2a, 0x48, 0x8e, 0x3b, 0x1e, 0x7b, 0x6d, 0x67, 0x2f, 0xdf, 0xf4, 0x89, 0xf6, 0x7d, 0xf0, 0x68, 0x65, 0x2f, 0xd4, 0xe3, 0x53, 0x01, 0x82, 0x83, 0x5d, 0xc7, 0x3d, 0x3c, 0x06, 0xa7 ], [ 0x5c, 0x20, 0xb2, 0xe1, 0xc2, 0xe8, 0x37, 0x56, 0x37, 0x78, 0x7d, 0xe9, 0x5d, 0x4e, 0x20, 0x77, 0x67, 0x54, 0x37, 0x5e, 0x53, 0xf5, 0x05, 0xa9, 0x5a, 0x4f, 0x5e, 0xcc, 0xb6, 0xdf, 0x5e, 0x97 ], [ 0xd6, 0x50, 0xc5, 0x35, 0xbe, 0xa5, 0x9e, 0xe8, 0x15, 0xe6, 0x45, 0xa1, 0xdd, 0x67, 0xc9, 0xdd, 0x99, 0x57, 0xfd, 0x18, 0xa5, 0x63, 0x4f, 0x28, 0xc0, 0xd5, 0xd7, 0xa2, 0xfb, 0x84, 0xcb, 0xbd ], [ 0xba, 0x81, 0x78, 0x77, 0xad, 0x41, 0xb8, 0xc7, 0x70, 0x67, 0x04, 0x26, 0x45, 0x7f, 0xa4, 0x24, 0x1e, 0x90, 0x68, 0x32, 0x9b, 0x39, 0x5c, 0xc0, 0x77, 0xaa, 0x0f, 0x2c, 0x33, 0xb6, 0x4b, 0x78 ], [ 0x4b, 0xe5, 0x2b, 0xf0, 0xae, 0xdf, 0x63, 0x96, 0x4f, 0x60, 0x2a, 0x71, 0x73, 0xf6, 0xb7, 0x32, 0x43, 0x27, 0x70, 0x95, 0x0e, 0xe3, 0x5d, 0x3a, 0xd6, 0xad, 0xf5, 0x9b, 0x51, 0x8e, 0x1c, 0xea ], [ 0xd2, 0x70, 0xc5, 0x46, 0xf2, 0x5b, 0x75, 0x09, 0x97, 0x58, 0x1b, 0x61, 0xa5, 0x8a, 0x25, 0x2a, 0x0a, 0x4b, 0xb2, 0x19, 0x06, 0x0c, 0x0b, 0x60, 0x80, 0x94, 0x44, 0x11, 0xa8, 0x24, 0x80, 0x6d ], [ 0x28, 0x04, 0x94, 0x35, 0xea, 0x0c, 0x68, 0x55, 0x97, 0xce, 0xef, 0x22, 0x18, 0x93, 0x28, 0x19, 0x25, 0xd6, 0x3d, 0xfa, 0x7b, 0x1b, 0x67, 0x12, 0x4c, 0xd8, 0x82, 0x8b, 0x77, 0x5c, 0x95, 0xfd ], [ 0x64, 0x59, 0x78, 0xc3, 0x82, 0x06, 0x56, 0x64, 0x86, 0x0f, 0xcf, 0x60, 0xdc, 0xe8, 0xf9, 0x14, 0x42, 0x53, 0xad, 0x4c, 0xc5, 0x8f, 0x93, 0x1e, 0x94, 0x34, 0x4a, 0xa6, 0x46, 0x8d, 0x2a, 0xe0 ], [ 0x3c, 0x2a, 0xd1, 0xbd, 0x81, 0x60, 0x94, 0xdc, 0x99, 0x79, 0x0a, 0xb0, 0x8a, 0xd9, 0xdc, 0x3f, 0x44, 0xfc, 0xa7, 0x1a, 0x84, 0xaf, 0x5c, 0xa1, 0x94, 0xa8, 0x49, 0x60, 0xdc, 0x96, 0x9c, 0x85 ], [ 0xe1, 0x20, 0x35, 0xd6, 0xfe, 0x97, 0x17, 0x21, 0xde, 0x96, 0xa5, 0xfe, 0x09, 0xf1, 0xac, 0x11, 0x8d, 0x12, 0x66, 0x14, 0x9e, 0xd5, 0xa0, 0xb3, 0x0a, 0x74, 0x00, 0x45, 0x88, 0xed, 0x9b, 0x07 ], [ 0x5d, 0x1d, 0x68, 0xff, 0xa0, 0x2c, 0x69, 0x21, 0xec, 0x15, 0xdd, 0x04, 0x40, 0x64, 0xbf, 0x9e, 0x1a, 0x4d, 0xd3, 0xb6, 0xf7, 0x4e, 0xfc, 0x7d, 0x81, 0xcb, 0x6d, 0xd0, 0xd9, 0xe7, 0xe7, 0x14 ], [ 0x73, 0xbd, 0xa7, 0x30, 0xdd, 0xde, 0x9e, 0xfc, 0x10, 0xf2, 0x85, 0x17, 0x5d, 0x2d, 0x10, 0xd2, 0x93, 0x8e, 0xdc, 0xf9, 0x81, 0x81, 0x3c, 0xe2, 0x92, 0x80, 0x8a, 0xa6, 0xa9, 0xe0, 0x65, 0xc4 ], [ 0x17, 0x27, 0x05, 0x71, 0x4d, 0xe1, 0xea, 0xb0, 0xf9, 0xa8, 0xab, 0xb2, 0xfe, 0x6d, 0xdd, 0x11, 0x1d, 0x8f, 0x24, 0x9f, 0x2d, 0x1f, 0x98, 0x5a, 0x62, 0x23, 0xa1, 0xb2, 0x75, 0xdf, 0x2f, 0xaf ], [ 0xc4, 0x69, 0x99, 0x32, 0x99, 0x49, 0x54, 0xae, 0xd4, 0x38, 0x06, 0xa1, 0x57, 0xcf, 0x99, 0x1b, 0xb8, 0xc8, 0x94, 0x7c, 0x5e, 0x80, 0x0e, 0x5b, 0x0e, 0xd2, 0x64, 0xb1, 0xaa, 0x1e, 0x2e, 0x5a ], [ 0x9e, 0x0c, 0xfe, 0x3e, 0xec, 0x6e, 0xb1, 0xd4, 0xe6, 0xff, 0x6d, 0xdb, 0xbf, 0xb4, 0x42, 0x58, 0x75, 0xd3, 0x5c, 0x4d, 0xf2, 0xd1, 0x24, 0x75, 0x8f, 0xab, 0xc3, 0x8b, 0x49, 0xf8, 0x5a, 0xff ], [ 0x85, 0x12, 0x1f, 0x24, 0x1c, 0xf4, 0x9c, 0xd4, 0x13, 0x57, 0x03, 0xba, 0x2e, 0x58, 0x3e, 0x40, 0xac, 0x62, 0x73, 0xfd, 0x3b, 0x33, 0xfd, 0x3e, 0xe4, 0xbb, 0xa6, 0x61, 0xae, 0xaf, 0x54, 0x55 ], [ 0xfb, 0x9b, 0xf7, 0xcc, 0x73, 0xb3, 0x07, 0x13, 0x8b, 0x99, 0x9c, 0x3f, 0xf1, 0xa3, 0x17, 0x62, 0x69, 0x4d, 0x10, 0x6d, 0x45, 0xb3, 0x58, 0x54, 0x51, 0x3c, 0x15, 0x44, 0x59, 0x6a, 0x11, 0xf3 ], [ 0x23, 0x2d, 0x6a, 0x3a, 0xe6, 0x85, 0x31, 0xbf, 0xcb, 0x94, 0x91, 0xf1, 0x33, 0x94, 0xea, 0x29, 0x7d, 0x92, 0x5c, 0x79, 0x00, 0x3e, 0xc4, 0xee, 0xaf, 0xce, 0xff, 0x81, 0x41, 0xfa, 0xc8, 0x15 ], [ 0xab, 0xd2, 0xb5, 0x2e, 0x27, 0x02, 0xf9, 0xfe, 0xe8, 0x09, 0xfa, 0x08, 0x09, 0x8b, 0x8c, 0x4a, 0x0f, 0x43, 0xa5, 0xcc, 0xbc, 0xcf, 0x21, 0x0f, 0x13, 0xdd, 0xce, 0xab, 0xb7, 0xd4, 0x4c, 0x2a ], [ 0x9b, 0x28, 0x4a, 0x37, 0xc4, 0x78, 0xa1, 0x57, 0xc9, 0x29, 0xe7, 0xa7, 0xdd, 0x16, 0xd8, 0x09, 0xf9, 0x04, 0xd5, 0x7c, 0x37, 0xa3, 0x0c, 0xf3, 0xa7, 0x27, 0xc9, 0x77, 0x17, 0xd8, 0x98, 0x0c ], [ 0xcd, 0xbe, 0xe0, 0xaf, 0x61, 0x92, 0xa0, 0x26, 0x95, 0x87, 0x92, 0x14, 0xb6, 0x0d, 0x57, 0x8f, 0x97, 0x2a, 0x37, 0xf5, 0xd7, 0x2e, 0xc8, 0xd0, 0xb5, 0xb6, 0x27, 0xd5, 0x42, 0xc7, 0x0c, 0xd3 ], [ 0x40, 0xff, 0x1b, 0xb2, 0x16, 0x13, 0x37, 0x99, 0xf3, 0xef, 0x4f, 0xaa, 0xba, 0xe5, 0xfa, 0x24, 0x09, 0xa5, 0xc9, 0x5a, 0xff, 0xc9, 0xb5, 0x42, 0xff, 0xe7, 0xad, 0xbf, 0xb6, 0x42, 0xa6, 0xc1 ], [ 0xcf, 0xaa, 0x36, 0xb3, 0xa0, 0xda, 0xcf, 0x1f, 0x43, 0xcb, 0x90, 0x7d, 0xf5, 0x3d, 0x0a, 0xc0, 0x68, 0x8d, 0x36, 0xfe, 0xb3, 0x0d, 0xf1, 0x16, 0x0d, 0xe1, 0x24, 0x43, 0xb0, 0x41, 0x5f, 0xbb ], ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" plain_texts3_128bit = [ [ 0x94, 0x75, 0xdd, 0x02, 0x15, 0x37, 0x32, 0xbb, 0x6b, 0x31, 0xe2, 0x9f, 0x8d, 0xa5, 0xc3, 0x57, 0x65, 0x8c, 0x2d, 0xad, 0x55, 0xbf, 0xe9, 0x60, 0xdf ], [ 0xed, 0x35, 0x0c, 0xb0, 0x5b, 0xa6, 0x5b, 0x5e, 0x5b, 0x1f, 0xe4, 0x37, 0xa1, 0x5d, 0xb5, 0x7c, 0x66, 0xb4, 0xc2, 0xb7, 0x48, 0x1a, 0x41, 0x5e, 0x6f ], [ 0x86, 0x12, 0x0e, 0x30, 0x8d, 0x7e, 0x38, 0xe7, 0xbd, 0x9b, 0x43, 0x77, 0x15, 0xe1, 0x9e, 0x43, 0xb2, 0x43, 0xfc, 0xa9, 0xe4, 0xcd, 0x05, 0xc0, 0xf5 ], [ 0x92, 0xde, 0xa2, 0xec, 0x45, 0x9a, 0x91, 0xdf, 0xe8, 0x4b, 0xdf, 0xcc, 0x5c, 0x08, 0xeb, 0x6a, 0x3c, 0x86, 0x12, 0x41, 0xc0, 0x52, 0x41, 0xc7, 0xfa ], [ 0xec, 0xbf, 0xfc, 0xcc, 0xdc, 0x9e, 0x1b, 0xbe, 0x60, 0x2f, 0x1a, 0xa1, 0xe5, 0x1b, 0xb3, 0xad, 0x0d, 0x70, 0xc5, 0x6d, 0x34, 0x40, 0x5b, 0xce, 0xdd ], [ 0x49, 0x0c, 0x6b, 0x50, 0x8d, 0x5d, 0x58, 0xfe, 0x24, 0xc5, 0xd3, 0xdf, 0x81, 0xdd, 0x90, 0x8c, 0xb0, 0x47, 0x47, 0x37, 0x57, 0xac, 0xb4, 0x61, 0x13 ], [ 0xdd, 0x74, 0x3f, 0x4d, 0xe3, 0xcb, 0xb9, 0x91, 0x1f, 0xc6, 0xb8, 0xa0, 0x49, 0x32, 0x1c, 0xd1, 0xfb, 0x81, 0x3a, 0x7e, 0x91, 0x52, 0xfe, 0xe4, 0x84 ], [ 0xf8, 0x26, 0x70, 0x8d, 0xf3, 0x91, 0xb4, 0x65, 0xc3, 0x95, 0x71, 0xcf, 0x69, 0x08, 0xa5, 0xf7, 0x30, 0xea, 0x60, 0x38, 0x03, 0x4f, 0x25, 0xa1, 0x50 ], [ 0x92, 0x43, 0x75, 0x49, 0x96, 0xb0, 0x06, 0x61, 0x08, 0x9e, 0x35, 0xac, 0x65, 0x42, 0x3d, 0x63, 0x17, 0x7d, 0xa0, 0x76, 0x46, 0x2c, 0x71, 0x85, 0xc6 ], [ 0x9a, 0xd2, 0x3c, 0xb9, 0xbd, 0x37, 0x7a, 0x05, 0x02, 0xe4, 0xcc, 0x9f, 0x9d, 0xf4, 0x3b, 0x8b, 0x83, 0x05, 0x49, 0x77, 0x9e, 0x92, 0x23, 0xfe, 0xf8 ], [ 0x54, 0x32, 0x4f, 0x39, 0xcf, 0xe3, 0x46, 0x31, 0x26, 0x92, 0x5e, 0xf4, 0x44, 0xca, 0xf1, 0x8b, 0x3b, 0xeb, 0xd2, 0x95, 0x66, 0x51, 0xf0, 0xe6, 0xfd ], [ 0xd3, 0xd4, 0x36, 0x53, 0x39, 0x38, 0x03, 0xfd, 0x1b, 0xc2, 0xbd, 0xb4, 0xa2, 0x7c, 0xad, 0x10, 0x85, 0xd8, 0x23, 0x5c, 0xf8, 0x75, 0x42, 0x6a, 0xf3 ], [ 0x2e, 0x6d, 0xa9, 0xda, 0xc3, 0xd1, 0x67, 0x20, 0xd0, 0xb4, 0x02, 0xea, 0xa4, 0x8d, 0x58, 0x5f, 0x76, 0xa3, 0xc6, 0xda, 0x6a, 0x87, 0x2e, 0x94, 0xdb ], [ 0x6e, 0x3a, 0x04, 0x42, 0x95, 0x8f, 0x64, 0x21, 0xa1, 0x47, 0xb2, 0xb4, 0xef, 0x7a, 0x8d, 0xe8, 0xcf, 0x3e, 0x37, 0x5a, 0xf8, 0xd0, 0x7d, 0x73, 0xbd ], [ 0x85, 0x86, 0x8e, 0xc4, 0xaf, 0x1d, 0xf8, 0x7f, 0xbc, 0x3a, 0x3c, 0xb8, 0x40, 0xea, 0x93, 0xbe, 0x60, 0x98, 0xc0, 0xdc, 0xf3, 0x5f, 0x18, 0x90, 0x1b ], [ 0xe5, 0xa0, 0xe9, 0x87, 0x44, 0x8f, 0xb9, 0x09, 0xb5, 0x80, 0x33, 0xf8, 0x67, 0x0a, 0xaa, 0x88, 0x23, 0x17, 0x37, 0x0f, 0x0a, 0x44, 0x27, 0xfb, 0xc3 ], [ 0xaf, 0x0d, 0xb7, 0x96, 0x8c, 0x67, 0xf6, 0x8f, 0x31, 0x37, 0x08, 0xa5, 0x5d, 0x1d, 0xe9, 0xde, 0x87, 0x49, 0x1c, 0x2c, 0x07, 0xf7, 0x4c, 0xdf, 0x85 ], [ 0xd6, 0x06, 0xec, 0x41, 0x46, 0x42, 0x81, 0x45, 0xdb, 0x4c, 0xac, 0xcb, 0x7b, 0x5b, 0x87, 0xfd, 0xc2, 0xd4, 0xd2, 0x5b, 0x7a, 0x44, 0xec, 0x99, 0x3a ], [ 0x63, 0xdb, 0x50, 0x6c, 0x7e, 0xa1, 0x7e, 0x5c, 0xd7, 0x5d, 0xcc, 0x12, 0xf6, 0xc4, 0xa4, 0x27, 0x30, 0x5b, 0xb9, 0x8e, 0xa6, 0x24, 0x7b, 0x47, 0xb2 ], [ 0xbd, 0x22, 0x51, 0x16, 0x0c, 0x6b, 0x3e, 0xa8, 0x0c, 0xcc, 0x35, 0x47, 0x58, 0xee, 0x29, 0x71, 0xbd, 0xc8, 0xde, 0x9e, 0xf7, 0xe9, 0x40, 0x56, 0xc4 ], [ 0xc6, 0x69, 0xd4, 0x46, 0x47, 0x84, 0xeb, 0x9b, 0xcd, 0xd0, 0x9f, 0x8e, 0x3a, 0xa3, 0x8a, 0x3c, 0x83, 0x8d, 0x1d, 0x34, 0xf8, 0xd3, 0xf5, 0x50, 0x52 ], [ 0xc3, 0xf4, 0x59, 0x37, 0x0e, 0xa0, 0x4d, 0x69, 0x97, 0xb4, 0x6a, 0x7c, 0xe5, 0x23, 0xf6, 0x3e, 0x26, 0x0a, 0x24, 0x95, 0xdc, 0xb6, 0x48, 0xae, 0xc7 ], [ 0xe9, 0x53, 0x2d, 0xa7, 0x5d, 0xa1, 0xa5, 0xc1, 0x3b, 0x74, 0x66, 0x67, 0xfb, 0x07, 0x26, 0x01, 0xdd, 0x70, 0x15, 0x67, 0x71, 0x4a, 0xdc, 0xe4, 0x2d ], [ 0x5a, 0xa1, 0x1c, 0x28, 0x74, 0x5d, 0x15, 0x56, 0x7c, 0x77, 0x4a, 0xd6, 0x18, 0x58, 0x13, 0xc2, 0x28, 0x06, 0x73, 0xc8, 0xf0, 0x32, 0xa6, 0x1c, 0x6c ], [ 0x04, 0x9e, 0xe2, 0xf3, 0xb0, 0x49, 0xe9, 0x30, 0x3a, 0x0d, 0x4b, 0xf4, 0x7f, 0x0c, 0x5b, 0x76, 0xe6, 0xf6, 0xd1, 0x43, 0x11, 0x58, 0xb2, 0xd2, 0x3a ], [ 0x81, 0xab, 0x55, 0x15, 0x1b, 0x51, 0xb4, 0x18, 0x81, 0xe6, 0x75, 0xc4, 0xd8, 0xbf, 0xb3, 0x76, 0xd7, 0x9c, 0x26, 0x42, 0x5b, 0xe1, 0xbd, 0x6a, 0x5e ], [ 0xc5, 0x98, 0x1c, 0x2f, 0x99, 0xd8, 0xba, 0xf6, 0xcf, 0x78, 0x50, 0xd9, 0xf3, 0x62, 0x9b, 0xe0, 0x55, 0x8d, 0x41, 0x1b, 0xaf, 0xa3, 0x06, 0x57, 0xe3 ], [ 0x33, 0xd4, 0xc7, 0x1a, 0x8c, 0x59, 0x39, 0x4c, 0x82, 0x62, 0xa9, 0x20, 0x9b, 0xec, 0x31, 0x48, 0x4c, 0xfe, 0xc2, 0x7f, 0x44, 0x9e, 0x22, 0x3b, 0x3b ], [ 0x95, 0xed, 0xed, 0xf9, 0xfa, 0x5c, 0xa3, 0x94, 0x8a, 0x84, 0x9e, 0x5e, 0x3e, 0xea, 0x11, 0x64, 0x2f, 0xae, 0xfd, 0xa4, 0xdb, 0x41, 0x5f, 0xab, 0x5b ], [ 0x35, 0x8e, 0x7b, 0xe7, 0x5e, 0x5a, 0x18, 0xa8, 0x23, 0x4e, 0x53, 0x6e, 0x37, 0x40, 0x24, 0xc4, 0x73, 0x68, 0x01, 0x86, 0xd3, 0xa8, 0x5f, 0x5d, 0x20 ], [ 0x82, 0xa0, 0x50, 0x58, 0x46, 0x4d, 0x90, 0xec, 0xc6, 0x7b, 0x5a, 0xd3, 0x14, 0xe5, 0x79, 0x5a, 0xb0, 0xa4, 0x56, 0x27, 0x41, 0x66, 0x32, 0x87, 0x3f ], [ 0xd8, 0x12, 0xb7, 0x64, 0x44, 0x9a, 0xc9, 0x57, 0xf8, 0x8b, 0x3c, 0xc6, 0x34, 0x9c, 0x0a, 0x74, 0x33, 0x8a, 0x52, 0x9d, 0xd7, 0x9d, 0x6b, 0xca, 0xab ], [ 0x4d, 0xb3, 0x87, 0x63, 0xd9, 0x3f, 0x33, 0x45, 0x47, 0xcc, 0x76, 0x0d, 0xfb, 0x6b, 0x18, 0x7a, 0xbe, 0x5b, 0x5a, 0x02, 0x46, 0xc5, 0x8e, 0xb0, 0x66 ], [ 0xd3, 0xfe, 0xf0, 0x15, 0x61, 0x3f, 0x51, 0xd2, 0xe3, 0x58, 0x83, 0x7f, 0x4e, 0x0e, 0x23, 0xa1, 0x05, 0xba, 0xa8, 0x74, 0xc6, 0x4d, 0xb2, 0x53, 0x1d ], [ 0x41, 0x26, 0x39, 0xe3, 0x06, 0xc3, 0x06, 0x13, 0x47, 0x6f, 0x95, 0x1e, 0xc6, 0x1a, 0x20, 0x32, 0x1a, 0x00, 0x83, 0x88, 0x6f, 0xc3, 0xc0, 0xe3, 0xa7 ], [ 0x9d, 0x24, 0x7e, 0xef, 0x8e, 0x3e, 0x00, 0xfc, 0xcf, 0x51, 0x9a, 0x7e, 0x0b, 0x61, 0x00, 0x8f, 0xd7, 0x3d, 0x2a, 0x5a, 0x17, 0x67, 0x72, 0x10, 0x96 ], [ 0xaa, 0x7a, 0x0f, 0xb2, 0x19, 0x3c, 0x6c, 0x57, 0xb8, 0x2d, 0x3f, 0x37, 0x56, 0x2f, 0x3f, 0xf8, 0xc9, 0xd8, 0xec, 0x0e, 0x5f, 0xe7, 0xea, 0xd0, 0xd6 ], [ 0x22, 0x90, 0x1e, 0xf0, 0xf8, 0x65, 0xe9, 0x2d, 0x2b, 0xea, 0x19, 0x23, 0x8c, 0xf5, 0xd7, 0x6a, 0x80, 0x2b, 0x7a, 0xf4, 0x76, 0x42, 0xeb, 0xd7, 0x42 ], [ 0x88, 0x1e, 0x90, 0xb4, 0xc7, 0x0d, 0xdb, 0xda, 0x40, 0xb7, 0xe4, 0xc4, 0x65, 0x48, 0x2e, 0x98, 0x54, 0xe1, 0x94, 0xba, 0x96, 0x4d, 0x1f, 0x80, 0xa2 ], [ 0x25, 0xb2, 0xed, 0x35, 0x46, 0xe7, 0xf1, 0x74, 0xa2, 0x9b, 0xf8, 0x43, 0x37, 0x7e, 0x91, 0x39, 0xae, 0x42, 0x8a, 0x24, 0xd4, 0xc9, 0xe6, 0x28, 0x52 ], [ 0x67, 0xa3, 0x7d, 0x74, 0xef, 0x2e, 0xde, 0x7c, 0xee, 0x56, 0xfd, 0x5e, 0xa3, 0xad, 0x41, 0x8d, 0x08, 0xcf, 0x9a, 0x1d, 0xbb, 0xf1, 0x1a, 0xf9, 0xc3 ], [ 0xc4, 0x48, 0x0c, 0x6e, 0x7c, 0xb1, 0x94, 0xe0, 0x86, 0xb9, 0x8f, 0xa2, 0xae, 0x41, 0xf6, 0x62, 0xc8, 0xb6, 0xbd, 0xad, 0xa2, 0x9e, 0x3d, 0x39, 0x4c ], [ 0x95, 0xa6, 0x5a, 0x9e, 0x57, 0xc8, 0x1a, 0xd3, 0xa3, 0x81, 0xb0, 0x99, 0x4c, 0xb7, 0x19, 0x71, 0x4a, 0xd6, 0x83, 0x82, 0x55, 0x53, 0x4d, 0x3d, 0x1b ], [ 0x29, 0xc3, 0x50, 0x8f, 0xba, 0x48, 0x28, 0x5f, 0x2c, 0x02, 0xea, 0xab, 0xf7, 0x5e, 0x79, 0x02, 0x68, 0xa6, 0xd5, 0x9e, 0x52, 0xfc, 0x2d, 0xcc, 0xab ], [ 0xa3, 0x2d, 0x4b, 0x93, 0x55, 0xaf, 0xa6, 0x90, 0x52, 0x52, 0x11, 0x18, 0x5e, 0x19, 0x58, 0x68, 0x60, 0xea, 0xb6, 0x7d, 0x34, 0x30, 0x8e, 0xc4, 0xa6 ], [ 0x59, 0x63, 0x16, 0x52, 0xdd, 0xbc, 0x62, 0x39, 0x57, 0x84, 0xbf, 0x18, 0xcb, 0xc9, 0x67, 0xce, 0xf6, 0x6e, 0xa5, 0x18, 0x0f, 0x3f, 0x6d, 0xf5, 0xaa ], [ 0xd4, 0x2a, 0xd0, 0x36, 0x52, 0x1b, 0x1d, 0x84, 0x20, 0x0f, 0xaf, 0x86, 0xd9, 0x78, 0x86, 0x79, 0xe8, 0x93, 0x77, 0x28, 0x0b, 0x78, 0x33, 0xe4, 0x34 ], [ 0x66, 0x31, 0x73, 0x22, 0xce, 0xf8, 0x42, 0x5d, 0x53, 0x5e, 0xb6, 0xb2, 0x95, 0x10, 0xac, 0x97, 0x62, 0xed, 0x07, 0x7c, 0x66, 0x24, 0xc5, 0x00, 0xe9 ], [ 0x86, 0x10, 0x52, 0xfe, 0xe0, 0xe7, 0x44, 0xf3, 0x46, 0xf1, 0x13, 0xaf, 0x0e, 0x81, 0x10, 0x03, 0x60, 0x08, 0x8f, 0xaf, 0x18, 0x34, 0xbc, 0x6c, 0xc5 ], [ 0x48, 0x0b, 0xfe, 0x39, 0x8c, 0x1a, 0x62, 0x71, 0x29, 0xd1, 0x1a, 0x51, 0xc9, 0xde, 0x9b, 0x4e, 0x0a, 0xbd, 0xa9, 0x40, 0x20, 0xdb, 0xc5, 0xd1, 0x49 ], [ 0x30, 0xa7, 0xe3, 0x38, 0x2b, 0x77, 0x78, 0xbb, 0x6f, 0xd2, 0xee, 0xc2, 0xb6, 0x1e, 0x29, 0x70, 0xdc, 0xc3, 0x4f, 0xe8, 0xe9, 0xb7, 0xb8, 0xbf, 0x4e ], [ 0x3d, 0x90, 0xee, 0xed, 0x5a, 0x13, 0x68, 0x06, 0x53, 0xb2, 0x1e, 0x6d, 0x8e, 0x76, 0x66, 0x24, 0x62, 0x1e, 0x00, 0x27, 0xf8, 0xc6, 0x0c, 0xd1, 0x05 ], [ 0xe1, 0x71, 0xb4, 0x93, 0x71, 0xf0, 0x13, 0x55, 0xb8, 0x6c, 0xa8, 0xf7, 0xe4, 0x5a, 0x9b, 0xf5, 0x35, 0x71, 0x3b, 0x05, 0xea, 0x0e, 0x14, 0x54, 0xe5 ], [ 0x54, 0xb3, 0xbf, 0xb4, 0x07, 0x6e, 0x61, 0xaa, 0x95, 0x23, 0x54, 0xf3, 0xc2, 0xe1, 0x5b, 0xab, 0xc3, 0x81, 0x7f, 0xc8, 0x64, 0xc2, 0xba, 0xd3, 0x29 ], [ 0x6e, 0x17, 0x2a, 0xa1, 0x52, 0x3c, 0x95, 0x1b, 0xe8, 0xe7, 0x60, 0xf5, 0x07, 0x84, 0xe7, 0x2b, 0x14, 0xe0, 0xb3, 0x51, 0x68, 0xa3, 0xc5, 0x41, 0xa3 ], [ 0xb1, 0x36, 0xf6, 0x20, 0x3b, 0x48, 0xcf, 0x1d, 0xef, 0x82, 0x61, 0xfc, 0x40, 0xab, 0x6e, 0xb8, 0x27, 0xc3, 0x3b, 0x7e, 0x53, 0xcc, 0xc4, 0xde, 0x95 ], [ 0xe1, 0x43, 0x71, 0xfe, 0xa2, 0x6a, 0xc4, 0x67, 0xe1, 0x4c, 0x13, 0x84, 0xb7, 0xe0, 0x50, 0xa3, 0xb5, 0x1d, 0x63, 0xbf, 0x9d, 0xd0, 0xd5, 0x77, 0x41 ], [ 0xad, 0x2a, 0xaa, 0xa8, 0x3e, 0x52, 0x61, 0x30, 0x34, 0xe0, 0x71, 0xc2, 0x2e, 0xd9, 0xa1, 0xac, 0xf5, 0x71, 0xfc, 0x56, 0x39, 0xd9, 0x6b, 0x94, 0x77 ], [ 0x15, 0xa9, 0xe6, 0x88, 0xa0, 0x1f, 0x8a, 0x20, 0x1d, 0xc7, 0xb8, 0x08, 0x47, 0xeb, 0xb5, 0x98, 0xa8, 0xd4, 0xd3, 0x9b, 0xa0, 0xde, 0x21, 0xdf, 0xc6 ], [ 0xa8, 0x7f, 0x0f, 0xef, 0xde, 0x2e, 0xfa, 0x27, 0x20, 0xf0, 0xdf, 0xff, 0x0c, 0xf1, 0x06, 0xbf, 0xe3, 0x52, 0x95, 0xdc, 0x29, 0xce, 0xf8, 0x63, 0x4b ], [ 0x65, 0xc5, 0xd0, 0xb8, 0xa6, 0xb2, 0xaf, 0x57, 0x16, 0xbf, 0xfd, 0xd8, 0xf6, 0xae, 0xa7, 0xb3, 0x9e, 0x5e, 0xe2, 0x02, 0x32, 0x47, 0x21, 0x99, 0x3e ], [ 0xd3, 0x59, 0x16, 0xfd, 0xe4, 0xf2, 0xe0, 0x86, 0xcc, 0x31, 0x0a, 0x17, 0xa5, 0x54, 0xa6, 0x0c, 0x9f, 0xc5, 0xa2, 0x27, 0x20, 0x78, 0xe0, 0x67, 0x42 ], [ 0x99, 0x5d, 0x9c, 0x98, 0x3d, 0xd7, 0x7b, 0xd6, 0x82, 0x83, 0x0f, 0x03, 0xc0, 0x43, 0xe7, 0xc4, 0xa1, 0x06, 0xb8, 0x97, 0x3e, 0x02, 0xe8, 0xb2, 0xa9 ], [ 0xe3, 0x5c, 0xb6, 0x77, 0x1a, 0x79, 0x83, 0xbd, 0x99, 0x0d, 0xec, 0x0d, 0xcb, 0x28, 0xef, 0x5d, 0x5b, 0xff, 0x22, 0x25, 0x3b, 0xf7, 0x41, 0xac, 0x87 ], [ 0xb2, 0x39, 0x68, 0x07, 0x4f, 0x63, 0x9f, 0xf6, 0x5c, 0xe5, 0x5f, 0x9f, 0x0f, 0xbe, 0xb5, 0x7a, 0x10, 0x95, 0x46, 0x8a, 0x98, 0x64, 0xf1, 0xd6, 0x16 ], [ 0x21, 0xe9, 0xa2, 0x41, 0xc5, 0x81, 0x40, 0xe0, 0x36, 0x9b, 0x36, 0x77, 0x04, 0x5a, 0xa4, 0xf2, 0x25, 0xca, 0x73, 0x5e, 0xf9, 0xac, 0x5e, 0x87, 0xd1 ], [ 0x4c, 0x5c, 0x75, 0xf0, 0xfe, 0xdc, 0x86, 0xb7, 0x66, 0xeb, 0x4d, 0xf5, 0x94, 0x65, 0x43, 0x1e, 0xb3, 0xe7, 0x16, 0x00, 0x7b, 0xba, 0x8d, 0xc9, 0xec ], [ 0x9b, 0x7d, 0x57, 0xf9, 0xd4, 0x58, 0x54, 0xa0, 0x11, 0x51, 0x6d, 0x93, 0xdc, 0x56, 0xff, 0x73, 0xda, 0x2c, 0xb3, 0x74, 0x56, 0x2a, 0x67, 0x1b, 0xef ], [ 0x72, 0x29, 0x1a, 0xea, 0x23, 0x0d, 0x2b, 0x52, 0xb9, 0x27, 0xd6, 0xaa, 0xe5, 0x95, 0x7c, 0x08, 0xa3, 0x8f, 0x21, 0xb2, 0x6a, 0x37, 0x99, 0x08, 0xec ], [ 0xc1, 0x10, 0x19, 0x1e, 0x9e, 0x93, 0x2d, 0xcb, 0x81, 0xfa, 0x86, 0xf9, 0x4f, 0xf5, 0x03, 0x88, 0x10, 0x44, 0xdd, 0x1e, 0x12, 0x9e, 0xdf, 0x16, 0xe5 ], [ 0xb2, 0x10, 0x74, 0xd1, 0x12, 0x57, 0xea, 0xdf, 0xd8, 0x28, 0x29, 0x1a, 0xd5, 0x7e, 0x1f, 0x29, 0x4f, 0xf7, 0x07, 0x94, 0xd3, 0x33, 0x82, 0x17, 0x26 ], [ 0xa7, 0xc8, 0xd6, 0x67, 0x21, 0xa4, 0xc7, 0x6d, 0x1c, 0xa9, 0xf5, 0x20, 0x5d, 0x53, 0x27, 0xb5, 0x20, 0x67, 0xcb, 0x6f, 0x51, 0x20, 0x95, 0xb8, 0x63 ], [ 0x85, 0x0d, 0xe3, 0x08, 0x2a, 0x0c, 0x7d, 0xe1, 0xee, 0xda, 0x92, 0x34, 0xb6, 0xeb, 0x6d, 0x76, 0x74, 0x7d, 0xe1, 0x26, 0x7a, 0x2e, 0xe3, 0xe5, 0xfe ], [ 0x8a, 0x95, 0x26, 0xbf, 0xd3, 0x45, 0x78, 0x40, 0x8b, 0xb7, 0xe8, 0x98, 0x45, 0xc6, 0xe5, 0xa7, 0x9c, 0x34, 0x8c, 0xd1, 0xc6, 0xa9, 0x5d, 0xab, 0x09 ], [ 0x7b, 0x3c, 0x94, 0x2a, 0x7b, 0x29, 0xc0, 0xf3, 0xa3, 0x12, 0x5f, 0x14, 0x73, 0xac, 0x20, 0x9f, 0xf5, 0x73, 0x12, 0x65, 0x82, 0x4f, 0xf2, 0xdf, 0x31 ], [ 0x98, 0xd6, 0xda, 0xdb, 0xad, 0xb6, 0x7b, 0x5b, 0x1d, 0xf7, 0x27, 0x94, 0xdb, 0xcc, 0xec, 0xb3, 0xc1, 0xbc, 0x1d, 0xe3, 0xef, 0xdb, 0x29, 0x83, 0xc3 ], [ 0x8a, 0x52, 0x24, 0xeb, 0xb2, 0x72, 0x92, 0xc6, 0x99, 0x63, 0x50, 0xb3, 0x2c, 0x3b, 0x1f, 0x2f, 0xf1, 0x88, 0x4c, 0x17, 0x9d, 0x3b, 0x5b, 0x4a, 0xbf ], [ 0xf4, 0x7d, 0xb3, 0x36, 0xf1, 0x94, 0xe8, 0x9a, 0x9e, 0x3f, 0x2a, 0xfa, 0xee, 0x51, 0xb5, 0x07, 0x55, 0x83, 0xa5, 0x33, 0x32, 0x0f, 0x92, 0x30, 0xb6 ], [ 0xdc, 0xdf, 0x42, 0x7f, 0x9c, 0x2b, 0xe9, 0x6f, 0xea, 0xaa, 0x58, 0x74, 0x09, 0x92, 0x4c, 0xe0, 0x0b, 0xd2, 0x7d, 0x4d, 0xc3, 0xd3, 0x98, 0x0c, 0x61 ], [ 0x1e, 0xd7, 0x4f, 0xf9, 0xe6, 0x35, 0x51, 0xd4, 0x74, 0xf5, 0x33, 0x1f, 0x63, 0xb3, 0xa2, 0x2d, 0x64, 0x40, 0xbe, 0x19, 0x33, 0x57, 0x32, 0x98, 0xfa ], [ 0x58, 0x58, 0xc5, 0xe8, 0x9f, 0x58, 0xdd, 0xe6, 0x00, 0xd3, 0x0a, 0xda, 0x52, 0x0c, 0x35, 0xef, 0x68, 0xa9, 0x18, 0x25, 0x07, 0x27, 0x17, 0x96, 0x42 ], [ 0x56, 0x79, 0x52, 0x1a, 0x1b, 0xa1, 0xda, 0xc5, 0xb6, 0xe3, 0xa6, 0x15, 0xe1, 0x2e, 0xa8, 0xa0, 0x5c, 0xe6, 0xc3, 0x5a, 0xc3, 0x6c, 0x80, 0x11, 0x8e ], [ 0x5f, 0xec, 0x25, 0xa3, 0x95, 0x6f, 0x46, 0xb4, 0x7e, 0x66, 0x07, 0x27, 0x9c, 0x50, 0xeb, 0xc3, 0x04, 0x36, 0xa4, 0xe6, 0xeb, 0xbf, 0xad, 0xed, 0xe4 ], [ 0x4e, 0xad, 0xbe, 0xb0, 0xba, 0xce, 0xeb, 0x9c, 0x50, 0x9c, 0xb9, 0x1b, 0x84, 0x24, 0x19, 0xb4, 0x58, 0x0c, 0x45, 0x48, 0x6b, 0xaf, 0xe7, 0xb2, 0xb1 ], [ 0xec, 0x7b, 0xd1, 0x11, 0x2c, 0x86, 0x90, 0xcf, 0x0e, 0xc3, 0x20, 0xa7, 0xe6, 0xde, 0x7b, 0x89, 0x8d, 0xca, 0xcf, 0x76, 0x87, 0xfa, 0xf4, 0x9a, 0xf9 ], [ 0x62, 0xdb, 0x2c, 0x1e, 0x58, 0x79, 0xd0, 0xc9, 0xb1, 0x6e, 0xfe, 0x58, 0xc2, 0x45, 0xc3, 0xe0, 0x11, 0xb3, 0x65, 0x74, 0x57, 0x04, 0x46, 0x47, 0x6a ], [ 0x0d, 0xad, 0x6e, 0x21, 0xac, 0x44, 0x0d, 0xe5, 0x42, 0x84, 0xe3, 0x87, 0x85, 0xdb, 0x84, 0x64, 0x86, 0x19, 0x01, 0x7a, 0xac, 0x90, 0xf2, 0xdc, 0x37 ], [ 0xfe, 0xa7, 0x11, 0x05, 0xd2, 0xd8, 0x6b, 0x1b, 0xcd, 0x1f, 0xfe, 0xb0, 0xf9, 0xd0, 0xfa, 0xf6, 0x1b, 0x6b, 0x99, 0xf2, 0x14, 0xb4, 0x6f, 0xf2, 0xce ], [ 0xe8, 0xe7, 0x5f, 0x23, 0xf2, 0xdd, 0x38, 0x4a, 0xdc, 0x24, 0x50, 0x53, 0x16, 0x9f, 0x25, 0xc4, 0x6a, 0xd0, 0x37, 0x4c, 0x41, 0xce, 0x40, 0x0f, 0x7f ], [ 0x30, 0x9f, 0x2c, 0x68, 0xbd, 0x7d, 0x10, 0x78, 0x5f, 0xac, 0x15, 0x4e, 0xf7, 0x47, 0xe0, 0x71, 0xf0, 0x08, 0x00, 0xfd, 0x3e, 0x23, 0x3a, 0x58, 0x51 ], [ 0x6f, 0x9a, 0x99, 0x54, 0x0b, 0x46, 0x70, 0xa0, 0x90, 0x81, 0xe7, 0x25, 0x08, 0x00, 0x7d, 0x5e, 0x98, 0x13, 0xed, 0xd9, 0x80, 0x9a, 0xd4, 0x79, 0x5e ], [ 0x1b, 0x7b, 0xd0, 0x9b, 0x86, 0x07, 0xa1, 0x76, 0xaf, 0xaf, 0xae, 0xdd, 0x46, 0xc7, 0x66, 0x71, 0xa4, 0x60, 0x8f, 0x3d, 0x0d, 0xe0, 0x99, 0x3d, 0x27 ], [ 0xf7, 0xfc, 0x57, 0x05, 0x48, 0xb2, 0x43, 0xa5, 0xf9, 0x83, 0xe9, 0x73, 0xf3, 0x4d, 0xf1, 0x7e, 0x65, 0x4f, 0x76, 0x1c, 0x47, 0xad, 0x95, 0x17, 0x38 ], [ 0x4d, 0xf1, 0x22, 0x79, 0xfa, 0x56, 0xbb, 0xce, 0x90, 0x47, 0x4c, 0xa3, 0x3d, 0x87, 0x98, 0x67, 0xab, 0x08, 0x79, 0x38, 0x31, 0x7c, 0x53, 0x20, 0x7e ], [ 0x38, 0xe0, 0x4d, 0xd8, 0x50, 0x78, 0x08, 0xd0, 0x74, 0x03, 0x21, 0xd8, 0xbe, 0x4a, 0x9f, 0xdd, 0x19, 0x61, 0xaa, 0x27, 0xf8, 0x7f, 0x33, 0x66, 0xcf ], [ 0x83, 0x78, 0xed, 0x13, 0x41, 0xe3, 0x87, 0xef, 0x4f, 0x27, 0xbe, 0xc0, 0x3a, 0x88, 0x65, 0x8d, 0x11, 0x29, 0x84, 0xef, 0x88, 0x89, 0x55, 0xc6, 0xd6 ], [ 0x65, 0x6b, 0x11, 0x42, 0xf3, 0x98, 0x26, 0x03, 0xc5, 0x49, 0xb1, 0xaa, 0x61, 0xe9, 0x76, 0x9a, 0xd7, 0x46, 0x70, 0x12, 0xc0, 0x3c, 0x41, 0x3d, 0xb8 ], [ 0x95, 0xf4, 0x13, 0x24, 0x08, 0xc7, 0xca, 0x95, 0x6c, 0x4f, 0xdc, 0x71, 0x2c, 0xc9, 0x93, 0xaf, 0x4a, 0x8c, 0x38, 0x77, 0x96, 0xa3, 0x17, 0x75, 0x5b ], [ 0x59, 0x9f, 0x54, 0x97, 0x75, 0xaa, 0x84, 0xbf, 0xe3, 0x98, 0xed, 0xf8, 0x91, 0x98, 0xed, 0x26, 0xc6, 0x12, 0x82, 0x8e, 0x69, 0x43, 0xce, 0x2e, 0x3f ], [ 0xf0, 0x8e, 0x49, 0x31, 0x75, 0xaa, 0xc4, 0x5d, 0x9b, 0x51, 0x78, 0xf5, 0x65, 0xf5, 0x0c, 0x2b, 0xbd, 0x3d, 0x58, 0x75, 0x65, 0xca, 0x67, 0x7c, 0x78 ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" plain_texts4_128bit = [ [ 0xa8, 0xac, 0x2b, 0xba, 0x1d, 0x5d, 0xe9, 0x39, 0x67, 0x9f, 0xbe, 0x3b, 0x97, 0x59, 0x09, 0x49, 0x01, 0x72, 0xfe, 0x86, 0x0e, 0x6c, 0x24, 0xc7, 0x07, 0x63, 0x74, 0xdc, 0x0c, 0xaf, 0x55, 0x35 ], [ 0xe4, 0x8c, 0x20, 0x8d, 0x26, 0x76, 0xad, 0xb2, 0xa5, 0xa6, 0x1d, 0x07, 0x67, 0x7d, 0x4a, 0xfc, 0x1e, 0xec, 0x52, 0x10, 0xc4, 0x17, 0xa9, 0x81, 0x3f, 0x57, 0x9c, 0xa6, 0x26, 0x2a, 0x70, 0xa8 ], [ 0xdb, 0x1d, 0x67, 0x61, 0x19, 0x74, 0xde, 0xf4, 0x90, 0x13, 0xf2, 0xa2, 0xdf, 0x32, 0x28, 0x29, 0xfb, 0xc9, 0x53, 0x62, 0xd1, 0xe0, 0x73, 0x70, 0x0d, 0x65, 0x60, 0xc7, 0x99, 0xa7, 0x5f, 0x09 ], [ 0x0b, 0xc2, 0x08, 0x38, 0x6e, 0xaa, 0xba, 0xe4, 0xc9, 0x86, 0x4e, 0x9f, 0x20, 0x1e, 0x7b, 0xe3, 0x76, 0x45, 0x68, 0xa3, 0x3d, 0x29, 0x29, 0x61, 0x64, 0x27, 0x21, 0x4e, 0xb4, 0x54, 0xae, 0xb6 ], [ 0x8a, 0x43, 0x6c, 0x6d, 0x15, 0xaf, 0xc0, 0xd6, 0x53, 0x54, 0xe8, 0xdd, 0xa2, 0x2d, 0x86, 0x29, 0x65, 0x37, 0xf7, 0x74, 0x68, 0xdf, 0xbf, 0x79, 0x9d, 0xd7, 0xa5, 0x51, 0x7e, 0xe3, 0x9b, 0x46 ], [ 0x8e, 0x1a, 0xc1, 0x76, 0xac, 0x7a, 0xce, 0x30, 0x7f, 0x54, 0xcb, 0xef, 0xdc, 0xfd, 0xd9, 0x62, 0x7d, 0x73, 0x6c, 0xb7, 0xcd, 0x8b, 0xdf, 0x1f, 0xab, 0xa3, 0x38, 0xc3, 0x65, 0x14, 0x61, 0x6f ], [ 0x42, 0x8d, 0x27, 0xa5, 0x57, 0xc5, 0xd6, 0x4f, 0xa7, 0xc3, 0xf3, 0x08, 0x82, 0x61, 0x20, 0x6e, 0x82, 0xdb, 0xa0, 0x3e, 0x31, 0x9a, 0x77, 0x60, 0x97, 0xab, 0x1a, 0x87, 0xb5, 0x4c, 0x4b, 0x19 ], [ 0xb8, 0xfe, 0x1b, 0x89, 0x72, 0xf1, 0xa5, 0xac, 0x81, 0x48, 0xef, 0x18, 0xdb, 0x69, 0x11, 0x86, 0x40, 0xed, 0x36, 0x88, 0x12, 0xa3, 0xa2, 0xd6, 0xbd, 0xc7, 0x1b, 0x09, 0x80, 0x3d, 0x4c, 0x37 ], [ 0xd3, 0x1a, 0xd7, 0xc6, 0xfb, 0x07, 0x8c, 0x5b, 0xef, 0xa0, 0x7c, 0xe9, 0x25, 0x65, 0xbd, 0xe2, 0xc6, 0xcb, 0x6d, 0x72, 0x1d, 0x6c, 0x29, 0x49, 0x91, 0x63, 0x80, 0x17, 0xfa, 0x94, 0x07, 0xfc ], [ 0xdf, 0x07, 0x27, 0xcf, 0x34, 0x56, 0xbf, 0x55, 0x1b, 0x80, 0x5e, 0x8c, 0x6a, 0xfd, 0xe6, 0x6b, 0x58, 0x68, 0x2e, 0xd0, 0x32, 0xba, 0x1f, 0x48, 0xa8, 0x2b, 0xe5, 0x78, 0xe3, 0x29, 0x3a, 0x7e ], [ 0x6b, 0x48, 0x8f, 0xb6, 0xb8, 0x67, 0xe0, 0xac, 0x60, 0xbd, 0x5d, 0x8f, 0xea, 0x9d, 0x5a, 0x89, 0xae, 0x49, 0xa4, 0x45, 0x87, 0x58, 0x33, 0x2d, 0xc5, 0x68, 0x17, 0xd6, 0x1e, 0x0d, 0x45, 0x5e ], [ 0xb6, 0x03, 0x65, 0xad, 0x30, 0xae, 0xa1, 0xf4, 0xdf, 0x65, 0x8b, 0x2c, 0x8d, 0xfd, 0x7e, 0x61, 0xf3, 0xdb, 0xae, 0x26, 0x22, 0xd5, 0x12, 0x12, 0x9c, 0xd9, 0x41, 0x8f, 0x68, 0x3b, 0x9f, 0x4f ], [ 0x2f, 0xf1, 0x89, 0xdf, 0x5c, 0x34, 0x43, 0x6c, 0x98, 0xed, 0xff, 0x0f, 0xa4, 0x75, 0xfa, 0x81, 0x7a, 0xc7, 0x6b, 0x9b, 0x6b, 0x3a, 0x1a, 0xcc, 0x20, 0x4b, 0xde, 0x61, 0xfe, 0xdd, 0xcf, 0xe8 ], [ 0x7a, 0x08, 0xa0, 0xd0, 0x4f, 0x29, 0x5c, 0x5e, 0x95, 0x0c, 0xe2, 0xcc, 0x23, 0x56, 0xc0, 0x59, 0x97, 0x09, 0xa5, 0xa0, 0xce, 0x6c, 0x8a, 0x72, 0xb5, 0xdc, 0xc3, 0x8f, 0x28, 0xdd, 0x08, 0x93 ], [ 0xb2, 0x83, 0x08, 0x6e, 0x62, 0x10, 0x4f, 0x78, 0x45, 0xa9, 0xbf, 0xdc, 0x68, 0xc6, 0xd9, 0x16, 0x65, 0xb5, 0x81, 0xb8, 0x11, 0x21, 0xf9, 0xfa, 0x9a, 0x9e, 0xa7, 0xea, 0x28, 0x87, 0xf1, 0x66 ], [ 0x96, 0x96, 0xc5, 0x5a, 0xc6, 0x63, 0xe9, 0x50, 0x6d, 0x41, 0x39, 0x30, 0x64, 0x1d, 0x6a, 0x25, 0xfd, 0x50, 0xa4, 0xab, 0xbb, 0x4b, 0xe6, 0x9b, 0xf0, 0xcd, 0xf0, 0xd4, 0x76, 0x73, 0xc0, 0x27 ], [ 0x43, 0xe7, 0x2a, 0x74, 0x12, 0x7c, 0x90, 0xb7, 0x2a, 0x94, 0xe2, 0xf0, 0xa5, 0x4c, 0x99, 0xb2, 0x0c, 0x2a, 0xb6, 0x31, 0x6f, 0x1d, 0x44, 0x6e, 0xe7, 0x4e, 0x47, 0x14, 0x5d, 0x99, 0x9e, 0x5b ], [ 0x9b, 0xaa, 0x10, 0x04, 0xf2, 0x9b, 0xf2, 0x1d, 0xe2, 0x37, 0xe3, 0x49, 0x1e, 0x41, 0x3b, 0xf2, 0x33, 0xb2, 0xfc, 0x68, 0x6d, 0x86, 0x59, 0x7b, 0xf9, 0x8f, 0x44, 0x4e, 0x1c, 0x4a, 0x5f, 0xcb ], [ 0x9b, 0x2e, 0x6d, 0x09, 0xd6, 0x33, 0xaa, 0xe3, 0xbb, 0x00, 0x23, 0x90, 0xc6, 0x30, 0x15, 0x05, 0xae, 0x97, 0x9c, 0x12, 0x19, 0x40, 0x0f, 0x47, 0x1a, 0x67, 0x15, 0x76, 0xd8, 0x8e, 0x00, 0x6d ], [ 0x89, 0xa4, 0x2f, 0xfe, 0xf6, 0x6f, 0x2a, 0xd4, 0x41, 0xb4, 0x40, 0x65, 0xda, 0xdc, 0xb7, 0x37, 0xaa, 0x42, 0x82, 0x06, 0xce, 0xaf, 0xe9, 0x13, 0xd0, 0xb5, 0x3d, 0x3d, 0xfb, 0x88, 0xef, 0xcb ], [ 0x22, 0x0f, 0x0b, 0x29, 0xa4, 0x18, 0x28, 0xde, 0x27, 0x1f, 0xbc, 0xd2, 0xc4, 0x61, 0x1a, 0xc6, 0xd2, 0x4f, 0x2d, 0x48, 0xa7, 0x88, 0x1e, 0x6d, 0xe9, 0x02, 0x2f, 0xe6, 0x26, 0x83, 0x8a, 0xeb ], [ 0x87, 0x54, 0xe4, 0xc8, 0xa7, 0xe8, 0xe3, 0xba, 0xb9, 0xa6, 0x15, 0x90, 0xdf, 0x5a, 0xea, 0x1b, 0xc5, 0x16, 0x51, 0xda, 0x24, 0xe3, 0x19, 0x1c, 0x3d, 0xbf, 0x0e, 0xc0, 0xc1, 0xec, 0x69, 0x67 ], [ 0x86, 0x7d, 0x72, 0x18, 0x70, 0x8f, 0x80, 0x95, 0xa5, 0x0a, 0x58, 0x31, 0xd9, 0x5f, 0xe6, 0xf0, 0x8f, 0x84, 0x2e, 0x43, 0x06, 0xe1, 0xc1, 0x55, 0x33, 0xb8, 0x07, 0x5b, 0xd0, 0x5d, 0x08, 0x05 ], [ 0x7b, 0x68, 0xea, 0x6b, 0xe1, 0x85, 0x52, 0xfa, 0x49, 0xa1, 0x4c, 0x0c, 0xc7, 0xc1, 0x07, 0x78, 0xbb, 0x43, 0xe4, 0x8d, 0xd4, 0xa7, 0x78, 0x21, 0xcb, 0x58, 0x97, 0x87, 0xbc, 0x2c, 0xa2, 0x27 ], [ 0x96, 0x2b, 0x33, 0xdf, 0x39, 0xd5, 0x31, 0x0b, 0x34, 0xb0, 0x26, 0xbc, 0x7d, 0x14, 0x7c, 0x9f, 0x13, 0xbe, 0xa7, 0x6d, 0x19, 0xd1, 0x1b, 0x66, 0xd3, 0x35, 0xe3, 0xf5, 0xb8, 0x25, 0x89, 0x3c ], [ 0x43, 0x37, 0x57, 0x26, 0x09, 0x2d, 0xed, 0xb5, 0x30, 0xb2, 0x2a, 0xb3, 0x7f, 0xa5, 0x73, 0x3a, 0x7b, 0xef, 0xb1, 0xc1, 0xc1, 0x14, 0x79, 0x1d, 0x97, 0x22, 0xee, 0x90, 0x5f, 0x96, 0xac, 0xbe ], [ 0xfa, 0x37, 0x0c, 0x44, 0xaa, 0xac, 0x8b, 0xa4, 0xfc, 0xd0, 0x7a, 0x81, 0x50, 0x79, 0xcf, 0x99, 0x1c, 0xed, 0x83, 0xe4, 0x35, 0xa9, 0x46, 0xf7, 0xcf, 0x52, 0xdf, 0xe3, 0xe3, 0x45, 0xa1, 0x0c ], [ 0xa4, 0x2f, 0xfa, 0x84, 0xb5, 0x7e, 0x27, 0xb0, 0x89, 0xaf, 0xd3, 0xf7, 0xae, 0xc4, 0x0e, 0xf7, 0xf5, 0xd5, 0x6e, 0xe3, 0xf4, 0xc8, 0x29, 0xfe, 0x93, 0x16, 0xf3, 0xef, 0xb5, 0xb7, 0x59, 0x0f ], [ 0x44, 0x3a, 0x21, 0x0f, 0x6a, 0xd8, 0xec, 0x3b, 0xf4, 0x55, 0x41, 0x13, 0xfe, 0x34, 0x64, 0x81, 0x4c, 0xa4, 0xdd, 0xe4, 0x02, 0xe7, 0x61, 0xd3, 0x9b, 0xe6, 0x74, 0x87, 0xfb, 0x57, 0xf6, 0x51 ], [ 0x6a, 0x6f, 0xc6, 0x5a, 0x0d, 0xf7, 0xac, 0x6d, 0x01, 0xd3, 0xb8, 0x94, 0x52, 0xd1, 0x2a, 0x91, 0x7a, 0x71, 0x8d, 0x97, 0xc8, 0xb7, 0x57, 0xe4, 0x9f, 0x08, 0x9a, 0x5d, 0x6f, 0x05, 0x1a, 0x13 ], [ 0xe6, 0xd0, 0xdd, 0xdf, 0x71, 0x11, 0xce, 0x86, 0xb6, 0x9d, 0x00, 0x88, 0xc3, 0x51, 0xc1, 0x94, 0xe7, 0x5f, 0xe0, 0x00, 0x27, 0x05, 0x8a, 0x33, 0xca, 0x84, 0x67, 0xd3, 0x23, 0x07, 0xdb, 0x49 ], [ 0x8b, 0x42, 0xa0, 0xa8, 0x76, 0x30, 0x20, 0x1a, 0x21, 0x2c, 0xc4, 0x81, 0x54, 0x55, 0xdb, 0x5c, 0x22, 0x99, 0x15, 0x28, 0x61, 0x6a, 0x7f, 0xd0, 0x66, 0xa7, 0x14, 0x6e, 0xe8, 0x62, 0x3e, 0x1f ], [ 0x22, 0x09, 0x9b, 0xe8, 0xcd, 0x7b, 0x4f, 0xf0, 0xd5, 0x0f, 0xe6, 0x8e, 0x8d, 0x8f, 0xcb, 0xeb, 0xdf, 0xd3, 0x53, 0x2d, 0x0b, 0x95, 0x18, 0x9d, 0x72, 0xd8, 0x33, 0x77, 0xb1, 0x17, 0xca, 0x83 ], [ 0x32, 0xe7, 0x21, 0x1a, 0x70, 0x91, 0x5a, 0xa7, 0x4c, 0xe0, 0x59, 0xfb, 0x05, 0xea, 0x54, 0x3d, 0x71, 0x73, 0x46, 0x94, 0x07, 0x89, 0xbf, 0x16, 0x37, 0x51, 0xa7, 0x44, 0x7d, 0x32, 0xe8, 0x4c ], [ 0xbc, 0xd2, 0xf0, 0xaf, 0xd0, 0x07, 0x8a, 0x93, 0x13, 0xa6, 0xf0, 0xf7, 0xe6, 0x83, 0xdc, 0xc8, 0x3b, 0x8a, 0x92, 0x80, 0x55, 0x51, 0xb0, 0xf1, 0x57, 0x55, 0x1c, 0xf6, 0x19, 0xa8, 0x02, 0x08 ], [ 0x5b, 0x22, 0x29, 0xea, 0x87, 0x09, 0x30, 0x99, 0x94, 0xef, 0xdc, 0x7d, 0xdf, 0x0e, 0xc9, 0x2b, 0xc5, 0x1f, 0x06, 0xa9, 0xfc, 0xb5, 0x9e, 0x5d, 0x2f, 0xa4, 0xc9, 0xef, 0x4b, 0xed, 0xaf, 0xb5 ], [ 0xf7, 0x1f, 0x0f, 0x2e, 0x51, 0x4b, 0x22, 0xb4, 0x13, 0x96, 0x29, 0xae, 0x6e, 0x45, 0xd5, 0xc5, 0xf3, 0x8c, 0xf4, 0xf0, 0xa3, 0x03, 0xa7, 0x8a, 0x08, 0x60, 0x3c, 0x2e, 0x6a, 0x11, 0xd7, 0xb1 ], [ 0x91, 0x35, 0x77, 0xa2, 0xd4, 0xa9, 0x8b, 0xca, 0x80, 0x1c, 0x85, 0x7d, 0xec, 0x36, 0x86, 0x74, 0xeb, 0x20, 0xbe, 0x04, 0xf5, 0xac, 0x8b, 0xea, 0x04, 0x7f, 0xe3, 0xa9, 0x37, 0x3d, 0xca, 0x62 ], [ 0x17, 0x49, 0x91, 0x83, 0x95, 0x07, 0x57, 0xc2, 0xf4, 0xcd, 0xfc, 0x37, 0xd0, 0xe5, 0x05, 0xa2, 0x77, 0xcf, 0x27, 0xe0, 0x09, 0x48, 0xb1, 0x1b, 0x4d, 0x35, 0x37, 0xcb, 0x36, 0x2a, 0xd7, 0x69 ], [ 0x74, 0x86, 0xcd, 0x75, 0x1a, 0x51, 0xd9, 0x19, 0x57, 0x20, 0x8b, 0x73, 0x89, 0x6f, 0x01, 0x42, 0x06, 0x2f, 0x87, 0x88, 0xb5, 0xf6, 0x78, 0x70, 0x11, 0x02, 0x0c, 0x9f, 0x18, 0xb2, 0x19, 0x69 ], [ 0x44, 0xef, 0xa5, 0x75, 0xe7, 0xbb, 0x73, 0xcd, 0xd6, 0x90, 0x57, 0x86, 0x50, 0x7d, 0xbd, 0x43, 0x71, 0xc9, 0x8a, 0xbc, 0x8f, 0xb2, 0xef, 0x1b, 0xdd, 0x58, 0xab, 0x1b, 0x6c, 0xb7, 0x0a, 0x49 ], [ 0xe8, 0x11, 0xe5, 0x45, 0xf4, 0xa9, 0x9e, 0x87, 0x53, 0x92, 0xb6, 0x2f, 0x0e, 0xab, 0x77, 0xfd, 0x7d, 0x77, 0x8a, 0x41, 0xf3, 0x6c, 0x0f, 0xed, 0x62, 0x25, 0xed, 0x57, 0xef, 0x40, 0xdb, 0xf9 ], [ 0x48, 0xea, 0x1e, 0x9c, 0x16, 0x07, 0x40, 0x30, 0x1b, 0x2f, 0x7e, 0x0e, 0xc0, 0x03, 0x51, 0xa2, 0x05, 0xba, 0x38, 0x05, 0x9d, 0x13, 0x4c, 0x69, 0x03, 0x61, 0x8f, 0x3a, 0x26, 0x9c, 0x87, 0xe3 ], [ 0xca, 0x91, 0x89, 0x59, 0x6b, 0x2a, 0x42, 0xf3, 0x78, 0x0e, 0x2b, 0x50, 0x92, 0x11, 0xa9, 0xbc, 0x81, 0xff, 0xa6, 0xc0, 0x0e, 0xae, 0x1f, 0x65, 0xe4, 0x49, 0x0d, 0xff, 0x66, 0x4c, 0xdb, 0xbd ], [ 0x96, 0x2d, 0xff, 0xd1, 0x2f, 0x95, 0xe0, 0xd6, 0xdc, 0x8f, 0x67, 0xba, 0x38, 0x77, 0x4f, 0x63, 0x51, 0xdd, 0x4a, 0x89, 0x69, 0x9d, 0xd9, 0xa8, 0xa9, 0xce, 0x3d, 0x7c, 0x69, 0x9b, 0x1f, 0x22 ], [ 0x65, 0x6d, 0x34, 0x1a, 0x14, 0xd0, 0x46, 0x56, 0xa6, 0x7b, 0x7a, 0xeb, 0x4b, 0xd7, 0x3b, 0x66, 0xd4, 0x7c, 0x34, 0xf9, 0x7f, 0xd2, 0xff, 0x45, 0x76, 0x6a, 0x22, 0x62, 0xda, 0x76, 0x7f, 0xc8 ], [ 0x6f, 0x32, 0x2b, 0xf7, 0x2d, 0x74, 0x4d, 0x51, 0x29, 0xe4, 0x9f, 0xb3, 0x73, 0x0f, 0x87, 0x2b, 0xa0, 0x39, 0xd8, 0x6a, 0x6c, 0x4e, 0xdd, 0x3f, 0xd9, 0x86, 0x4f, 0xb7, 0x96, 0x39, 0x3f, 0x04 ], [ 0xb0, 0x2c, 0x69, 0xe0, 0x84, 0xe3, 0xbe, 0x5c, 0x79, 0x48, 0xf8, 0x2c, 0x20, 0x10, 0x59, 0x3f, 0x4c, 0x4a, 0x0d, 0xbd, 0x7c, 0x4e, 0xbf, 0x28, 0x41, 0x9e, 0x65, 0xf3, 0x34, 0x73, 0xc5, 0x08 ], [ 0x33, 0x46, 0x6c, 0xae, 0xd9, 0xda, 0x1f, 0x28, 0x05, 0x6d, 0x2c, 0x81, 0xb5, 0x75, 0x7b, 0xfe, 0x54, 0xd2, 0xda, 0x18, 0x8e, 0x5c, 0x88, 0xc1, 0x73, 0x54, 0x1e, 0xd1, 0xfc, 0x4b, 0xc3, 0x77 ], [ 0x78, 0x1f, 0xe9, 0xd6, 0x55, 0x42, 0x04, 0xb6, 0xd3, 0x8f, 0xae, 0x0b, 0x53, 0x0d, 0xbc, 0x7e, 0xde, 0x39, 0x26, 0x9a, 0x52, 0x27, 0x61, 0xc1, 0x71, 0x65, 0x86, 0xb3, 0x51, 0xaa, 0xef, 0x17 ], [ 0x2c, 0x1c, 0x50, 0xc8, 0x72, 0xa1, 0x6f, 0x3b, 0x51, 0x55, 0x0e, 0x87, 0x36, 0x77, 0xba, 0xaa, 0x08, 0xe9, 0x04, 0x31, 0xf4, 0xf3, 0xe6, 0xd0, 0xcc, 0x88, 0x0d, 0xa0, 0xf8, 0x24, 0x40, 0x23 ], [ 0xe2, 0xdd, 0xec, 0xc1, 0xf7, 0x01, 0x7b, 0x21, 0x19, 0xcf, 0xc2, 0x6b, 0xa2, 0x0f, 0xb4, 0xab, 0x0d, 0x31, 0xe1, 0x58, 0x75, 0xee, 0x2b, 0xb9, 0xb0, 0xb3, 0xe6, 0x27, 0xd8, 0xa5, 0xa3, 0xfc ], [ 0x87, 0x3c, 0xbc, 0x71, 0xd5, 0x07, 0x03, 0x07, 0xa5, 0xf9, 0x36, 0x47, 0xac, 0xe4, 0xea, 0xf1, 0x1f, 0xdf, 0x82, 0x7a, 0x35, 0x6e, 0xac, 0xf9, 0x7a, 0x45, 0x7f, 0x5e, 0x53, 0x39, 0x27, 0x5f ], [ 0xfa, 0xde, 0xd1, 0xd0, 0x57, 0xe3, 0xad, 0xfb, 0xe6, 0x86, 0x12, 0x03, 0xf7, 0x62, 0x44, 0xc7, 0x3d, 0xde, 0x51, 0x96, 0x65, 0x20, 0xa9, 0x07, 0x16, 0x15, 0xff, 0x63, 0x39, 0x84, 0x04, 0xf1 ], [ 0x06, 0x52, 0x95, 0x77, 0xd8, 0x12, 0x4b, 0x46, 0x26, 0x4c, 0xcc, 0x8c, 0xdf, 0x57, 0xab, 0xb8, 0xcb, 0x97, 0x35, 0x32, 0x5a, 0xdd, 0xfb, 0x64, 0x33, 0xbc, 0x68, 0x46, 0x23, 0xf3, 0x7c, 0x51 ], [ 0xb4, 0x6d, 0xf5, 0xbf, 0x50, 0xa4, 0x8f, 0x51, 0x69, 0x51, 0x47, 0x8a, 0x96, 0x11, 0xdc, 0x69, 0x56, 0x96, 0xc8, 0x2d, 0xf8, 0xba, 0x7c, 0x57, 0x81, 0x61, 0x0f, 0x70, 0xc2, 0x71, 0x86, 0x5e ], [ 0x0e, 0x67, 0xb5, 0xa5, 0x27, 0x83, 0x33, 0xb2, 0x2b, 0x83, 0x90, 0xbb, 0xea, 0xfb, 0x90, 0xb4, 0xfb, 0x49, 0x83, 0xea, 0x4f, 0x70, 0x90, 0xeb, 0x2e, 0x8e, 0xca, 0x46, 0xd4, 0xcc, 0xf6, 0x0d ], [ 0xa4, 0x08, 0xfa, 0x05, 0xf3, 0xfa, 0x23, 0x93, 0x12, 0x3c, 0x3f, 0xab, 0xf7, 0x97, 0x29, 0x3f, 0x80, 0x6c, 0xc1, 0xfb, 0x83, 0xe0, 0xdb, 0xa2, 0x27, 0x20, 0x57, 0x33, 0x68, 0x76, 0x6b, 0xbe ], [ 0xb4, 0x1d, 0x7c, 0xd7, 0xb6, 0xb9, 0xbb, 0x8d, 0xef, 0x7f, 0x88, 0xad, 0xaa, 0x69, 0x5f, 0xe1, 0x5e, 0x9c, 0x19, 0x5d, 0x60, 0xd4, 0xc7, 0x31, 0xb5, 0xaf, 0x57, 0xe4, 0x33, 0x0a, 0x71, 0x68 ], [ 0x74, 0xc3, 0x6e, 0x7d, 0xef, 0xa0, 0x7e, 0x87, 0xb1, 0x97, 0x48, 0x82, 0xb6, 0xb0, 0xf0, 0xd7, 0x0c, 0x00, 0x81, 0x91, 0x29, 0x89, 0xdd, 0x70, 0xde, 0x74, 0xad, 0xf0, 0x61, 0xf5, 0xe7, 0x64 ], [ 0xf2, 0x9e, 0x94, 0xe3, 0x42, 0x40, 0x9f, 0x19, 0x83, 0xf4, 0xe6, 0x4c, 0x8f, 0x7d, 0xf5, 0x86, 0x5d, 0x1c, 0xe9, 0xe2, 0x8f, 0x11, 0x74, 0x16, 0x70, 0x79, 0x1d, 0xaa, 0xc0, 0x91, 0xc5, 0x1d ], [ 0xcd, 0x53, 0x6b, 0xf7, 0x8f, 0xd3, 0x4c, 0x81, 0x2a, 0x24, 0x3f, 0x14, 0xe7, 0x75, 0x7a, 0xc2, 0xa9, 0x6b, 0xe4, 0xc5, 0x26, 0xf1, 0xf8, 0x4d, 0xd3, 0x06, 0xae, 0x43, 0x97, 0xe6, 0xee, 0x0d ], [ 0x08, 0xbf, 0x47, 0x2a, 0x32, 0x11, 0xf7, 0xd8, 0xc4, 0x61, 0x33, 0xeb, 0x9c, 0x08, 0x7f, 0x17, 0xcd, 0xe9, 0x34, 0x83, 0x60, 0xd6, 0x3e, 0x2a, 0x8e, 0xc9, 0x50, 0x19, 0x36, 0x91, 0xba, 0x67 ], [ 0x16, 0xca, 0x76, 0x6a, 0x9b, 0x91, 0x3f, 0x56, 0x9e, 0x47, 0xde, 0x8c, 0x03, 0x60, 0xc2, 0x22, 0x89, 0x99, 0x7c, 0x4a, 0xb7, 0x9a, 0xdb, 0x26, 0x3d, 0x54, 0x6c, 0x2f, 0x2d, 0xf0, 0xae, 0x75 ], [ 0xc3, 0x16, 0x49, 0xe0, 0x9f, 0x35, 0x01, 0xcc, 0xf9, 0xea, 0x6d, 0x9e, 0x48, 0x98, 0xff, 0x4c, 0x1d, 0x54, 0x11, 0xa6, 0xa0, 0x91, 0xca, 0xdc, 0x96, 0xa0, 0x83, 0x81, 0x58, 0x3e, 0xc0, 0xa3 ], [ 0xa5, 0x66, 0x94, 0xcb, 0x3b, 0x80, 0x23, 0x8f, 0xa8, 0x28, 0x45, 0x48, 0xaf, 0x91, 0x08, 0xd7, 0x69, 0xe7, 0xa3, 0xf3, 0xdb, 0xaa, 0xb0, 0x04, 0x74, 0x98, 0xc9, 0xe8, 0xc0, 0x56, 0xf6, 0x0c ], [ 0xbf, 0x26, 0x73, 0xc9, 0xd6, 0x53, 0xdc, 0xbd, 0x55, 0xf6, 0x7e, 0xc2, 0xd3, 0xc4, 0x08, 0x8a, 0x44, 0x2f, 0xf5, 0xd5, 0x07, 0x65, 0x80, 0x9a, 0x20, 0x40, 0x39, 0xf3, 0xee, 0xd8, 0xba, 0xd7 ], [ 0xf5, 0xdc, 0x9a, 0xfc, 0xae, 0xfe, 0x38, 0x7c, 0x3d, 0x16, 0x2d, 0x02, 0xba, 0xac, 0x1e, 0x8d, 0xa6, 0x9f, 0xe2, 0x16, 0xa7, 0x2c, 0x16, 0xb7, 0xb1, 0x74, 0x82, 0x3a, 0x32, 0xbf, 0x91, 0x61 ], [ 0x11, 0x28, 0x3c, 0x92, 0x62, 0xd5, 0xe2, 0x14, 0xdb, 0x2f, 0x29, 0xc1, 0x6b, 0x5c, 0xd0, 0x25, 0x68, 0x22, 0xca, 0x94, 0xc8, 0x1d, 0x9b, 0xe5, 0xc0, 0x33, 0xc6, 0xd2, 0xaf, 0x2a, 0xad, 0x84 ], [ 0xe4, 0xa1, 0xae, 0xeb, 0x8f, 0x2e, 0x85, 0x8b, 0x03, 0x0d, 0x24, 0x97, 0xe0, 0x88, 0xf9, 0x0c, 0x02, 0x4c, 0x9d, 0x82, 0x0c, 0x32, 0x86, 0x57, 0x67, 0xe4, 0x95, 0x0c, 0x20, 0xd9, 0x06, 0xe4 ], [ 0xc9, 0x22, 0xea, 0xde, 0xc1, 0x65, 0x21, 0x67, 0x8d, 0xc5, 0x12, 0xf8, 0x99, 0xb9, 0x2a, 0x16, 0x9d, 0xb8, 0xb5, 0x14, 0xfb, 0xd3, 0xcf, 0x01, 0x42, 0x97, 0x86, 0xf5, 0x4a, 0xfa, 0xaf, 0x5d ], [ 0xdd, 0xb6, 0xd4, 0xc3, 0xb6, 0x20, 0xbd, 0x22, 0xe0, 0xb7, 0xb5, 0x2d, 0xf4, 0x7c, 0xde, 0xcb, 0x18, 0x18, 0x02, 0x8c, 0xd4, 0x6e, 0x02, 0x83, 0xfb, 0x82, 0x54, 0x6a, 0x09, 0x5c, 0x42, 0x77 ], [ 0xa3, 0x60, 0x27, 0x59, 0x5a, 0xc1, 0x00, 0x7c, 0x48, 0x6f, 0xa7, 0x35, 0x3d, 0x7f, 0x6a, 0xa2, 0xda, 0xc3, 0x6f, 0xcd, 0x3c, 0x08, 0xfb, 0x32, 0xbd, 0x5e, 0x72, 0x86, 0x62, 0xec, 0x2b, 0xd9 ], [ 0x1b, 0x0f, 0xe2, 0xa5, 0x67, 0xf5, 0x62, 0x28, 0x97, 0x39, 0xe2, 0x98, 0xa9, 0x12, 0x41, 0x5a, 0x10, 0x21, 0xdd, 0xf3, 0x23, 0x27, 0x84, 0x59, 0x68, 0xf5, 0x36, 0x3f, 0x7f, 0xe7, 0x41, 0x35 ], [ 0x86, 0x7d, 0x46, 0xa7, 0x39, 0x70, 0xc7, 0xc9, 0xca, 0xcc, 0xa6, 0x35, 0x54, 0xc8, 0x59, 0xb6, 0x43, 0xd6, 0x26, 0x6a, 0xeb, 0xc1, 0xf9, 0x1d, 0x67, 0x4e, 0xd7, 0x39, 0xfd, 0x2d, 0x4c, 0xf5 ], [ 0x28, 0xb4, 0x0e, 0x90, 0xb5, 0x4c, 0x8f, 0xab, 0xad, 0xa1, 0xd0, 0xad, 0x5d, 0x08, 0x04, 0x03, 0x89, 0x3f, 0x41, 0xa1, 0x75, 0x3b, 0xe6, 0x15, 0x7c, 0x15, 0x4b, 0xce, 0x7c, 0x18, 0x94, 0xd1 ], [ 0x66, 0x3d, 0x63, 0x38, 0x24, 0xe9, 0xde, 0x45, 0x58, 0xa3, 0xf2, 0x64, 0xc7, 0x60, 0xa9, 0xee, 0xe6, 0x04, 0x1e, 0x19, 0xc1, 0x94, 0xff, 0x8d, 0xf3, 0xfe, 0xe4, 0xd4, 0xf8, 0x00, 0xad, 0xd7 ], [ 0xc9, 0x0c, 0x05, 0x13, 0x3a, 0x3c, 0x98, 0x90, 0xc3, 0x32, 0xfb, 0x2a, 0xf5, 0xe9, 0xe2, 0x3b, 0x2a, 0xf6, 0x62, 0xcd, 0x6c, 0x17, 0xf4, 0x2e, 0xa6, 0xfc, 0xf9, 0x14, 0x62, 0x72, 0xee, 0x03 ], [ 0xeb, 0x3d, 0x61, 0xb6, 0xfe, 0x42, 0x41, 0xd4, 0x26, 0xfd, 0xaa, 0xe3, 0x84, 0xcc, 0xd0, 0x51, 0xac, 0xf3, 0x74, 0x82, 0xe2, 0x51, 0x27, 0x64, 0x8f, 0xdb, 0x5e, 0x27, 0xfe, 0x9a, 0x8c, 0xdc ], [ 0xa6, 0xca, 0x82, 0x3c, 0xb5, 0xcd, 0xd2, 0x48, 0x99, 0x99, 0x03, 0x45, 0xcb, 0x57, 0x62, 0x08, 0x39, 0xae, 0x99, 0xc9, 0xbc, 0xa2, 0xeb, 0x83, 0x7b, 0x3f, 0x8d, 0x5c, 0xea, 0xc9, 0xd6, 0xd7 ], [ 0x10, 0x76, 0x76, 0x29, 0x1b, 0x7f, 0x53, 0x19, 0xfd, 0xd8, 0x96, 0xfd, 0x2d, 0xb6, 0x0a, 0x1f, 0x8e, 0x2b, 0xf7, 0xda, 0x12, 0x53, 0x77, 0x2d, 0x4c, 0x8b, 0x46, 0xe3, 0x02, 0x35, 0xb7, 0xde ], [ 0xb0, 0xb1, 0x26, 0xea, 0x7f, 0x1d, 0xba, 0xc0, 0x6c, 0x95, 0x8d, 0xaf, 0xd4, 0x6c, 0xeb, 0xfc, 0x7c, 0x61, 0x12, 0xde, 0x15, 0x40, 0x83, 0x43, 0xac, 0xee, 0x91, 0x87, 0x94, 0x6b, 0xc9, 0xa7 ], [ 0xd3, 0xc6, 0x41, 0x13, 0x20, 0x78, 0x8f, 0xd6, 0x46, 0x9e, 0x79, 0x7a, 0x53, 0x6b, 0x3f, 0x2c, 0x20, 0x2e, 0x27, 0xb8, 0x2b, 0x21, 0x23, 0x35, 0x48, 0xa9, 0x4b, 0xd0, 0x6c, 0xe7, 0x0a, 0xff ], [ 0x40, 0x29, 0xde, 0xb5, 0x20, 0xea, 0xb1, 0x5d, 0xea, 0x3a, 0x3f, 0x78, 0x0d, 0xa9, 0x43, 0x70, 0x98, 0x5a, 0xb9, 0x09, 0xe2, 0xf4, 0x49, 0x45, 0xc5, 0xbd, 0xe0, 0x12, 0x31, 0x6e, 0x1c, 0xdc ], [ 0x1b, 0xc4, 0x1d, 0x7f, 0x8e, 0x50, 0x06, 0xf0, 0x43, 0x67, 0xfe, 0xe1, 0x64, 0xd9, 0x75, 0xa7, 0xac, 0xe7, 0x7b, 0x78, 0x4e, 0xf5, 0xa0, 0xdb, 0x8a, 0x31, 0xbc, 0xa0, 0x5b, 0xf6, 0xcc, 0x88 ], [ 0x43, 0xe0, 0x7f, 0xf6, 0xfe, 0x1b, 0x25, 0xdc, 0xac, 0x7d, 0x0c, 0x25, 0xdb, 0x07, 0x06, 0x97, 0x27, 0xec, 0xf4, 0x12, 0x09, 0x0a, 0x6a, 0x68, 0x7b, 0x09, 0x75, 0x91, 0x16, 0x17, 0x84, 0xab ], [ 0xef, 0xca, 0x2d, 0x3e, 0x28, 0x97, 0x65, 0xa8, 0xa5, 0xba, 0x7a, 0x86, 0x16, 0xf0, 0xfc, 0x12, 0x4d, 0xc3, 0xe0, 0x24, 0xc2, 0x03, 0xc8, 0xd2, 0xc8, 0xd8, 0xe7, 0x7b, 0x50, 0x73, 0xd0, 0xbf ], [ 0x73, 0xf7, 0x1c, 0x5b, 0x72, 0xdd, 0xa8, 0xaf, 0xb9, 0x14, 0x07, 0x9e, 0xbe, 0xa2, 0x74, 0x86, 0x12, 0xf1, 0x3e, 0xba, 0x8f, 0xf3, 0xc1, 0xa1, 0x0a, 0xe9, 0x61, 0x7e, 0xa1, 0xfc, 0x04, 0x38 ], [ 0x9b, 0x86, 0x41, 0x18, 0xd8, 0xcb, 0xb9, 0x5c, 0x2b, 0xe7, 0x22, 0xd8, 0x86, 0xe0, 0xce, 0xee, 0x81, 0x0e, 0x1b, 0x50, 0x60, 0x0d, 0xff, 0x1f, 0x95, 0x02, 0x83, 0x62, 0x31, 0xf9, 0xf8, 0x5d ], [ 0xcc, 0xbf, 0xf8, 0x3f, 0xe4, 0x41, 0xe5, 0x2d, 0xcc, 0x54, 0x79, 0x5a, 0xa4, 0xf7, 0x8a, 0xb8, 0x71, 0x78, 0x4b, 0x9a, 0x7b, 0x84, 0x82, 0x63, 0x5d, 0x45, 0x49, 0x82, 0x31, 0xbf, 0x60, 0x52 ], [ 0x6d, 0x40, 0x0c, 0x0b, 0x88, 0x0c, 0x35, 0xac, 0x29, 0xe5, 0x12, 0xda, 0x89, 0x92, 0x0c, 0xbe, 0x83, 0xbb, 0xbd, 0x75, 0xa6, 0x62, 0x86, 0xf5, 0x8a, 0xe2, 0x4b, 0x37, 0x58, 0x67, 0xc8, 0x3d ], [ 0x58, 0x6d, 0x9a, 0x10, 0x78, 0xf0, 0xac, 0xf4, 0xaf, 0x36, 0x13, 0xc5, 0x10, 0xc8, 0x6b, 0x02, 0x23, 0x6e, 0xc8, 0x6d, 0x39, 0x62, 0x1b, 0x6f, 0x7d, 0x60, 0x5f, 0xac, 0x8f, 0xdc, 0x35, 0xd2 ], [ 0xb9, 0x8b, 0x68, 0xf3, 0x96, 0xd3, 0x53, 0xd1, 0x01, 0x17, 0x95, 0x29, 0x21, 0x53, 0xd5, 0x3a, 0xd0, 0x3d, 0x34, 0xb4, 0xb2, 0x35, 0x95, 0xe1, 0x1b, 0xb4, 0x6c, 0xab, 0x7f, 0x40, 0xfc, 0xe1 ], [ 0x7d, 0x14, 0x51, 0x49, 0xf8, 0x84, 0x96, 0xcc, 0x0b, 0x1c, 0x19, 0x70, 0xfd, 0x3b, 0x9c, 0x6a, 0x4d, 0x2c, 0x3d, 0x50, 0xdc, 0x9b, 0x6b, 0x52, 0x11, 0x68, 0x44, 0x80, 0x43, 0xfb, 0x00, 0x85 ], [ 0x28, 0xec, 0xab, 0x53, 0xa5, 0xd8, 0xe7, 0x44, 0x79, 0x12, 0xaf, 0xb5, 0xf9, 0x9d, 0x02, 0x6c, 0xc5, 0xf3, 0xa1, 0xb9, 0xe8, 0x41, 0x23, 0xeb, 0xd7, 0x79, 0x6f, 0x7b, 0xcc, 0xf8, 0x4d, 0x81 ], [ 0xc3, 0x79, 0x3e, 0x73, 0x74, 0xab, 0x0f, 0x7b, 0x16, 0xfe, 0x33, 0x4b, 0xe0, 0x5c, 0x64, 0xc7, 0xa9, 0x21, 0x7d, 0xc7, 0xeb, 0x24, 0xf5, 0x70, 0x05, 0x67, 0xe3, 0x20, 0x7f, 0x2c, 0x5b, 0x54 ], [ 0x77, 0xbd, 0x79, 0x42, 0x69, 0x80, 0x8f, 0x22, 0xa1, 0x50, 0xd7, 0x5f, 0xa0, 0xc4, 0x2a, 0x9a, 0x28, 0x87, 0xae, 0xfd, 0x88, 0xcc, 0xad, 0xec, 0x38, 0x75, 0x7f, 0x71, 0xb9, 0xc3, 0x34, 0xb7 ], [ 0xc6, 0xdc, 0xaf, 0xbd, 0xbf, 0xd7, 0xf7, 0x1b, 0x02, 0x9b, 0x92, 0x40, 0xce, 0x57, 0xd6, 0x34, 0x95, 0xba, 0x68, 0xc1, 0xc3, 0x13, 0x1e, 0x6e, 0xb1, 0x0d, 0x09, 0xcb, 0x5a, 0x1f, 0xcb, 0x5e ], [ 0x2d, 0x93, 0xfe, 0x17, 0xfc, 0xd5, 0x1e, 0xf1, 0x9c, 0x4a, 0x04, 0x89, 0xf7, 0x72, 0xf1, 0xab, 0x91, 0x92, 0x1b, 0x26, 0x1a, 0x30, 0x17, 0x51, 0xf1, 0x0d, 0xf8, 0x19, 0xf6, 0x5d, 0xf8, 0xe8 ], [ 0x40, 0x1e, 0xfe, 0x5c, 0x41, 0xce, 0xa2, 0x3d, 0xa0, 0xd3, 0x3c, 0xaa, 0x94, 0x6b, 0x91, 0x6c, 0x88, 0xad, 0x99, 0xd6, 0x5f, 0xb8, 0x23, 0x80, 0x47, 0x59, 0x7b, 0x94, 0xbc, 0xdb, 0x88, 0xb7 ] ] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES256.rsp" keys_256bit = [] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES256.rsp" cipher_texts1_256bit = [] # Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES256.rsp" plain_texts1_256bit = [] print("Testing AES-XTS 128-bit decryption\t"), result = True for test_index in range(0, 100): test_key = bytes(bytearray(keys1_128bit[test_index][:16])) test_tweak_key = bytes(bytearray(keys1_128bit[test_index][16:])) test_tweak_value = bytes(bytearray(tweak_value1_128bit[test_index])) test_cipher_text = bytes(bytearray(cipher_texts1_128bit[test_index])) test_plain_text = bytes(bytearray(plain_texts1_128bit[test_index])) result = pycaes_test_crypt_xts( pycaes.crypt_modes.DECRYPT, test_key, test_tweak_key, test_tweak_value, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False print("Testing AES-XTS 128-bit decryption\t"), result = True for test_index in range(0, 100): test_key = bytes(bytearray(keys2_128bit[test_index][:16])) test_tweak_key = bytes(bytearray(keys2_128bit[test_index][16:])) test_tweak_value = bytes(bytearray(tweak_value2_128bit[test_index])) test_cipher_text = bytes(bytearray(cipher_texts2_128bit[test_index])) test_plain_text = bytes(bytearray(plain_texts2_128bit[test_index])) result = pycaes_test_crypt_xts( pycaes.crypt_modes.DECRYPT, test_key, test_tweak_key, test_tweak_value, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False print("Testing AES-XTS 128-bit decryption\t"), result = True for test_index in range(0, 100): test_key = bytes(bytearray(keys3_128bit[test_index][:16])) test_tweak_key = bytes(bytearray(keys3_128bit[test_index][16:])) test_tweak_value = bytes(bytearray(tweak_value3_128bit[test_index])) test_cipher_text = bytes(bytearray(cipher_texts3_128bit[test_index])) test_plain_text = bytes(bytearray(plain_texts3_128bit[test_index])) result = pycaes_test_crypt_xts( pycaes.crypt_modes.DECRYPT, test_key, test_tweak_key, test_tweak_value, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False print("Testing AES-XTS 128-bit decryption\t"), result = True for test_index in range(0, 100): test_key = bytes(bytearray(keys4_128bit[test_index][:16])) test_tweak_key = bytes(bytearray(keys4_128bit[test_index][16:])) test_tweak_value = bytes(bytearray(tweak_value4_128bit[test_index])) test_cipher_text = bytes(bytearray(cipher_texts4_128bit[test_index])) test_plain_text = bytes(bytearray(plain_texts4_128bit[test_index])) result = pycaes_test_crypt_xts( pycaes.crypt_modes.DECRYPT, test_key, test_tweak_key, test_tweak_value, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False # TODO: add encryption tests. return True if __name__ == "__main__": if not main(): sys.exit(1) else: sys.exit(0) libcaes-20240413/tests/test_runner.sh0000644000175000017500000010150714606473413020275 0ustar00lordyestalordyesta#!/usr/bin/env bash # Bash functions to run an executable for testing. # # Version: 20231119 # # When CHECK_WITH_ASAN is set to a non-empty value the test executable # is run with asan, otherwise it is run without. # # When CHECK_WITH_GDB is set to a non-empty value the test executable # is run with gdb, otherwise it is run without. # # When CHECK_WITH_STDERR is set to a non-empty value the test executable # is run with error output to stderr. # # When CHECK_WITH_VALGRIND is set to a non-empty value the test executable # is run with valgrind, otherwise it is run without. # # PYTHON is used to determine the Python interpreter. EXIT_SUCCESS=0; EXIT_FAILURE=1; EXIT_IGNORE=77; # Checks the availability of a binary and exits if not available. # # Arguments: # a string containing the name of the binary # assert_availability_binary() { local BINARY=$1; which ${BINARY} > /dev/null 2>&1; if test $? -ne ${EXIT_SUCCESS}; then echo "Missing binary: ${BINARY}"; echo ""; exit ${EXIT_FAILURE}; fi } # Checks the availability of binaries and exits if not available. # # Globals: # CHECK_WITH_GDB # CHECK_WITH_VALGRIND # assert_availability_binaries() { assert_availability_binary cat; assert_availability_binary cut; assert_availability_binary diff; assert_availability_binary file; assert_availability_binary gzip; assert_availability_binary ls; assert_availability_binary readlink; assert_availability_binary sed; assert_availability_binary tr; assert_availability_binary uname; assert_availability_binary wc; assert_availability_binary zcat; if test -n "${CHECK_WITH_GDB}"; then assert_availability_binary gdb; elif test -n "${CHECK_WITH_VALGRIND}"; then assert_availability_binary valgrind; fi } # Checks if the test set is in the ignore list. # # Arguments: # a string containing the test set # a string containing space separated ignore list # # Returns: # an integer containing the exit status to indicate the input directory # was found in the ignore list. # check_for_test_set_in_ignore_list() { local TEST_SET=$1; local IGNORE_LIST=$2; local IFS=" "; for LIST_ELEMENT in ${IGNORE_LIST}; do if test "${LIST_ELEMENT}" = "${TEST_SET}"; then return ${EXIT_SUCCESS}; fi done return ${EXIT_FAILURE}; } # Checks if the input directory is in the ignore list. # # Arguments: # a string containing the path of the test input directory # a string containing space separated ignore list # # Returns: # an integer containing the exit status to indicate the input directory # was found in the ignore list. # check_for_directory_in_ignore_list() { local INPUT_DIRECTORY=$1; local IGNORE_LIST=$2; local INPUT_BASENAME=`basename ${INPUT_DIRECTORY}`; local IFS=" "; for LIST_ELEMENT in ${IGNORE_LIST}; do if test "${LIST_ELEMENT}" = "${INPUT_BASENAME}"; then return ${EXIT_SUCCESS}; fi done return ${EXIT_FAILURE}; } # Searches for the binary variant of the executable in case the test executable # refers to a libtool shell script. # # Arguments: # a string containing the path of the test executable # # Returns: # a string containing the path of the binary variant of the test executable # find_binary_executable() { local TEST_EXECUTABLE=$1; TEST_EXECUTABLE=$( readlink_f "${TEST_EXECUTABLE}" ); # Note that the behavior of `file -bi` is not helpful on Mac OS X. local EXECUTABLE_TYPE=`file -b ${TEST_EXECUTABLE}`; # Check if the test executable is a libtool shell script. # Linux: POSIX shell script, ASCII text executable, with very long lines # Mac OS X: POSIX shell script text executable echo "${EXECUTABLE_TYPE}" | grep "POSIX shell script" > /dev/null 2>&1; RESULT=$?; if test ${RESULT} -eq ${EXIT_SUCCESS}; then local TEST_EXECUTABLE_BASENAME=`basename ${TEST_EXECUTABLE}`; local TEST_EXECUTABLE_DIRNAME=`dirname ${TEST_EXECUTABLE}`; TEST_EXECUTABLE="${TEST_EXECUTABLE_DIRNAME}/.libs/${TEST_EXECUTABLE_BASENAME}"; if test -x ${TEST_EXECUTABLE}; then # Note that the behavior of `file -bi` is not helpful on Mac OS X. EXECUTABLE_TYPE=`file -b ${TEST_EXECUTABLE}`; # Linux: ELF 64-bit LSB executable, x86-64, ... # Mac OS X: Mach-O 64-bit executable x86_64 echo "${EXECUTABLE_TYPE}" | grep "executable" > /dev/null 2>&1; RESULT=$?; if test ${RESULT} -ne ${EXIT_SUCCESS}; then echo "Invalid test executable: ${TEST_EXECUTABLE}"; exit ${EXIT_FAILURE}; fi fi fi echo ${TEST_EXECUTABLE}; } # Searches for the path to the binary variant of the library. # # Arguments: # a string containing the path of the test executable # # Returns: # a string containing the path of the binary variant of the library. # find_binary_library_path() { local TEST_EXECUTABLE=$1; local LIBRARY_NAME=`dirname ${TEST_EXECUTABLE}`; local NAME=`basename ${LIBRARY_NAME}`; if test ${NAME} = ".libs"; then LIBRARY_NAME=`dirname ${LIBRARY_NAME}`; NAME=`basename ${LIBRARY_NAME}`; fi if test ${NAME} = "tests"; then LIBRARY_NAME=`dirname ${LIBRARY_NAME}`; NAME=`basename ${LIBRARY_NAME}`; fi echo ${LIBRARY_NAME} | grep 'tools' > /dev/null 2>&1; if test $? -eq ${EXIT_SUCCESS}; then LIBRARY_NAME=`basename ${LIBRARY_NAME} | sed 's/\(.*\)tools$/lib\1/'`; else LIBRARY_NAME=`basename ${LIBRARY_NAME} | sed 's/^py//' | sed 's/^\([^_]*\)_test_.*$/lib\1/'`; fi TEST_EXECUTABLE=`dirname ${TEST_EXECUTABLE}`; TEST_EXECUTABLE=`dirname ${TEST_EXECUTABLE}`; TEST_EXECUTABLE=`dirname ${TEST_EXECUTABLE}`; local LIBRARY_PATH="${TEST_EXECUTABLE}/${LIBRARY_NAME}/.libs"; if ! test -d "${LIBRARY_PATH}"; then LIBRARY_PATH="../${LIBRARY_NAME}/.libs"; fi echo "${LIBRARY_PATH}"; } # Searches for the path to the binary variant of the Python module # # Arguments: # a string containing the path of the test executable # # Returns: # a string containing the path of the binary variant of the Python module # find_binary_python_module_path() { local TEST_EXECUTABLE=$1; local PYTHON_MODULE_NAME=`basename ${TEST_EXECUTABLE} | sed 's/^py\(.*\)_test_.*$/py\1/'`; TEST_EXECUTABLE=`dirname ${TEST_EXECUTABLE}`; TEST_EXECUTABLE=`dirname ${TEST_EXECUTABLE}`; TEST_EXECUTABLE=`dirname ${TEST_EXECUTABLE}`; local PYTHON_MODULE_PATH="${TEST_EXECUTABLE}/${PYTHON_MODULE_NAME}/.libs"; if ! test -d "${PYTHON_MODULE_PATH}"; then PYTHON_MODULE_PATH="../${PYTHON_MODULE_NAME}/.libs"; fi echo "${PYTHON_MODULE_PATH}"; } # Determines the test data option file. # # Arguments: # a string containing the path of the test set directory # a string containing the path of the test input file # a string containing the name of the test data option set # # Returns: # a string containing the test input files # get_test_data_option_file() { local TEST_SET_DIRECTORY=$1; local INPUT_FILE=$2; local OPTION_SET=$3; local INPUT_NAME=`basename "${INPUT_FILE}"`; local TEST_DATA_OPTION_FILE="${TEST_SET_DIRECTORY}/${INPUT_NAME}.${OPTION_SET}"; echo "${TEST_DATA_OPTION_FILE}"; } # Determines the test profile directory. # The directory is created if it does not exist. # # Arguments: # a string containing the path of the test input directory # a string containing the name of the test profile # # Returns: # a string containing the path of the test profile directory # get_test_profile_directory() { local TEST_INPUT_DIRECTORY=$1; local TEST_PROFILE=$2; local TEST_PROFILE_DIRECTORY="${TEST_INPUT_DIRECTORY}/.${TEST_PROFILE}"; if ! test -d "${TEST_PROFILE_DIRECTORY}"; then mkdir "${TEST_PROFILE_DIRECTORY}"; fi echo "${TEST_PROFILE_DIRECTORY}"; } # Determines the test set directory. # The directory is created if it does not exist. # # Arguments: # a string containing the path of the test profile directory # a string containing the path of the test set input directory # # Returns: # a string containing the path of the test set directory # get_test_set_directory() { local TEST_PROFILE_DIRECTORY=$1; local TEST_SET_INPUT_DIRECTORY=$2; local TEST_SET=`basename ${TEST_SET_INPUT_DIRECTORY}`; local TEST_SET_DIRECTORY="${TEST_PROFILE_DIRECTORY}/${TEST_SET}"; if ! test -d "${TEST_SET_DIRECTORY}"; then mkdir "${TEST_SET_DIRECTORY}"; fi echo "${TEST_SET_DIRECTORY}"; } # Provides a cross-platform variant of "readlink -f" # # Arguments: # a string containing a path # # Returns: # a string containing the path with all symbolic links resolved # readlink_f() { local TARGET="$1" if test -f "${TARGET}"; then while test -L "${TARGET}"; do TARGET=`readlink "${TARGET}"`; done fi local BASENAME=`basename "${TARGET}"`; local DIRNAME=`dirname "${TARGET}"`; DIRNAME=`(cd "${DIRNAME}" && pwd -P)`; echo "${DIRNAME}/${BASENAME}"; } # Reads the test profile ignore file if it exists. # # Arguments: # a string containing the path of the test profile directory # # Returns: # a string containing a space separated ignore list # read_ignore_list() { local TEST_PROFILE_DIRECTORY=$1; local IGNORE_FILE="${TEST_PROFILE_DIRECTORY}/ignore"; local IGNORE_LIST=""; if test -f "${IGNORE_FILE}"; then IGNORE_LIST=`cat ${IGNORE_FILE} | sed '/^#/d' | tr '\n' ' '`; fi echo ${IGNORE_LIST}; } # Reads a test data option file. # # Arguments: # a string containing the path of the test set directory # a string containing the path of the test input file # a string containing the name of the test data option set # # Returns: # a string containing the test data specific options # read_test_data_option_file() { local TEST_SET_DIRECTORY=$1; local INPUT_FILE=$2; local OPTION_SET=$3; local TEST_DATA_OPTION_FILE="${INPUT_FILE}.${OPTION_SET}"; if ! test -f "${TEST_DATA_OPTION_FILE}"; then TEST_DATA_OPTION_FILE=$(get_test_data_option_file "${TEST_SET_DIRECTORY}" "${INPUT_FILE}" "${OPTION_SET}"); fi local OPTIONS_STRING=`head -n 1 "${TEST_DATA_OPTION_FILE}" | sed 's/[\r\n]*$//'`; if test "${OPTIONS_STRING}" = "# libyal test data options"; then OPTIONS_STRING=`tail -n +2 "${TEST_DATA_OPTION_FILE}" | sed 's/^offset=/-o/;s/^password=/-p/;s/^recovery_password=/-r/;s/^startup_key=/-s/;s/virtual_address=/-v/' | tr '\n' ' '`; fi echo "${OPTIONS_STRING}"; } # Runs the test with optional arguments. # # Globals: # CHECK_WITH_ASAN # CHECK_WITH_GDB # CHECK_WITH_STDERR # CHECK_WITH_VALGRIND # # Arguments: # a string containing the test description # a string containing the path of the test executable # an array containing the arguments for the test executable # # Returns: # an integer containg the exit status of the test executable # run_test_with_arguments() { local TEST_DESCRIPTION=$1; local TEST_EXECUTABLE=$2; shift 2; local ARGUMENTS=("$@"); if ! test -f "${TEST_EXECUTABLE}"; then echo "Missing test executable: ${TEST_EXECUTABLE}"; echo ""; return ${EXIT_FAILURE}; fi local PLATFORM=`uname -s | sed 's/-.*$//'`; # Note that the behavior of `file -bi` is not helpful on Mac OS X. local EXECUTABLE_TYPE=`file -b ${TEST_EXECUTABLE}`; # Check if the test executable is a Python script. # Linux: Python script, ASCII text executable # Mac OS X: a python script text executable echo "${EXECUTABLE_TYPE}" | grep -i "python script" > /dev/null 2>&1; local IS_PYTHON_SCRIPT=$?; if test ${IS_PYTHON_SCRIPT} -eq 0 && test -z ${PYTHON}; then local PYTHON=`which python 2> /dev/null`; if ! test -x ${PYTHON}; then echo "Missing executable: ${PYTHON}"; exit ${EXIT_FAILURE}; fi fi local RESULT=0; if test -n "${CHECK_WITH_ASAN}"; then local TEST_EXECUTABLE=$( find_binary_executable ${TEST_EXECUTABLE} ); local LIBRARY_PATH=$( find_binary_library_path ${TEST_EXECUTABLE} ); local PYTHON_MODULE_PATH=$( find_binary_python_module_path ${TEST_EXECUTABLE} ); local LSAN_SUPPRESSIONS="lsan.suppressions"; if ! test -f ${LSAN_SUPPRESSIONS}; then LSAN_SUPPRESSIONS="../lsan.suppressions"; fi if test "${PLATFORM}" = "Darwin"; then if test ${IS_PYTHON_SCRIPT} -eq 0; then LSAN_OPTIONS=suppressions="${LSAN_SUPPRESSIONS}" DYLD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; else LSAN_OPTIONS=suppressions="${LSAN_SUPPRESSIONS}" DYLD_LIBRARY_PATH="${LIBRARY_PATH}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; fi else local CONFIG_LOG="../config.log"; if ! test -f ${CONFIG_LOG}; then CONFIG_LOG="../../config.log"; fi local CC=`cat ${CONFIG_LOG} | grep -e "^CC=" | sed "s/CC='\\(.*\\)'/\1/"`; local LIBASAN=""; if test -z ${CC} || test ${CC} != "clang"; then local LDCONFIG=`which ldconfig 2> /dev/null`; if test -z ${LDCONFIG} || ! test -x ${LDCONFIG}; then LDCONFIG="/sbin/ldconfig"; fi if test -z ${LDCONFIG} || ! test -x ${LDCONFIG}; then echo "Missing binary: ldconfig"; echo ""; exit ${EXIT_FAILURE}; fi LIBASAN=`${LDCONFIG} -p | grep libasan | sed 's/^.* => //' | sort | tail -n 1`; if ! test -f ${LIBASAN}; then echo "Missing library: ${BINARY}"; echo ""; exit ${EXIT_FAILURE}; fi fi if test ${IS_PYTHON_SCRIPT} -eq 0; then LSAN_OPTIONS=suppressions="${LSAN_SUPPRESSIONS}" LD_PRELOAD="${LIBASAN}" LD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; else LSAN_OPTIONS=suppressions="${LSAN_SUPPRESSIONS}" LD_PRELOAD="${LIBASAN}" LD_LIBRARY_PATH="${LIBRARY_PATH}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; fi fi elif test -n "${CHECK_WITH_GDB}"; then local TEST_EXECUTABLE=$( find_binary_executable ${TEST_EXECUTABLE} ); local LIBRARY_PATH=$( find_binary_library_path ${TEST_EXECUTABLE} ); local PYTHON_MODULE_PATH=$( find_binary_python_module_path ${TEST_EXECUTABLE} ); if test "${PLATFORM}" = "Darwin"; then if test ${IS_PYTHON_SCRIPT} -eq 0; then DYLD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" gdb -ex "set non-stop on" -ex "run" -ex "quit" --args "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; else DYLD_LIBRARY_PATH="${LIBRARY_PATH}" gdb -ex "set non-stop on" -ex "run" -ex "quit" --args "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; fi elif test "${PLATFORM}" = "CYGWIN_NT"; then if test ${IS_PYTHON_SCRIPT} -eq 0; then PATH="${LIBRARY_PATH}:${PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" gdb -ex "set non-stop on" -ex "run" -ex "quit" --args "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; else PATH="${LIBRARY_PATH}:${PATH}" gdb -ex "set non-stop on" -ex "run" -ex "quit" --args "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; fi else if test ${IS_PYTHON_SCRIPT} -eq 0; then LD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" gdb -ex "set non-stop on" -ex "run" -ex "quit" --args "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; else LD_LIBRARY_PATH="${LIBRARY_PATH}" gdb -ex "set non-stop on" -ex "run" -ex "quit" --args "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; fi fi elif test -n "${CHECK_WITH_VALGRIND}"; then local TEST_EXECUTABLE=$( find_binary_executable ${TEST_EXECUTABLE} ); local LIBRARY_PATH=$( find_binary_library_path ${TEST_EXECUTABLE} ); local PYTHON_MODULE_PATH=$( find_binary_python_module_path ${TEST_EXECUTABLE} ); local VALGRIND_LOG="valgrind.log-$$"; local VALGRIND_OPTIONS=("--tool=memcheck" "--leak-check=full" "--show-leak-kinds=definite,indirect,possible" "--track-origins=yes" "--log-file=${VALGRIND_LOG}"); if test "${PLATFORM}" = "Darwin"; then if test ${IS_PYTHON_SCRIPT} -eq 0; then DYLD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" valgrind ${VALGRIND_OPTIONS[@]} "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; else DYLD_LIBRARY_PATH="${LIBRARY_PATH}" valgrind ${VALGRIND_OPTIONS[@]} "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; fi elif test "${PLATFORM}" = "CYGWIN_NT"; then if test ${IS_PYTHON_SCRIPT} -eq 0; then PATH="${LIBRARY_PATH}:${PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" valgrind ${VALGRIND_OPTIONS[@]} "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; else PATH="${LIBRARY_PATH}:${PATH}" valgrind ${VALGRIND_OPTIONS[@]} "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; fi else if test ${IS_PYTHON_SCRIPT} -eq 0; then LD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" valgrind ${VALGRIND_OPTIONS[@]} "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; else LD_LIBRARY_PATH="${LIBRARY_PATH}" valgrind ${VALGRIND_OPTIONS[@]} "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; fi fi if test ${RESULT} -eq ${EXIT_SUCCESS}; then grep "All heap blocks were freed -- no leaks are possible" ${VALGRIND_LOG} > /dev/null 2>&1; if test $? -ne ${EXIT_SUCCESS}; then # Ignore "still reachable" # Also see: http://valgrind.org/docs/manual/faq.html#faq.deflost grep "definitely lost: 0 bytes in 0 blocks" ${VALGRIND_LOG} > /dev/null 2>&1; RESULT_DIRECTLY_LOST=$?; grep "indirectly lost: 0 bytes in 0 blocks" ${VALGRIND_LOG} > /dev/null 2>&1; RESULT_INDIRECTLY_LOST=$?; grep "possibly lost: 0 bytes in 0 blocks" ${VALGRIND_LOG} > /dev/null 2>&1; RESULT_POSSIBLY_LOST=$?; grep "suppressed: 0 bytes in 0 blocks" ${VALGRIND_LOG} > /dev/null 2>&1; RESULT_SUPPRESSED=$?; if test ${RESULT_DIRECTLY_LOST} -ne ${EXIT_SUCCESS} || test ${RESULT_INDIRECTLY_LOST} -ne ${EXIT_SUCCESS} || test ${RESULT_POSSIBLY_LOST} -ne ${EXIT_SUCCESS} || test ${RESULT_SUPPRESSED} -ne ${EXIT_SUCCESS}; then echo "Memory leakage detected."; cat ${VALGRIND_LOG}; RESULT=${EXIT_FAILURE}; fi fi # Detect valgrind warnings. local NUMBER_OF_LINES=`wc -l ${VALGRIND_LOG} | awk '{ print $1 }'`; if test ${NUMBER_OF_LINES} -ne 15 && test ${NUMBER_OF_LINES} -ne 22; then echo "Unsupported number of lines: ${NUMBER_OF_LINES}"; cat ${VALGRIND_LOG}; RESULT=${EXIT_FAILURE}; fi fi rm -f ${VALGRIND_LOG}; elif test ${IS_PYTHON_SCRIPT} -eq 0; then if ! test -f "${TEST_EXECUTABLE}"; then echo "Invalid test Python script: ${TEST_EXECUTABLE}"; echo ""; return ${EXIT_FAILURE}; fi local TEST_EXECUTABLE=$( find_binary_executable ${TEST_EXECUTABLE} ); local LIBRARY_PATH=$( find_binary_library_path ${TEST_EXECUTABLE} ); local PYTHON_MODULE_PATH=$( find_binary_python_module_path ${TEST_EXECUTABLE} ); if test "${PLATFORM}" = "Darwin"; then if test -n "${CHECK_WITH_STDERR}"; then DYLD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; else DYLD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} 2> /dev/null; RESULT=$?; fi elif test "${PLATFORM}" = "CYGWIN_NT"; then if test -n "${CHECK_WITH_STDERR}"; then PATH="${LIBRARY_PATH}:${PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; else PATH="${LIBRARY_PATH}:${PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} 2> /dev/null; RESULT=$?; fi else if test -n "${CHECK_WITH_STDERR}"; then LD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]}; RESULT=$?; else LD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} 2> /dev/null; RESULT=$?; fi fi else if ! test -x "${TEST_EXECUTABLE}"; then echo "Invalid test executable: ${TEST_EXECUTABLE}"; echo ""; return ${EXIT_FAILURE}; fi if test -n "${CHECK_WITH_STDERR}"; then ${TEST_EXECUTABLE} ${ARGUMENTS[@]}; RESULT=$?; else ${TEST_EXECUTABLE} ${ARGUMENTS[@]} 2> /dev/null; RESULT=$?; fi fi if test -n "${TEST_DESCRIPTION}"; then echo -n "${TEST_DESCRIPTION}"; if test ${RESULT} -ne ${EXIT_SUCCESS}; then echo " (FAIL)"; else echo " (PASS)"; fi fi return ${RESULT}; } # Runs the test with an input file and optional arguments. # # Globals: # CHECK_WITH_ASAN # CHECK_WITH_GDB # CHECK_WITH_STDERR # CHECK_WITH_VALGRIND # # Arguments: # a string containing the path of the test executable # a string containing the path of the test input file # an array containing the arguments for the test executable # # Returns: # an integer containg the exit status of the test executable # run_test_with_input_and_arguments() { local TEST_EXECUTABLE=$1; local INPUT_FILE=$2; shift 2; local ARGUMENTS=("$@"); if ! test -f "${TEST_EXECUTABLE}"; then echo "Missing test executable: ${TEST_EXECUTABLE}"; echo ""; return ${EXIT_FAILURE}; fi local PLATFORM=`uname -s | sed 's/-.*$//'`; # Note that the behavior of `file -bi` is not helpful on Mac OS X. local EXECUTABLE_TYPE=`file -b ${TEST_EXECUTABLE}`; # Check if the test executable is a Python script. # Linux: Python script, ASCII text executable # Mac OS X: a python script text executable echo "${EXECUTABLE_TYPE}" | grep -i "python script" > /dev/null 2>&1; local IS_PYTHON_SCRIPT=$?; if test ${IS_PYTHON_SCRIPT} -eq 0 && test -z ${PYTHON}; then local PYTHON=`which python 2> /dev/null`; if ! test -x ${PYTHON}; then echo "Missing executable: ${PYTHON}"; exit ${EXIT_FAILURE}; fi fi local RESULT=0; if test -n "${CHECK_WITH_ASAN}"; then local TEST_EXECUTABLE=$( find_binary_executable ${TEST_EXECUTABLE} ); local LIBRARY_PATH=$( find_binary_library_path ${TEST_EXECUTABLE} ); local PYTHON_MODULE_PATH=$( find_binary_python_module_path ${TEST_EXECUTABLE} ); local LSAN_SUPPRESSIONS="lsan.suppressions"; if ! test -f ${LSAN_SUPPRESSIONS}; then LSAN_SUPPRESSIONS="../lsan.suppressions"; fi if test "${PLATFORM}" = "Darwin"; then # TODO DYLD_INSERT_LIBRARIES=/Library/Developer/CommandLineTools/usr/lib/clang/8.1.0/lib/darwin/libclang_rt.asan_osx_dynamic.dylib if test ${IS_PYTHON_SCRIPT} -eq 0; then LSAN_OPTIONS=suppressions="${LSAN_SUPPRESSIONS}" DYLD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; else LSAN_OPTIONS=suppressions="${LSAN_SUPPRESSIONS}" DYLD_LIBRARY_PATH="${LIBRARY_PATH}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; fi else local CONFIG_LOG="../config.log"; if ! test -f ${CONFIG_LOG}; then CONFIG_LOG="../../config.log"; fi local CC=`cat ${CONFIG_LOG} | grep -e "^CC=" | sed "s/CC='\\(.*\\)'/\1/"`; local LIBASAN=""; if test -z ${CC} || test ${CC} != "clang"; then local LDCONFIG=`which ldconfig 2> /dev/null`; if test -z ${LDCONFIG} || ! test -x ${LDCONFIG}; then LDCONFIG="/sbin/ldconfig"; fi if test -z ${LDCONFIG} || ! test -x ${LDCONFIG}; then echo "Missing binary: ldconfig"; echo ""; exit ${EXIT_FAILURE}; fi LIBASAN=`${LDCONFIG} -p | grep libasan | sed 's/^.* => //' | sort | tail -n 1`; if ! test -f ${LIBASAN}; then echo "Missing library: ${BINARY}"; echo ""; exit ${EXIT_FAILURE}; fi fi if test ${IS_PYTHON_SCRIPT} -eq 0; then LSAN_OPTIONS=suppressions="${LSAN_SUPPRESSIONS}" LD_PRELOAD="${LIBASAN}" LD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; else LSAN_OPTIONS=suppressions="${LSAN_SUPPRESSIONS}" LD_PRELOAD="${LIBASAN}" LD_LIBRARY_PATH="${LIBRARY_PATH}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; fi fi elif test -n "${CHECK_WITH_GDB}"; then local TEST_EXECUTABLE=$( find_binary_executable ${TEST_EXECUTABLE} ); local LIBRARY_PATH=$( find_binary_library_path ${TEST_EXECUTABLE} ); local PYTHON_MODULE_PATH=$( find_binary_python_module_path ${TEST_EXECUTABLE} ); if test "${PLATFORM}" = "Darwin"; then if test ${IS_PYTHON_SCRIPT} -eq 0; then DYLD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" gdb -ex "set non-stop on" -ex "run" -ex "quit" --args "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; else DYLD_LIBRARY_PATH="${LIBRARY_PATH}" gdb -ex "set non-stop on" -ex "run" -ex "quit" --args "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; fi elif test "${PLATFORM}" = "CYGWIN_NT"; then if test ${IS_PYTHON_SCRIPT} -eq 0; then PATH="${LIBRARY_PATH}:${PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" gdb -ex "set non-stop on" -ex "run" -ex "quit" --args "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; else PATH="${LIBRARY_PATH}:${PATH}" gdb -ex "set non-stop on" -ex "run" -ex "quit" --args "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; fi else if test ${IS_PYTHON_SCRIPT} -eq 0; then LD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" gdb -ex "set non-stop on" -ex "run" -ex "quit" --args "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; else LD_LIBRARY_PATH="${LIBRARY_PATH}" gdb -ex "set non-stop on" -ex "run" -ex "quit" --args "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; fi fi elif test -n "${CHECK_WITH_VALGRIND}"; then local TEST_EXECUTABLE=$( find_binary_executable ${TEST_EXECUTABLE} ); local LIBRARY_PATH=$( find_binary_library_path ${TEST_EXECUTABLE} ); local PYTHON_MODULE_PATH=$( find_binary_python_module_path ${TEST_EXECUTABLE} ); local VALGRIND_LOG="valgrind.log-$$"; local VALGRIND_OPTIONS=("--tool=memcheck" "--leak-check=full" "--show-leak-kinds=definite,indirect,possible" "--track-origins=yes" "--log-file=${VALGRIND_LOG}"); if test "${PLATFORM}" = "Darwin"; then if test ${IS_PYTHON_SCRIPT} -eq 0; then DYLD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" valgrind ${VALGRIND_OPTIONS[@]} "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; else DYLD_LIBRARY_PATH="${LIBRARY_PATH}" valgrind ${VALGRIND_OPTIONS[@]} "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; fi elif test "${PLATFORM}" = "CYGWIN_NT"; then if test ${IS_PYTHON_SCRIPT} -eq 0; then PATH="${LIBRARY_PATH}:${PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" valgrind ${VALGRIND_OPTIONS[@]} "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; else PATH="${LIBRARY_PATH}:${PATH}" valgrind ${VALGRIND_OPTIONS[@]} "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; fi else if test ${IS_PYTHON_SCRIPT} -eq 0; then LD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" valgrind ${VALGRIND_OPTIONS[@]} "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; else LD_LIBRARY_PATH="${LIBRARY_PATH}" valgrind ${VALGRIND_OPTIONS[@]} "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; fi fi if test ${RESULT} -eq ${EXIT_SUCCESS}; then grep "All heap blocks were freed -- no leaks are possible" ${VALGRIND_LOG} > /dev/null 2>&1; if test $? -ne ${EXIT_SUCCESS}; then # Ignore "still reachable" # Also see: http://valgrind.org/docs/manual/faq.html#faq.deflost grep "definitely lost: 0 bytes in 0 blocks" ${VALGRIND_LOG} > /dev/null 2>&1; RESULT_DIRECTLY_LOST=$?; grep "indirectly lost: 0 bytes in 0 blocks" ${VALGRIND_LOG} > /dev/null 2>&1; RESULT_INDIRECTLY_LOST=$?; grep "possibly lost: 0 bytes in 0 blocks" ${VALGRIND_LOG} > /dev/null 2>&1; RESULT_POSSIBLY_LOST=$?; grep "suppressed: 0 bytes in 0 blocks" ${VALGRIND_LOG} > /dev/null 2>&1; RESULT_SUPPRESSED=$?; if test ${RESULT_DIRECTLY_LOST} -ne ${EXIT_SUCCESS} || test ${RESULT_INDIRECTLY_LOST} -ne ${EXIT_SUCCESS} || test ${RESULT_POSSIBLY_LOST} -ne ${EXIT_SUCCESS} || test ${RESULT_SUPPRESSED} -ne ${EXIT_SUCCESS}; then echo "Memory leakage detected."; cat ${VALGRIND_LOG}; RESULT=${EXIT_FAILURE}; fi fi # Detect valgrind warnings. local NUMBER_OF_LINES=`wc -l ${VALGRIND_LOG} | awk '{ print $1 }'`; if test ${NUMBER_OF_LINES} -ne 15 && test ${NUMBER_OF_LINES} -ne 22; then echo "Unsupported number of lines: ${NUMBER_OF_LINES}"; cat ${VALGRIND_LOG}; RESULT=${EXIT_FAILURE}; fi fi rm -f ${VALGRIND_LOG}; elif test ${IS_PYTHON_SCRIPT} -eq 0; then if ! test -f "${TEST_EXECUTABLE}"; then echo "Invalid test Python script: ${TEST_EXECUTABLE}"; echo ""; return ${EXIT_FAILURE}; fi local TEST_EXECUTABLE=$( find_binary_executable ${TEST_EXECUTABLE} ); local LIBRARY_PATH=$( find_binary_library_path ${TEST_EXECUTABLE} ); local PYTHON_MODULE_PATH=$( find_binary_python_module_path ${TEST_EXECUTABLE} ); if test "${PLATFORM}" = "Darwin"; then if test -n "${CHECK_WITH_STDERR}"; then DYLD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; else DYLD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}" 2> /dev/null; RESULT=$?; fi elif test "${PLATFORM}" = "CYGWIN_NT"; then if test -n "${CHECK_WITH_STDERR}"; then PATH="${LIBRARY_PATH}:${PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; else PATH="${LIBRARY_PATH}:${PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}" 2> /dev/null; RESULT=$?; fi else if test -n "${CHECK_WITH_STDERR}"; then LD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; else LD_LIBRARY_PATH="${LIBRARY_PATH}" PYTHONPATH="${PYTHON_MODULE_PATH}" "${PYTHON}" "${TEST_EXECUTABLE}" ${ARGUMENTS[@]} "${INPUT_FILE}" 2> /dev/null; RESULT=$?; fi fi else if ! test -x "${TEST_EXECUTABLE}"; then echo "Invalid test executable: ${TEST_EXECUTABLE}"; echo ""; return ${EXIT_FAILURE}; fi if test -n "${CHECK_WITH_STDERR}"; then ${TEST_EXECUTABLE} ${ARGUMENTS[@]} "${INPUT_FILE}"; RESULT=$?; else ${TEST_EXECUTABLE} ${ARGUMENTS[@]} "${INPUT_FILE}" 2> /dev/null; RESULT=$?; fi fi return ${RESULT}; } # Runs the test on the input file. # # Note that this function is not intended to be directly invoked # from outside the test runner script. # # Arguments: # a string containing the path of the test set directory # a string containing the description of the test # a string containing the test mode # a string containing the name of the test data option set # a string containing the path of the test executable # a string containing the path of the test input file # an array containing the arguments for the test executable # # Returns: # an integer containg the exit status of the test executable # run_test_on_input_file() { local TEST_SET_DIRECTORY=$1; local TEST_DESCRIPTION=$2; local TEST_MODE=$3; local OPTION_SET=$4; local TEST_EXECUTABLE=$5; local INPUT_FILE=$6; shift 6; local ARGUMENTS=("$@"); local INPUT_NAME=`basename "${INPUT_FILE}"`; local TEST_OUTPUT="${INPUT_NAME}"; if test -n "${OPTION_SET}"; then TEST_OUTPUT="${INPUT_NAME}-${OPTION_SET}"; fi local TMPDIR="tmp$$"; local RESULT=0; rm -rf ${TMPDIR}; mkdir ${TMPDIR}; if test "${TEST_MODE}" = "with_callback"; then test_callback "${TMPDIR}" "${TEST_SET_DIRECTORY}" "${TEST_OUTPUT}" "${TEST_EXECUTABLE}" "${TEST_INPUT}" ${ARGUMENTS[@]}; RESULT=$?; elif test "${TEST_MODE}" = "with_stdout_reference"; then TEST_EXECUTABLE=$( readlink_f "${TEST_EXECUTABLE}" ); if ! test -x ${TEST_EXECUTABLE}; then echo "Invalid test executable: ${TEST_EXECUTABLE}"; echo ""; return ${EXIT_FAILURE}; fi local INPUT_FILE_FULL_PATH=$( readlink_f "${INPUT_FILE}" ); local TEST_LOG="${TEST_OUTPUT}.log"; (cd ${TMPDIR} && run_test_with_input_and_arguments "${TEST_EXECUTABLE}" "${INPUT_FILE_FULL_PATH}" ${ARGUMENTS[@]} > "${TEST_LOG}"); RESULT=$?; # Compare output if test ran successfully. if test ${RESULT} -eq ${EXIT_SUCCESS}; then local TEST_RESULTS="${TMPDIR}/${TEST_LOG}"; local STORED_TEST_RESULTS="${TEST_SET_DIRECTORY}/${TEST_LOG}.gz"; # Strip header with version. sed -i'~' '1,2d' "${TEST_RESULTS}"; if test -f "${STORED_TEST_RESULTS}"; then # Using zcat here since zdiff has issues on Mac OS X. # Note that zcat on Mac OS X requires the input from stdin. zcat < "${STORED_TEST_RESULTS}" | diff "${TEST_RESULTS}" -; RESULT=$?; else gzip "${TEST_RESULTS}"; mv "${TEST_RESULTS}.gz" ${TEST_SET_DIRECTORY}; fi fi else run_test_with_input_and_arguments "${TEST_EXECUTABLE}" "${INPUT_FILE}" ${ARGUMENTS[@]}; RESULT=$?; fi rm -rf ${TMPDIR}; if test -n "${TEST_DESCRIPTION}"; then ARGUMENTS=`echo "${ARGUMENTS[*]}" | tr '\n' ' ' | sed 's/[ ]\$//'`; if test -z "${ARGUMENTS}"; then echo -n "${TEST_DESCRIPTION} with input: ${INPUT_FILE}"; else echo -n "${TEST_DESCRIPTION} with options: '${ARGUMENTS}' and input: ${INPUT_FILE}"; fi if test ${RESULT} -ne ${EXIT_SUCCESS}; then echo " (FAIL)"; else echo " (PASS)"; fi fi return ${RESULT}; } libcaes-20240413/tests/caes_test_libcerror.h0000644000175000017500000000264114606473413021556 0ustar00lordyestalordyesta/* * The libcerror header wrapper * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _CAES_TEST_LIBCERROR_H ) #define _CAES_TEST_LIBCERROR_H #include /* Define HAVE_LOCAL_LIBCERROR for local use of libcerror */ #if defined( HAVE_LOCAL_LIBCERROR ) #include #include #include #include #else /* If libtool DLL support is enabled set LIBCERROR_DLL_IMPORT * before including libcerror.h */ #if defined( _WIN32 ) && defined( DLL_IMPORT ) #define LIBCERROR_DLL_IMPORT #endif #include #endif /* defined( HAVE_LOCAL_LIBCERROR ) */ #endif /* !defined( _CAES_TEST_LIBCERROR_H ) */ libcaes-20240413/tests/caes_test_crypt_cbc.c0000644000175000017500000053270414606473413021546 0ustar00lordyestalordyesta/* * Library AES-CBC de/encryption testing program * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include #include #if defined( HAVE_STDLIB_H ) || defined( WINAPI ) #include #endif #include "caes_test_libcaes.h" #include "caes_test_libcerror.h" #include "caes_test_unused.h" /* Tests AES-CBC de/encryption * Returns 1 if successful, 0 if not or -1 on error */ int caes_test_crypt_cbc( int mode, const uint8_t *key, size_t key_bit_size, const uint8_t *initialization_vector, size_t initialization_vector_size, const uint8_t *input_data, size_t input_data_size, const uint8_t *expected_output_data, size_t expected_output_data_size ) { uint8_t output_data[ 32 ]; libcaes_context_t *context = NULL; libcerror_error_t *error = NULL; static char *function = "caes_test_crypt_cbc"; size_t output_data_size = 32; int result = 0; if( input_data_size > output_data_size ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid input data size value out of bounds.", function ); goto on_error; } if( libcaes_context_initialize( &context, &error ) != 1 ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to create context.", function ); goto on_error; } if( libcaes_context_set_key( context, mode, key, key_bit_size, &error ) != 1 ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to set key in context.", function ); goto on_error; } if( libcaes_crypt_cbc( context, mode, initialization_vector, initialization_vector_size, input_data, input_data_size, output_data, output_data_size, &error ) != 1 ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_ENCRYPTION, LIBCERROR_ENCRYPTION_ERROR_GENERIC, "%s: unable to de/encrypt data.", function ); goto on_error; } result = memory_compare( output_data, expected_output_data, expected_output_data_size ); if( libcaes_context_free( &context, &error ) != 1 ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_FINALIZE_FAILED, "%s: unable to free context.", function ); goto on_error; } if( result != 0 ) { return( 0 ); } return( 1 ); on_error: if( error != NULL ) { libcerror_error_backtrace_fprint( error, stdout ); libcerror_error_free( &error ); } if( context != NULL ) { libcaes_context_free( &context, NULL ); } return( -1 ); } /* The main program */ #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) int wmain( int argc, wchar_t * const argv[] CAES_TEST_ATTRIBUTE_UNUSED ) #else int main( int argc, char * const argv[] CAES_TEST_ATTRIBUTE_UNUSED ) #endif { /* Values from NIST KAT-AES CBCVarKey128.rsp, CBCVarKey192.rsp and CBCVarKey256.rsp */ uint8_t keys[ 256 ][ 32 ] = { { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff } }; /* Values from NIST KAT-AES CBCVarTxt128.rsp */ uint8_t cipher_texts1_128bit[ 128 ][ 16 ] = { { 0x3a, 0xd7, 0x8e, 0x72, 0x6c, 0x1e, 0xc0, 0x2b, 0x7e, 0xbf, 0xe9, 0x2b, 0x23, 0xd9, 0xec, 0x34 }, { 0xaa, 0xe5, 0x93, 0x9c, 0x8e, 0xfd, 0xf2, 0xf0, 0x4e, 0x60, 0xb9, 0xfe, 0x71, 0x17, 0xb2, 0xc2 }, { 0xf0, 0x31, 0xd4, 0xd7, 0x4f, 0x5d, 0xcb, 0xf3, 0x9d, 0xaa, 0xf8, 0xca, 0x3a, 0xf6, 0xe5, 0x27 }, { 0x96, 0xd9, 0xfd, 0x5c, 0xc4, 0xf0, 0x74, 0x41, 0x72, 0x7d, 0xf0, 0xf3, 0x3e, 0x40, 0x1a, 0x36 }, { 0x30, 0xcc, 0xdb, 0x04, 0x46, 0x46, 0xd7, 0xe1, 0xf3, 0xcc, 0xea, 0x3d, 0xca, 0x08, 0xb8, 0xc0 }, { 0x16, 0xae, 0x4c, 0xe5, 0x04, 0x2a, 0x67, 0xee, 0x8e, 0x17, 0x7b, 0x7c, 0x58, 0x7e, 0xcc, 0x82 }, { 0xb6, 0xda, 0x0b, 0xb1, 0x1a, 0x23, 0x85, 0x5d, 0x9c, 0x5c, 0xb1, 0xb4, 0xc6, 0x41, 0x2e, 0x0a }, { 0xdb, 0x4f, 0x1a, 0xa5, 0x30, 0x96, 0x7d, 0x67, 0x32, 0xce, 0x47, 0x15, 0xeb, 0x0e, 0xe2, 0x4b }, { 0xa8, 0x17, 0x38, 0x25, 0x26, 0x21, 0xdd, 0x18, 0x0a, 0x34, 0xf3, 0x45, 0x5b, 0x4b, 0xaa, 0x2f }, { 0x77, 0xe2, 0xb5, 0x08, 0xdb, 0x7f, 0xd8, 0x92, 0x34, 0xca, 0xf7, 0x93, 0x9e, 0xe5, 0x62, 0x1a }, { 0xb8, 0x49, 0x9c, 0x25, 0x1f, 0x84, 0x42, 0xee, 0x13, 0xf0, 0x93, 0x3b, 0x68, 0x8f, 0xcd, 0x19 }, { 0x96, 0x51, 0x35, 0xf8, 0xa8, 0x1f, 0x25, 0xc9, 0xd6, 0x30, 0xb1, 0x75, 0x02, 0xf6, 0x8e, 0x53 }, { 0x8b, 0x87, 0x14, 0x5a, 0x01, 0xad, 0x1c, 0x6c, 0xed, 0xe9, 0x95, 0xea, 0x36, 0x70, 0x45, 0x4f }, { 0x8e, 0xae, 0x3b, 0x10, 0xa0, 0xc8, 0xca, 0x6d, 0x1d, 0x3b, 0x0f, 0xa6, 0x1e, 0x56, 0xb0, 0xb2 }, { 0x64, 0xb4, 0xd6, 0x29, 0x81, 0x0f, 0xda, 0x6b, 0xaf, 0xdf, 0x08, 0xf3, 0xb0, 0xd8, 0xd2, 0xc5 }, { 0xd7, 0xe5, 0xdb, 0xd3, 0x32, 0x45, 0x95, 0xf8, 0xfd, 0xc7, 0xd7, 0xc5, 0x71, 0xda, 0x6c, 0x2a }, { 0xf3, 0xf7, 0x23, 0x75, 0x26, 0x4e, 0x16, 0x7f, 0xca, 0x9d, 0xe2, 0xc1, 0x52, 0x7d, 0x96, 0x06 }, { 0x8e, 0xe7, 0x9d, 0xd4, 0xf4, 0x01, 0xff, 0x9b, 0x7e, 0xa9, 0x45, 0xd8, 0x66, 0x66, 0xc1, 0x3b }, { 0xdd, 0x35, 0xce, 0xa2, 0x79, 0x99, 0x40, 0xb4, 0x0d, 0xb3, 0xf8, 0x19, 0xcb, 0x94, 0xc0, 0x8b }, { 0x69, 0x41, 0xcb, 0x6b, 0x3e, 0x08, 0xc2, 0xb7, 0xaf, 0xa5, 0x81, 0xeb, 0xdd, 0x60, 0x7b, 0x87 }, { 0x2c, 0x20, 0xf4, 0x39, 0xf6, 0xbb, 0x09, 0x7b, 0x29, 0xb8, 0xbd, 0x6d, 0x99, 0xaa, 0xd7, 0x99 }, { 0x62, 0x5d, 0x01, 0xf0, 0x58, 0xe5, 0x65, 0xf7, 0x7a, 0xe8, 0x63, 0x78, 0xbd, 0x2c, 0x49, 0xb3 }, { 0xc0, 0xb5, 0xfd, 0x98, 0x19, 0x0e, 0xf4, 0x5f, 0xbb, 0x43, 0x01, 0x43, 0x8d, 0x09, 0x59, 0x50 }, { 0x13, 0x00, 0x1f, 0xf5, 0xd9, 0x98, 0x06, 0xef, 0xd2, 0x5d, 0xa3, 0x4f, 0x56, 0xbe, 0x85, 0x4b }, { 0x3b, 0x59, 0x4c, 0x60, 0xf5, 0xc8, 0x27, 0x7a, 0x51, 0x13, 0x67, 0x7f, 0x94, 0x20, 0x8d, 0x82 }, { 0xe9, 0xc0, 0xfc, 0x18, 0x18, 0xe4, 0xaa, 0x46, 0xbd, 0x2e, 0x39, 0xd6, 0x38, 0xf8, 0x9e, 0x05 }, { 0xf8, 0x02, 0x3e, 0xe9, 0xc3, 0xfd, 0xc4, 0x5a, 0x01, 0x9b, 0x4e, 0x98, 0x5c, 0x7e, 0x1a, 0x54 }, { 0x35, 0xf4, 0x01, 0x82, 0xab, 0x46, 0x62, 0xf3, 0x02, 0x3b, 0xae, 0xc1, 0xee, 0x79, 0x6b, 0x57 }, { 0x3a, 0xeb, 0xba, 0xd7, 0x30, 0x36, 0x49, 0xb4, 0x19, 0x4a, 0x69, 0x45, 0xc6, 0xcc, 0x36, 0x94 }, { 0xa2, 0x12, 0x4b, 0xea, 0x53, 0xec, 0x28, 0x34, 0x27, 0x9b, 0xed, 0x7f, 0x7e, 0xb0, 0xf9, 0x38 }, { 0xb9, 0xfb, 0x43, 0x99, 0xfa, 0x4f, 0xac, 0xc7, 0x30, 0x9e, 0x14, 0xec, 0x98, 0x36, 0x0b, 0x0a }, { 0xc2, 0x62, 0x77, 0x43, 0x74, 0x20, 0xc5, 0xd6, 0x34, 0xf7, 0x15, 0xae, 0xa8, 0x1a, 0x91, 0x32 }, { 0x17, 0x1a, 0x0e, 0x1b, 0x2d, 0xd4, 0x24, 0xf0, 0xe0, 0x89, 0xaf, 0x2c, 0x4c, 0x10, 0xf3, 0x2f }, { 0x7c, 0xad, 0xbe, 0x40, 0x2d, 0x1b, 0x20, 0x8f, 0xe7, 0x35, 0xed, 0xce, 0x00, 0xae, 0xe7, 0xce }, { 0x43, 0xb0, 0x2f, 0xf9, 0x29, 0xa1, 0x48, 0x5a, 0xf6, 0xf5, 0xc6, 0xd6, 0x55, 0x8b, 0xaa, 0x0f }, { 0x09, 0x2f, 0xaa, 0xcc, 0x9b, 0xf4, 0x35, 0x08, 0xbf, 0x8f, 0xa8, 0x61, 0x3c, 0xa7, 0x5d, 0xea }, { 0xcb, 0x2b, 0xf8, 0x28, 0x0f, 0x3f, 0x97, 0x42, 0xc7, 0xed, 0x51, 0x3f, 0xe8, 0x02, 0x62, 0x9c }, { 0x21, 0x5a, 0x41, 0xee, 0x44, 0x2f, 0xa9, 0x92, 0xa6, 0xe3, 0x23, 0x98, 0x6d, 0xed, 0x3f, 0x68 }, { 0xf2, 0x1e, 0x99, 0xcf, 0x4f, 0x0f, 0x77, 0xce, 0xa8, 0x36, 0xe1, 0x1a, 0x2f, 0xe7, 0x5f, 0xb1 }, { 0x95, 0xe3, 0xa0, 0xca, 0x90, 0x79, 0xe6, 0x46, 0x33, 0x1d, 0xf8, 0xb4, 0xe7, 0x0d, 0x2c, 0xd6 }, { 0x4a, 0xfe, 0x7f, 0x12, 0x0c, 0xe7, 0x61, 0x3f, 0x74, 0xfc, 0x12, 0xa0, 0x1a, 0x82, 0x80, 0x73 }, { 0x82, 0x7f, 0x00, 0x0e, 0x75, 0xe2, 0xc8, 0xb9, 0xd4, 0x79, 0xbe, 0xed, 0x91, 0x3f, 0xe6, 0x78 }, { 0x35, 0x83, 0x0c, 0x8e, 0x7a, 0xae, 0xfe, 0x2d, 0x30, 0x31, 0x0e, 0xf3, 0x81, 0xcb, 0xf6, 0x91 }, { 0x19, 0x1a, 0xa0, 0xf2, 0xc8, 0x57, 0x01, 0x44, 0xf3, 0x86, 0x57, 0xea, 0x40, 0x85, 0xeb, 0xe5 }, { 0x85, 0x06, 0x2c, 0x2c, 0x90, 0x9f, 0x15, 0xd9, 0x26, 0x9b, 0x6c, 0x18, 0xce, 0x99, 0xc4, 0xf0 }, { 0x67, 0x80, 0x34, 0xdc, 0x9e, 0x41, 0xb5, 0xa5, 0x60, 0xed, 0x23, 0x9e, 0xea, 0xb1, 0xbc, 0x78 }, { 0xc2, 0xf9, 0x3a, 0x4c, 0xe5, 0xab, 0x6d, 0x5d, 0x56, 0xf1, 0xb9, 0x3c, 0xf1, 0x99, 0x11, 0xc1 }, { 0x1c, 0x31, 0x12, 0xbc, 0xb0, 0xc1, 0xdc, 0xc7, 0x49, 0xd7, 0x99, 0x74, 0x36, 0x91, 0xbf, 0x82 }, { 0x00, 0xc5, 0x5b, 0xd7, 0x5c, 0x7f, 0x9c, 0x88, 0x19, 0x89, 0xd3, 0xec, 0x19, 0x11, 0xc0, 0xd4 }, { 0xea, 0x2e, 0x6b, 0x5e, 0xf1, 0x82, 0xb7, 0xdf, 0xf3, 0x62, 0x9a, 0xbd, 0x6a, 0x12, 0x04, 0x5f }, { 0x22, 0x32, 0x23, 0x27, 0xe0, 0x17, 0x80, 0xb1, 0x73, 0x97, 0xf2, 0x40, 0x87, 0xf8, 0xcc, 0x6f }, { 0xc9, 0xca, 0xcb, 0x5c, 0xd1, 0x16, 0x92, 0xc3, 0x73, 0xb2, 0x41, 0x17, 0x68, 0x14, 0x9e, 0xe7 }, { 0xa1, 0x8e, 0x3d, 0xbb, 0xca, 0x57, 0x78, 0x60, 0xda, 0xb6, 0xb8, 0x0d, 0xa3, 0x13, 0x92, 0x56 }, { 0x79, 0xb6, 0x1c, 0x37, 0xbf, 0x32, 0x8e, 0xcc, 0xa8, 0xd7, 0x43, 0x26, 0x5a, 0x3d, 0x42, 0x5c }, { 0xd2, 0xd9, 0x9c, 0x6b, 0xcc, 0x1f, 0x06, 0xfd, 0xa8, 0xe2, 0x7e, 0x8a, 0xe3, 0xf1, 0xcc, 0xc7 }, { 0x1b, 0xfd, 0x4b, 0x91, 0xc7, 0x01, 0xfd, 0x6b, 0x61, 0xb7, 0xf9, 0x97, 0x82, 0x9d, 0x66, 0x3b }, { 0x11, 0x00, 0x5d, 0x52, 0xf2, 0x5f, 0x16, 0xbd, 0xc9, 0x54, 0x5a, 0x87, 0x6a, 0x63, 0x49, 0x0a }, { 0x3a, 0x4d, 0x35, 0x4f, 0x02, 0xbb, 0x5a, 0x5e, 0x47, 0xd3, 0x96, 0x66, 0x86, 0x7f, 0x24, 0x6a }, { 0xd4, 0x51, 0xb8, 0xd6, 0xe1, 0xe1, 0xa0, 0xeb, 0xb1, 0x55, 0xfb, 0xbf, 0x6e, 0x7b, 0x7d, 0xc3 }, { 0x68, 0x98, 0xd4, 0xf4, 0x2f, 0xa7, 0xba, 0x6a, 0x10, 0xac, 0x05, 0xe8, 0x7b, 0x9f, 0x20, 0x80 }, { 0xb6, 0x11, 0x29, 0x5e, 0x73, 0x9c, 0xa7, 0xd9, 0xb5, 0x0f, 0x8e, 0x4c, 0x0e, 0x75, 0x4a, 0x3f }, { 0x7d, 0x33, 0xfc, 0x7d, 0x8a, 0xbe, 0x3c, 0xa1, 0x93, 0x67, 0x59, 0xf8, 0xf5, 0xde, 0xaf, 0x20 }, { 0x3b, 0x5e, 0x0f, 0x56, 0x6d, 0xc9, 0x6c, 0x29, 0x8f, 0x0c, 0x12, 0x63, 0x75, 0x39, 0xb2, 0x5c }, { 0xf8, 0x07, 0xc3, 0xe7, 0x98, 0x5f, 0xe0, 0xf5, 0xa5, 0x0e, 0x2c, 0xdb, 0x25, 0xc5, 0x10, 0x9e }, { 0x41, 0xf9, 0x92, 0xa8, 0x56, 0xfb, 0x27, 0x8b, 0x38, 0x9a, 0x62, 0xf5, 0xd2, 0x74, 0xd7, 0xe9 }, { 0x10, 0xd3, 0xed, 0x7a, 0x6f, 0xe1, 0x5a, 0xb4, 0xd9, 0x1a, 0xcb, 0xc7, 0xd0, 0x76, 0x7a, 0xb1 }, { 0x21, 0xfe, 0xec, 0xd4, 0x5b, 0x2e, 0x67, 0x59, 0x73, 0xac, 0x33, 0xbf, 0x0c, 0x54, 0x24, 0xfc }, { 0x14, 0x80, 0xcb, 0x39, 0x55, 0xba, 0x62, 0xd0, 0x9e, 0xea, 0x66, 0x8f, 0x7c, 0x70, 0x88, 0x17 }, { 0x66, 0x40, 0x40, 0x33, 0xd6, 0xb7, 0x2b, 0x60, 0x93, 0x54, 0xd5, 0x49, 0x6e, 0x7e, 0xb5, 0x11 }, { 0x1c, 0x31, 0x7a, 0x22, 0x0a, 0x7d, 0x70, 0x0d, 0xa2, 0xb1, 0xe0, 0x75, 0xb0, 0x02, 0x66, 0xe1 }, { 0xab, 0x3b, 0x89, 0x54, 0x22, 0x33, 0xf1, 0x27, 0x1b, 0xf8, 0xfd, 0x0c, 0x0f, 0x40, 0x35, 0x45 }, { 0xd9, 0x3e, 0xae, 0x96, 0x6f, 0xac, 0x46, 0xdc, 0xa9, 0x27, 0xd6, 0xb1, 0x14, 0xfa, 0x3f, 0x9e }, { 0x1b, 0xde, 0xc5, 0x21, 0x31, 0x65, 0x03, 0xd9, 0xd5, 0xee, 0x65, 0xdf, 0x3e, 0xa9, 0x4d, 0xdf }, { 0xee, 0xf4, 0x56, 0x43, 0x1d, 0xea, 0x8b, 0x4a, 0xcf, 0x83, 0xbd, 0xae, 0x37, 0x17, 0xf7, 0x5f }, { 0x06, 0xf2, 0x51, 0x9a, 0x2f, 0xaf, 0xaa, 0x59, 0x6b, 0xfe, 0xf5, 0xcf, 0xa1, 0x5c, 0x21, 0xb9 }, { 0x25, 0x1a, 0x7e, 0xac, 0x7e, 0x2f, 0xe8, 0x09, 0xe4, 0xaa, 0x8d, 0x0d, 0x70, 0x12, 0x53, 0x1a }, { 0x3b, 0xff, 0xc1, 0x6e, 0x4c, 0x49, 0xb2, 0x68, 0xa2, 0x0f, 0x8d, 0x96, 0xa6, 0x0b, 0x40, 0x58 }, { 0xe8, 0x86, 0xf9, 0x28, 0x19, 0x99, 0xc5, 0xbb, 0x3b, 0x3e, 0x88, 0x62, 0xe2, 0xf7, 0xc9, 0x88 }, { 0x56, 0x3b, 0xf9, 0x0d, 0x61, 0xbe, 0xef, 0x39, 0xf4, 0x8d, 0xd6, 0x25, 0xfc, 0xef, 0x13, 0x61 }, { 0x4d, 0x37, 0xc8, 0x50, 0x64, 0x45, 0x63, 0xc6, 0x9f, 0xd0, 0xac, 0xd9, 0xa0, 0x49, 0x32, 0x5b }, { 0xb8, 0x7c, 0x92, 0x1b, 0x91, 0x82, 0x9e, 0xf3, 0xb1, 0x3c, 0xa5, 0x41, 0xee, 0x11, 0x30, 0xa6 }, { 0x2e, 0x65, 0xeb, 0x6b, 0x6e, 0xa3, 0x83, 0xe1, 0x09, 0xac, 0xcc, 0xe8, 0x32, 0x6b, 0x03, 0x93 }, { 0x9c, 0xa5, 0x47, 0xf7, 0x43, 0x9e, 0xdc, 0x3e, 0x25, 0x5c, 0x0f, 0x4d, 0x49, 0xaa, 0x89, 0x90 }, { 0xa5, 0xe6, 0x52, 0x61, 0x4c, 0x93, 0x00, 0xf3, 0x78, 0x16, 0xb1, 0xf9, 0xfd, 0x0c, 0x87, 0xf9 }, { 0x14, 0x95, 0x4f, 0x0b, 0x46, 0x97, 0x77, 0x6f, 0x44, 0x49, 0x4f, 0xe4, 0x58, 0xd8, 0x14, 0xed }, { 0x7c, 0x8d, 0x9a, 0xb6, 0xc2, 0x76, 0x17, 0x23, 0xfe, 0x42, 0xf8, 0xbb, 0x50, 0x6c, 0xbc, 0xf7 }, { 0xdb, 0x7e, 0x19, 0x32, 0x67, 0x9f, 0xdd, 0x99, 0x74, 0x2a, 0xab, 0x04, 0xaa, 0x0d, 0x5a, 0x80 }, { 0x4c, 0x6a, 0x1c, 0x83, 0xe5, 0x68, 0xcd, 0x10, 0xf2, 0x7c, 0x2d, 0x73, 0xde, 0xd1, 0x9c, 0x28 }, { 0x90, 0xec, 0xbe, 0x61, 0x77, 0xe6, 0x74, 0xc9, 0x8d, 0xe4, 0x12, 0x41, 0x3f, 0x7a, 0xc9, 0x15 }, { 0x90, 0x68, 0x4a, 0x2a, 0xc5, 0x5f, 0xe1, 0xec, 0x2b, 0x8e, 0xbd, 0x56, 0x22, 0x52, 0x0b, 0x73 }, { 0x74, 0x72, 0xf9, 0xa7, 0x98, 0x86, 0x07, 0xca, 0x79, 0x70, 0x77, 0x95, 0x99, 0x10, 0x35, 0xe6 }, { 0x56, 0xaf, 0xf0, 0x89, 0x87, 0x8b, 0xf3, 0x35, 0x2f, 0x8d, 0xf1, 0x72, 0xa3, 0xae, 0x47, 0xd8 }, { 0x65, 0xc0, 0x52, 0x6c, 0xbe, 0x40, 0x16, 0x1b, 0x80, 0x19, 0xa2, 0xa3, 0x17, 0x1a, 0xbd, 0x23 }, { 0x37, 0x7b, 0xe0, 0xbe, 0x33, 0xb4, 0xe3, 0xe3, 0x10, 0xb4, 0xaa, 0xbd, 0xa1, 0x73, 0xf8, 0x4f }, { 0x94, 0x02, 0xe9, 0xaa, 0x6f, 0x69, 0xde, 0x65, 0x04, 0xda, 0x8d, 0x20, 0xc4, 0xfc, 0xaa, 0x2f }, { 0x12, 0x3c, 0x1f, 0x4a, 0xf3, 0x13, 0xad, 0x8c, 0x2c, 0xe6, 0x48, 0xb2, 0xe7, 0x1f, 0xb6, 0xe1 }, { 0x1f, 0xfc, 0x62, 0x6d, 0x30, 0x20, 0x3d, 0xcd, 0xb0, 0x01, 0x9f, 0xb8, 0x0f, 0x72, 0x6c, 0xf4 }, { 0x76, 0xda, 0x1f, 0xbe, 0x3a, 0x50, 0x72, 0x8c, 0x50, 0xfd, 0x2e, 0x62, 0x1b, 0x5a, 0xd8, 0x85 }, { 0x08, 0x2e, 0xb8, 0xbe, 0x35, 0xf4, 0x42, 0xfb, 0x52, 0x66, 0x8e, 0x16, 0xa5, 0x91, 0xd1, 0xd6 }, { 0xe6, 0x56, 0xf9, 0xec, 0xf5, 0xfe, 0x27, 0xec, 0x3e, 0x4a, 0x73, 0xd0, 0x0c, 0x28, 0x2f, 0xb3 }, { 0x2c, 0xa8, 0x20, 0x9d, 0x63, 0x27, 0x4c, 0xd9, 0xa2, 0x9b, 0xb7, 0x4b, 0xcd, 0x77, 0x68, 0x3a }, { 0x79, 0xbf, 0x5d, 0xce, 0x14, 0xbb, 0x7d, 0xd7, 0x3a, 0x8e, 0x36, 0x11, 0xde, 0x7c, 0xe0, 0x26 }, { 0x3c, 0x84, 0x99, 0x39, 0xa5, 0xd2, 0x93, 0x99, 0xf3, 0x44, 0xc4, 0xa0, 0xec, 0xa8, 0xa5, 0x76 }, { 0xed, 0x3c, 0x0a, 0x94, 0xd5, 0x9b, 0xec, 0xe9, 0x88, 0x35, 0xda, 0x7a, 0xa4, 0xf0, 0x7c, 0xa2 }, { 0x63, 0x91, 0x9e, 0xd4, 0xce, 0x10, 0x19, 0x64, 0x38, 0xb6, 0xad, 0x09, 0xd9, 0x9c, 0xd7, 0x95 }, { 0x76, 0x78, 0xf3, 0xa8, 0x33, 0xf1, 0x9f, 0xea, 0x95, 0xf3, 0xc6, 0x02, 0x9e, 0x2b, 0xc6, 0x10 }, { 0x3a, 0xa4, 0x26, 0x83, 0x10, 0x67, 0xd3, 0x6b, 0x92, 0xbe, 0x7c, 0x5f, 0x81, 0xc1, 0x3c, 0x56 }, { 0x92, 0x72, 0xe2, 0xd2, 0xcd, 0xd1, 0x10, 0x50, 0x99, 0x8c, 0x84, 0x50, 0x77, 0xa3, 0x0e, 0xa0 }, { 0x08, 0x8c, 0x4b, 0x53, 0xf5, 0xec, 0x0f, 0xf8, 0x14, 0xc1, 0x9a, 0xda, 0xe7, 0xf6, 0x24, 0x6c }, { 0x40, 0x10, 0xa5, 0xe4, 0x01, 0xfd, 0xf0, 0xa0, 0x35, 0x4d, 0xdb, 0xcc, 0x0d, 0x01, 0x2b, 0x17 }, { 0xa8, 0x7a, 0x38, 0x57, 0x36, 0xc0, 0xa6, 0x18, 0x9b, 0xd6, 0x58, 0x9b, 0xd8, 0x44, 0x5a, 0x93 }, { 0x54, 0x5f, 0x2b, 0x83, 0xd9, 0x61, 0x6d, 0xcc, 0xf6, 0x0f, 0xa9, 0x83, 0x0e, 0x9c, 0xd2, 0x87 }, { 0x4b, 0x70, 0x6f, 0x7f, 0x92, 0x40, 0x63, 0x52, 0x39, 0x40, 0x37, 0xa6, 0xd4, 0xf4, 0x68, 0x8d }, { 0xb7, 0x97, 0x2b, 0x39, 0x41, 0xc4, 0x4b, 0x90, 0xaf, 0xa7, 0xb2, 0x64, 0xbf, 0xba, 0x73, 0x87 }, { 0x6f, 0x45, 0x73, 0x2c, 0xf1, 0x08, 0x81, 0x54, 0x6f, 0x0f, 0xd2, 0x38, 0x96, 0xd2, 0xbb, 0x60 }, { 0x2e, 0x35, 0x79, 0xca, 0x15, 0xaf, 0x27, 0xf6, 0x4b, 0x3c, 0x95, 0x5a, 0x5b, 0xfc, 0x30, 0xba }, { 0x34, 0xa2, 0xc5, 0xa9, 0x1a, 0xe2, 0xae, 0xc9, 0x9b, 0x7d, 0x1b, 0x5f, 0xa6, 0x78, 0x04, 0x47 }, { 0xa4, 0xd6, 0x61, 0x6b, 0xd0, 0x4f, 0x87, 0x33, 0x5b, 0x0e, 0x53, 0x35, 0x12, 0x27, 0xa9, 0xee }, { 0x7f, 0x69, 0x2b, 0x03, 0x94, 0x58, 0x67, 0xd1, 0x61, 0x79, 0xa8, 0xce, 0xfc, 0x83, 0xea, 0x3f }, { 0x3b, 0xd1, 0x41, 0xee, 0x84, 0xa0, 0xe6, 0x41, 0x4a, 0x26, 0xe7, 0xa4, 0xf2, 0x81, 0xf8, 0xa2 }, { 0xd1, 0x78, 0x8f, 0x57, 0x2d, 0x98, 0xb2, 0xb1, 0x6e, 0xc5, 0xd5, 0xf3, 0x92, 0x2b, 0x99, 0xbc }, { 0x08, 0x33, 0xff, 0x6f, 0x61, 0xd9, 0x8a, 0x57, 0xb2, 0x88, 0xe8, 0xc3, 0x58, 0x6b, 0x85, 0xa6 }, { 0x85, 0x68, 0x26, 0x17, 0x97, 0xde, 0x17, 0x6b, 0xf0, 0xb4, 0x3b, 0xec, 0xc6, 0x28, 0x5a, 0xfb }, { 0xf9, 0xb0, 0xfd, 0xa0, 0xc4, 0xa8, 0x98, 0xf5, 0xb9, 0xe6, 0xf6, 0x61, 0xc4, 0xce, 0x4d, 0x07 }, { 0x8a, 0xde, 0x89, 0x59, 0x13, 0x68, 0x5c, 0x67, 0xc5, 0x26, 0x9f, 0x8a, 0xae, 0x42, 0x98, 0x3e }, { 0x39, 0xbd, 0xe6, 0x7d, 0x5c, 0x8e, 0xd8, 0xa8, 0xb1, 0xc3, 0x7e, 0xb8, 0xfa, 0x9f, 0x5a, 0xc0 }, { 0x5c, 0x00, 0x5e, 0x72, 0xc1, 0x41, 0x8c, 0x44, 0xf5, 0x69, 0xf2, 0xea, 0x33, 0xba, 0x54, 0xf3 }, { 0x3f, 0x5b, 0x8c, 0xc9, 0xea, 0x85, 0x5a, 0x0a, 0xfa, 0x73, 0x47, 0xd2, 0x3e, 0x8d, 0x66, 0x4e } }; /* Values from NIST KAT-AES CBCVarKey128.rsp */ uint8_t cipher_texts2_128bit[ 128 ][ 16 ] = { { 0x0e, 0xdd, 0x33, 0xd3, 0xc6, 0x21, 0xe5, 0x46, 0x45, 0x5b, 0xd8, 0xba, 0x14, 0x18, 0xbe, 0xc8 }, { 0x4b, 0xc3, 0xf8, 0x83, 0x45, 0x0c, 0x11, 0x3c, 0x64, 0xca, 0x42, 0xe1, 0x11, 0x2a, 0x9e, 0x87 }, { 0x72, 0xa1, 0xda, 0x77, 0x0f, 0x5d, 0x7a, 0xc4, 0xc9, 0xef, 0x94, 0xd8, 0x22, 0xaf, 0xfd, 0x97 }, { 0x97, 0x00, 0x14, 0xd6, 0x34, 0xe2, 0xb7, 0x65, 0x07, 0x77, 0xe8, 0xe8, 0x4d, 0x03, 0xcc, 0xd8 }, { 0xf1, 0x7e, 0x79, 0xae, 0xd0, 0xdb, 0x7e, 0x27, 0x9e, 0x95, 0x5b, 0x5f, 0x49, 0x38, 0x75, 0xa7 }, { 0x9e, 0xd5, 0xa7, 0x51, 0x36, 0xa9, 0x40, 0xd0, 0x96, 0x3d, 0xa3, 0x79, 0xdb, 0x4a, 0xf2, 0x6a }, { 0xc4, 0x29, 0x5f, 0x83, 0x46, 0x5c, 0x77, 0x55, 0xe8, 0xfa, 0x36, 0x4b, 0xac, 0x6a, 0x7e, 0xa5 }, { 0xb1, 0xd7, 0x58, 0x25, 0x6b, 0x28, 0xfd, 0x85, 0x0a, 0xd4, 0x94, 0x42, 0x08, 0xcf, 0x11, 0x55 }, { 0x42, 0xff, 0xb3, 0x4c, 0x74, 0x3d, 0xe4, 0xd8, 0x8c, 0xa3, 0x80, 0x11, 0xc9, 0x90, 0x89, 0x0b }, { 0x99, 0x58, 0xf0, 0xec, 0xea, 0x8b, 0x21, 0x72, 0xc0, 0xc1, 0x99, 0x5f, 0x91, 0x82, 0xc0, 0xf3 }, { 0x95, 0x6d, 0x77, 0x98, 0xfa, 0xc2, 0x0f, 0x82, 0xa8, 0x82, 0x3f, 0x98, 0x4d, 0x06, 0xf7, 0xf5 }, { 0xa0, 0x1b, 0xf4, 0x4f, 0x2d, 0x16, 0xbe, 0x92, 0x8c, 0xa4, 0x4a, 0xaf, 0x7b, 0x9b, 0x10, 0x6b }, { 0xb5, 0xf1, 0xa3, 0x3e, 0x50, 0xd4, 0x0d, 0x10, 0x37, 0x64, 0xc7, 0x6b, 0xd4, 0xc6, 0xb6, 0xf8 }, { 0x26, 0x37, 0x05, 0x0c, 0x9f, 0xc0, 0xd4, 0x81, 0x7e, 0x2d, 0x69, 0xde, 0x87, 0x8a, 0xee, 0x8d }, { 0x11, 0x3e, 0xcb, 0xe4, 0xa4, 0x53, 0x26, 0x9a, 0x0d, 0xd2, 0x60, 0x69, 0x46, 0x7f, 0xb5, 0xb5 }, { 0x97, 0xd0, 0x75, 0x4f, 0xe6, 0x8f, 0x11, 0xb9, 0xe3, 0x75, 0xd0, 0x70, 0xa6, 0x08, 0xc8, 0x84 }, { 0xc6, 0xa0, 0xb3, 0xe9, 0x98, 0xd0, 0x50, 0x68, 0xa5, 0x39, 0x97, 0x78, 0x40, 0x52, 0x00, 0xb4 }, { 0xdf, 0x55, 0x6a, 0x33, 0x43, 0x8d, 0xb8, 0x7b, 0xc4, 0x1b, 0x17, 0x52, 0xc5, 0x5e, 0x5e, 0x49 }, { 0x90, 0xfb, 0x12, 0x8d, 0x3a, 0x1a, 0xf6, 0xe5, 0x48, 0x52, 0x1b, 0xb9, 0x62, 0xbf, 0x1f, 0x05 }, { 0x26, 0x29, 0x8e, 0x9c, 0x1d, 0xb5, 0x17, 0xc2, 0x15, 0xfa, 0xdf, 0xb7, 0xd2, 0xa8, 0xd6, 0x91 }, { 0xa6, 0xcb, 0x76, 0x1d, 0x61, 0xf8, 0x29, 0x2d, 0x0d, 0xf3, 0x93, 0xa2, 0x79, 0xad, 0x03, 0x80 }, { 0x12, 0xac, 0xd8, 0x9b, 0x13, 0xcd, 0x5f, 0x87, 0x26, 0xe3, 0x4d, 0x44, 0xfd, 0x48, 0x61, 0x08 }, { 0x95, 0xb1, 0x70, 0x3f, 0xc5, 0x7b, 0xa0, 0x9f, 0xe0, 0xc3, 0x58, 0x0f, 0xeb, 0xdd, 0x7e, 0xd4 }, { 0xde, 0x11, 0x72, 0x2d, 0x89, 0x3e, 0x9f, 0x91, 0x21, 0xc3, 0x81, 0xbe, 0xcc, 0x1d, 0xa5, 0x9a }, { 0x6d, 0x11, 0x4c, 0xcb, 0x27, 0xbf, 0x39, 0x10, 0x12, 0xe8, 0x97, 0x4c, 0x54, 0x6d, 0x9b, 0xf2 }, { 0x5c, 0xe3, 0x7e, 0x17, 0xeb, 0x46, 0x46, 0xec, 0xfa, 0xc2, 0x9b, 0x9c, 0xc3, 0x8d, 0x93, 0x40 }, { 0x18, 0xc1, 0xb6, 0xe2, 0x15, 0x71, 0x22, 0x05, 0x6d, 0x02, 0x43, 0xd8, 0xa1, 0x65, 0xcd, 0xdb }, { 0x99, 0x69, 0x3e, 0x6a, 0x59, 0xd1, 0x36, 0x6c, 0x74, 0xd8, 0x23, 0x56, 0x2d, 0x7e, 0x14, 0x31 }, { 0x6c, 0x7c, 0x64, 0xdc, 0x84, 0xa8, 0xbb, 0xa7, 0x58, 0xed, 0x17, 0xeb, 0x02, 0x5a, 0x57, 0xe3 }, { 0xe1, 0x7b, 0xc7, 0x9f, 0x30, 0xea, 0xab, 0x2f, 0xac, 0x2c, 0xbb, 0xe3, 0x45, 0x8d, 0x68, 0x7a }, { 0x11, 0x14, 0xbc, 0x20, 0x28, 0x00, 0x9b, 0x92, 0x3f, 0x0b, 0x01, 0x91, 0x5c, 0xe5, 0xe7, 0xc4 }, { 0x9c, 0x28, 0x52, 0x4a, 0x16, 0xa1, 0xe1, 0xc1, 0x45, 0x29, 0x71, 0xca, 0xa8, 0xd1, 0x34, 0x76 }, { 0xed, 0x62, 0xe1, 0x63, 0x63, 0x63, 0x83, 0x60, 0xfd, 0xd6, 0xad, 0x62, 0x11, 0x27, 0x94, 0xf0 }, { 0x5a, 0x86, 0x88, 0xf0, 0xb2, 0xa2, 0xc1, 0x62, 0x24, 0xc1, 0x61, 0x65, 0x8f, 0xfd, 0x40, 0x44 }, { 0x23, 0xf7, 0x10, 0x84, 0x2b, 0x9b, 0xb9, 0xc3, 0x2f, 0x26, 0x64, 0x8c, 0x78, 0x68, 0x07, 0xca }, { 0x44, 0xa9, 0x8b, 0xf1, 0x1e, 0x16, 0x3f, 0x63, 0x2c, 0x47, 0xec, 0x6a, 0x49, 0x68, 0x3a, 0x89 }, { 0x0f, 0x18, 0xaf, 0xf9, 0x42, 0x74, 0x69, 0x6d, 0x9b, 0x61, 0x84, 0x8b, 0xd5, 0x0a, 0xc5, 0xe5 }, { 0x82, 0x40, 0x85, 0x71, 0xc3, 0xe2, 0x42, 0x45, 0x40, 0x20, 0x7f, 0x83, 0x3b, 0x6d, 0xda, 0x69 }, { 0x30, 0x3f, 0xf9, 0x96, 0x94, 0x7f, 0x0c, 0x7d, 0x1f, 0x43, 0xc8, 0xf3, 0x02, 0x7b, 0x9b, 0x75 }, { 0x7d, 0xf4, 0xda, 0xf4, 0xad, 0x29, 0xa3, 0x61, 0x5a, 0x9b, 0x6e, 0xce, 0x5c, 0x99, 0x51, 0x8a }, { 0xc7, 0x29, 0x54, 0xa4, 0x8d, 0x07, 0x74, 0xdb, 0x0b, 0x49, 0x71, 0xc5, 0x26, 0x26, 0x04, 0x15 }, { 0x1d, 0xf9, 0xb7, 0x61, 0x12, 0xdc, 0x65, 0x31, 0xe0, 0x7d, 0x2c, 0xfd, 0xa0, 0x44, 0x11, 0xf0 }, { 0x8e, 0x4d, 0x8e, 0x69, 0x91, 0x19, 0xe1, 0xfc, 0x87, 0x54, 0x5a, 0x64, 0x7f, 0xb1, 0xd3, 0x4f }, { 0xe6, 0xc4, 0x80, 0x7a, 0xe1, 0x1f, 0x36, 0xf0, 0x91, 0xc5, 0x7d, 0x9f, 0xb6, 0x85, 0x48, 0xd1 }, { 0x8e, 0xbf, 0x73, 0xaa, 0xd4, 0x9c, 0x82, 0x00, 0x7f, 0x77, 0xa5, 0xc1, 0xcc, 0xec, 0x6a, 0xb4 }, { 0x4f, 0xb2, 0x88, 0xcc, 0x20, 0x40, 0x04, 0x90, 0x01, 0xd2, 0xc7, 0x58, 0x5a, 0xd1, 0x23, 0xfc }, { 0x04, 0x49, 0x71, 0x10, 0xef, 0xb9, 0xdc, 0xeb, 0x13, 0xe2, 0xb1, 0x3f, 0xb4, 0x46, 0x55, 0x64 }, { 0x75, 0x55, 0x0e, 0x6c, 0xb5, 0xa8, 0x8e, 0x49, 0x63, 0x4c, 0x9a, 0xb6, 0x9e, 0xda, 0x04, 0x30 }, { 0xb6, 0x76, 0x84, 0x73, 0xce, 0x98, 0x43, 0xea, 0x66, 0xa8, 0x14, 0x05, 0xdd, 0x50, 0xb3, 0x45 }, { 0xcb, 0x2f, 0x43, 0x03, 0x83, 0xf9, 0x08, 0x4e, 0x03, 0xa6, 0x53, 0x57, 0x1e, 0x06, 0x5d, 0xe6 }, { 0xff, 0x4e, 0x66, 0xc0, 0x7b, 0xae, 0x3e, 0x79, 0xfb, 0x7d, 0x21, 0x08, 0x47, 0xa3, 0xb0, 0xba }, { 0x7b, 0x90, 0x78, 0x51, 0x25, 0x50, 0x5f, 0xad, 0x59, 0xb1, 0x3c, 0x18, 0x6d, 0xd6, 0x6c, 0xe3 }, { 0x8b, 0x52, 0x7a, 0x6a, 0xeb, 0xda, 0xec, 0x9e, 0xae, 0xf8, 0xed, 0xa2, 0xcb, 0x77, 0x83, 0xe5 }, { 0x43, 0xfd, 0xaf, 0x53, 0xeb, 0xbc, 0x98, 0x80, 0xc2, 0x28, 0x61, 0x7d, 0x6a, 0x9b, 0x54, 0x8b }, { 0x53, 0x78, 0x61, 0x04, 0xb9, 0x74, 0x4b, 0x98, 0xf0, 0x52, 0xc4, 0x6f, 0x1c, 0x85, 0x0d, 0x0b }, { 0xb5, 0xab, 0x30, 0x13, 0xdd, 0x1e, 0x61, 0xdf, 0x06, 0xcb, 0xaf, 0x34, 0xca, 0x2a, 0xee, 0x78 }, { 0x74, 0x70, 0x46, 0x9b, 0xe9, 0x72, 0x30, 0x30, 0xfd, 0xcc, 0x73, 0xa8, 0xcd, 0x4f, 0xbb, 0x10 }, { 0xa3, 0x5a, 0x63, 0xf5, 0x34, 0x3e, 0xbe, 0x9e, 0xf8, 0x16, 0x7b, 0xcb, 0x48, 0xad, 0x12, 0x2e }, { 0xfd, 0x86, 0x87, 0xf0, 0x75, 0x7a, 0x21, 0x0e, 0x9f, 0xdf, 0x18, 0x12, 0x04, 0xc3, 0x08, 0x63 }, { 0x7a, 0x18, 0x1e, 0x84, 0xbd, 0x54, 0x57, 0xd2, 0x6a, 0x88, 0xfb, 0xae, 0x96, 0x01, 0x8f, 0xb0 }, { 0x65, 0x33, 0x17, 0xb9, 0x36, 0x2b, 0x6f, 0x9b, 0x9e, 0x1a, 0x58, 0x0e, 0x68, 0xd4, 0x94, 0xb5 }, { 0x99, 0x5c, 0x9d, 0xc0, 0xb6, 0x89, 0xf0, 0x3c, 0x45, 0x86, 0x7b, 0x5f, 0xaa, 0x5c, 0x18, 0xd1 }, { 0x77, 0xa4, 0xd9, 0x6d, 0x56, 0xdd, 0xa3, 0x98, 0xb9, 0xaa, 0xbe, 0xcf, 0xc7, 0x57, 0x29, 0xfd }, { 0x84, 0xbe, 0x19, 0xe0, 0x53, 0x63, 0x5f, 0x09, 0xf2, 0x66, 0x5e, 0x7b, 0xae, 0x85, 0xb4, 0x2d }, { 0x32, 0xcd, 0x65, 0x28, 0x42, 0x92, 0x6a, 0xea, 0x4a, 0xa6, 0x13, 0x7b, 0xb2, 0xbe, 0x2b, 0x5e }, { 0x49, 0x3d, 0x4a, 0x4f, 0x38, 0xeb, 0xb3, 0x37, 0xd1, 0x0a, 0xa8, 0x4e, 0x91, 0x71, 0xa5, 0x54 }, { 0xd9, 0xbf, 0xf7, 0xff, 0x45, 0x4b, 0x0e, 0xc5, 0xa4, 0xa2, 0xa6, 0x95, 0x66, 0xe2, 0xcb, 0x84 }, { 0x35, 0x35, 0xd5, 0x65, 0xac, 0xe3, 0xf3, 0x1e, 0xb2, 0x49, 0xba, 0x2c, 0xc6, 0x76, 0x5d, 0x7a }, { 0xf6, 0x0e, 0x91, 0xfc, 0x32, 0x69, 0xee, 0xcf, 0x32, 0x31, 0xc6, 0xe9, 0x94, 0x56, 0x97, 0xc6 }, { 0xab, 0x69, 0xcf, 0xad, 0xf5, 0x1f, 0x8e, 0x60, 0x4d, 0x9c, 0xc3, 0x71, 0x82, 0xf6, 0x63, 0x5a }, { 0x78, 0x66, 0x37, 0x3f, 0x24, 0xa0, 0xb6, 0xed, 0x56, 0xe0, 0xd9, 0x6f, 0xcd, 0xaf, 0xb8, 0x77 }, { 0x1e, 0xa4, 0x48, 0xc2, 0xaa, 0xc9, 0x54, 0xf5, 0xd8, 0x12, 0xe9, 0xd7, 0x84, 0x94, 0x44, 0x6a }, { 0xac, 0xc5, 0x59, 0x9d, 0xd8, 0xac, 0x02, 0x23, 0x9a, 0x0f, 0xef, 0x4a, 0x36, 0xdd, 0x16, 0x68 }, { 0xd8, 0x76, 0x44, 0x68, 0xbb, 0x10, 0x38, 0x28, 0xcf, 0x7e, 0x14, 0x73, 0xce, 0x89, 0x50, 0x73 }, { 0x1b, 0x0d, 0x02, 0x89, 0x36, 0x83, 0xb9, 0xf1, 0x80, 0x45, 0x8e, 0x4a, 0xa6, 0xb7, 0x39, 0x82 }, { 0x96, 0xd9, 0xb0, 0x17, 0xd3, 0x02, 0xdf, 0x41, 0x0a, 0x93, 0x7d, 0xcd, 0xb8, 0xbb, 0x6e, 0x43 }, { 0xef, 0x16, 0x23, 0xcc, 0x44, 0x31, 0x3c, 0xff, 0x44, 0x0b, 0x15, 0x94, 0xa7, 0xe2, 0x1c, 0xc6 }, { 0x28, 0x4c, 0xa2, 0xfa, 0x35, 0x80, 0x7b, 0x8b, 0x0a, 0xe4, 0xd1, 0x9e, 0x11, 0xd7, 0xdb, 0xd7 }, { 0xf2, 0xe9, 0x76, 0x87, 0x57, 0x55, 0xf9, 0x40, 0x1d, 0x54, 0xf3, 0x6e, 0x2a, 0x23, 0xa5, 0x94 }, { 0xec, 0x19, 0x8a, 0x18, 0xe1, 0x0e, 0x53, 0x24, 0x03, 0xb7, 0xe2, 0x08, 0x87, 0xc8, 0xdd, 0x80 }, { 0x54, 0x5d, 0x50, 0xeb, 0xd9, 0x19, 0xe4, 0xa6, 0x94, 0x9d, 0x96, 0xad, 0x47, 0xe4, 0x6a, 0x80 }, { 0xdb, 0xdf, 0xb5, 0x27, 0x06, 0x0e, 0x0a, 0x71, 0x00, 0x9c, 0x7b, 0xb0, 0xc6, 0x8f, 0x1d, 0x44 }, { 0x9c, 0xfa, 0x13, 0x22, 0xea, 0x33, 0xda, 0x21, 0x73, 0xa0, 0x24, 0xf2, 0xff, 0x0d, 0x89, 0x6d }, { 0x87, 0x85, 0xb1, 0xa7, 0x5b, 0x0f, 0x3b, 0xd9, 0x58, 0xdc, 0xd0, 0xe2, 0x93, 0x18, 0xc5, 0x21 }, { 0x38, 0xf6, 0x7b, 0x9e, 0x98, 0xe4, 0xa9, 0x7b, 0x6d, 0xf0, 0x30, 0xa9, 0xfc, 0xdd, 0x01, 0x04 }, { 0x19, 0x2a, 0xff, 0xfb, 0x2c, 0x88, 0x0e, 0x82, 0xb0, 0x59, 0x26, 0xd0, 0xfc, 0x6c, 0x44, 0x8b }, { 0x6a, 0x79, 0x80, 0xce, 0x7b, 0x10, 0x5c, 0xf5, 0x30, 0x95, 0x2d, 0x74, 0xda, 0xaf, 0x79, 0x8c }, { 0xea, 0x36, 0x95, 0xe1, 0x35, 0x1b, 0x9d, 0x68, 0x58, 0xbd, 0x95, 0x8c, 0xf5, 0x13, 0xef, 0x6c }, { 0x6d, 0xa0, 0x49, 0x0b, 0xa0, 0xba, 0x03, 0x43, 0xb9, 0x35, 0x68, 0x1d, 0x2c, 0xce, 0x5b, 0xa1 }, { 0xf0, 0xea, 0x23, 0xaf, 0x08, 0x53, 0x40, 0x11, 0xc6, 0x00, 0x09, 0xab, 0x29, 0xad, 0xa2, 0xf1 }, { 0xff, 0x13, 0x80, 0x6c, 0xf1, 0x9c, 0xc3, 0x87, 0x21, 0x55, 0x4d, 0x7c, 0x0f, 0xcd, 0xcd, 0x4b }, { 0x68, 0x38, 0xaf, 0x1f, 0x4f, 0x69, 0xba, 0xe9, 0xd8, 0x5d, 0xd1, 0x88, 0xdc, 0xdf, 0x06, 0x88 }, { 0x36, 0xcf, 0x44, 0xc9, 0x2d, 0x55, 0x0b, 0xfb, 0x1e, 0xd2, 0x8e, 0xf5, 0x83, 0xdd, 0xf5, 0xd7 }, { 0xd0, 0x6e, 0x31, 0x95, 0xb5, 0x37, 0x6f, 0x10, 0x9d, 0x5c, 0x4e, 0xc6, 0xc5, 0xd6, 0x2c, 0xed }, { 0xc4, 0x40, 0xde, 0x01, 0x4d, 0x3d, 0x61, 0x07, 0x07, 0x27, 0x9b, 0x13, 0x24, 0x2a, 0x5c, 0x36 }, { 0xf0, 0xc5, 0xc6, 0xff, 0xa5, 0xe0, 0xbd, 0x3a, 0x94, 0xc8, 0x8f, 0x6b, 0x6f, 0x7c, 0x16, 0xb9 }, { 0x3e, 0x40, 0xc3, 0x90, 0x1c, 0xd7, 0xef, 0xfc, 0x22, 0xbf, 0xfc, 0x35, 0xde, 0xe0, 0xb4, 0xd9 }, { 0xb6, 0x33, 0x05, 0xc7, 0x2b, 0xed, 0xfa, 0xb9, 0x73, 0x82, 0xc4, 0x06, 0xd0, 0xc4, 0x9b, 0xc6 }, { 0x36, 0xbb, 0xaa, 0xb2, 0x2a, 0x6b, 0xd4, 0x92, 0x5a, 0x99, 0xa2, 0xb4, 0x08, 0xd2, 0xdb, 0xae }, { 0x30, 0x7c, 0x5b, 0x8f, 0xcd, 0x05, 0x33, 0xab, 0x98, 0xbc, 0x51, 0xe2, 0x7a, 0x6c, 0xe4, 0x61 }, { 0x82, 0x9c, 0x04, 0xff, 0x4c, 0x07, 0x51, 0x3c, 0x0b, 0x3e, 0xf0, 0x5c, 0x03, 0xe3, 0x37, 0xb5 }, { 0xf1, 0x7a, 0xf0, 0xe8, 0x95, 0xdd, 0xa5, 0xeb, 0x98, 0xef, 0xc6, 0x80, 0x66, 0xe8, 0x4c, 0x54 }, { 0x27, 0x71, 0x67, 0xf3, 0x81, 0x2a, 0xff, 0xf1, 0xff, 0xac, 0xb4, 0xa9, 0x34, 0x37, 0x9f, 0xc3 }, { 0x2c, 0xb1, 0xdc, 0x3a, 0x9c, 0x72, 0x97, 0x2e, 0x42, 0x5a, 0xe2, 0xef, 0x3e, 0xb5, 0x97, 0xcd }, { 0x36, 0xae, 0xaa, 0x3a, 0x21, 0x3e, 0x96, 0x8d, 0x4b, 0x5b, 0x67, 0x9d, 0x3a, 0x2c, 0x97, 0xfe }, { 0x92, 0x41, 0xda, 0xca, 0x4f, 0xdd, 0x03, 0x4a, 0x82, 0x37, 0x2d, 0xb5, 0x0e, 0x1a, 0x0f, 0x3f }, { 0xc1, 0x45, 0x74, 0xd9, 0xcd, 0x00, 0xcf, 0x2b, 0x5a, 0x7f, 0x77, 0xe5, 0x3c, 0xd5, 0x78, 0x85 }, { 0x79, 0x3d, 0xe3, 0x92, 0x36, 0x57, 0x0a, 0xba, 0x83, 0xab, 0x9b, 0x73, 0x7c, 0xb5, 0x21, 0xc9 }, { 0x16, 0x59, 0x1c, 0x0f, 0x27, 0xd6, 0x0e, 0x29, 0xb8, 0x5a, 0x96, 0xc3, 0x38, 0x61, 0xa7, 0xef }, { 0x44, 0xfb, 0x5c, 0x4d, 0x4f, 0x5c, 0xb7, 0x9b, 0xe5, 0xc1, 0x74, 0xa3, 0xb1, 0xc9, 0x73, 0x48 }, { 0x67, 0x4d, 0x2b, 0x61, 0x63, 0x3d, 0x16, 0x2b, 0xe5, 0x9d, 0xde, 0x04, 0x22, 0x2f, 0x47, 0x40 }, { 0xb4, 0x75, 0x0f, 0xf2, 0x63, 0xa6, 0x5e, 0x1f, 0x9e, 0x92, 0x4c, 0xcf, 0xd9, 0x8f, 0x3e, 0x37 }, { 0x62, 0xd0, 0x66, 0x2d, 0x6e, 0xae, 0xdd, 0xed, 0xeb, 0xae, 0x7f, 0x7e, 0xa3, 0xa4, 0xf6, 0xb6 }, { 0x70, 0xc4, 0x6b, 0xb3, 0x06, 0x92, 0xbe, 0x65, 0x7f, 0x7e, 0xaa, 0x93, 0xeb, 0xad, 0x98, 0x97 }, { 0x32, 0x39, 0x94, 0xcf, 0xb9, 0xda, 0x28, 0x5a, 0x5d, 0x96, 0x42, 0xe1, 0x75, 0x9b, 0x22, 0x4a }, { 0x1d, 0xbf, 0x57, 0x87, 0x7b, 0x7b, 0x17, 0x38, 0x5c, 0x85, 0xd0, 0xb5, 0x48, 0x51, 0xe3, 0x71 }, { 0xdf, 0xa5, 0xc0, 0x97, 0xcd, 0xc1, 0x53, 0x2a, 0xc0, 0x71, 0xd5, 0x7b, 0x1d, 0x28, 0xd1, 0xbd }, { 0x3a, 0x0c, 0x53, 0xfa, 0x37, 0x31, 0x1f, 0xc1, 0x0b, 0xd2, 0xa9, 0x98, 0x1f, 0x51, 0x31, 0x74 }, { 0xba, 0x4f, 0x97, 0x0c, 0x0a, 0x25, 0xc4, 0x18, 0x14, 0xbd, 0xae, 0x2e, 0x50, 0x6b, 0xe3, 0xb4 }, { 0x2d, 0xce, 0x3a, 0xcb, 0x72, 0x7c, 0xd1, 0x3c, 0xcd, 0x76, 0xd4, 0x25, 0xea, 0x56, 0xe4, 0xf6 }, { 0x51, 0x60, 0x47, 0x4d, 0x50, 0x4b, 0x9b, 0x3e, 0xef, 0xb6, 0x8d, 0x35, 0xf2, 0x45, 0xf4, 0xb3 }, { 0x41, 0xa8, 0xa9, 0x47, 0x76, 0x66, 0x35, 0xde, 0xc3, 0x75, 0x53, 0xd9, 0xa6, 0xc0, 0xcb, 0xb7 }, { 0x25, 0xd6, 0xcf, 0xe6, 0x88, 0x1f, 0x2b, 0xf4, 0x97, 0xdd, 0x14, 0xcd, 0x4d, 0xdf, 0x44, 0x5b }, { 0x41, 0xc7, 0x8c, 0x13, 0x5e, 0xd9, 0xe9, 0x8c, 0x09, 0x66, 0x40, 0x64, 0x72, 0x65, 0xda, 0x1e }, { 0x5a, 0x4d, 0x40, 0x4d, 0x89, 0x17, 0xe3, 0x53, 0xe9, 0x2a, 0x21, 0x07, 0x2c, 0x3b, 0x23, 0x05 }, { 0x02, 0xbc, 0x96, 0x84, 0x6b, 0x3f, 0xdc, 0x71, 0x64, 0x3f, 0x38, 0x4c, 0xd3, 0xcc, 0x3e, 0xaf }, { 0x9b, 0xa4, 0xa9, 0x14, 0x3f, 0x4e, 0x5d, 0x40, 0x48, 0x52, 0x1c, 0x4f, 0x88, 0x77, 0xd8, 0x8e }, { 0xa1, 0xf6, 0x25, 0x8c, 0x87, 0x7d, 0x5f, 0xcd, 0x89, 0x64, 0x48, 0x45, 0x38, 0xbf, 0xc9, 0x2c } }; /* Values from NIST KAT-AES CBCVarTxt192.rsp */ uint8_t cipher_texts1_192bit[ 128 ][ 16 ] = { { 0x6c, 0xd0, 0x25, 0x13, 0xe8, 0xd4, 0xdc, 0x98, 0x6b, 0x4a, 0xfe, 0x08, 0x7a, 0x60, 0xbd, 0x0c }, { 0x2c, 0xe1, 0xf8, 0xb7, 0xe3, 0x06, 0x27, 0xc1, 0xc4, 0x51, 0x9e, 0xad, 0xa4, 0x4b, 0xc4, 0x36 }, { 0x99, 0x46, 0xb5, 0xf8, 0x7a, 0xf4, 0x46, 0xf5, 0x79, 0x6c, 0x1f, 0xee, 0x63, 0xa2, 0xda, 0x24 }, { 0x2a, 0x56, 0x03, 0x64, 0xce, 0x52, 0x9e, 0xfc, 0x21, 0x78, 0x87, 0x79, 0x56, 0x8d, 0x55, 0x55 }, { 0x35, 0xc1, 0x47, 0x18, 0x37, 0xaf, 0x44, 0x61, 0x53, 0xbc, 0xe5, 0x5d, 0x5b, 0xa7, 0x2a, 0x0a }, { 0xce, 0x60, 0xbc, 0x52, 0x38, 0x62, 0x34, 0xf1, 0x58, 0xf8, 0x43, 0x41, 0xe5, 0x34, 0xcd, 0x9e }, { 0x8c, 0x7c, 0x27, 0xff, 0x32, 0xbc, 0xf8, 0xdc, 0x2d, 0xc5, 0x7c, 0x90, 0xc2, 0x90, 0x39, 0x61 }, { 0x32, 0xbb, 0x6a, 0x7e, 0xc8, 0x44, 0x99, 0xe1, 0x66, 0xf9, 0x36, 0x00, 0x3d, 0x55, 0xa5, 0xbb }, { 0xa5, 0xc7, 0x72, 0xe5, 0xc6, 0x26, 0x31, 0xef, 0x66, 0x0e, 0xe1, 0xd5, 0x87, 0x7f, 0x6d, 0x1b }, { 0x03, 0x0d, 0x7e, 0x5b, 0x64, 0xf3, 0x80, 0xa7, 0xe4, 0xea, 0x53, 0x87, 0xb5, 0xcd, 0x7f, 0x49 }, { 0x0d, 0xc9, 0xa2, 0x61, 0x00, 0x37, 0x00, 0x9b, 0x69, 0x8f, 0x11, 0xbb, 0x7e, 0x86, 0xc8, 0x3e }, { 0x00, 0x46, 0x61, 0x2c, 0x76, 0x6d, 0x18, 0x40, 0xc2, 0x26, 0x36, 0x4f, 0x1f, 0xa7, 0xed, 0x72 }, { 0x48, 0x80, 0xc7, 0xe0, 0x8f, 0x27, 0xbe, 0xfe, 0x78, 0x59, 0x07, 0x43, 0xc0, 0x5e, 0x69, 0x8b }, { 0x25, 0x20, 0xce, 0x82, 0x9a, 0x26, 0x57, 0x7f, 0x0f, 0x48, 0x22, 0xc4, 0xec, 0xc8, 0x74, 0x01 }, { 0x87, 0x65, 0xe8, 0xac, 0xc1, 0x69, 0x75, 0x83, 0x19, 0xcb, 0x46, 0xdc, 0x7b, 0xcf, 0x3d, 0xca }, { 0xe9, 0x8f, 0x4b, 0xa4, 0xf0, 0x73, 0xdf, 0x4b, 0xaa, 0x11, 0x6d, 0x01, 0x1d, 0xc2, 0x4a, 0x28 }, { 0xf3, 0x78, 0xf6, 0x8c, 0x5d, 0xbf, 0x59, 0xe2, 0x11, 0xb3, 0xa6, 0x59, 0xa7, 0x31, 0x7d, 0x94 }, { 0x28, 0x3d, 0x3b, 0x06, 0x9d, 0x8e, 0xb9, 0xfb, 0x43, 0x2d, 0x74, 0xb9, 0x6c, 0xa7, 0x62, 0xb4 }, { 0xa7, 0xe1, 0x84, 0x2e, 0x8a, 0x87, 0x86, 0x1c, 0x22, 0x1a, 0x50, 0x08, 0x83, 0x24, 0x5c, 0x51 }, { 0x77, 0xaa, 0x27, 0x04, 0x71, 0x88, 0x1b, 0xe0, 0x70, 0xfb, 0x52, 0xc7, 0x06, 0x7c, 0xe7, 0x32 }, { 0x01, 0xb0, 0xf4, 0x76, 0xd4, 0x84, 0xf4, 0x3f, 0x1a, 0xeb, 0x6e, 0xfa, 0x93, 0x61, 0xa8, 0xac }, { 0x1c, 0x3a, 0x94, 0xf1, 0xc0, 0x52, 0xc5, 0x5c, 0x2d, 0x83, 0x59, 0xaf, 0xf2, 0x16, 0x3b, 0x4f }, { 0xe8, 0xa0, 0x67, 0xb6, 0x04, 0xd5, 0x37, 0x3d, 0x8b, 0x0f, 0x2e, 0x05, 0xa0, 0x3b, 0x34, 0x1b }, { 0xa7, 0x87, 0x6e, 0xc8, 0x7f, 0x5a, 0x09, 0xbf, 0xea, 0x42, 0xc7, 0x7d, 0xa3, 0x0f, 0xd5, 0x0e }, { 0x0c, 0xf3, 0xe9, 0xd3, 0xa4, 0x2b, 0xe5, 0xb8, 0x54, 0xca, 0x65, 0xb1, 0x3f, 0x35, 0xf4, 0x8d }, { 0x6c, 0x62, 0xf6, 0xbb, 0xca, 0xb7, 0xc3, 0xe8, 0x21, 0xc9, 0x29, 0x0f, 0x08, 0x89, 0x2d, 0xda }, { 0x7f, 0x5e, 0x05, 0xbd, 0x20, 0x68, 0x73, 0x81, 0x96, 0xfe, 0xe7, 0x9a, 0xce, 0x7e, 0x3a, 0xec }, { 0x44, 0x0e, 0x0d, 0x73, 0x32, 0x55, 0xcd, 0xa9, 0x2f, 0xb4, 0x6e, 0x84, 0x2f, 0xe5, 0x80, 0x54 }, { 0xaa, 0x5d, 0x5b, 0x1c, 0x4e, 0xa1, 0xb7, 0xa2, 0x2e, 0x55, 0x83, 0xac, 0x2e, 0x9e, 0xd8, 0xa7 }, { 0x77, 0xe5, 0x37, 0xe8, 0x9e, 0x84, 0x91, 0xe8, 0x66, 0x2a, 0xae, 0x3b, 0xc8, 0x09, 0x42, 0x1d }, { 0x99, 0x7d, 0xd3, 0xe9, 0xf1, 0x59, 0x8b, 0xfa, 0x73, 0xf7, 0x59, 0x73, 0xf7, 0xe9, 0x3b, 0x76 }, { 0x1b, 0x38, 0xd4, 0xf7, 0x45, 0x2a, 0xfe, 0xfc, 0xb7, 0xfc, 0x72, 0x12, 0x44, 0xe4, 0xb7, 0x2e }, { 0x0b, 0xe2, 0xb1, 0x82, 0x52, 0xe7, 0x74, 0xdd, 0xa3, 0x0c, 0xdd, 0xa0, 0x2c, 0x69, 0x06, 0xe3 }, { 0xd2, 0x69, 0x5e, 0x59, 0xc2, 0x03, 0x61, 0xd8, 0x26, 0x52, 0xd7, 0xd5, 0x8b, 0x6f, 0x11, 0xb2 }, { 0x90, 0x2d, 0x88, 0xd1, 0x3e, 0xae, 0x52, 0x08, 0x9a, 0xbd, 0x61, 0x43, 0xcf, 0xe3, 0x94, 0xe9 }, { 0xd4, 0x9b, 0xce, 0xb3, 0xb8, 0x23, 0xfe, 0xdd, 0x60, 0x2c, 0x30, 0x53, 0x45, 0x73, 0x4b, 0xd2 }, { 0x70, 0x7b, 0x1d, 0xbb, 0x0f, 0xfa, 0x40, 0xef, 0x7d, 0x95, 0xde, 0xf4, 0x21, 0x23, 0x3f, 0xae }, { 0x7c, 0xa0, 0xc1, 0xd9, 0x33, 0x56, 0xd9, 0xeb, 0x8a, 0xa9, 0x52, 0x08, 0x4d, 0x75, 0xf9, 0x13 }, { 0xf2, 0xcb, 0xf9, 0xcb, 0x18, 0x6e, 0x27, 0x0d, 0xd7, 0xbd, 0xb0, 0xc2, 0x8f, 0xeb, 0xc5, 0x7d }, { 0xc9, 0x43, 0x37, 0xc3, 0x7c, 0x4e, 0x79, 0x0a, 0xb4, 0x57, 0x80, 0xbd, 0x9c, 0x36, 0x74, 0xa0 }, { 0x8e, 0x35, 0x58, 0xc1, 0x35, 0x25, 0x2f, 0xb9, 0xc9, 0xf3, 0x67, 0xed, 0x60, 0x94, 0x67, 0xa1 }, { 0x1b, 0x72, 0xee, 0xae, 0xe4, 0x89, 0x9b, 0x44, 0x39, 0x14, 0xe5, 0xb3, 0xa5, 0x7f, 0xba, 0x92 }, { 0x01, 0x18, 0x65, 0xf9, 0x1b, 0xc5, 0x68, 0x68, 0xd0, 0x51, 0xe5, 0x2c, 0x9e, 0xfd, 0x59, 0xb7 }, { 0xe4, 0x77, 0x13, 0x18, 0xad, 0x7a, 0x63, 0xdd, 0x68, 0x0f, 0x6e, 0x58, 0x3b, 0x77, 0x47, 0xea }, { 0x61, 0xe3, 0xd1, 0x94, 0x08, 0x8d, 0xc8, 0xd9, 0x7e, 0x9e, 0x6d, 0xb3, 0x74, 0x57, 0xea, 0xc5 }, { 0x36, 0xff, 0x1e, 0xc9, 0xcc, 0xfb, 0xc3, 0x49, 0xe5, 0xd3, 0x56, 0xd0, 0x63, 0x69, 0x3a, 0xd6 }, { 0x3c, 0xc9, 0xe9, 0xa9, 0xbe, 0x8c, 0xc3, 0xf6, 0xfb, 0x2e, 0xa2, 0x40, 0x88, 0xe9, 0xbb, 0x19 }, { 0x1e, 0xe5, 0xab, 0x00, 0x3d, 0xc8, 0x72, 0x2e, 0x74, 0x90, 0x5d, 0x9a, 0x8f, 0xe3, 0xd3, 0x50 }, { 0x24, 0x53, 0x39, 0x31, 0x95, 0x84, 0xb0, 0xa4, 0x12, 0x41, 0x28, 0x69, 0xd6, 0xc2, 0xea, 0xda }, { 0x7b, 0xd4, 0x96, 0x91, 0x81, 0x15, 0xd1, 0x4e, 0xd5, 0x38, 0x08, 0x52, 0x71, 0x6c, 0x88, 0x14 }, { 0x27, 0x3a, 0xb2, 0xf2, 0xb4, 0xa3, 0x66, 0xa5, 0x7d, 0x58, 0x2a, 0x33, 0x93, 0x13, 0xc8, 0xb1 }, { 0x11, 0x33, 0x65, 0xa9, 0xff, 0xbe, 0x3b, 0x0c, 0xa6, 0x1e, 0x98, 0x50, 0x75, 0x54, 0x16, 0x8b }, { 0xaf, 0xa9, 0x9c, 0x99, 0x7a, 0xc4, 0x78, 0xa0, 0xde, 0xa4, 0x11, 0x9c, 0x9e, 0x45, 0xf8, 0xb1 }, { 0x92, 0x16, 0x30, 0x9a, 0x78, 0x42, 0x43, 0x0b, 0x83, 0xff, 0xb9, 0x86, 0x38, 0x01, 0x15, 0x12 }, { 0x62, 0xab, 0xc7, 0x92, 0x28, 0x82, 0x58, 0x49, 0x2a, 0x7c, 0xb4, 0x51, 0x45, 0xf4, 0xb7, 0x59 }, { 0x53, 0x49, 0x23, 0xc1, 0x69, 0xd5, 0x04, 0xd7, 0x51, 0x9c, 0x15, 0xd3, 0x0e, 0x75, 0x6c, 0x50 }, { 0xfa, 0x75, 0xe0, 0x5b, 0xcd, 0xc7, 0xe0, 0x0c, 0x27, 0x3f, 0xa3, 0x3f, 0x6e, 0xe4, 0x41, 0xd2 }, { 0x7d, 0x35, 0x0f, 0xa6, 0x05, 0x70, 0x80, 0xf1, 0x08, 0x6a, 0x56, 0xb1, 0x7e, 0xc2, 0x40, 0xdb }, { 0xf3, 0x4e, 0x4a, 0x63, 0x24, 0xea, 0x4a, 0x5c, 0x39, 0xa6, 0x61, 0xc8, 0xfe, 0x5a, 0xda, 0x8f }, { 0x08, 0x82, 0xa1, 0x6f, 0x44, 0x08, 0x8d, 0x42, 0x44, 0x7a, 0x29, 0xac, 0x09, 0x0e, 0xc1, 0x7e }, { 0x3a, 0x3c, 0x15, 0xbf, 0xc1, 0x1a, 0x95, 0x37, 0xc1, 0x30, 0x68, 0x70, 0x04, 0xe1, 0x36, 0xee }, { 0x22, 0xc0, 0xa7, 0x67, 0x8d, 0xc6, 0xd8, 0xcf, 0x5c, 0x8a, 0x6d, 0x5a, 0x99, 0x60, 0x76, 0x7c }, { 0xb4, 0x6b, 0x09, 0x80, 0x9d, 0x68, 0xb9, 0xa4, 0x56, 0x43, 0x2a, 0x79, 0xbd, 0xc2, 0xe3, 0x8c }, { 0x93, 0xba, 0xaf, 0xfb, 0x35, 0xfb, 0xe7, 0x39, 0xc1, 0x7c, 0x6a, 0xc2, 0x2e, 0xec, 0xf1, 0x8f }, { 0xc8, 0xaa, 0x80, 0xa7, 0x85, 0x06, 0x75, 0xbc, 0x00, 0x7c, 0x46, 0xdf, 0x06, 0xb4, 0x98, 0x68 }, { 0x12, 0xc6, 0xf3, 0x87, 0x7a, 0xf4, 0x21, 0xa9, 0x18, 0xa8, 0x4b, 0x77, 0x58, 0x58, 0x02, 0x1d }, { 0x33, 0xf1, 0x23, 0x28, 0x2c, 0x5d, 0x63, 0x39, 0x24, 0xf7, 0xd5, 0xba, 0x3f, 0x3c, 0xab, 0x11 }, { 0xa8, 0xf1, 0x61, 0x00, 0x27, 0x33, 0xe9, 0x3c, 0xa4, 0x52, 0x7d, 0x22, 0xc1, 0xa0, 0xc5, 0xbb }, { 0xb7, 0x2f, 0x70, 0xeb, 0xf3, 0xe3, 0xfd, 0xa2, 0x3f, 0x50, 0x8e, 0xec, 0x76, 0xb4, 0x2c, 0x02 }, { 0x6a, 0x9d, 0x96, 0x5e, 0x62, 0x74, 0x14, 0x3f, 0x25, 0xaf, 0xdc, 0xfc, 0x88, 0xff, 0xd7, 0x7c }, { 0xa0, 0xc7, 0x4f, 0xd0, 0xb9, 0x36, 0x17, 0x64, 0xce, 0x91, 0xc5, 0x20, 0x0b, 0x09, 0x53, 0x57 }, { 0x09, 0x1d, 0x1f, 0xdc, 0x2b, 0xd2, 0xc3, 0x46, 0xcd, 0x50, 0x46, 0xa8, 0xc6, 0x20, 0x91, 0x46 }, { 0xe2, 0xa3, 0x75, 0x80, 0x11, 0x6c, 0xfb, 0x71, 0x85, 0x62, 0x54, 0x49, 0x6a, 0xb0, 0xac, 0xa8 }, { 0xe0, 0xb3, 0xa0, 0x07, 0x85, 0x91, 0x7c, 0x7e, 0xfc, 0x9a, 0xdb, 0xa3, 0x22, 0x81, 0x35, 0x71 }, { 0x73, 0x3d, 0x41, 0xf4, 0x72, 0x7b, 0x5e, 0xf0, 0xdf, 0x4a, 0xf4, 0xcf, 0x3c, 0xff, 0xa0, 0xcb }, { 0xa9, 0x9e, 0xbb, 0x03, 0x02, 0x60, 0x82, 0x6f, 0x98, 0x1a, 0xd3, 0xe6, 0x44, 0x90, 0xaa, 0x4f }, { 0x73, 0xf3, 0x4c, 0x7d, 0x3e, 0xae, 0x5e, 0x80, 0x08, 0x2c, 0x16, 0x47, 0x52, 0x43, 0x08, 0xee }, { 0x40, 0xeb, 0xd5, 0xad, 0x08, 0x23, 0x45, 0xb7, 0xa2, 0x09, 0x7c, 0xcd, 0x34, 0x64, 0xda, 0x02 }, { 0x7c, 0xc4, 0xae, 0x9a, 0x42, 0x4b, 0x2c, 0xec, 0x90, 0xc9, 0x71, 0x53, 0xc2, 0x45, 0x7e, 0xc5 }, { 0x54, 0xd6, 0x32, 0xd0, 0x3a, 0xba, 0x0b, 0xd0, 0xf9, 0x18, 0x77, 0xeb, 0xdd, 0x4d, 0x09, 0xcb }, { 0xd3, 0x42, 0x7b, 0xe7, 0xe4, 0xd2, 0x7c, 0xd5, 0x4f, 0x5f, 0xe3, 0x7b, 0x03, 0xcf, 0x08, 0x97 }, { 0xb2, 0x09, 0x97, 0x95, 0xe8, 0x8c, 0xc1, 0x58, 0xfd, 0x75, 0xea, 0x13, 0x3d, 0x7e, 0x7f, 0xbe }, { 0xa6, 0xca, 0xe4, 0x6f, 0xb6, 0xfa, 0xdf, 0xe7, 0xa2, 0xc3, 0x02, 0xa3, 0x42, 0x42, 0x81, 0x7b }, { 0x02, 0x6a, 0x70, 0x24, 0xd6, 0xa9, 0x02, 0xe0, 0xb3, 0xff, 0xcc, 0xba, 0xa9, 0x10, 0xcc, 0x3f }, { 0x15, 0x6f, 0x07, 0x76, 0x7a, 0x85, 0xa4, 0x31, 0x23, 0x21, 0xf6, 0x39, 0x68, 0x33, 0x8a, 0x01 }, { 0x15, 0xee, 0xc9, 0xeb, 0xf4, 0x2b, 0x9c, 0xa7, 0x68, 0x97, 0xd2, 0xcd, 0x6c, 0x5a, 0x12, 0xe2 }, { 0xdb, 0x0d, 0x3a, 0x6f, 0xdc, 0xc1, 0x3f, 0x91, 0x5e, 0x2b, 0x30, 0x2c, 0xee, 0xb7, 0x0f, 0xd8 }, { 0x71, 0xdb, 0xf3, 0x7e, 0x87, 0xa2, 0xe3, 0x4d, 0x15, 0xb2, 0x0e, 0x8f, 0x10, 0xe4, 0x89, 0x24 }, { 0xc7, 0x45, 0xc4, 0x51, 0xe9, 0x6f, 0xf3, 0xc0, 0x45, 0xe4, 0x36, 0x7c, 0x83, 0x3e, 0x3b, 0x54 }, { 0x34, 0x0d, 0xa0, 0x9c, 0x2d, 0xd1, 0x1c, 0x3b, 0x67, 0x9d, 0x08, 0xcc, 0xd2, 0x7d, 0xd5, 0x95 }, { 0x82, 0x79, 0xf7, 0xc0, 0xc2, 0xa0, 0x3e, 0xe6, 0x60, 0xc6, 0xd3, 0x92, 0xdb, 0x02, 0x5d, 0x18 }, { 0xa4, 0xb2, 0xc7, 0xd8, 0xeb, 0xa5, 0x31, 0xff, 0x47, 0xc5, 0x04, 0x1a, 0x55, 0xfb, 0xd1, 0xec }, { 0x74, 0x56, 0x9a, 0x2c, 0xa5, 0xa7, 0xbd, 0x51, 0x31, 0xce, 0x8d, 0xc7, 0xcb, 0xfb, 0xf7, 0x2f }, { 0x37, 0x13, 0xda, 0x0c, 0x02, 0x19, 0xb6, 0x34, 0x54, 0x03, 0x56, 0x13, 0xb5, 0xa4, 0x03, 0xdd }, { 0x88, 0x27, 0x55, 0x1d, 0xdc, 0xc9, 0xdf, 0x23, 0xfa, 0x72, 0xa3, 0xde, 0x4e, 0x9f, 0x0b, 0x07 }, { 0x2e, 0x3f, 0xeb, 0xfd, 0x62, 0x5b, 0xfc, 0xd0, 0xa2, 0xc0, 0x6e, 0xb4, 0x60, 0xda, 0x17, 0x32 }, { 0xee, 0x82, 0xe6, 0xba, 0x48, 0x81, 0x56, 0xf7, 0x64, 0x96, 0x31, 0x1d, 0xa6, 0x94, 0x1d, 0xeb }, { 0x47, 0x70, 0x44, 0x6f, 0x01, 0xd1, 0xf3, 0x91, 0x25, 0x6e, 0x85, 0xa1, 0xb3, 0x0d, 0x89, 0xd3 }, { 0xaf, 0x04, 0xb6, 0x8f, 0x10, 0x4f, 0x21, 0xef, 0x2a, 0xfb, 0x47, 0x67, 0xcf, 0x74, 0x14, 0x3c }, { 0xcf, 0x35, 0x79, 0xa9, 0xba, 0x38, 0xc8, 0xe4, 0x36, 0x53, 0x17, 0x3e, 0x14, 0xf3, 0xa4, 0xc6 }, { 0xb3, 0xbb, 0xa9, 0x04, 0xf4, 0x95, 0x3e, 0x09, 0xb5, 0x48, 0x00, 0xaf, 0x2f, 0x62, 0xe7, 0xd4 }, { 0xfc, 0x42, 0x49, 0x65, 0x6e, 0x14, 0xb2, 0x9e, 0xb9, 0xc4, 0x48, 0x29, 0xb4, 0xc5, 0x9a, 0x46 }, { 0x9b, 0x31, 0x56, 0x8f, 0xeb, 0xe8, 0x1c, 0xfc, 0x2e, 0x65, 0xaf, 0x1c, 0x86, 0xd1, 0xa3, 0x08 }, { 0x9c, 0xa0, 0x9c, 0x25, 0xf2, 0x73, 0xa7, 0x66, 0xdb, 0x98, 0xa4, 0x80, 0xce, 0x8d, 0xfe, 0xdc }, { 0xb9, 0x09, 0x92, 0x57, 0x86, 0xf3, 0x4c, 0x3c, 0x92, 0xd9, 0x71, 0x88, 0x3c, 0x9f, 0xbe, 0xdf }, { 0x82, 0x64, 0x7f, 0x13, 0x32, 0xfe, 0x57, 0x0a, 0x9d, 0x4d, 0x92, 0xb2, 0xee, 0x77, 0x1d, 0x3b }, { 0x36, 0x04, 0xa7, 0xe8, 0x08, 0x32, 0xb3, 0xa9, 0x99, 0x54, 0xbc, 0xa6, 0xf5, 0xb9, 0xf5, 0x01 }, { 0x88, 0x46, 0x07, 0xb1, 0x28, 0xc5, 0xde, 0x3a, 0xb3, 0x9a, 0x52, 0x9a, 0x1e, 0xf5, 0x1b, 0xef }, { 0x67, 0x0c, 0xfa, 0x09, 0x3d, 0x1d, 0xbd, 0xb2, 0x31, 0x70, 0x41, 0x40, 0x41, 0x02, 0x43, 0x5e }, { 0x7a, 0x86, 0x71, 0x95, 0xf3, 0xce, 0x87, 0x69, 0xcb, 0xd3, 0x36, 0x50, 0x2f, 0xbb, 0x51, 0x30 }, { 0x52, 0xef, 0xcf, 0x64, 0xc7, 0x2b, 0x2f, 0x7c, 0xa5, 0xb3, 0xc8, 0x36, 0xb1, 0x07, 0x8c, 0x15 }, { 0x40, 0x19, 0x25, 0x0f, 0x6e, 0xef, 0xb2, 0xac, 0x5c, 0xcb, 0xca, 0xe0, 0x44, 0xe7, 0x5c, 0x7e }, { 0x02, 0x2c, 0x4f, 0x6f, 0x5a, 0x01, 0x7d, 0x29, 0x27, 0x85, 0x62, 0x76, 0x67, 0xdd, 0xef, 0x24 }, { 0xe9, 0xc2, 0x10, 0x78, 0xa2, 0xeb, 0x7e, 0x03, 0x25, 0x0f, 0x71, 0x00, 0x0f, 0xa9, 0xe3, 0xed }, { 0xa1, 0x3e, 0xae, 0xeb, 0x9c, 0xd3, 0x91, 0xda, 0x4e, 0x2b, 0x09, 0x49, 0x0b, 0x3e, 0x7f, 0xad }, { 0xc9, 0x58, 0xa1, 0x71, 0xdc, 0xa1, 0xd4, 0xed, 0x53, 0xe1, 0xaf, 0x1d, 0x38, 0x08, 0x03, 0xa9 }, { 0x21, 0x44, 0x2e, 0x07, 0xa1, 0x10, 0x66, 0x7f, 0x25, 0x83, 0xea, 0xee, 0xee, 0x44, 0xdc, 0x8c }, { 0x59, 0xbb, 0xb3, 0x53, 0xcf, 0x1d, 0xd8, 0x67, 0xa6, 0xe3, 0x37, 0x37, 0xaf, 0x65, 0x5e, 0x99 }, { 0x43, 0xcd, 0x3b, 0x25, 0x37, 0x5d, 0x0c, 0xe4, 0x10, 0x87, 0xff, 0x9f, 0xe2, 0x82, 0x96, 0x39 }, { 0x6b, 0x98, 0xb1, 0x7e, 0x80, 0xd1, 0x11, 0x8e, 0x35, 0x16, 0xbd, 0x76, 0x8b, 0x28, 0x5a, 0x84 }, { 0xae, 0x47, 0xed, 0x36, 0x76, 0xca, 0x0c, 0x08, 0xde, 0xea, 0x02, 0xd9, 0x5b, 0x81, 0xdb, 0x58 }, { 0x34, 0xec, 0x40, 0xdc, 0x20, 0x41, 0x37, 0x95, 0xed, 0x53, 0x62, 0x8e, 0xa7, 0x48, 0x72, 0x0b }, { 0x4d, 0xc6, 0x81, 0x63, 0xf8, 0xe9, 0x83, 0x54, 0x73, 0x25, 0x35, 0x42, 0xc8, 0xa6, 0x5d, 0x46 }, { 0x2a, 0xab, 0xb9, 0x99, 0xf4, 0x36, 0x93, 0x17, 0x5a, 0xf6, 0x5c, 0x6c, 0x61, 0x2c, 0x46, 0xfb }, { 0xe0, 0x1f, 0x94, 0x49, 0x9d, 0xac, 0x35, 0x47, 0x51, 0x5c, 0x5b, 0x1d, 0x75, 0x6f, 0x0f, 0x58 }, { 0x9d, 0x12, 0x43, 0x5a, 0x46, 0x48, 0x0c, 0xe0, 0x0e, 0xa3, 0x49, 0xf7, 0x17, 0x99, 0xdf, 0x9a }, { 0xce, 0xf4, 0x1d, 0x16, 0xd2, 0x66, 0xbd, 0xfe, 0x46, 0x93, 0x8a, 0xd7, 0x88, 0x4c, 0xc0, 0xcf }, { 0xb1, 0x3d, 0xb4, 0xda, 0x1f, 0x71, 0x8b, 0xc6, 0x90, 0x47, 0x97, 0xc8, 0x2b, 0xcf, 0x2d, 0x32 } }; /* Values from NIST KAT-AES CBCVarKey192.rsp */ uint8_t cipher_texts2_192bit[ 192 ][ 16 ] = { { 0xde, 0x88, 0x5d, 0xc8, 0x7f, 0x5a, 0x92, 0x59, 0x40, 0x82, 0xd0, 0x2c, 0xc1, 0xe1, 0xb4, 0x2c }, { 0x13, 0x2b, 0x07, 0x4e, 0x80, 0xf2, 0xa5, 0x97, 0xbf, 0x5f, 0xeb, 0xd8, 0xea, 0x5d, 0xa5, 0x5e }, { 0x6e, 0xcc, 0xed, 0xf8, 0xde, 0x59, 0x2c, 0x22, 0xfb, 0x81, 0x34, 0x7b, 0x79, 0xf2, 0xdb, 0x1f }, { 0x18, 0x0b, 0x09, 0xf2, 0x67, 0xc4, 0x51, 0x45, 0xdb, 0x2f, 0x82, 0x6c, 0x25, 0x82, 0xd3, 0x5c }, { 0xed, 0xd8, 0x07, 0xef, 0x76, 0x52, 0xd7, 0xeb, 0x0e, 0x13, 0xc8, 0xb5, 0xe1, 0x5b, 0x3b, 0xc0 }, { 0x99, 0x78, 0xbc, 0xf8, 0xdd, 0x8f, 0xd7, 0x22, 0x41, 0x22, 0x3a, 0xd2, 0x4b, 0x31, 0xb8, 0xa4 }, { 0x53, 0x10, 0xf6, 0x54, 0x34, 0x3e, 0x8f, 0x27, 0xe1, 0x2c, 0x83, 0xa4, 0x8d, 0x24, 0xff, 0x81 }, { 0x83, 0x3f, 0x71, 0x25, 0x8d, 0x53, 0x03, 0x6b, 0x02, 0x95, 0x2c, 0x76, 0xc7, 0x44, 0xf5, 0xa1 }, { 0xeb, 0xa8, 0x3f, 0xf2, 0x00, 0xcf, 0xf9, 0x31, 0x8a, 0x92, 0xf8, 0x69, 0x1a, 0x06, 0xb0, 0x9f }, { 0xff, 0x62, 0x0c, 0xcb, 0xe9, 0xf3, 0x29, 0x2a, 0xbd, 0xf2, 0x17, 0x6b, 0x09, 0xf0, 0x4e, 0xba }, { 0x7a, 0xba, 0xbc, 0x4b, 0x3f, 0x51, 0x6c, 0x9a, 0xaf, 0xb3, 0x5f, 0x41, 0x40, 0xb5, 0x48, 0xf9 }, { 0xaa, 0x18, 0x78, 0x24, 0xd9, 0xc4, 0x58, 0x2b, 0x09, 0x16, 0x49, 0x3e, 0xcb, 0xde, 0x8c, 0x57 }, { 0x1c, 0x0a, 0xd5, 0x53, 0x17, 0x7f, 0xd5, 0xea, 0x10, 0x92, 0xc9, 0xd6, 0x26, 0xa2, 0x9d, 0xc4 }, { 0xa5, 0xdc, 0x46, 0xc3, 0x72, 0x61, 0x19, 0x41, 0x24, 0xec, 0xae, 0xbd, 0x68, 0x04, 0x08, 0xec }, { 0xe4, 0xf2, 0xf2, 0xae, 0x23, 0xe9, 0xb1, 0x0b, 0xac, 0xfa, 0x58, 0x60, 0x15, 0x31, 0xba, 0x54 }, { 0xb7, 0xd6, 0x7c, 0xf1, 0xa1, 0xe9, 0x1e, 0x8f, 0xf3, 0xa5, 0x7a, 0x17, 0x2c, 0x7b, 0xf4, 0x12 }, { 0x26, 0x70, 0x6b, 0xe0, 0x69, 0x67, 0x88, 0x4e, 0x84, 0x7d, 0x13, 0x71, 0x28, 0xce, 0x47, 0xb3 }, { 0xb2, 0xf8, 0xb4, 0x09, 0xb0, 0x58, 0x59, 0x09, 0xaa, 0xd3, 0xa7, 0xb5, 0xa2, 0x19, 0x07, 0x2a }, { 0x5e, 0x4b, 0x7b, 0xff, 0x02, 0x90, 0xc7, 0x83, 0x44, 0xc5, 0x4a, 0x23, 0xb7, 0x22, 0xcd, 0x20 }, { 0x07, 0x09, 0x36, 0x57, 0x55, 0x2d, 0x44, 0x14, 0x22, 0x7c, 0xe1, 0x61, 0xe9, 0xeb, 0xf7, 0xdd }, { 0xe1, 0xaf, 0x1e, 0x7d, 0x8b, 0xc2, 0x25, 0xed, 0x4d, 0xff, 0xb7, 0x71, 0xec, 0xbb, 0x9e, 0x67 }, { 0xef, 0x65, 0x55, 0x25, 0x36, 0x35, 0xd8, 0x43, 0x21, 0x56, 0xcf, 0xd9, 0xc1, 0x1b, 0x14, 0x5a }, { 0xfb, 0x40, 0x35, 0x07, 0x4a, 0x5d, 0x42, 0x60, 0xc9, 0x0c, 0xbd, 0x6d, 0xa6, 0xc3, 0xfc, 0xeb }, { 0x44, 0x6e, 0xe4, 0x16, 0xf9, 0xad, 0x1c, 0x10, 0x3e, 0xb0, 0xcc, 0x96, 0x75, 0x1c, 0x88, 0xe1 }, { 0x19, 0x8a, 0xe2, 0xa4, 0x63, 0x7a, 0xc0, 0xa7, 0x89, 0x0a, 0x8f, 0xd1, 0x48, 0x54, 0x45, 0xc9 }, { 0x56, 0x20, 0x12, 0xec, 0x8f, 0xad, 0xed, 0x08, 0x25, 0xfb, 0x2f, 0xa7, 0x0a, 0xb3, 0x0c, 0xbd }, { 0xcc, 0x8a, 0x64, 0xb4, 0x6b, 0x5d, 0x88, 0xbf, 0x7f, 0x24, 0x7d, 0x4d, 0xba, 0xf3, 0x8f, 0x05 }, { 0xa1, 0x68, 0x25, 0x37, 0x62, 0xe2, 0xcc, 0x81, 0xb4, 0x2d, 0x1e, 0x50, 0x01, 0x76, 0x26, 0x99 }, { 0x1b, 0x41, 0xf8, 0x3b, 0x38, 0xce, 0x50, 0x32, 0xc6, 0xcd, 0x7a, 0xf9, 0x8c, 0xf6, 0x20, 0x61 }, { 0x61, 0xa8, 0x99, 0x90, 0xcd, 0x14, 0x11, 0x75, 0x0d, 0x5f, 0xb0, 0xdc, 0x98, 0x84, 0x47, 0xd4 }, { 0xb5, 0xac, 0xcc, 0x8e, 0xd6, 0x29, 0xed, 0xf8, 0xc6, 0x8a, 0x53, 0x91, 0x83, 0xb1, 0xea, 0x82 }, { 0xb1, 0x6f, 0xa7, 0x1f, 0x84, 0x6b, 0x81, 0xa1, 0x3f, 0x36, 0x1c, 0x43, 0xa8, 0x51, 0xf2, 0x90 }, { 0x4f, 0xad, 0x6e, 0xfd, 0xff, 0x59, 0x75, 0xae, 0xe7, 0x69, 0x22, 0x34, 0xbc, 0xd5, 0x44, 0x88 }, { 0xeb, 0xfd, 0xb0, 0x5a, 0x78, 0x3d, 0x03, 0x08, 0x2d, 0xfe, 0x5f, 0xdd, 0x80, 0xa0, 0x0b, 0x17 }, { 0xeb, 0x81, 0xb5, 0x84, 0x76, 0x69, 0x97, 0xaf, 0x6b, 0xa5, 0x52, 0x9d, 0x3b, 0xdd, 0x86, 0x09 }, { 0x0c, 0xf4, 0xff, 0x4f, 0x49, 0xc8, 0xa0, 0xca, 0x06, 0x0c, 0x44, 0x34, 0x99, 0xe2, 0x93, 0x13 }, { 0xcc, 0x4b, 0xa8, 0xa8, 0xe0, 0x29, 0xf8, 0xb2, 0x6d, 0x8a, 0xff, 0xf9, 0xdf, 0x13, 0x3b, 0xb6 }, { 0xfe, 0xfe, 0xbf, 0x64, 0x36, 0x0f, 0x38, 0xe4, 0xe6, 0x35, 0x58, 0xf0, 0xff, 0xc5, 0x50, 0xc3 }, { 0x12, 0xad, 0x98, 0xcb, 0xf7, 0x25, 0x13, 0x7d, 0x6a, 0x81, 0x08, 0xc2, 0xbe, 0xd9, 0x93, 0x22 }, { 0x6a, 0xfa, 0xa9, 0x96, 0x22, 0x61, 0x98, 0xb3, 0xe2, 0x61, 0x04, 0x13, 0xce, 0x1b, 0x3f, 0x78 }, { 0x2a, 0x8c, 0xe6, 0x74, 0x7a, 0x7e, 0x39, 0x36, 0x78, 0x28, 0xe2, 0x90, 0x84, 0x85, 0x02, 0xd9 }, { 0x22, 0x37, 0x36, 0xe8, 0xb8, 0xf8, 0x9c, 0xa1, 0xe3, 0x7b, 0x6d, 0xea, 0xb4, 0x0f, 0xac, 0xf1 }, { 0xc0, 0xf7, 0x97, 0xe5, 0x04, 0x18, 0xb9, 0x5f, 0xa6, 0x01, 0x33, 0x33, 0x91, 0x7a, 0x94, 0x80 }, { 0xa7, 0x58, 0xde, 0x37, 0xc2, 0xec, 0xe2, 0xa0, 0x2c, 0x73, 0xc0, 0x1f, 0xed, 0xc9, 0xa1, 0x32 }, { 0x3a, 0x9b, 0x87, 0xae, 0x77, 0xba, 0xe7, 0x06, 0x80, 0x39, 0x66, 0xc6, 0x6c, 0x73, 0xad, 0xbd }, { 0xd3, 0x65, 0xab, 0x8d, 0xf8, 0xff, 0xd7, 0x82, 0xe3, 0x58, 0x12, 0x1a, 0x4a, 0x4f, 0xc5, 0x41 }, { 0xc8, 0xdc, 0xd9, 0xe6, 0xf7, 0x5e, 0x6c, 0x36, 0xc8, 0xda, 0xee, 0x04, 0x66, 0xf0, 0xed, 0x74 }, { 0xc7, 0x9a, 0x63, 0x7b, 0xeb, 0x1c, 0x03, 0x04, 0xf1, 0x40, 0x14, 0xc0, 0x37, 0xe7, 0x36, 0xdd }, { 0x10, 0x5f, 0x0a, 0x25, 0xe8, 0x4a, 0xc9, 0x30, 0xd9, 0x96, 0x28, 0x1a, 0x5f, 0x95, 0x4d, 0xd9 }, { 0x42, 0xe4, 0x07, 0x4b, 0x29, 0x27, 0x97, 0x3e, 0x8d, 0x17, 0xff, 0xa9, 0x2f, 0x7f, 0xe6, 0x15 }, { 0x4f, 0xe2, 0xa9, 0xd2, 0xc1, 0x82, 0x44, 0x49, 0xc6, 0x9e, 0x3e, 0x03, 0x98, 0xf1, 0x29, 0x63 }, { 0xb7, 0xf2, 0x9c, 0x1e, 0x1f, 0x62, 0x84, 0x7a, 0x15, 0x25, 0x3b, 0x28, 0xa1, 0xe9, 0xd7, 0x12 }, { 0x36, 0xed, 0x5d, 0x29, 0xb9, 0x03, 0xf3, 0x1e, 0x89, 0x83, 0xef, 0x8b, 0x0a, 0x2b, 0xf9, 0x90 }, { 0x27, 0xb8, 0x07, 0x02, 0x70, 0x81, 0x0f, 0x9d, 0x02, 0x3f, 0x9d, 0xd7, 0xff, 0x3b, 0x4a, 0xa2 }, { 0x94, 0xd4, 0x6e, 0x15, 0x5c, 0x12, 0x28, 0xf6, 0x1d, 0x1a, 0x0d, 0xb4, 0x81, 0x5e, 0xcc, 0x4b }, { 0xca, 0x61, 0x08, 0xd1, 0xd9, 0x80, 0x71, 0x42, 0x8e, 0xec, 0xee, 0xf1, 0x71, 0x4b, 0x96, 0xdd }, { 0xdc, 0x5b, 0x25, 0xb7, 0x1b, 0x62, 0x96, 0xcf, 0x73, 0xdd, 0x2c, 0xdc, 0xac, 0x2f, 0x70, 0xb1 }, { 0x44, 0xab, 0xa9, 0x5e, 0x8a, 0x06, 0xa2, 0xd9, 0xd3, 0x53, 0x0d, 0x26, 0x77, 0x87, 0x8c, 0x80 }, { 0xa5, 0x70, 0xd2, 0x0e, 0x89, 0xb4, 0x67, 0xe8, 0xf5, 0x17, 0x60, 0x61, 0xb8, 0x1d, 0xd3, 0x96 }, { 0x75, 0x8f, 0x44, 0x67, 0xa5, 0xd8, 0xf1, 0xe7, 0x30, 0x7d, 0xc3, 0x0b, 0x34, 0xe4, 0x04, 0xf4 }, { 0xbc, 0xea, 0x28, 0xe9, 0x07, 0x1b, 0x5a, 0x23, 0x02, 0x97, 0x0f, 0xf3, 0x52, 0x45, 0x1b, 0xc5 }, { 0x75, 0x23, 0xc0, 0x0b, 0xc1, 0x77, 0xd3, 0x31, 0xad, 0x31, 0x2e, 0x09, 0xc9, 0x01, 0x5c, 0x1c }, { 0xcc, 0xac, 0x61, 0xe3, 0x18, 0x37, 0x47, 0xb3, 0xf5, 0x83, 0x6d, 0xa2, 0x1a, 0x1b, 0xc4, 0xf4 }, { 0x70, 0x7b, 0x07, 0x57, 0x91, 0x87, 0x88, 0x80, 0xb4, 0x41, 0x89, 0xd3, 0x52, 0x2b, 0x8c, 0x30 }, { 0x71, 0x32, 0xd0, 0xc0, 0xe4, 0xa0, 0x75, 0x93, 0xcf, 0x12, 0xeb, 0xb1, 0x2b, 0xe7, 0x68, 0x8c }, { 0xef, 0xfb, 0xac, 0x16, 0x44, 0xde, 0xb0, 0xc7, 0x84, 0x27, 0x5f, 0xe5, 0x6e, 0x19, 0xea, 0xd3 }, { 0xa0, 0x05, 0x06, 0x3f, 0x30, 0xf4, 0x22, 0x8b, 0x37, 0x4e, 0x24, 0x59, 0x73, 0x8f, 0x26, 0xbb }, { 0x29, 0x97, 0x5b, 0x5f, 0x48, 0xbb, 0x68, 0xfc, 0xbb, 0xc7, 0xce, 0xa9, 0x3b, 0x45, 0x2e, 0xd7 }, { 0xcf, 0x3f, 0x25, 0x76, 0xe2, 0xaf, 0xed, 0xc7, 0x4b, 0xb1, 0xca, 0x7e, 0xee, 0xc1, 0xc0, 0xe7 }, { 0x07, 0xc4, 0x03, 0xf5, 0xf9, 0x66, 0xe0, 0xe3, 0xd9, 0xf2, 0x96, 0xd6, 0x22, 0x6d, 0xca, 0x28 }, { 0xc8, 0xc2, 0x09, 0x08, 0x24, 0x9a, 0xb4, 0xa3, 0x4d, 0x6d, 0xd0, 0xa3, 0x13, 0x27, 0xff, 0x1a }, { 0xc0, 0x54, 0x13, 0x29, 0xec, 0xb6, 0x15, 0x9a, 0xb2, 0x3b, 0x7f, 0xc5, 0xe6, 0xa2, 0x1b, 0xca }, { 0x7a, 0xa1, 0xac, 0xf1, 0xa2, 0xed, 0x9b, 0xa7, 0x2b, 0xc6, 0xde, 0xb3, 0x1d, 0x88, 0xb8, 0x63 }, { 0x80, 0x8b, 0xd8, 0xed, 0xda, 0xbb, 0x6f, 0x3b, 0xf0, 0xd5, 0xa8, 0xa2, 0x7b, 0xe1, 0xfe, 0x8a }, { 0x27, 0x3c, 0x7d, 0x76, 0x85, 0xe1, 0x4e, 0xc6, 0x6b, 0xbb, 0x96, 0xb8, 0xf0, 0x5b, 0x6d, 0xdd }, { 0x32, 0x75, 0x2e, 0xef, 0xc8, 0xc2, 0xa9, 0x3f, 0x91, 0xb6, 0xe7, 0x3e, 0xb0, 0x7c, 0xca, 0x6e }, { 0xd8, 0x93, 0xe7, 0xd6, 0x2f, 0x6c, 0xe5, 0x02, 0xc6, 0x4f, 0x75, 0xe2, 0x81, 0xf9, 0xc0, 0x00 }, { 0x8d, 0xfd, 0x99, 0x9b, 0xe5, 0xd0, 0xcf, 0xa3, 0x57, 0x32, 0xc0, 0xdd, 0xc8, 0x8f, 0xf5, 0xa5 }, { 0x02, 0x64, 0x7c, 0x76, 0xa3, 0x00, 0xc3, 0x17, 0x3b, 0x84, 0x14, 0x87, 0xeb, 0x2b, 0xae, 0x9f }, { 0x17, 0x2d, 0xf8, 0xb0, 0x2f, 0x04, 0xb5, 0x3a, 0xda, 0xb0, 0x28, 0xb4, 0xe0, 0x1a, 0xcd, 0x87 }, { 0x05, 0x4b, 0x3b, 0xf4, 0x99, 0x8a, 0xeb, 0x05, 0xaf, 0xd8, 0x7e, 0xc5, 0x36, 0x53, 0x3a, 0x36 }, { 0x37, 0x83, 0xf7, 0xbf, 0x44, 0xc9, 0x7f, 0x06, 0x52, 0x58, 0xa6, 0x66, 0xca, 0xe0, 0x30, 0x20 }, { 0xaa, 0xd4, 0xc8, 0xa6, 0x3f, 0x80, 0x95, 0x41, 0x04, 0xde, 0x7b, 0x92, 0xce, 0xde, 0x1b, 0xe1 }, { 0xcb, 0xfe, 0x61, 0x81, 0x0f, 0xd5, 0x46, 0x7c, 0xcd, 0xac, 0xb7, 0x58, 0x00, 0xf3, 0xac, 0x07 }, { 0x83, 0x0d, 0x8a, 0x25, 0x90, 0xf7, 0xd8, 0xe1, 0xb5, 0x5a, 0x73, 0x7f, 0x4a, 0xf4, 0x5f, 0x34 }, { 0xff, 0xfc, 0xd4, 0x68, 0x3f, 0x85, 0x80, 0x58, 0xe7, 0x43, 0x14, 0x67, 0x1d, 0x43, 0xfa, 0x2c }, { 0x52, 0x3d, 0x0b, 0xab, 0xbb, 0x82, 0xf4, 0x6e, 0xbc, 0x9e, 0x70, 0xb1, 0xcd, 0x41, 0xdd, 0xd0 }, { 0x34, 0x4a, 0xab, 0x37, 0x08, 0x0d, 0x74, 0x86, 0xf7, 0xd5, 0x42, 0xa3, 0x09, 0xe5, 0x3e, 0xed }, { 0x56, 0xc5, 0x60, 0x9d, 0x09, 0x06, 0xb2, 0x3a, 0xb9, 0xca, 0xca, 0x81, 0x6f, 0x5d, 0xbe, 0xbd }, { 0x70, 0x26, 0x02, 0x6e, 0xed, 0xd9, 0x1a, 0xdc, 0x6d, 0x83, 0x1c, 0xdf, 0x98, 0x94, 0xbd, 0xc6 }, { 0x88, 0x33, 0x0b, 0xaa, 0x4f, 0x2b, 0x61, 0x8f, 0xc9, 0xd9, 0xb0, 0x21, 0xbf, 0x50, 0x3d, 0x5a }, { 0xfc, 0x9e, 0x0e, 0xa2, 0x24, 0x80, 0xb0, 0xba, 0xc9, 0x35, 0xc8, 0xa8, 0xeb, 0xef, 0xcd, 0xcf }, { 0x29, 0xca, 0x77, 0x9f, 0x39, 0x8f, 0xb0, 0x4f, 0x86, 0x7d, 0xa7, 0xe8, 0xa4, 0x47, 0x56, 0xcb }, { 0x51, 0xf8, 0x9c, 0x42, 0x98, 0x57, 0x86, 0xbf, 0xc4, 0x3c, 0x6d, 0xf8, 0xad, 0xa3, 0x68, 0x32 }, { 0x6a, 0xc1, 0xde, 0x5f, 0xb8, 0xf2, 0x1d, 0x87, 0x4e, 0x91, 0xc5, 0x3b, 0x56, 0x0c, 0x50, 0xe3 }, { 0x03, 0xaa, 0x90, 0x58, 0x49, 0x0e, 0xda, 0x30, 0x60, 0x01, 0xa8, 0xa9, 0xf4, 0x8d, 0x0c, 0xa7 }, { 0xe3, 0x4e, 0xc7, 0x1d, 0x61, 0x28, 0xd4, 0x87, 0x18, 0x65, 0xd6, 0x17, 0xc3, 0x0b, 0x37, 0xe3 }, { 0x14, 0xbe, 0x1c, 0x53, 0x5b, 0x17, 0xca, 0xbd, 0x0c, 0x4d, 0x93, 0x52, 0x9d, 0x69, 0xbf, 0x47 }, { 0xc9, 0xef, 0x67, 0x75, 0x65, 0x07, 0xbe, 0xec, 0x9d, 0xd3, 0x86, 0x28, 0x83, 0x47, 0x80, 0x44 }, { 0x40, 0xe2, 0x31, 0xfa, 0x5a, 0x59, 0x48, 0xce, 0x21, 0x34, 0xe9, 0x2f, 0xc0, 0x66, 0x4d, 0x4b }, { 0x03, 0x19, 0x4b, 0x8e, 0x5d, 0xda, 0x55, 0x30, 0xd0, 0xc6, 0x78, 0xc0, 0xb4, 0x8f, 0x5d, 0x92 }, { 0x90, 0xbd, 0x08, 0x6f, 0x23, 0x7c, 0xc4, 0xfd, 0x99, 0xf4, 0xd7, 0x6b, 0xde, 0x6b, 0x48, 0x26 }, { 0x19, 0x25, 0x97, 0x61, 0xca, 0x17, 0x13, 0x0d, 0x6e, 0xd8, 0x6d, 0x57, 0xcd, 0x79, 0x51, 0xee }, { 0xd7, 0xcb, 0xb3, 0xf3, 0x4b, 0x9b, 0x45, 0x0f, 0x24, 0xb0, 0xe8, 0x51, 0x8e, 0x54, 0xda, 0x6d }, { 0x72, 0x5b, 0x9c, 0xae, 0xbe, 0x9f, 0x7f, 0x41, 0x7f, 0x40, 0x68, 0xd0, 0xd2, 0xee, 0x20, 0xb3 }, { 0x9d, 0x92, 0x4b, 0x93, 0x4a, 0x90, 0xce, 0x1f, 0xd3, 0x9b, 0x8a, 0x97, 0x94, 0xf8, 0x26, 0x72 }, { 0xc5, 0x05, 0x62, 0xbf, 0x09, 0x45, 0x26, 0xa9, 0x1c, 0x5b, 0xc6, 0x3c, 0x0c, 0x22, 0x49, 0x95 }, { 0xd2, 0xf1, 0x18, 0x05, 0x04, 0x67, 0x43, 0xbd, 0x74, 0xf5, 0x71, 0x88, 0xd9, 0x18, 0x8d, 0xf7 }, { 0x8d, 0xd2, 0x74, 0xbd, 0x0f, 0x1b, 0x58, 0xae, 0x34, 0x5d, 0x9e, 0x72, 0x33, 0xf9, 0xb8, 0xf3 }, { 0x9d, 0x6b, 0xdc, 0x8f, 0x4c, 0xe5, 0xfe, 0xb0, 0xf3, 0xbe, 0xd2, 0xe4, 0xb9, 0xa9, 0xbb, 0x0b }, { 0xfd, 0x55, 0x48, 0xbc, 0xf3, 0xf4, 0x25, 0x65, 0xf7, 0xef, 0xa9, 0x45, 0x62, 0x52, 0x8d, 0x46 }, { 0xd2, 0xcc, 0xae, 0xbd, 0x3a, 0x4c, 0x3e, 0x80, 0xb0, 0x63, 0x74, 0x81, 0x31, 0xba, 0x4a, 0x71 }, { 0xe0, 0x3c, 0xb2, 0x3d, 0x9e, 0x11, 0xc9, 0xd9, 0x3f, 0x11, 0x7e, 0x9c, 0x0a, 0x91, 0xb5, 0x76 }, { 0x78, 0xf9, 0x33, 0xa2, 0x08, 0x1a, 0xc1, 0xdb, 0x84, 0xf6, 0x9d, 0x10, 0xf4, 0x52, 0x3f, 0xe0 }, { 0x40, 0x61, 0xf7, 0x41, 0x2e, 0xd3, 0x20, 0xde, 0x0e, 0xdc, 0x88, 0x51, 0xc2, 0xe2, 0x43, 0x6f }, { 0x90, 0x64, 0xba, 0x1c, 0xd0, 0x4c, 0xe6, 0xba, 0xb9, 0x84, 0x74, 0x33, 0x08, 0x14, 0xb4, 0xd4 }, { 0x48, 0x39, 0x1b, 0xff, 0xb9, 0xcf, 0xff, 0x80, 0xac, 0x23, 0x8c, 0x88, 0x6e, 0xf0, 0xa4, 0x61 }, { 0xb8, 0xd2, 0xa6, 0x7d, 0xf5, 0xa9, 0x99, 0xfd, 0xbf, 0x93, 0xed, 0xd0, 0x34, 0x32, 0x96, 0xc9 }, { 0xaa, 0xca, 0x73, 0x67, 0x39, 0x6b, 0x69, 0xa2, 0x21, 0xbd, 0x63, 0x2b, 0xea, 0x38, 0x6e, 0xec }, { 0xa8, 0x0f, 0xd5, 0x02, 0x0d, 0xfe, 0x65, 0xf5, 0xf1, 0x62, 0x93, 0xec, 0x92, 0xc6, 0xfd, 0x89 }, { 0x21, 0x62, 0x99, 0x5b, 0x82, 0x17, 0xa6, 0x7f, 0x1a, 0xbc, 0x34, 0x2e, 0x14, 0x64, 0x06, 0xf8 }, { 0xc6, 0xa6, 0x16, 0x4b, 0x7a, 0x60, 0xba, 0xe4, 0xe9, 0x86, 0xff, 0xac, 0x28, 0xdf, 0xad, 0xd9 }, { 0x64, 0xe0, 0xd7, 0xf9, 0x00, 0xe3, 0xd9, 0xc8, 0x3e, 0x4b, 0x8f, 0x96, 0x71, 0x7b, 0x21, 0x46 }, { 0x1a, 0xd2, 0x56, 0x1d, 0xe8, 0xc1, 0x23, 0x2f, 0x5d, 0x8d, 0xba, 0xb4, 0x73, 0x9b, 0x6c, 0xbb }, { 0x27, 0x96, 0x89, 0xe9, 0xa5, 0x57, 0xf5, 0x8b, 0x1c, 0x3b, 0xf4, 0x0c, 0x97, 0xa9, 0x09, 0x64 }, { 0xc4, 0x63, 0x7e, 0x4a, 0x5e, 0x63, 0x77, 0xf9, 0xcc, 0x5a, 0x86, 0x38, 0x04, 0x5d, 0xe0, 0x29 }, { 0x49, 0x2e, 0x60, 0x7e, 0x5a, 0xea, 0x46, 0x88, 0x59, 0x4b, 0x45, 0xf3, 0xae, 0xe3, 0xdf, 0x90 }, { 0xe8, 0xc4, 0xe4, 0x38, 0x1f, 0xee, 0xc7, 0x40, 0x54, 0x95, 0x4c, 0x05, 0xb7, 0x77, 0xa0, 0x0a }, { 0x91, 0x54, 0x95, 0x14, 0x60, 0x5f, 0x38, 0x24, 0x6c, 0x9b, 0x72, 0x4a, 0xd8, 0x39, 0xf0, 0x1d }, { 0x74, 0xb2, 0x4e, 0x3b, 0x6f, 0xef, 0xe4, 0x0a, 0x4f, 0x9e, 0xf7, 0xac, 0x6e, 0x44, 0xd7, 0x6a }, { 0x24, 0x37, 0xa6, 0x83, 0xdc, 0x5d, 0x4b, 0x52, 0xab, 0xb4, 0xa1, 0x23, 0xa8, 0xdf, 0x86, 0xc6 }, { 0xbb, 0x28, 0x52, 0xc8, 0x91, 0xc5, 0x94, 0x7d, 0x2e, 0xd4, 0x40, 0x32, 0xc4, 0x21, 0xb8, 0x5f }, { 0x1b, 0x9f, 0x5f, 0xbd, 0x5e, 0x8a, 0x42, 0x64, 0xc0, 0xa8, 0x5b, 0x80, 0x40, 0x9a, 0xfa, 0x5e }, { 0x30, 0xda, 0xb8, 0x09, 0xf8, 0x5a, 0x91, 0x7f, 0xe9, 0x24, 0x73, 0x3f, 0x42, 0x4a, 0xc5, 0x89 }, { 0xea, 0xef, 0x5c, 0x1f, 0x8d, 0x60, 0x51, 0x92, 0x64, 0x66, 0x95, 0xce, 0xad, 0xc6, 0x5f, 0x32 }, { 0xb8, 0xaa, 0x90, 0x04, 0x0b, 0x4c, 0x15, 0xa1, 0x23, 0x16, 0xb7, 0x8e, 0x0f, 0x95, 0x86, 0xfc }, { 0x97, 0xfa, 0xc8, 0x29, 0x7c, 0xea, 0xab, 0xc8, 0x7d, 0x45, 0x43, 0x50, 0x60, 0x1e, 0x06, 0x73 }, { 0x9b, 0x47, 0xef, 0x56, 0x7a, 0xc2, 0x8d, 0xfe, 0x48, 0x84, 0x92, 0xf1, 0x57, 0xe2, 0xb2, 0xe0 }, { 0x1b, 0x84, 0x26, 0x02, 0x7d, 0xdb, 0x96, 0x2b, 0x5c, 0x5b, 0xa7, 0xeb, 0x8b, 0xc9, 0xab, 0x63 }, { 0xe9, 0x17, 0xfc, 0x77, 0xe7, 0x19, 0x92, 0xa1, 0x2d, 0xbe, 0x4c, 0x18, 0x06, 0x8b, 0xec, 0x82 }, { 0xdc, 0xee, 0xbb, 0xc9, 0x88, 0x40, 0xf8, 0xae, 0x6d, 0xaf, 0x76, 0x57, 0x3b, 0x7e, 0x56, 0xf4 }, { 0x4e, 0x11, 0xa9, 0xf7, 0x42, 0x05, 0x12, 0x5b, 0x61, 0xe0, 0xae, 0xe0, 0x47, 0xec, 0xa2, 0x0d }, { 0xf6, 0x04, 0x67, 0xf5, 0x5a, 0x1f, 0x17, 0xea, 0xb8, 0x8e, 0x80, 0x01, 0x20, 0xcb, 0xc2, 0x84 }, { 0xd4, 0x36, 0x64, 0x9f, 0x60, 0x0b, 0x44, 0x9e, 0xe2, 0x76, 0x53, 0x0f, 0x0c, 0xd8, 0x3c, 0x11 }, { 0x3b, 0xc0, 0xe3, 0x65, 0x6a, 0x9e, 0x3a, 0xc7, 0xcd, 0x37, 0x8a, 0x73, 0x7f, 0x53, 0xb6, 0x37 }, { 0x6b, 0xac, 0xae, 0x63, 0xd3, 0x3b, 0x92, 0x8a, 0xa8, 0x38, 0x0f, 0x8d, 0x54, 0xd8, 0x8c, 0x17 }, { 0x89, 0x35, 0xff, 0xbc, 0x75, 0xae, 0x62, 0x51, 0xbf, 0x8e, 0x85, 0x9f, 0x08, 0x5a, 0xdc, 0xb9 }, { 0x93, 0xdc, 0x49, 0x70, 0xfe, 0x35, 0xf6, 0x77, 0x47, 0xcb, 0x05, 0x62, 0xc0, 0x6d, 0x87, 0x5a }, { 0x14, 0xf9, 0xdf, 0x85, 0x89, 0x75, 0x85, 0x17, 0x97, 0xba, 0x60, 0x4f, 0xb0, 0xd1, 0x6c, 0xc7 }, { 0x02, 0xea, 0x0c, 0x98, 0xdc, 0xa1, 0x0b, 0x38, 0xc2, 0x1b, 0x3b, 0x14, 0xe8, 0xd1, 0xb7, 0x1f }, { 0x8f, 0x09, 0x1b, 0x1b, 0x5b, 0x07, 0x49, 0xb2, 0xad, 0xc8, 0x03, 0xe6, 0x3d, 0xda, 0x9b, 0x72 }, { 0x05, 0xb3, 0x89, 0xe3, 0x32, 0x2c, 0x6d, 0xa0, 0x83, 0x84, 0x34, 0x5a, 0x41, 0x37, 0xfd, 0x08 }, { 0x38, 0x13, 0x08, 0xc4, 0x38, 0xf3, 0x5b, 0x39, 0x9f, 0x10, 0xad, 0x71, 0xb0, 0x50, 0x27, 0xd8 }, { 0x68, 0xc2, 0x30, 0xfc, 0xfa, 0x92, 0x79, 0xc3, 0x40, 0x9f, 0xc4, 0x23, 0xe2, 0xac, 0xbe, 0x04 }, { 0x1c, 0x84, 0xa4, 0x75, 0xac, 0xb0, 0x11, 0xf3, 0xf5, 0x9f, 0x4f, 0x46, 0xb7, 0x62, 0x74, 0xc0 }, { 0x45, 0x11, 0x9b, 0x68, 0xcb, 0x3f, 0x83, 0x99, 0xee, 0x60, 0x06, 0x6b, 0x56, 0x11, 0xa4, 0xd7 }, { 0x94, 0x23, 0x76, 0x2f, 0x52, 0x7a, 0x40, 0x60, 0xff, 0xca, 0x31, 0x2d, 0xcc, 0xa2, 0x2a, 0x16 }, { 0xf3, 0x61, 0xa2, 0x74, 0x5a, 0x33, 0xf0, 0x56, 0xa5, 0xac, 0x6a, 0xce, 0x2f, 0x08, 0xe3, 0x44 }, { 0x5e, 0xf1, 0x45, 0x76, 0x6e, 0xca, 0x84, 0x9f, 0x5d, 0x01, 0x15, 0x36, 0xa6, 0x55, 0x7f, 0xdb }, { 0xc9, 0xaf, 0x27, 0xb2, 0xc8, 0x9c, 0x9b, 0x4c, 0xf4, 0xa0, 0xc4, 0x10, 0x6a, 0xc8, 0x03, 0x18 }, { 0xfb, 0x9c, 0x4f, 0x16, 0xc6, 0x21, 0xf4, 0xea, 0xb7, 0xe9, 0xac, 0x1d, 0x75, 0x51, 0xdd, 0x57 }, { 0x13, 0x8e, 0x06, 0xfb, 0xa4, 0x66, 0xfa, 0x70, 0x85, 0x4d, 0x8c, 0x2e, 0x52, 0x4c, 0xff, 0xb2 }, { 0xfb, 0x4b, 0xc7, 0x8b, 0x22, 0x50, 0x70, 0x77, 0x3f, 0x04, 0xc4, 0x04, 0x66, 0xd4, 0xe9, 0x0c }, { 0x8b, 0x2c, 0xbf, 0xf1, 0xed, 0x01, 0x50, 0xfe, 0xda, 0x8a, 0x47, 0x99, 0xbe, 0x94, 0x55, 0x1f }, { 0x08, 0xb3, 0x0d, 0x7b, 0x3f, 0x27, 0x96, 0x27, 0x09, 0xa3, 0x6b, 0xca, 0xdf, 0xb9, 0x74, 0xbd }, { 0xfd, 0xf6, 0xd3, 0x2e, 0x04, 0x4d, 0x77, 0xad, 0xcf, 0x37, 0xfb, 0x97, 0xac, 0x21, 0x33, 0x26 }, { 0x93, 0xcb, 0x28, 0x4e, 0xcd, 0xcf, 0xd7, 0x81, 0xa8, 0xaf, 0xe3, 0x20, 0x77, 0x94, 0x9e, 0x88 }, { 0x7b, 0x01, 0x7b, 0xb0, 0x2e, 0xc8, 0x7b, 0x2b, 0x94, 0xc9, 0x6e, 0x40, 0xa2, 0x6f, 0xc7, 0x1a }, { 0xc5, 0xc0, 0x38, 0xb6, 0x99, 0x06, 0x64, 0xab, 0x08, 0xa3, 0xaa, 0xa5, 0xdf, 0x9f, 0x32, 0x66 }, { 0x4b, 0x70, 0x20, 0xbe, 0x37, 0xfa, 0xb6, 0x25, 0x9b, 0x2a, 0x27, 0xf4, 0xec, 0x55, 0x15, 0x76 }, { 0x60, 0x13, 0x67, 0x03, 0x37, 0x4f, 0x64, 0xe8, 0x60, 0xb4, 0x8c, 0xe3, 0x1f, 0x93, 0x07, 0x16 }, { 0x8d, 0x63, 0xa2, 0x69, 0xb1, 0x4d, 0x50, 0x6c, 0xcc, 0x40, 0x1a, 0xb8, 0xa9, 0xf1, 0xb5, 0x91 }, { 0xd3, 0x17, 0xf8, 0x1d, 0xc6, 0xaa, 0x45, 0x4a, 0xee, 0x4b, 0xd4, 0xa5, 0xa5, 0xcf, 0xf4, 0xbd }, { 0xdd, 0xde, 0xce, 0xcd, 0x53, 0x54, 0xf0, 0x4d, 0x53, 0x0d, 0x76, 0xed, 0x88, 0x42, 0x46, 0xeb }, { 0x41, 0xc5, 0x20, 0x5c, 0xc8, 0xfd, 0x8e, 0xda, 0x9a, 0x3c, 0xff, 0xd2, 0x51, 0x8f, 0x36, 0x5a }, { 0xcf, 0x42, 0xfb, 0x47, 0x42, 0x93, 0xd9, 0x6e, 0xca, 0x9d, 0xb1, 0xb3, 0x7b, 0x1b, 0xa6, 0x76 }, { 0xa2, 0x31, 0x69, 0x26, 0x07, 0x16, 0x9b, 0x4e, 0xcd, 0xea, 0xd5, 0xcd, 0x3b, 0x10, 0xdb, 0x3e }, { 0xac, 0xe4, 0xb9, 0x1c, 0x9c, 0x66, 0x9e, 0x77, 0xe7, 0xac, 0xac, 0xd1, 0x98, 0x59, 0xed, 0x49 }, { 0x75, 0xdb, 0x7c, 0xfd, 0x4a, 0x7b, 0x2b, 0x62, 0xab, 0x78, 0xa4, 0x8f, 0x3d, 0xda, 0xf4, 0xaf }, { 0xc1, 0xfa, 0xba, 0x2d, 0x46, 0xe2, 0x59, 0xcf, 0x48, 0x0d, 0x7c, 0x38, 0xe4, 0x57, 0x2a, 0x58 }, { 0x24, 0x1c, 0x45, 0xbc, 0x6a, 0xe1, 0x6d, 0xee, 0x6e, 0xb7, 0xbe, 0xa1, 0x28, 0x70, 0x15, 0x82 }, { 0x8f, 0xd0, 0x30, 0x57, 0xcf, 0x13, 0x64, 0x42, 0x0c, 0x2b, 0x78, 0x06, 0x9a, 0x3e, 0x25, 0x02 }, { 0xdd, 0xb5, 0x05, 0xe6, 0xcc, 0x13, 0x84, 0xcb, 0xae, 0xc1, 0xdf, 0x90, 0xb8, 0x0b, 0xeb, 0x20 }, { 0x56, 0x74, 0xa3, 0xbe, 0xd2, 0x7b, 0xf4, 0xbd, 0x36, 0x22, 0xf9, 0xf5, 0xfe, 0x20, 0x83, 0x06 }, { 0xb6, 0x87, 0xf2, 0x6a, 0x89, 0xcf, 0xbf, 0xbb, 0x8e, 0x5e, 0xea, 0xc5, 0x40, 0x55, 0x31, 0x5e }, { 0x05, 0x47, 0xdd, 0x32, 0xd3, 0xb2, 0x9a, 0xb6, 0xa4, 0xca, 0xeb, 0x60, 0x6c, 0x5b, 0x6f, 0x78 }, { 0x18, 0x68, 0x61, 0xf8, 0xbc, 0x53, 0x86, 0xd3, 0x1f, 0xb7, 0x7f, 0x72, 0x0c, 0x32, 0x26, 0xe6 }, { 0xea, 0xcf, 0x1e, 0x6c, 0x42, 0x24, 0xef, 0xb3, 0x89, 0x00, 0xb1, 0x85, 0xab, 0x1d, 0xfd, 0x42 }, { 0xd2, 0x41, 0xaa, 0xb0, 0x5a, 0x42, 0xd3, 0x19, 0xde, 0x81, 0xd8, 0x74, 0xf5, 0xc7, 0xb9, 0x0d }, { 0x5e, 0xb9, 0xbc, 0x75, 0x9e, 0x2a, 0xd8, 0xd2, 0x14, 0x0a, 0x6c, 0x76, 0x2a, 0xe9, 0xe1, 0xab }, { 0x01, 0x85, 0x96, 0xe1, 0x5e, 0x78, 0xe2, 0xc0, 0x64, 0x15, 0x9d, 0xef, 0xce, 0x5f, 0x30, 0x85 }, { 0xdd, 0x8a, 0x49, 0x35, 0x14, 0x23, 0x1c, 0xbf, 0x56, 0xec, 0xce, 0xe4, 0xc4, 0x08, 0x89, 0xfb } }; /* Values from NIST KAT-AES CBCVarTxt256.rsp */ uint8_t cipher_texts1_256bit[ 128 ][ 16 ] = { { 0xdd, 0xc6, 0xbf, 0x79, 0x0c, 0x15, 0x76, 0x0d, 0x8d, 0x9a, 0xeb, 0x6f, 0x9a, 0x75, 0xfd, 0x4e }, { 0x0a, 0x6b, 0xdc, 0x6d, 0x4c, 0x1e, 0x62, 0x80, 0x30, 0x1f, 0xd8, 0xe9, 0x7d, 0xdb, 0xe6, 0x01 }, { 0x9b, 0x80, 0xee, 0xfb, 0x7e, 0xbe, 0x2d, 0x2b, 0x16, 0x24, 0x7a, 0xa0, 0xef, 0xc7, 0x2f, 0x5d }, { 0x7f, 0x2c, 0x5e, 0xce, 0x07, 0xa9, 0x8d, 0x8b, 0xee, 0x13, 0xc5, 0x11, 0x77, 0x39, 0x5f, 0xf7 }, { 0x78, 0x18, 0xd8, 0x00, 0xdc, 0xf6, 0xf4, 0xbe, 0x1e, 0x0e, 0x94, 0xf4, 0x03, 0xd1, 0xe4, 0xc2 }, { 0xe7, 0x4c, 0xd1, 0xc9, 0x2f, 0x09, 0x19, 0xc3, 0x5a, 0x03, 0x24, 0x12, 0x3d, 0x61, 0x77, 0xd3 }, { 0x80, 0x92, 0xa4, 0xdc, 0xf2, 0xda, 0x7e, 0x77, 0xe9, 0x3b, 0xdd, 0x37, 0x1d, 0xfe, 0xd8, 0x2e }, { 0x49, 0xaf, 0x6b, 0x37, 0x21, 0x35, 0xac, 0xef, 0x10, 0x13, 0x2e, 0x54, 0x8f, 0x21, 0x7b, 0x17 }, { 0x8b, 0xcd, 0x40, 0xf9, 0x4e, 0xbb, 0x63, 0xb9, 0xf7, 0x90, 0x96, 0x76, 0xe6, 0x67, 0xf1, 0xe7 }, { 0xfe, 0x1c, 0xff, 0xb8, 0x3f, 0x45, 0xdc, 0xfb, 0x38, 0xb2, 0x9b, 0xe4, 0x38, 0xdb, 0xd3, 0xab }, { 0x0d, 0xc5, 0x8a, 0x8d, 0x88, 0x66, 0x23, 0x70, 0x5a, 0xec, 0x15, 0xcb, 0x1e, 0x70, 0xdc, 0x0e }, { 0xc2, 0x18, 0xfa, 0xa1, 0x60, 0x56, 0xbd, 0x07, 0x74, 0xc3, 0xe8, 0xd7, 0x9c, 0x35, 0xa5, 0xe4 }, { 0x04, 0x7b, 0xba, 0x83, 0xf7, 0xaa, 0x84, 0x17, 0x31, 0x50, 0x4e, 0x01, 0x22, 0x08, 0xfc, 0x9e }, { 0xdc, 0x8f, 0x0e, 0x49, 0x15, 0xfd, 0x81, 0xba, 0x70, 0xa3, 0x31, 0x31, 0x08, 0x82, 0xf6, 0xda }, { 0x15, 0x69, 0x85, 0x9e, 0xa6, 0xb7, 0x20, 0x6c, 0x30, 0xbf, 0x4f, 0xd0, 0xcb, 0xfa, 0xc3, 0x3c }, { 0x30, 0x0a, 0xde, 0x92, 0xf8, 0x8f, 0x48, 0xfa, 0x2d, 0xf7, 0x30, 0xec, 0x16, 0xef, 0x44, 0xcd }, { 0x1f, 0xe6, 0xcc, 0x3c, 0x05, 0x96, 0x5d, 0xc0, 0x8e, 0xb0, 0x59, 0x0c, 0x95, 0xac, 0x71, 0xd0 }, { 0x59, 0xe8, 0x58, 0xea, 0xaa, 0x97, 0xfe, 0xc3, 0x81, 0x11, 0x27, 0x5b, 0x6c, 0xf5, 0xab, 0xc0 }, { 0x22, 0x39, 0x45, 0x5e, 0x7a, 0xfe, 0x3b, 0x06, 0x16, 0x10, 0x02, 0x88, 0xcc, 0x5a, 0x72, 0x3b }, { 0x3e, 0xe5, 0x00, 0xc5, 0xc8, 0xd6, 0x34, 0x79, 0x71, 0x71, 0x63, 0xe5, 0x5c, 0x5c, 0x45, 0x22 }, { 0xd5, 0xe3, 0x8b, 0xf1, 0x5f, 0x16, 0xd9, 0x0e, 0x3e, 0x21, 0x40, 0x41, 0xd7, 0x74, 0xda, 0xa8 }, { 0xb1, 0xf4, 0x06, 0x6e, 0x6f, 0x4f, 0x18, 0x7d, 0xfe, 0x5f, 0x2a, 0xd1, 0xb1, 0x78, 0x19, 0xd0 }, { 0x6e, 0xf4, 0xcc, 0x4d, 0xe4, 0x9b, 0x11, 0x06, 0x5d, 0x7a, 0xf2, 0x90, 0x98, 0x54, 0x79, 0x4a }, { 0xac, 0x86, 0xbc, 0x60, 0x6b, 0x66, 0x40, 0xc3, 0x09, 0xe7, 0x82, 0xf2, 0x32, 0xbf, 0x36, 0x7f }, { 0x36, 0xaf, 0xf0, 0xef, 0x7b, 0xf3, 0x28, 0x07, 0x72, 0xcf, 0x4c, 0xac, 0x80, 0xa0, 0xd2, 0xb2 }, { 0x1f, 0x8e, 0xed, 0xea, 0x0f, 0x62, 0xa1, 0x40, 0x6d, 0x58, 0xcf, 0xc3, 0xec, 0xea, 0x72, 0xcf }, { 0xab, 0xf4, 0x15, 0x4a, 0x33, 0x75, 0xa1, 0xd3, 0xe6, 0xb1, 0xd4, 0x54, 0x43, 0x8f, 0x95, 0xa6 }, { 0x96, 0xf9, 0x6e, 0x9d, 0x60, 0x7f, 0x66, 0x15, 0xfc, 0x19, 0x20, 0x61, 0xee, 0x64, 0x8b, 0x07 }, { 0xcf, 0x37, 0xcd, 0xaa, 0xa0, 0xd2, 0xd5, 0x36, 0xc7, 0x18, 0x57, 0x63, 0x4c, 0x79, 0x20, 0x64 }, { 0xfb, 0xd6, 0x64, 0x0c, 0x80, 0x24, 0x5c, 0x2b, 0x80, 0x53, 0x73, 0xf1, 0x30, 0x70, 0x31, 0x27 }, { 0x8d, 0x6a, 0x8a, 0xfe, 0x55, 0xa6, 0xe4, 0x81, 0xba, 0xda, 0xe0, 0xd1, 0x46, 0xf4, 0x36, 0xdb }, { 0x6a, 0x49, 0x81, 0xf2, 0x91, 0x5e, 0x3e, 0x68, 0xaf, 0x6c, 0x22, 0x38, 0x5d, 0xd0, 0x67, 0x56 }, { 0x42, 0xa1, 0x13, 0x6e, 0x5f, 0x8d, 0x8d, 0x21, 0xd3, 0x10, 0x19, 0x98, 0x64, 0x2d, 0x57, 0x3b }, { 0x9b, 0x47, 0x15, 0x96, 0xdc, 0x69, 0xae, 0x15, 0x86, 0xce, 0xe6, 0x15, 0x8b, 0x0b, 0x01, 0x81 }, { 0x75, 0x36, 0x65, 0xc4, 0xaf, 0x1e, 0xff, 0x33, 0xaa, 0x8b, 0x62, 0x8b, 0xf8, 0x74, 0x1c, 0xfd }, { 0x9a, 0x68, 0x2a, 0xcf, 0x40, 0xbe, 0x01, 0xf5, 0xb2, 0xa4, 0x19, 0x3c, 0x9a, 0x82, 0x40, 0x4d }, { 0x54, 0xfa, 0xfe, 0x26, 0xe4, 0x28, 0x7f, 0x17, 0xd1, 0x93, 0x5f, 0x87, 0xeb, 0x9a, 0xde, 0x01 }, { 0x49, 0xd5, 0x41, 0xb2, 0xe7, 0x4c, 0xfe, 0x73, 0xe6, 0xa8, 0xe8, 0x22, 0x5f, 0x7b, 0xd4, 0x49 }, { 0x11, 0xa4, 0x55, 0x30, 0xf6, 0x24, 0xff, 0x6f, 0x76, 0xa1, 0xb3, 0x82, 0x66, 0x26, 0xff, 0x7b }, { 0xf9, 0x6b, 0x0c, 0x4a, 0x8b, 0xc6, 0xc8, 0x61, 0x30, 0x28, 0x9f, 0x60, 0xb4, 0x3b, 0x8f, 0xba }, { 0x48, 0xc7, 0xd0, 0xe8, 0x08, 0x34, 0xeb, 0xdc, 0x35, 0xb6, 0x73, 0x5f, 0x76, 0xb4, 0x6c, 0x8b }, { 0x24, 0x63, 0x53, 0x1a, 0xb5, 0x4d, 0x66, 0x95, 0x5e, 0x73, 0xed, 0xc4, 0xcb, 0x8e, 0xaa, 0x45 }, { 0xac, 0x9b, 0xd8, 0xe2, 0x53, 0x04, 0x69, 0x13, 0x4b, 0x9d, 0x5b, 0x06, 0x5d, 0x4f, 0x56, 0x5b }, { 0x3f, 0x5f, 0x91, 0x06, 0xd0, 0xe5, 0x2f, 0x97, 0x3d, 0x48, 0x90, 0xe6, 0xf3, 0x7e, 0x8a, 0x00 }, { 0x20, 0xeb, 0xc8, 0x6f, 0x13, 0x04, 0xd2, 0x72, 0xe2, 0xe2, 0x07, 0xe5, 0x9d, 0xb6, 0x39, 0xf0 }, { 0xe6, 0x7a, 0xe6, 0x42, 0x6b, 0xf9, 0x52, 0x6c, 0x97, 0x2c, 0xff, 0x07, 0x2b, 0x52, 0x25, 0x2c }, { 0x1a, 0x51, 0x8d, 0xdd, 0xaf, 0x9e, 0xfa, 0x0d, 0x00, 0x2c, 0xc5, 0x8d, 0x10, 0x7e, 0xdf, 0xc8 }, { 0xea, 0xd7, 0x31, 0xaf, 0x4d, 0x3a, 0x2f, 0xe3, 0xb3, 0x4b, 0xed, 0x04, 0x79, 0x42, 0xa4, 0x9f }, { 0xb1, 0xd4, 0xef, 0xe4, 0x02, 0x42, 0xf8, 0x3e, 0x93, 0xb6, 0xc8, 0xd7, 0xef, 0xb5, 0xea, 0xe9 }, { 0xcd, 0x2b, 0x1f, 0xec, 0x11, 0xfd, 0x90, 0x6c, 0x5c, 0x76, 0x30, 0x09, 0x94, 0x43, 0x61, 0x0a }, { 0xa1, 0x85, 0x3f, 0xe4, 0x7f, 0xe2, 0x92, 0x89, 0xd1, 0x53, 0x16, 0x1d, 0x06, 0x38, 0x7d, 0x21 }, { 0x46, 0x32, 0x15, 0x41, 0x79, 0xa5, 0x55, 0xc1, 0x7e, 0xa6, 0x04, 0xd0, 0x88, 0x9f, 0xab, 0x14 }, { 0xdd, 0x27, 0xca, 0xc6, 0x40, 0x1a, 0x02, 0x2e, 0x8f, 0x38, 0xf9, 0xf9, 0x3e, 0x77, 0x44, 0x17 }, { 0xc0, 0x90, 0x31, 0x3e, 0xb9, 0x86, 0x74, 0xf3, 0x5f, 0x31, 0x23, 0x38, 0x5f, 0xb9, 0x5d, 0x4d }, { 0xcc, 0x35, 0x26, 0x26, 0x2b, 0x92, 0xf0, 0x2e, 0xdc, 0xe5, 0x48, 0xf7, 0x16, 0xb9, 0xf4, 0x5c }, { 0xc0, 0x83, 0x8d, 0x1a, 0x2b, 0x16, 0xa7, 0xc7, 0xf0, 0xdf, 0xcc, 0x43, 0x3c, 0x39, 0x9c, 0x33 }, { 0x0d, 0x9a, 0xc7, 0x56, 0xeb, 0x29, 0x76, 0x95, 0xee, 0xd4, 0xd3, 0x82, 0xeb, 0x12, 0x6d, 0x26 }, { 0x56, 0xed, 0xe9, 0xdd, 0xa3, 0xf6, 0xf1, 0x41, 0xbf, 0xf1, 0x75, 0x7f, 0xa6, 0x89, 0xc3, 0xe1 }, { 0x76, 0x8f, 0x52, 0x0e, 0xfe, 0x0f, 0x23, 0xe6, 0x1d, 0x3e, 0xc8, 0xad, 0x9c, 0xe9, 0x17, 0x74 }, { 0xb1, 0x14, 0x4d, 0xdf, 0xa7, 0x57, 0x55, 0x21, 0x33, 0x90, 0xe7, 0xc5, 0x96, 0x66, 0x04, 0x90 }, { 0x1d, 0x7c, 0x0c, 0x40, 0x40, 0xb3, 0x55, 0xb9, 0xd1, 0x07, 0xa9, 0x93, 0x25, 0xe3, 0xb0, 0x50 }, { 0xd8, 0xe2, 0xbb, 0x1a, 0xe8, 0xee, 0x3d, 0xcf, 0x5b, 0xf7, 0xd6, 0xc3, 0x8d, 0xa8, 0x2a, 0x1a }, { 0xfa, 0xf8, 0x2d, 0x17, 0x8a, 0xf2, 0x5a, 0x98, 0x86, 0xa4, 0x7e, 0x7f, 0x78, 0x9b, 0x98, 0xd7 }, { 0x9b, 0x58, 0xdb, 0xfd, 0x77, 0xfe, 0x5a, 0xca, 0x9c, 0xfc, 0x19, 0x0c, 0xd1, 0xb8, 0x2d, 0x19 }, { 0x77, 0xf3, 0x92, 0x08, 0x90, 0x42, 0xe4, 0x78, 0xac, 0x16, 0xc0, 0xc8, 0x6a, 0x0b, 0x5d, 0xb5 }, { 0x19, 0xf0, 0x8e, 0x34, 0x20, 0xee, 0x69, 0xb4, 0x77, 0xca, 0x14, 0x20, 0x28, 0x1c, 0x47, 0x82 }, { 0xa1, 0xb1, 0x9b, 0xee, 0xe4, 0xe1, 0x17, 0x13, 0x9f, 0x74, 0xb3, 0xc5, 0x3f, 0xdc, 0xb8, 0x75 }, { 0xa3, 0x7a, 0x58, 0x69, 0xb2, 0x18, 0xa9, 0xf3, 0xa0, 0x86, 0x8d, 0x19, 0xae, 0xa0, 0xad, 0x6a }, { 0xbc, 0x35, 0x94, 0xe8, 0x65, 0xbc, 0xd0, 0x26, 0x1b, 0x13, 0x20, 0x27, 0x31, 0xf3, 0x35, 0x80 }, { 0x81, 0x14, 0x41, 0xce, 0x1d, 0x30, 0x9e, 0xee, 0x71, 0x85, 0xe8, 0xc7, 0x52, 0xc0, 0x75, 0x57 }, { 0x95, 0x99, 0x71, 0xce, 0x41, 0x34, 0x19, 0x05, 0x63, 0x51, 0x8e, 0x70, 0x0b, 0x98, 0x74, 0xd1 }, { 0x76, 0xb5, 0x61, 0x4a, 0x04, 0x27, 0x07, 0xc9, 0x8e, 0x21, 0x32, 0xe2, 0xe8, 0x05, 0xfe, 0x63 }, { 0x7d, 0x9f, 0xa6, 0xa5, 0x75, 0x30, 0xd0, 0xf0, 0x36, 0xfe, 0xc3, 0x1c, 0x23, 0x0b, 0x0c, 0xc6 }, { 0x96, 0x41, 0x53, 0xa8, 0x3b, 0xf6, 0x98, 0x9a, 0x4b, 0xa8, 0x0d, 0xaa, 0x91, 0xc3, 0xe0, 0x81 }, { 0xa0, 0x13, 0x01, 0x4d, 0x4c, 0xe8, 0x05, 0x4c, 0xf2, 0x59, 0x1d, 0x06, 0xf6, 0xf2, 0xf1, 0x76 }, { 0xd1, 0xc5, 0xf6, 0x39, 0x9b, 0xf3, 0x82, 0x50, 0x2e, 0x38, 0x5e, 0xee, 0x14, 0x74, 0xa8, 0x69 }, { 0x00, 0x07, 0xe2, 0x0b, 0x82, 0x98, 0xec, 0x35, 0x4f, 0x0f, 0x5f, 0xe7, 0x47, 0x0f, 0x36, 0xbd }, { 0xb9, 0x5b, 0xa0, 0x5b, 0x33, 0x2d, 0xa6, 0x1e, 0xf6, 0x3a, 0x2b, 0x31, 0xfc, 0xad, 0x98, 0x79 }, { 0x46, 0x20, 0xa4, 0x9b, 0xd9, 0x67, 0x49, 0x15, 0x61, 0x66, 0x9a, 0xb2, 0x5d, 0xce, 0x45, 0xf4 }, { 0x12, 0xe7, 0x12, 0x14, 0xae, 0x8e, 0x04, 0xf0, 0xbb, 0x63, 0xd7, 0x42, 0x5c, 0x6f, 0x14, 0xd5 }, { 0x4c, 0xc4, 0x2f, 0xc1, 0x40, 0x7b, 0x00, 0x8f, 0xe3, 0x50, 0x90, 0x7c, 0x09, 0x2e, 0x80, 0xac }, { 0x08, 0xb2, 0x44, 0xce, 0x7c, 0xbc, 0x8e, 0xe9, 0x7f, 0xbb, 0xa8, 0x08, 0xcb, 0x14, 0x6f, 0xda }, { 0x39, 0xb3, 0x33, 0xe8, 0x69, 0x4f, 0x21, 0x54, 0x6a, 0xd1, 0xed, 0xd9, 0xd8, 0x7e, 0xd9, 0x5b }, { 0x3b, 0x27, 0x1f, 0x8a, 0xb2, 0xe6, 0xe4, 0xa2, 0x0b, 0xa8, 0x09, 0x0f, 0x43, 0xba, 0x78, 0xf3 }, { 0x9a, 0xd9, 0x83, 0xf3, 0xbf, 0x65, 0x1c, 0xd0, 0x39, 0x3f, 0x0a, 0x73, 0xcc, 0xcd, 0xea, 0x50 }, { 0x8f, 0x47, 0x6c, 0xbf, 0xf7, 0x5c, 0x1f, 0x72, 0x5c, 0xe1, 0x8e, 0x4b, 0xbc, 0xd1, 0x9b, 0x32 }, { 0x90, 0x5b, 0x62, 0x67, 0xf1, 0xd6, 0xab, 0x53, 0x20, 0x83, 0x5a, 0x13, 0x3f, 0x09, 0x6f, 0x2a }, { 0x14, 0x5b, 0x60, 0xd6, 0xd0, 0x19, 0x3c, 0x23, 0xf4, 0x22, 0x18, 0x48, 0xa8, 0x92, 0xd6, 0x1a }, { 0x55, 0xcf, 0xb3, 0xfb, 0x6d, 0x75, 0xca, 0xd0, 0x44, 0x5b, 0xbc, 0x8d, 0xaf, 0xa2, 0x5b, 0x0f }, { 0x7b, 0x8e, 0x70, 0x98, 0xe3, 0x57, 0xef, 0x71, 0x23, 0x7d, 0x46, 0xd8, 0xb0, 0x75, 0xb0, 0xf5 }, { 0x2b, 0xf2, 0x72, 0x29, 0x90, 0x1e, 0xb4, 0x0f, 0x2d, 0xf9, 0xd8, 0x39, 0x8d, 0x15, 0x05, 0xae }, { 0x83, 0xa6, 0x34, 0x02, 0xa7, 0x7f, 0x9a, 0xd5, 0xc1, 0xe9, 0x31, 0xa9, 0x31, 0xec, 0xd7, 0x06 }, { 0x6f, 0x8b, 0xa6, 0x52, 0x11, 0x52, 0xd3, 0x1f, 0x2b, 0xad, 0xa1, 0x84, 0x3e, 0x26, 0xb9, 0x73 }, { 0xe5, 0xc3, 0xb8, 0xe3, 0x0f, 0xd2, 0xd8, 0xe6, 0x23, 0x9b, 0x17, 0xb4, 0x4b, 0xd2, 0x3b, 0xbd }, { 0x1a, 0xc1, 0xf7, 0x10, 0x2c, 0x59, 0x93, 0x3e, 0x8b, 0x2d, 0xdc, 0x3f, 0x14, 0xe9, 0x4b, 0xaa }, { 0x21, 0xd9, 0xba, 0x49, 0xf2, 0x76, 0xb4, 0x5f, 0x11, 0xaf, 0x8f, 0xc7, 0x1a, 0x08, 0x8e, 0x3d }, { 0x64, 0x9f, 0x1c, 0xdd, 0xc3, 0x79, 0x2b, 0x46, 0x38, 0x63, 0x5a, 0x39, 0x2b, 0xc9, 0xba, 0xde }, { 0xe2, 0x77, 0x5e, 0x4b, 0x59, 0xc1, 0xbc, 0x2e, 0x31, 0xa2, 0x07, 0x8c, 0x11, 0xb5, 0xa0, 0x8c }, { 0x2b, 0xe1, 0xfa, 0xe5, 0x04, 0x8a, 0x25, 0x58, 0x2a, 0x67, 0x9c, 0xa1, 0x09, 0x05, 0xeb, 0x80 }, { 0xda, 0x86, 0xf2, 0x92, 0xc6, 0xf4, 0x1e, 0xa3, 0x4f, 0xb2, 0x06, 0x8d, 0xf7, 0x5e, 0xcc, 0x29 }, { 0x22, 0x0d, 0xf1, 0x9f, 0x85, 0xd6, 0x9b, 0x1b, 0x56, 0x2f, 0xa6, 0x9a, 0x3c, 0x5b, 0xec, 0xa5 }, { 0x1f, 0x11, 0xd5, 0xd0, 0x35, 0x5e, 0x0b, 0x55, 0x6c, 0xcd, 0xb6, 0xc7, 0xf5, 0x08, 0x3b, 0x4d }, { 0x62, 0x52, 0x6b, 0x78, 0xbe, 0x79, 0xcb, 0x38, 0x46, 0x33, 0xc9, 0x1f, 0x83, 0xb4, 0x15, 0x1b }, { 0x90, 0xdd, 0xbc, 0xb9, 0x50, 0x84, 0x35, 0x92, 0xdd, 0x47, 0xbb, 0xef, 0x00, 0xfd, 0xc8, 0x76 }, { 0x2f, 0xd0, 0xe4, 0x1c, 0x5b, 0x84, 0x02, 0x27, 0x73, 0x54, 0xa7, 0x39, 0x1d, 0x26, 0x18, 0xe2 }, { 0x3c, 0xdf, 0x13, 0xe7, 0x2d, 0xee, 0x4c, 0x58, 0x1b, 0xaf, 0xec, 0x70, 0xb8, 0x5f, 0x96, 0x60 }, { 0xaf, 0xa2, 0xff, 0xc1, 0x37, 0x57, 0x70, 0x92, 0xe2, 0xb6, 0x54, 0xfa, 0x19, 0x9d, 0x2c, 0x43 }, { 0x8d, 0x68, 0x3e, 0xe6, 0x3e, 0x60, 0xd2, 0x08, 0xe3, 0x43, 0xce, 0x48, 0xdb, 0xc4, 0x4c, 0xac }, { 0x70, 0x5a, 0x4e, 0xf8, 0xba, 0x21, 0x33, 0x72, 0x9c, 0x20, 0x18, 0x5c, 0x3d, 0x3a, 0x47, 0x63 }, { 0x08, 0x61, 0xa8, 0x61, 0xc3, 0xdb, 0x4e, 0x94, 0x19, 0x42, 0x11, 0xb7, 0x7e, 0xd7, 0x61, 0xb9 }, { 0x4b, 0x00, 0xc2, 0x7e, 0x8b, 0x26, 0xda, 0x7e, 0xab, 0x9d, 0x3a, 0x88, 0xde, 0xc8, 0xb0, 0x31 }, { 0x5f, 0x39, 0x7b, 0xf0, 0x30, 0x84, 0x82, 0x0c, 0xc8, 0x81, 0x0d, 0x52, 0xe5, 0xb6, 0x66, 0xe9 }, { 0x63, 0xfa, 0xfa, 0xbb, 0x72, 0xc0, 0x7b, 0xfb, 0xd3, 0xdd, 0xc9, 0xb1, 0x20, 0x31, 0x04, 0xb8 }, { 0x68, 0x3e, 0x21, 0x40, 0x58, 0x5b, 0x18, 0x45, 0x2d, 0xd4, 0xff, 0xbb, 0x93, 0xc9, 0x5d, 0xf9 }, { 0x28, 0x68, 0x94, 0xe4, 0x8e, 0x53, 0x7f, 0x87, 0x63, 0xb5, 0x67, 0x07, 0xd7, 0xd1, 0x55, 0xc8 }, { 0xa4, 0x23, 0xde, 0xab, 0xc1, 0x73, 0xdc, 0xf7, 0xe2, 0xc4, 0xc5, 0x3e, 0x77, 0xd3, 0x7c, 0xd1 }, { 0xeb, 0x81, 0x68, 0x31, 0x3e, 0x1c, 0xfd, 0xfd, 0xb5, 0xe9, 0x86, 0xd5, 0x42, 0x9c, 0xf1, 0x72 }, { 0x27, 0x12, 0x7d, 0xaa, 0xfc, 0x9a, 0xcc, 0xd2, 0xfb, 0x33, 0x4e, 0xc3, 0xeb, 0xa5, 0x23, 0x23 }, { 0xee, 0x07, 0x15, 0xb9, 0x6f, 0x72, 0xe3, 0xf7, 0xa2, 0x2a, 0x50, 0x64, 0xfc, 0x59, 0x2f, 0x4c }, { 0x29, 0xee, 0x52, 0x67, 0x70, 0xf2, 0xa1, 0x1d, 0xcf, 0xa9, 0x89, 0xd1, 0xce, 0x88, 0x83, 0x0f }, { 0x04, 0x93, 0x37, 0x0e, 0x05, 0x4b, 0x09, 0x87, 0x11, 0x30, 0xfe, 0x49, 0xaf, 0x73, 0x0a, 0x5a }, { 0x9b, 0x7b, 0x94, 0x0f, 0x6c, 0x50, 0x9f, 0x9e, 0x44, 0xa4, 0xee, 0x14, 0x04, 0x48, 0xee, 0x46 }, { 0x29, 0x15, 0xbe, 0x4a, 0x1e, 0xcf, 0xdc, 0xbe, 0x3e, 0x02, 0x38, 0x11, 0xa1, 0x2b, 0xb6, 0xc7 }, { 0x72, 0x40, 0xe5, 0x24, 0xbc, 0x51, 0xd8, 0xc4, 0xd4, 0x40, 0xb1, 0xbe, 0x55, 0xd1, 0x06, 0x2c }, { 0xda, 0x63, 0x03, 0x9d, 0x38, 0xcb, 0x46, 0x12, 0xb2, 0xdc, 0x36, 0xba, 0x26, 0x68, 0x4b, 0x93 }, { 0x0f, 0x59, 0xcb, 0x5a, 0x4b, 0x52, 0x2e, 0x2a, 0xc5, 0x6c, 0x1a, 0x64, 0xf5, 0x58, 0xad, 0x9a }, { 0x7b, 0xfe, 0x9d, 0x87, 0x6c, 0x6d, 0x63, 0xc1, 0xd0, 0x35, 0xda, 0x8f, 0xe2, 0x1c, 0x40, 0x9d }, { 0xac, 0xda, 0xce, 0x80, 0x78, 0xa3, 0x2b, 0x1a, 0x18, 0x2b, 0xfa, 0x49, 0x87, 0xca, 0x13, 0x47 } }; /* Values from NIST KAT-AES CBCVarKey256.rsp */ uint8_t cipher_texts2_256bit[ 256 ][ 16 ] = { { 0xe3, 0x5a, 0x6d, 0xcb, 0x19, 0xb2, 0x01, 0xa0, 0x1e, 0xbc, 0xfa, 0x8a, 0xa2, 0x2b, 0x57, 0x59 }, { 0xb2, 0x91, 0x69, 0xcd, 0xcf, 0x2d, 0x83, 0xe8, 0x38, 0x12, 0x5a, 0x12, 0xee, 0x6a, 0xa4, 0x00 }, { 0xd8, 0xf3, 0xa7, 0x2f, 0xc3, 0xcd, 0xf7, 0x4d, 0xfa, 0xf6, 0xc3, 0xe6, 0xb9, 0x7b, 0x2f, 0xa6 }, { 0x1c, 0x77, 0x76, 0x79, 0xd5, 0x00, 0x37, 0xc7, 0x94, 0x91, 0xa9, 0x4d, 0xa7, 0x6a, 0x9a, 0x35 }, { 0x9c, 0xf4, 0x89, 0x3e, 0xca, 0xfa, 0x0a, 0x02, 0x47, 0xa8, 0x98, 0xe0, 0x40, 0x69, 0x15, 0x59 }, { 0x8f, 0xbb, 0x41, 0x37, 0x03, 0x73, 0x53, 0x26, 0x31, 0x0a, 0x26, 0x9b, 0xd3, 0xaa, 0x94, 0xb2 }, { 0x60, 0xe3, 0x22, 0x46, 0xbe, 0xd2, 0xb0, 0xe8, 0x59, 0xe5, 0x5c, 0x1c, 0xc6, 0xb2, 0x65, 0x02 }, { 0xec, 0x52, 0xa2, 0x12, 0xf8, 0x0a, 0x09, 0xdf, 0x63, 0x17, 0x02, 0x1b, 0xc2, 0xa9, 0x81, 0x9e }, { 0xf2, 0x3e, 0x5b, 0x60, 0x0e, 0xb7, 0x0d, 0xbc, 0xcf, 0x6c, 0x0b, 0x1d, 0x9a, 0x68, 0x18, 0x2c }, { 0xa3, 0xf5, 0x99, 0xd6, 0x3a, 0x82, 0xa9, 0x68, 0xc3, 0x3f, 0xe2, 0x65, 0x90, 0x74, 0x59, 0x70 }, { 0xd1, 0xcc, 0xb9, 0xb1, 0x33, 0x70, 0x02, 0xcb, 0xac, 0x42, 0xc5, 0x20, 0xb5, 0xd6, 0x77, 0x22 }, { 0xcc, 0x11, 0x1f, 0x6c, 0x37, 0xcf, 0x40, 0xa1, 0x15, 0x9d, 0x00, 0xfb, 0x59, 0xfb, 0x04, 0x88 }, { 0xdc, 0x43, 0xb5, 0x1a, 0xb6, 0x09, 0x05, 0x23, 0x72, 0x98, 0x9a, 0x26, 0xe9, 0xcd, 0xd7, 0x14 }, { 0x4d, 0xce, 0xde, 0x8d, 0xa9, 0xe2, 0x57, 0x8f, 0x39, 0x70, 0x3d, 0x44, 0x33, 0xdc, 0x64, 0x59 }, { 0x1a, 0x4c, 0x1c, 0x26, 0x3b, 0xbc, 0xcf, 0xaf, 0xc1, 0x17, 0x82, 0x89, 0x46, 0x85, 0xe3, 0xa8 }, { 0x93, 0x7a, 0xd8, 0x48, 0x80, 0xdb, 0x50, 0x61, 0x34, 0x23, 0xd6, 0xd5, 0x27, 0xa2, 0x82, 0x3d }, { 0x61, 0x0b, 0x71, 0xdf, 0xc6, 0x88, 0xe1, 0x50, 0xd8, 0x15, 0x2c, 0x5b, 0x35, 0xeb, 0xc1, 0x4d }, { 0x27, 0xef, 0x24, 0x95, 0xda, 0xbf, 0x32, 0x38, 0x85, 0xaa, 0xb3, 0x9c, 0x80, 0xf1, 0x8d, 0x8b }, { 0x63, 0x3c, 0xaf, 0xea, 0x39, 0x5b, 0xc0, 0x3a, 0xda, 0xe3, 0xa1, 0xe2, 0x06, 0x8e, 0x4b, 0x4e }, { 0x6e, 0x1b, 0x48, 0x2b, 0x53, 0x76, 0x1c, 0xf6, 0x31, 0x81, 0x9b, 0x74, 0x9a, 0x6f, 0x37, 0x24 }, { 0x97, 0x6e, 0x6f, 0x85, 0x1a, 0xb5, 0x2c, 0x77, 0x19, 0x98, 0xdb, 0xb2, 0xd7, 0x1c, 0x75, 0xa9 }, { 0x85, 0xf2, 0xba, 0x84, 0xf8, 0xc3, 0x07, 0xcf, 0x52, 0x5e, 0x12, 0x4c, 0x3e, 0x22, 0xe6, 0xcc }, { 0x6b, 0xcc, 0xa9, 0x8b, 0xf6, 0xa8, 0x35, 0xfa, 0x64, 0x95, 0x5f, 0x72, 0xde, 0x41, 0x15, 0xfe }, { 0x2c, 0x75, 0xe2, 0xd3, 0x6e, 0xeb, 0xd6, 0x54, 0x11, 0xf1, 0x4f, 0xd0, 0xeb, 0x1d, 0x2a, 0x06 }, { 0xbd, 0x49, 0x29, 0x50, 0x06, 0x25, 0x0f, 0xfc, 0xa5, 0x10, 0x0b, 0x60, 0x07, 0xa0, 0xea, 0xde }, { 0xa1, 0x90, 0x52, 0x7d, 0x0e, 0xf7, 0xc7, 0x0f, 0x45, 0x9c, 0xd3, 0x94, 0x0d, 0xf3, 0x16, 0xec }, { 0xbb, 0xd1, 0x09, 0x7a, 0x62, 0x43, 0x3f, 0x79, 0x44, 0x9f, 0xa9, 0x7d, 0x4e, 0xe8, 0x0d, 0xbf }, { 0x07, 0x05, 0x8e, 0x40, 0x8f, 0x5b, 0x99, 0xb0, 0xe0, 0xf0, 0x61, 0xa1, 0x76, 0x1b, 0x5b, 0x3b }, { 0x5f, 0xd1, 0xf1, 0x3f, 0xa0, 0xf3, 0x1e, 0x37, 0xfa, 0xbd, 0xe3, 0x28, 0xf8, 0x94, 0xea, 0xc2 }, { 0xfc, 0x4a, 0xf7, 0xc9, 0x48, 0xdf, 0x26, 0xe2, 0xef, 0x3e, 0x01, 0xc1, 0xee, 0x5b, 0x8f, 0x6f }, { 0x82, 0x9f, 0xd7, 0x20, 0x8f, 0xb9, 0x2d, 0x44, 0xa0, 0x74, 0xa6, 0x77, 0xee, 0x98, 0x61, 0xac }, { 0xad, 0x9f, 0xc6, 0x13, 0xa7, 0x03, 0x25, 0x1b, 0x54, 0xc6, 0x4a, 0x0e, 0x76, 0x43, 0x17, 0x11 }, { 0x33, 0xac, 0x9e, 0xcc, 0xc4, 0xcc, 0x75, 0xe2, 0x71, 0x16, 0x18, 0xf8, 0x0b, 0x15, 0x48, 0xe8 }, { 0x20, 0x25, 0xc7, 0x4b, 0x8a, 0xd8, 0xf4, 0xcd, 0xa1, 0x7e, 0xe2, 0x04, 0x9c, 0x4c, 0x90, 0x2d }, { 0xf8, 0x5c, 0xa0, 0x5f, 0xe5, 0x28, 0xf1, 0xce, 0x9b, 0x79, 0x01, 0x66, 0xe8, 0xd5, 0x51, 0xe7 }, { 0x6f, 0x62, 0x38, 0xd8, 0x96, 0x60, 0x48, 0xd4, 0x96, 0x71, 0x54, 0xe0, 0xda, 0xd5, 0xa6, 0xc9 }, { 0xf2, 0xb2, 0x1b, 0x4e, 0x76, 0x40, 0xa9, 0xb3, 0x34, 0x6d, 0xe8, 0xb8, 0x2f, 0xb4, 0x1e, 0x49 }, { 0xf8, 0x36, 0xf2, 0x51, 0xad, 0x1d, 0x11, 0xd4, 0x9d, 0xc3, 0x44, 0x62, 0x8b, 0x18, 0x84, 0xe1 }, { 0x07, 0x7e, 0x94, 0x70, 0xae, 0x7a, 0xbe, 0xa5, 0xa9, 0x76, 0x9d, 0x49, 0x18, 0x26, 0x28, 0xc3 }, { 0xe0, 0xdc, 0xc2, 0xd2, 0x7f, 0xc9, 0x86, 0x56, 0x33, 0xf8, 0x52, 0x23, 0xcf, 0x0d, 0x61, 0x1f }, { 0xbe, 0x66, 0xcf, 0xea, 0x2f, 0xec, 0xd6, 0xbf, 0x0e, 0xc7, 0xb4, 0x35, 0x2c, 0x99, 0xbc, 0xaa }, { 0xdf, 0x31, 0x14, 0x4f, 0x87, 0xa2, 0xef, 0x52, 0x3f, 0xac, 0xdc, 0xf2, 0x1a, 0x42, 0x78, 0x04 }, { 0xb5, 0xbb, 0x0f, 0x56, 0x29, 0xfb, 0x6a, 0xae, 0x5e, 0x18, 0x39, 0xa3, 0xc3, 0x62, 0x5d, 0x63 }, { 0x3c, 0x9d, 0xb3, 0x33, 0x53, 0x06, 0xfe, 0x1e, 0xc6, 0x12, 0xbd, 0xbf, 0xae, 0x6b, 0x60, 0x28 }, { 0x3d, 0xd5, 0xc3, 0x46, 0x34, 0xa7, 0x9d, 0x3c, 0xfc, 0xc8, 0x33, 0x97, 0x60, 0xe6, 0xf5, 0xf4 }, { 0x82, 0xbd, 0xa1, 0x18, 0xa3, 0xed, 0x7a, 0xf3, 0x14, 0xfa, 0x2c, 0xcc, 0x5c, 0x07, 0xb7, 0x61 }, { 0x29, 0x37, 0xa6, 0x4f, 0x7d, 0x4f, 0x46, 0xfe, 0x6f, 0xea, 0x3b, 0x34, 0x9e, 0xc7, 0x8e, 0x38 }, { 0x22, 0x5f, 0x06, 0x8c, 0x28, 0x47, 0x66, 0x05, 0x73, 0x5a, 0xd6, 0x71, 0xbb, 0x8f, 0x39, 0xf3 }, { 0xae, 0x68, 0x2c, 0x5e, 0xcd, 0x71, 0x89, 0x8e, 0x08, 0x94, 0x2a, 0xc9, 0xaa, 0x89, 0x87, 0x5c }, { 0x5e, 0x03, 0x1c, 0xb9, 0xd6, 0x76, 0xc3, 0x02, 0x2d, 0x7f, 0x26, 0x22, 0x7e, 0x85, 0xc3, 0x8f }, { 0xa7, 0x84, 0x63, 0xfb, 0x06, 0x4d, 0xb5, 0xd5, 0x2b, 0xb6, 0x4b, 0xfe, 0xf6, 0x4f, 0x2d, 0xda }, { 0x8a, 0xa9, 0xb7, 0x5e, 0x78, 0x45, 0x93, 0x87, 0x6c, 0x53, 0xa0, 0x0e, 0xae, 0x5a, 0xf5, 0x2b }, { 0x3f, 0x84, 0x56, 0x6d, 0xf2, 0x3d, 0xa4, 0x8a, 0xf6, 0x92, 0x72, 0x2f, 0xe9, 0x80, 0x57, 0x3a }, { 0x31, 0x69, 0x0b, 0x5e, 0xd4, 0x1c, 0x7e, 0xb4, 0x2a, 0x1e, 0x83, 0x27, 0x0a, 0x7f, 0xf0, 0xe6 }, { 0x77, 0xdd, 0x77, 0x02, 0x64, 0x6d, 0x55, 0xf0, 0x83, 0x65, 0xe4, 0x77, 0xd3, 0x59, 0x0e, 0xda }, { 0x4c, 0x02, 0x2a, 0xc6, 0x2b, 0x3c, 0xb7, 0x8d, 0x73, 0x9c, 0xc6, 0x7b, 0x3e, 0x20, 0xbb, 0x7e }, { 0x09, 0x2f, 0xa1, 0x37, 0xce, 0x18, 0xb5, 0xdf, 0xe7, 0x90, 0x6f, 0x55, 0x0b, 0xb1, 0x33, 0x70 }, { 0x3e, 0x0c, 0xda, 0xdf, 0x2e, 0x68, 0x35, 0x3c, 0x00, 0x27, 0x67, 0x2c, 0x97, 0x14, 0x4d, 0xd3 }, { 0xd8, 0xc4, 0xb2, 0x00, 0xb3, 0x83, 0xfc, 0x1f, 0x2b, 0x2e, 0xa6, 0x77, 0x61, 0x8a, 0x1d, 0x27 }, { 0x11, 0x82, 0x5f, 0x99, 0xb0, 0xe9, 0xbb, 0x34, 0x77, 0xc1, 0xc0, 0x71, 0x3b, 0x01, 0x5a, 0xac }, { 0xf8, 0xb9, 0xff, 0xfb, 0x5c, 0x18, 0x7f, 0x7d, 0xdc, 0x7a, 0xb1, 0x0f, 0x4f, 0xb7, 0x75, 0x76 }, { 0xff, 0xb4, 0xe8, 0x7a, 0x32, 0xb3, 0x7d, 0x6f, 0x2c, 0x83, 0x28, 0xd3, 0xb5, 0x37, 0x78, 0x02 }, { 0xd2, 0x76, 0xc1, 0x3a, 0x5d, 0x22, 0x0f, 0x4d, 0xa9, 0x22, 0x4e, 0x74, 0x89, 0x63, 0x91, 0xce }, { 0x94, 0xef, 0xe7, 0xa0, 0xe2, 0xe0, 0x31, 0xe2, 0x53, 0x6d, 0xa0, 0x1d, 0xf7, 0x99, 0xc9, 0x27 }, { 0x8f, 0x8f, 0xd8, 0x22, 0x68, 0x0a, 0x85, 0x97, 0x4e, 0x53, 0xa5, 0xa8, 0xeb, 0x9d, 0x38, 0xde }, { 0xe0, 0xf0, 0xa9, 0x1b, 0x2e, 0x45, 0xf8, 0xcc, 0x37, 0xb7, 0x80, 0x5a, 0x30, 0x42, 0x58, 0x8d }, { 0x59, 0x7a, 0x62, 0x52, 0x25, 0x5e, 0x46, 0xd6, 0x36, 0x4d, 0xbe, 0xed, 0xa3, 0x1e, 0x27, 0x9c }, { 0xf5, 0x1a, 0x0f, 0x69, 0x44, 0x42, 0xb8, 0xf0, 0x55, 0x71, 0x79, 0x7f, 0xec, 0x7e, 0xe8, 0xbf }, { 0x9f, 0xf0, 0x71, 0xb1, 0x65, 0xb5, 0x19, 0x8a, 0x93, 0xdd, 0xde, 0xeb, 0xc5, 0x4d, 0x09, 0xb5 }, { 0xc2, 0x0a, 0x19, 0xfd, 0x57, 0x58, 0xb0, 0xc4, 0xbc, 0x1a, 0x5d, 0xf8, 0x9c, 0xf7, 0x38, 0x77 }, { 0x97, 0x12, 0x01, 0x66, 0x30, 0x71, 0x19, 0xca, 0x22, 0x80, 0xe9, 0x31, 0x56, 0x68, 0xe9, 0x6f }, { 0x4b, 0x3b, 0x9f, 0x1e, 0x09, 0x9c, 0x2a, 0x09, 0xdc, 0x09, 0x1e, 0x90, 0xe4, 0xf1, 0x8f, 0x0a }, { 0xeb, 0x04, 0x0b, 0x89, 0x1d, 0x4b, 0x37, 0xf6, 0x85, 0x1f, 0x7e, 0xc2, 0x19, 0xcd, 0x3f, 0x6d }, { 0x9f, 0x0f, 0xde, 0xc0, 0x8b, 0x7f, 0xd7, 0x9a, 0xa3, 0x95, 0x35, 0xbe, 0xa4, 0x2d, 0xb9, 0x2a }, { 0x2e, 0x70, 0xf1, 0x68, 0xfc, 0x74, 0xbf, 0x91, 0x1d, 0xf2, 0x40, 0xbc, 0xd2, 0xce, 0xf2, 0x36 }, { 0x46, 0x2c, 0xcd, 0x7f, 0x5f, 0xd1, 0x10, 0x8d, 0xbc, 0x15, 0x2f, 0x3c, 0xac, 0xad, 0x32, 0x8b }, { 0xa4, 0xaf, 0x53, 0x4a, 0x7d, 0x0b, 0x64, 0x3a, 0x01, 0x86, 0x87, 0x85, 0xd8, 0x6d, 0xfb, 0x95 }, { 0xab, 0x98, 0x02, 0x96, 0x19, 0x7e, 0x1a, 0x50, 0x22, 0x32, 0x6c, 0x31, 0xda, 0x4b, 0xf6, 0xf3 }, { 0xf9, 0x7d, 0x57, 0xb3, 0x33, 0x3b, 0x62, 0x81, 0xb0, 0x7d, 0x48, 0x6d, 0xb2, 0xd4, 0xe2, 0x0c }, { 0xf3, 0x3f, 0xa3, 0x67, 0x20, 0x23, 0x1a, 0xfe, 0x4c, 0x75, 0x9a, 0xde, 0x6b, 0xd6, 0x2e, 0xb6 }, { 0xfd, 0xcf, 0xac, 0x0c, 0x02, 0xca, 0x53, 0x83, 0x43, 0xc6, 0x81, 0x17, 0xe0, 0xa1, 0x59, 0x38 }, { 0xad, 0x49, 0x16, 0xf5, 0xee, 0x57, 0x72, 0xbe, 0x76, 0x4f, 0xc0, 0x27, 0xb8, 0xa6, 0xe5, 0x39 }, { 0x2e, 0x16, 0x87, 0x3e, 0x16, 0x78, 0x61, 0x0d, 0x7e, 0x14, 0xc0, 0x2d, 0x00, 0x2e, 0xa8, 0x45 }, { 0x4e, 0x6e, 0x62, 0x7c, 0x1a, 0xcc, 0x51, 0x34, 0x00, 0x53, 0xa8, 0x23, 0x6d, 0x57, 0x95, 0x76 }, { 0xab, 0x0c, 0x84, 0x10, 0xae, 0xee, 0xad, 0x92, 0xfe, 0xec, 0x1e, 0xb4, 0x30, 0xd6, 0x52, 0xcb }, { 0xe8, 0x6f, 0x7e, 0x23, 0xe8, 0x35, 0xe1, 0x14, 0x97, 0x7f, 0x60, 0xe1, 0xa5, 0x92, 0x20, 0x2e }, { 0xe6, 0x8a, 0xd5, 0x05, 0x5a, 0x36, 0x70, 0x41, 0xfa, 0xde, 0x09, 0xd9, 0xa7, 0x0a, 0x79, 0x4b }, { 0x07, 0x91, 0x82, 0x3a, 0x3c, 0x66, 0x6b, 0xb6, 0x16, 0x28, 0x25, 0xe7, 0x86, 0x06, 0xa7, 0xfe }, { 0xdc, 0xca, 0x36, 0x6a, 0x9b, 0xf4, 0x7b, 0x7b, 0x86, 0x8b, 0x77, 0xe2, 0x5c, 0x18, 0xa3, 0x64 }, { 0x68, 0x4c, 0x9e, 0xfc, 0x23, 0x7e, 0x4a, 0x44, 0x29, 0x65, 0xf8, 0x4b, 0xce, 0x20, 0x24, 0x7a }, { 0xa8, 0x58, 0x41, 0x1f, 0xfb, 0xe6, 0x3f, 0xdb, 0x9c, 0x8a, 0xa1, 0xbf, 0xae, 0xd6, 0x7b, 0x52 }, { 0x04, 0xbc, 0x3d, 0xa2, 0x17, 0x9c, 0x30, 0x15, 0x49, 0x8b, 0x0e, 0x03, 0x91, 0x0d, 0xb5, 0xb8 }, { 0x40, 0x07, 0x1e, 0xea, 0xb3, 0xf9, 0x35, 0xdb, 0xc2, 0x5d, 0x00, 0x84, 0x14, 0x60, 0x26, 0x0f }, { 0x0e, 0xbd, 0x7c, 0x30, 0xed, 0x20, 0x16, 0xe0, 0x8b, 0xa8, 0x06, 0xdd, 0xb0, 0x08, 0xbc, 0xc8 }, { 0x15, 0xc6, 0xbe, 0xcf, 0x0f, 0x4c, 0xec, 0x71, 0x29, 0xcb, 0xd2, 0x2d, 0x1a, 0x79, 0xb1, 0xb8 }, { 0x0a, 0xee, 0xde, 0x5b, 0x91, 0xf7, 0x21, 0x70, 0x0e, 0x9e, 0x62, 0xed, 0xbf, 0x60, 0xb7, 0x81 }, { 0x26, 0x65, 0x81, 0xaf, 0x0d, 0xcf, 0xbe, 0xd1, 0x58, 0x5e, 0x0a, 0x24, 0x2c, 0x64, 0xb8, 0xdf }, { 0x66, 0x93, 0xdc, 0x91, 0x16, 0x62, 0xae, 0x47, 0x32, 0x16, 0xba, 0x22, 0x18, 0x9a, 0x51, 0x1a }, { 0x76, 0x06, 0xfa, 0x36, 0xd8, 0x64, 0x73, 0xe6, 0xfb, 0x3a, 0x1b, 0xb0, 0xe2, 0xc0, 0xad, 0xf5 }, { 0x11, 0x20, 0x78, 0xe9, 0xe1, 0x1f, 0xbb, 0x78, 0xe2, 0x6f, 0xfb, 0x88, 0x99, 0xe9, 0x6b, 0x9a }, { 0x40, 0xb2, 0x64, 0xe9, 0x21, 0xe9, 0xe4, 0xa8, 0x26, 0x94, 0x58, 0x9e, 0xf3, 0x79, 0x82, 0x62 }, { 0x8d, 0x45, 0x95, 0xcb, 0x4f, 0xa7, 0x02, 0x67, 0x15, 0xf5, 0x5b, 0xd6, 0x8e, 0x28, 0x82, 0xf9 }, { 0xb5, 0x88, 0xa3, 0x02, 0xbd, 0xbc, 0x09, 0x19, 0x7d, 0xf1, 0xed, 0xae, 0x68, 0x92, 0x6e, 0xd9 }, { 0x33, 0xf7, 0x50, 0x23, 0x90, 0xb8, 0xa4, 0xa2, 0x21, 0xcf, 0xec, 0xd0, 0x66, 0x66, 0x24, 0xba }, { 0x3d, 0x20, 0x25, 0x3a, 0xdb, 0xce, 0x3b, 0xe2, 0x37, 0x37, 0x67, 0xc4, 0xd8, 0x22, 0xc5, 0x66 }, { 0xa4, 0x27, 0x34, 0xa3, 0x92, 0x9b, 0xf8, 0x4c, 0xf0, 0x11, 0x6c, 0x98, 0x56, 0xa3, 0xc1, 0x8c }, { 0xe3, 0xab, 0xc4, 0x93, 0x94, 0x57, 0x42, 0x2b, 0xb9, 0x57, 0xda, 0x3c, 0x56, 0x93, 0x8c, 0x6d }, { 0x97, 0x2b, 0xdd, 0x2e, 0x7c, 0x52, 0x51, 0x30, 0xfa, 0xdc, 0x8f, 0x76, 0xfc, 0x6f, 0x4b, 0x3f }, { 0x84, 0xa8, 0x3d, 0x7b, 0x94, 0xc6, 0x99, 0xcb, 0xcb, 0x8a, 0x7d, 0x9b, 0x61, 0xf6, 0x40, 0x93 }, { 0xce, 0x61, 0xd6, 0x35, 0x14, 0xad, 0xed, 0x03, 0xd4, 0x3e, 0x6e, 0xbf, 0xc3, 0xa9, 0x00, 0x1f }, { 0x6c, 0x83, 0x9d, 0xd5, 0x8e, 0xea, 0xe6, 0xb8, 0xa3, 0x6a, 0xf4, 0x8e, 0xd6, 0x3d, 0x2d, 0xc9 }, { 0xcd, 0x5e, 0xce, 0x55, 0xb8, 0xda, 0x3b, 0xf6, 0x22, 0xc4, 0x10, 0x0d, 0xf5, 0xde, 0x46, 0xf9 }, { 0x3b, 0x6f, 0x46, 0xf4, 0x0e, 0x0a, 0xc5, 0xfc, 0x0a, 0x9c, 0x11, 0x05, 0xf8, 0x00, 0xf4, 0x8d }, { 0xba, 0x26, 0xd4, 0x7d, 0xa3, 0xae, 0xb0, 0x28, 0xde, 0x4f, 0xb5, 0xb3, 0xa8, 0x54, 0xa2, 0x4b }, { 0x87, 0xf5, 0x3b, 0xf6, 0x20, 0xd3, 0x67, 0x72, 0x68, 0x44, 0x52, 0x12, 0x90, 0x43, 0x89, 0xd5 }, { 0x10, 0x61, 0x7d, 0x28, 0xb5, 0xe0, 0xf4, 0x60, 0x54, 0x92, 0xb1, 0x82, 0xa5, 0xd7, 0xf9, 0xf6 }, { 0x9a, 0xae, 0xc4, 0xfa, 0xbb, 0xf6, 0xfa, 0xe2, 0xa7, 0x1f, 0xef, 0xf0, 0x2e, 0x37, 0x2b, 0x39 }, { 0x3a, 0x90, 0xc6, 0x2d, 0x88, 0xb5, 0xc4, 0x28, 0x09, 0xab, 0xf7, 0x82, 0x48, 0x8e, 0xd1, 0x30 }, { 0xf1, 0xf1, 0xc5, 0xa4, 0x08, 0x99, 0xe1, 0x57, 0x72, 0x85, 0x7c, 0xcb, 0x65, 0xc7, 0xa0, 0x9a }, { 0x19, 0x08, 0x43, 0xd2, 0x9b, 0x25, 0xa3, 0x89, 0x7c, 0x69, 0x2c, 0xe1, 0xdd, 0x81, 0xee, 0x52 }, { 0xa8, 0x66, 0xbc, 0x65, 0xb6, 0x94, 0x1d, 0x86, 0xe8, 0x42, 0x0a, 0x7f, 0xfb, 0x09, 0x64, 0xdb }, { 0x81, 0x93, 0xc6, 0xff, 0x85, 0x22, 0x5c, 0xed, 0x42, 0x55, 0xe9, 0x2f, 0x6e, 0x07, 0x8a, 0x14 }, { 0x96, 0x61, 0xcb, 0x24, 0x24, 0xd7, 0xd4, 0xa3, 0x80, 0xd5, 0x47, 0xf9, 0xe7, 0xec, 0x1c, 0xb9 }, { 0x86, 0xf9, 0x3d, 0x9e, 0xc0, 0x84, 0x53, 0xa0, 0x71, 0xe2, 0xe2, 0x87, 0x78, 0x77, 0xa9, 0xc8 }, { 0x27, 0xee, 0xfa, 0x80, 0xce, 0x6a, 0x4a, 0x9d, 0x59, 0x8e, 0x3f, 0xec, 0x36, 0x54, 0x34, 0xd2 }, { 0xd6, 0x20, 0x68, 0x44, 0x45, 0x78, 0xe3, 0xab, 0x39, 0xce, 0x7e, 0xc9, 0x5d, 0xd0, 0x45, 0xdc }, { 0xb5, 0xf7, 0x1d, 0x4d, 0xd9, 0xa7, 0x1f, 0xe5, 0xd8, 0xbc, 0x8b, 0xa7, 0xe6, 0xea, 0x30, 0x48 }, { 0x68, 0x25, 0xa3, 0x47, 0xac, 0x47, 0x9d, 0x4f, 0x9d, 0x95, 0xc5, 0xcb, 0x8d, 0x3f, 0xd7, 0xe9 }, { 0xe3, 0x71, 0x4e, 0x94, 0xa5, 0x77, 0x89, 0x55, 0xcc, 0x03, 0x46, 0x35, 0x8e, 0x94, 0x78, 0x3a }, { 0xd8, 0x36, 0xb4, 0x4b, 0xb2, 0x9e, 0x0c, 0x7d, 0x89, 0xfa, 0x4b, 0x2d, 0x4b, 0x67, 0x7d, 0x2a }, { 0x5d, 0x45, 0x4b, 0x75, 0x02, 0x1d, 0x76, 0xd4, 0xb8, 0x4f, 0x87, 0x3a, 0x8f, 0x87, 0x7b, 0x92 }, { 0xc3, 0x49, 0x8f, 0x7e, 0xce, 0xd2, 0x09, 0x53, 0x14, 0xfc, 0x28, 0x11, 0x58, 0x85, 0xb3, 0x3f }, { 0x6e, 0x66, 0x88, 0x56, 0x53, 0x9a, 0xd8, 0xe4, 0x05, 0xbd, 0x12, 0x3f, 0xe6, 0xc8, 0x85, 0x30 }, { 0x86, 0x80, 0xdb, 0x7f, 0x3a, 0x87, 0xb8, 0x60, 0x55, 0x43, 0xcf, 0xdb, 0xe6, 0x75, 0x40, 0x76 }, { 0x6c, 0x5d, 0x03, 0xb1, 0x30, 0x69, 0xc3, 0x65, 0x8b, 0x31, 0x79, 0xbe, 0x91, 0xb0, 0x80, 0x0c }, { 0xef, 0x1b, 0x38, 0x4a, 0xc4, 0xd9, 0x3e, 0xda, 0x00, 0xc9, 0x2a, 0xdd, 0x09, 0x95, 0xea, 0x5f }, { 0xbf, 0x81, 0x15, 0x80, 0x54, 0x71, 0x74, 0x1b, 0xd5, 0xad, 0x20, 0xa0, 0x39, 0x44, 0x79, 0x0f }, { 0xc6, 0x4c, 0x24, 0xb6, 0x89, 0x4b, 0x03, 0x8b, 0x3c, 0x0d, 0x09, 0xb1, 0xdf, 0x06, 0x8b, 0x0b }, { 0x39, 0x67, 0xa1, 0x0c, 0xff, 0xe2, 0x7d, 0x01, 0x78, 0x54, 0x5f, 0xbf, 0x6a, 0x40, 0x54, 0x4b }, { 0x7c, 0x85, 0xe9, 0xc9, 0x5d, 0xe1, 0xa9, 0xec, 0x5a, 0x53, 0x63, 0xa8, 0xa0, 0x53, 0x47, 0x2d }, { 0xa9, 0xee, 0xc0, 0x3c, 0x8a, 0xbe, 0xc7, 0xba, 0x68, 0x31, 0x5c, 0x2c, 0x8c, 0x23, 0x16, 0xe0 }, { 0xca, 0xc8, 0xe4, 0x14, 0xc2, 0xf3, 0x88, 0x22, 0x7a, 0xe1, 0x49, 0x86, 0xfc, 0x98, 0x35, 0x24 }, { 0x5d, 0x94, 0x2b, 0x7f, 0x46, 0x22, 0xce, 0x05, 0x6c, 0x3c, 0xe3, 0xce, 0x5f, 0x1d, 0xd9, 0xd6 }, { 0xd2, 0x40, 0xd6, 0x48, 0xce, 0x21, 0xa3, 0x02, 0x02, 0x82, 0xc3, 0xf1, 0xb5, 0x28, 0xa0, 0xb6 }, { 0x45, 0xd0, 0x89, 0xc3, 0x6d, 0x5c, 0x5a, 0x4e, 0xfc, 0x68, 0x9e, 0x3b, 0x0d, 0xe1, 0x0d, 0xd5 }, { 0xb4, 0xda, 0x5d, 0xf4, 0xbe, 0xcb, 0x54, 0x62, 0xe0, 0x3a, 0x0e, 0xd0, 0x0d, 0x29, 0x56, 0x29 }, { 0xdc, 0xf4, 0xe1, 0x29, 0x13, 0x6c, 0x1a, 0x4b, 0x7a, 0x0f, 0x38, 0x93, 0x5c, 0xc3, 0x4b, 0x2b }, { 0xd9, 0xa4, 0xc7, 0x61, 0x8b, 0x0c, 0xe4, 0x8a, 0x3d, 0x5a, 0xee, 0x1a, 0x1c, 0x01, 0x14, 0xc4 }, { 0xca, 0x35, 0x2d, 0xf0, 0x25, 0xc6, 0x5c, 0x7b, 0x0b, 0xf3, 0x06, 0xfb, 0xee, 0x0f, 0x36, 0xba }, { 0x23, 0x8a, 0xca, 0x23, 0xfd, 0x34, 0x09, 0xf3, 0x8a, 0xf6, 0x33, 0x78, 0xed, 0x2f, 0x54, 0x73 }, { 0x59, 0x83, 0x6a, 0x0e, 0x06, 0xa7, 0x96, 0x91, 0xb3, 0x66, 0x67, 0xd5, 0x38, 0x0d, 0x81, 0x88 }, { 0x33, 0x90, 0x50, 0x80, 0xf7, 0xac, 0xf1, 0xcd, 0xae, 0x0a, 0x91, 0xfc, 0x3e, 0x85, 0xae, 0xe4 }, { 0x72, 0xc9, 0xe4, 0x64, 0x6d, 0xbc, 0x3d, 0x63, 0x20, 0xfc, 0x66, 0x89, 0xd9, 0x3e, 0x88, 0x33 }, { 0xba, 0x77, 0x41, 0x3d, 0xea, 0x59, 0x25, 0xb7, 0xf5, 0x41, 0x7e, 0xa4, 0x7f, 0xf1, 0x9f, 0x59 }, { 0x6c, 0xae, 0x81, 0x29, 0xf8, 0x43, 0xd8, 0x6d, 0xc7, 0x86, 0xa0, 0xfb, 0x1a, 0x18, 0x49, 0x70 }, { 0xfc, 0xfe, 0xfb, 0x53, 0x41, 0x00, 0x79, 0x6e, 0xeb, 0xbd, 0x99, 0x02, 0x06, 0x75, 0x4e, 0x19 }, { 0x8c, 0x79, 0x1d, 0x5f, 0xdd, 0xdf, 0x47, 0x0d, 0xa0, 0x4f, 0x3e, 0x6d, 0xc4, 0xa5, 0xb5, 0xb5 }, { 0xc9, 0x3b, 0xbd, 0xc0, 0x7a, 0x46, 0x11, 0xae, 0x4b, 0xb2, 0x66, 0xea, 0x50, 0x34, 0xa3, 0x87 }, { 0xc1, 0x02, 0xe3, 0x8e, 0x48, 0x9a, 0xa7, 0x47, 0x62, 0xf3, 0xef, 0xc5, 0xbb, 0x23, 0x20, 0x5a }, { 0x93, 0x20, 0x14, 0x81, 0x66, 0x5c, 0xba, 0xfc, 0x1f, 0xcc, 0x22, 0x0b, 0xc5, 0x45, 0xfb, 0x3d }, { 0x49, 0x60, 0x75, 0x7e, 0xc6, 0xce, 0x68, 0xcf, 0x19, 0x5e, 0x45, 0x4c, 0xfd, 0x0f, 0x32, 0xca }, { 0xfe, 0xec, 0x7c, 0xe6, 0xa6, 0xcb, 0xd0, 0x7c, 0x04, 0x34, 0x16, 0x73, 0x7f, 0x1b, 0xbb, 0x33 }, { 0x11, 0xc5, 0x41, 0x39, 0x04, 0x48, 0x7a, 0x80, 0x5d, 0x70, 0xa8, 0xed, 0xd9, 0xc3, 0x55, 0x27 }, { 0x34, 0x78, 0x46, 0xb2, 0xb2, 0xe3, 0x6f, 0x1f, 0x03, 0x24, 0xc8, 0x6f, 0x7f, 0x1b, 0x98, 0xe2 }, { 0x33, 0x2e, 0xee, 0x1a, 0x0c, 0xbd, 0x19, 0xca, 0x2d, 0x69, 0xb4, 0x26, 0x89, 0x40, 0x44, 0xf0 }, { 0x86, 0x6b, 0x5b, 0x39, 0x77, 0xba, 0x6e, 0xfa, 0x51, 0x28, 0xef, 0xbd, 0xa9, 0xff, 0x03, 0xcd }, { 0xcc, 0x14, 0x45, 0xee, 0x94, 0xc0, 0xf0, 0x8c, 0xde, 0xe5, 0xc3, 0x44, 0xec, 0xd1, 0xe2, 0x33 }, { 0xbe, 0x28, 0x83, 0x19, 0x02, 0x93, 0x63, 0xc2, 0x62, 0x2f, 0xeb, 0xa4, 0xb0, 0x5d, 0xfd, 0xfe }, { 0xcf, 0xd1, 0x87, 0x55, 0x23, 0xf3, 0xcd, 0x21, 0xc3, 0x95, 0x65, 0x1e, 0x6e, 0xe1, 0x5e, 0x56 }, { 0xcb, 0x5a, 0x40, 0x86, 0x57, 0x83, 0x7c, 0x53, 0xbf, 0x16, 0xf9, 0xd8, 0x46, 0x5d, 0xce, 0x19 }, { 0xca, 0x0b, 0xf4, 0x2c, 0xb1, 0x07, 0xf5, 0x5c, 0xcf, 0xf2, 0xfc, 0x09, 0xee, 0x08, 0xca, 0x15 }, { 0xfd, 0xd9, 0xbb, 0xb4, 0xa7, 0xdc, 0x2e, 0x4a, 0x23, 0x53, 0x6a, 0x58, 0x80, 0xa2, 0xdb, 0x67 }, { 0xed, 0xe4, 0x47, 0xb3, 0x62, 0xc4, 0x84, 0x99, 0x3d, 0xec, 0x94, 0x42, 0xa3, 0xb4, 0x6a, 0xef }, { 0x10, 0xdf, 0xfb, 0x05, 0x90, 0x4b, 0xff, 0x7c, 0x47, 0x81, 0xdf, 0x78, 0x0a, 0xd2, 0x68, 0x37 }, { 0xc3, 0x3b, 0xc1, 0x3e, 0x8d, 0xe8, 0x8a, 0xc2, 0x52, 0x32, 0xaa, 0x74, 0x96, 0x39, 0x87, 0x83 }, { 0xca, 0x35, 0x9c, 0x70, 0x80, 0x3a, 0x3b, 0x2a, 0x3d, 0x54, 0x2e, 0x87, 0x81, 0xde, 0xa9, 0x75 }, { 0xbc, 0xc6, 0x5b, 0x52, 0x6f, 0x88, 0xd0, 0x5b, 0x89, 0xce, 0x8a, 0x52, 0x02, 0x1f, 0xdb, 0x06 }, { 0xdb, 0x91, 0xa3, 0x88, 0x55, 0xc8, 0xc4, 0x64, 0x38, 0x51, 0xfb, 0xfb, 0x35, 0x8b, 0x01, 0x09 }, { 0xca, 0x6e, 0x88, 0x93, 0xa1, 0x14, 0xae, 0x8e, 0x27, 0xd5, 0xab, 0x03, 0xa5, 0x49, 0x96, 0x10 }, { 0x66, 0x29, 0xd2, 0xb8, 0xdf, 0x97, 0xda, 0x72, 0x8c, 0xdd, 0x8b, 0x1e, 0x7f, 0x94, 0x50, 0x77 }, { 0x45, 0x70, 0xa5, 0xa1, 0x8c, 0xfc, 0x0d, 0xd5, 0x82, 0xf1, 0xd8, 0x8d, 0x5c, 0x9a, 0x17, 0x20 }, { 0x72, 0xbc, 0x65, 0xaa, 0x8e, 0x89, 0x56, 0x2e, 0x3f, 0x27, 0x4d, 0x45, 0xaf, 0x1c, 0xd1, 0x0b }, { 0x98, 0x55, 0x1d, 0xa1, 0xa6, 0x50, 0x32, 0x76, 0xae, 0x1c, 0x77, 0x62, 0x5f, 0x9e, 0xa6, 0x15 }, { 0x0d, 0xdf, 0xe5, 0x1c, 0xed, 0x7e, 0x3f, 0x4a, 0xe9, 0x27, 0xda, 0xa3, 0xfe, 0x45, 0x2c, 0xee }, { 0xdb, 0x82, 0x62, 0x51, 0xe4, 0xce, 0x38, 0x4b, 0x80, 0x21, 0x8b, 0x0e, 0x1d, 0xa1, 0xdd, 0x4c }, { 0x2c, 0xac, 0xf7, 0x28, 0xb8, 0x8a, 0xbb, 0xad, 0x70, 0x11, 0xed, 0x0e, 0x64, 0xa1, 0x68, 0x0c }, { 0x33, 0x0d, 0x8e, 0xe7, 0xc5, 0x67, 0x7e, 0x09, 0x9a, 0xc7, 0x4c, 0x99, 0x94, 0xee, 0x4c, 0xfb }, { 0xed, 0xf6, 0x1a, 0xe3, 0x62, 0xe8, 0x82, 0xdd, 0xc0, 0x16, 0x74, 0x74, 0xa7, 0xa7, 0x7f, 0x3a }, { 0x61, 0x68, 0xb0, 0x0b, 0xa7, 0x85, 0x9e, 0x09, 0x70, 0xec, 0xfd, 0x75, 0x7e, 0xfe, 0xcf, 0x7c }, { 0xd1, 0x41, 0x54, 0x47, 0x86, 0x62, 0x30, 0xd2, 0x8b, 0xb1, 0xea, 0x18, 0xa4, 0xcd, 0xfd, 0x02 }, { 0x51, 0x61, 0x83, 0x39, 0x2f, 0x7a, 0x87, 0x63, 0xaf, 0xec, 0x68, 0xa0, 0x60, 0x26, 0x41, 0x41 }, { 0x77, 0x56, 0x5c, 0x8d, 0x73, 0xcf, 0xd4, 0x13, 0x0b, 0x4a, 0xa1, 0x4d, 0x89, 0x11, 0x71, 0x0f }, { 0x37, 0x23, 0x2a, 0x4e, 0xd2, 0x1c, 0xcc, 0x27, 0xc1, 0x9c, 0x96, 0x10, 0x07, 0x8c, 0xab, 0xac }, { 0x80, 0x4f, 0x32, 0xea, 0x71, 0x82, 0x8c, 0x7d, 0x32, 0x90, 0x77, 0xe7, 0x12, 0x23, 0x16, 0x66 }, { 0xd6, 0x44, 0x24, 0xf2, 0x3c, 0xb9, 0x72, 0x15, 0xe9, 0xc2, 0xc6, 0xf2, 0x8d, 0x29, 0xea, 0xb7 }, { 0x02, 0x3e, 0x82, 0xb5, 0x33, 0xf6, 0x8c, 0x75, 0xc2, 0x38, 0xce, 0xbd, 0xb2, 0xee, 0x89, 0xa2 }, { 0x19, 0x3a, 0x3d, 0x24, 0x15, 0x7a, 0x51, 0xf1, 0xee, 0x08, 0x93, 0xf6, 0x77, 0x74, 0x17, 0xe7 }, { 0x84, 0xec, 0xac, 0xfc, 0xd4, 0x00, 0x08, 0x4d, 0x07, 0x86, 0x12, 0xb1, 0x94, 0x5f, 0x2e, 0xf5 }, { 0x1d, 0xcd, 0x8b, 0xb1, 0x73, 0x25, 0x9e, 0xb3, 0x3a, 0x52, 0x42, 0xb0, 0xde, 0x31, 0xa4, 0x55 }, { 0x35, 0xe9, 0xed, 0xdb, 0xc3, 0x75, 0xe7, 0x92, 0xc1, 0x99, 0x92, 0xc1, 0x91, 0x65, 0x01, 0x2b }, { 0x8a, 0x77, 0x22, 0x31, 0xc0, 0x1d, 0xfd, 0xd7, 0xc9, 0x8e, 0x4c, 0xfd, 0xdc, 0xc0, 0x80, 0x7a }, { 0x6e, 0xda, 0x7f, 0xf6, 0xb8, 0x31, 0x91, 0x80, 0xff, 0x0d, 0x6e, 0x65, 0x62, 0x9d, 0x01, 0xc3 }, { 0xc2, 0x67, 0xef, 0x0e, 0x2d, 0x01, 0xa9, 0x93, 0x94, 0x4d, 0xd3, 0x97, 0x10, 0x14, 0x13, 0xcb }, { 0xe9, 0xf8, 0x0e, 0x9d, 0x84, 0x5b, 0xcc, 0x0f, 0x62, 0x92, 0x6a, 0xf7, 0x2e, 0xab, 0xca, 0x39 }, { 0x67, 0x02, 0x99, 0x07, 0x27, 0xaa, 0x08, 0x78, 0x63, 0x7b, 0x45, 0xdc, 0xd3, 0xa3, 0xb0, 0x74 }, { 0x2e, 0x2e, 0x64, 0x7d, 0x53, 0x60, 0xe0, 0x92, 0x30, 0xa5, 0xd7, 0x38, 0xca, 0x33, 0x47, 0x1e }, { 0x1f, 0x56, 0x41, 0x3c, 0x7a, 0xdd, 0x6f, 0x43, 0xd1, 0xd5, 0x6e, 0x4f, 0x02, 0x19, 0x03, 0x30 }, { 0x69, 0xcd, 0x06, 0x06, 0xe1, 0x5a, 0xf7, 0x29, 0xd6, 0xbc, 0xa1, 0x43, 0x01, 0x6d, 0x98, 0x42 }, { 0xa0, 0x85, 0xd7, 0xc1, 0xa5, 0x00, 0x87, 0x3a, 0x20, 0x09, 0x9c, 0x4c, 0xaa, 0x3c, 0x3f, 0x5b }, { 0x4f, 0xc0, 0xd2, 0x30, 0xf8, 0x89, 0x14, 0x15, 0xb8, 0x7b, 0x83, 0xf9, 0x5f, 0x2e, 0x09, 0xd1 }, { 0x43, 0x27, 0xd0, 0x8c, 0x52, 0x3d, 0x8e, 0xba, 0x69, 0x7a, 0x43, 0x36, 0x50, 0x7d, 0x1f, 0x42 }, { 0x7a, 0x15, 0xaa, 0xb8, 0x27, 0x01, 0xef, 0xa5, 0xae, 0x36, 0xab, 0x1d, 0x6b, 0x76, 0x29, 0x0f }, { 0x5b, 0xf0, 0x05, 0x18, 0x93, 0xa1, 0x8b, 0xb3, 0x0e, 0x13, 0x9a, 0x58, 0xfe, 0xd0, 0xfa, 0x54 }, { 0x97, 0xe8, 0xad, 0xf6, 0x56, 0x38, 0xfd, 0x9c, 0xdf, 0x3b, 0xc2, 0x2c, 0x17, 0xfe, 0x4d, 0xbd }, { 0x1e, 0xe6, 0xee, 0x32, 0x65, 0x83, 0xa0, 0x58, 0x64, 0x91, 0xc9, 0x64, 0x18, 0xd1, 0xa3, 0x5d }, { 0x26, 0xb5, 0x49, 0xc2, 0xec, 0x75, 0x6f, 0x82, 0xec, 0xc4, 0x80, 0x08, 0xe5, 0x29, 0x95, 0x6b }, { 0x70, 0x37, 0x7b, 0x6d, 0xa6, 0x69, 0xb0, 0x72, 0x12, 0x9e, 0x05, 0x7c, 0xc2, 0x8e, 0x9c, 0xa5 }, { 0x9c, 0x94, 0xb8, 0xb0, 0xcb, 0x8b, 0xcc, 0x91, 0x90, 0x72, 0x26, 0x2b, 0x3f, 0xa0, 0x5a, 0xd9 }, { 0x2f, 0xbb, 0x83, 0xdf, 0xd0, 0xd7, 0xab, 0xcb, 0x05, 0xcd, 0x28, 0xca, 0xd2, 0xdf, 0xb5, 0x23 }, { 0x96, 0x87, 0x78, 0x03, 0xde, 0x77, 0x74, 0x4b, 0xb9, 0x70, 0xd0, 0xa9, 0x1f, 0x4d, 0xeb, 0xae }, { 0x73, 0x79, 0xf3, 0x37, 0x0c, 0xf6, 0xe5, 0xce, 0x12, 0xae, 0x59, 0x69, 0xc8, 0xee, 0xa3, 0x12 }, { 0x02, 0xdc, 0x99, 0xfa, 0x3d, 0x4f, 0x98, 0xce, 0x80, 0x98, 0x5e, 0x72, 0x33, 0x88, 0x93, 0x13 }, { 0x1e, 0x38, 0xe7, 0x59, 0x07, 0x5b, 0xa5, 0xca, 0xb6, 0x45, 0x7d, 0xa5, 0x18, 0x44, 0x29, 0x5a }, { 0x70, 0xbe, 0xd8, 0xdb, 0xf6, 0x15, 0x86, 0x8a, 0x1f, 0x9d, 0x9b, 0x05, 0xd3, 0xe7, 0xa2, 0x67 }, { 0x23, 0x4b, 0x14, 0x8b, 0x8c, 0xb1, 0xd8, 0xc3, 0x2b, 0x28, 0x7e, 0x89, 0x69, 0x03, 0xd1, 0x50 }, { 0x29, 0x4b, 0x03, 0x3d, 0xf4, 0xda, 0x85, 0x3f, 0x4b, 0xe3, 0xe2, 0x43, 0xf7, 0xe5, 0x13, 0xf4 }, { 0x3f, 0x58, 0xc9, 0x50, 0xf0, 0x36, 0x71, 0x60, 0xad, 0xec, 0x45, 0xf2, 0x44, 0x1e, 0x74, 0x11 }, { 0x37, 0xf6, 0x55, 0x53, 0x6a, 0x70, 0x4e, 0x5a, 0xce, 0x18, 0x2d, 0x74, 0x2a, 0x82, 0x0c, 0xf4 }, { 0xea, 0x7b, 0xd6, 0xbb, 0x63, 0x41, 0x87, 0x31, 0xae, 0xac, 0x79, 0x0f, 0xe4, 0x2d, 0x61, 0xe8 }, { 0xe7, 0x4a, 0x4c, 0x99, 0x9b, 0x4c, 0x06, 0x4e, 0x48, 0xbb, 0x1e, 0x41, 0x3f, 0x51, 0xe5, 0xea }, { 0xba, 0x9e, 0xbe, 0xfd, 0xb4, 0xcc, 0xf3, 0x0f, 0x29, 0x6c, 0xec, 0xb3, 0xbc, 0x19, 0x43, 0xe8 }, { 0x31, 0x94, 0x36, 0x7a, 0x48, 0x98, 0xc5, 0x02, 0xc1, 0x3b, 0xb7, 0x47, 0x86, 0x40, 0xa7, 0x2d }, { 0xda, 0x79, 0x77, 0x13, 0x26, 0x3d, 0x6f, 0x33, 0xa5, 0x47, 0x8a, 0x65, 0xef, 0x60, 0xd4, 0x12 }, { 0xd1, 0xac, 0x39, 0xbb, 0x1e, 0xf8, 0x6b, 0x9c, 0x13, 0x44, 0xf2, 0x14, 0x67, 0x9a, 0xa3, 0x76 }, { 0x2f, 0xde, 0xa9, 0xe6, 0x50, 0x53, 0x2b, 0xe5, 0xbc, 0x0e, 0x73, 0x25, 0x33, 0x7f, 0xd3, 0x63 }, { 0xd3, 0xa2, 0x04, 0xdb, 0xd9, 0xc2, 0xaf, 0x15, 0x8b, 0x6c, 0xa6, 0x7a, 0x51, 0x56, 0xce, 0x4a }, { 0x3a, 0x0a, 0x0e, 0x75, 0xa8, 0xda, 0x36, 0x73, 0x5a, 0xee, 0x66, 0x84, 0xd9, 0x65, 0xa7, 0x78 }, { 0x52, 0xfc, 0x3e, 0x62, 0x04, 0x92, 0xea, 0x99, 0x64, 0x1e, 0xa1, 0x68, 0xda, 0x5b, 0x6d, 0x52 }, { 0xd2, 0xe0, 0xc7, 0xf1, 0x5b, 0x47, 0x72, 0x46, 0x7d, 0x2c, 0xfc, 0x87, 0x30, 0x00, 0xb2, 0xca }, { 0x56, 0x35, 0x31, 0x13, 0x5e, 0x0c, 0x4d, 0x70, 0xa3, 0x8f, 0x8b, 0xdb, 0x19, 0x0b, 0xa0, 0x4e }, { 0xa8, 0xa3, 0x9a, 0x0f, 0x56, 0x63, 0xf4, 0xc0, 0xfe, 0x5f, 0x2d, 0x3c, 0xaf, 0xff, 0x42, 0x1a }, { 0xd9, 0x4b, 0x5e, 0x90, 0xdb, 0x35, 0x4c, 0x1e, 0x42, 0xf6, 0x1f, 0xab, 0xe1, 0x67, 0xb2, 0xc0 }, { 0x50, 0xe6, 0xd3, 0xc9, 0xb6, 0x69, 0x8a, 0x7c, 0xd2, 0x76, 0xf9, 0x6b, 0x14, 0x73, 0xf3, 0x5a }, { 0x93, 0x38, 0xf0, 0x8e, 0x0e, 0xbe, 0xe9, 0x69, 0x05, 0xd8, 0xf2, 0xe8, 0x25, 0x20, 0x8f, 0x43 }, { 0x8b, 0x37, 0x8c, 0x86, 0x67, 0x2a, 0xa5, 0x4a, 0x3a, 0x26, 0x6b, 0xa1, 0x9d, 0x25, 0x80, 0xca }, { 0xcc, 0xa7, 0xc3, 0x08, 0x6f, 0x5f, 0x95, 0x11, 0xb3, 0x12, 0x33, 0xda, 0x7c, 0xab, 0x91, 0x60 }, { 0x5b, 0x40, 0xff, 0x4e, 0xc9, 0xbe, 0x53, 0x6b, 0xa2, 0x30, 0x35, 0xfa, 0x4f, 0x06, 0x06, 0x4c }, { 0x60, 0xeb, 0x5a, 0xf8, 0x41, 0x6b, 0x25, 0x71, 0x49, 0x37, 0x21, 0x94, 0xe8, 0xb8, 0x87, 0x49 }, { 0x2f, 0x00, 0x5a, 0x8a, 0xed, 0x8a, 0x36, 0x1c, 0x92, 0xe4, 0x40, 0xc1, 0x55, 0x20, 0xcb, 0xd1 }, { 0x7b, 0x03, 0x62, 0x76, 0x11, 0x67, 0x8a, 0x99, 0x77, 0x17, 0x57, 0x88, 0x07, 0xa8, 0x00, 0xe2 }, { 0xcf, 0x78, 0x61, 0x8f, 0x74, 0xf6, 0xf3, 0x69, 0x6e, 0x0a, 0x47, 0x79, 0xb9, 0x0b, 0x5a, 0x77 }, { 0x03, 0x72, 0x03, 0x71, 0xa0, 0x49, 0x62, 0xea, 0xea, 0x0a, 0x85, 0x2e, 0x69, 0x97, 0x28, 0x58 }, { 0x1f, 0x8a, 0x81, 0x33, 0xaa, 0x8c, 0xcf, 0x70, 0xe2, 0xbd, 0x32, 0x85, 0x83, 0x1c, 0xa6, 0xb7 }, { 0x27, 0x93, 0x6b, 0xd2, 0x7f, 0xb1, 0x46, 0x8f, 0xc8, 0xb4, 0x8b, 0xc4, 0x83, 0x32, 0x17, 0x25 }, { 0xb0, 0x7d, 0x4f, 0x3e, 0x2c, 0xd2, 0xef, 0x2e, 0xb5, 0x45, 0x98, 0x07, 0x54, 0xdf, 0xea, 0x0f }, { 0x4b, 0xf8, 0x5f, 0x1b, 0x5d, 0x54, 0xad, 0xbc, 0x30, 0x7b, 0x0a, 0x04, 0x83, 0x89, 0xad, 0xcb } }; /* Values from NIST KAT-AES CBCVarTxt128.rsp, CBCVarTxt192.rsp and CBCVarTxt256.rsp */ uint8_t plain_texts1[ 128 ][ 16 ] = { { 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe }, { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff } }; uint8_t key[ 32 ] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; uint8_t initialization_vector[ 16 ] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; uint8_t plain_text[ 16 ] = { 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 }; int result = 0; int test_index = 0; CAES_TEST_UNREFERENCED_PARAMETER( argv ) if( argc != 1 ) { fprintf( stderr, "Unsupported number of arguments.\n" ); return( EXIT_FAILURE ); } /* Decryption tests */ fprintf( stdout, "Testing AES-CBC 128-bit decryption\t" ); for( test_index = 0; test_index < 128; test_index++ ) { result = caes_test_crypt_cbc( LIBCAES_CRYPT_MODE_DECRYPT, key, 128, initialization_vector, 16, cipher_texts1_128bit[ test_index ], 16, plain_texts1[ test_index ], 16 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-CBC 128-bit decryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-CBC 128-bit decryption\t" ); for( test_index = 0; test_index < 128; test_index++ ) { result = caes_test_crypt_cbc( LIBCAES_CRYPT_MODE_DECRYPT, keys[ test_index ], 128, initialization_vector, 16, cipher_texts2_128bit[ test_index ], 16, plain_text, 16 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-CBC 128-bit decryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-CBC 192-bit decryption\t" ); for( test_index = 0; test_index < 128; test_index++ ) { result = caes_test_crypt_cbc( LIBCAES_CRYPT_MODE_DECRYPT, key, 192, initialization_vector, 16, cipher_texts1_192bit[ test_index ], 16, plain_texts1[ test_index ], 16 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-CBC 192-bit decryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-CBC 192-bit decryption\t" ); for( test_index = 0; test_index < 192; test_index++ ) { result = caes_test_crypt_cbc( LIBCAES_CRYPT_MODE_DECRYPT, keys[ test_index ], 192, initialization_vector, 16, cipher_texts2_192bit[ test_index ], 16, plain_text, 16 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-CBC 192-bit decryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-CBC 256-bit decryption\t" ); for( test_index = 0; test_index < 128; test_index++ ) { result = caes_test_crypt_cbc( LIBCAES_CRYPT_MODE_DECRYPT, key, 256, initialization_vector, 16, cipher_texts1_256bit[ test_index ], 16, plain_texts1[ test_index ], 16 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-CBC 256-bit decryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-CBC 256-bit decryption\t" ); for( test_index = 0; test_index < 256; test_index++ ) { result = caes_test_crypt_cbc( LIBCAES_CRYPT_MODE_DECRYPT, keys[ test_index ], 256, initialization_vector, 16, cipher_texts2_256bit[ test_index ], 16, plain_text, 16 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-CBC 256-bit decryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } /* Encryption tests */ fprintf( stdout, "Testing AES-CBC 128-bit encryption\t" ); for( test_index = 0; test_index < 128; test_index++ ) { result = caes_test_crypt_cbc( LIBCAES_CRYPT_MODE_ENCRYPT, key, 128, initialization_vector, 16, plain_texts1[ test_index ], 16, cipher_texts1_128bit[ test_index ], 16 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-CBC 128-bit encryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-CBC 128-bit encryption\t" ); for( test_index = 0; test_index < 128; test_index++ ) { result = caes_test_crypt_cbc( LIBCAES_CRYPT_MODE_ENCRYPT, keys[ test_index ], 128, initialization_vector, 16, plain_text, 16, cipher_texts2_128bit[ test_index ], 16 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-CBC 128-bit encryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-CBC 192-bit encryption\t" ); for( test_index = 0; test_index < 128; test_index++ ) { result = caes_test_crypt_cbc( LIBCAES_CRYPT_MODE_ENCRYPT, key, 192, initialization_vector, 16, plain_texts1[ test_index ], 16, cipher_texts1_192bit[ test_index ], 16 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-CBC 192-bit encryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-CBC 192-bit encryption\t" ); for( test_index = 0; test_index < 192; test_index++ ) { result = caes_test_crypt_cbc( LIBCAES_CRYPT_MODE_ENCRYPT, keys[ test_index ], 192, initialization_vector, 16, plain_text, 16, cipher_texts2_192bit[ test_index ], 16 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-CBC 192-bit encryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-CBC 256-bit encryption\t" ); for( test_index = 0; test_index < 128; test_index++ ) { result = caes_test_crypt_cbc( LIBCAES_CRYPT_MODE_ENCRYPT, key, 256, initialization_vector, 16, plain_texts1[ test_index ], 16, cipher_texts1_256bit[ test_index ], 16 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-CBC 256-bit encryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-CBC 256-bit encryption\t" ); for( test_index = 0; test_index < 256; test_index++ ) { result = caes_test_crypt_cbc( LIBCAES_CRYPT_MODE_ENCRYPT, keys[ test_index ], 256, initialization_vector, 16, plain_text, 16, cipher_texts2_256bit[ test_index ], 16 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-CBC 256-bit encryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } return( EXIT_SUCCESS ); } libcaes-20240413/tests/caes_test_crypt_xts.c0000644000175000017500000101511014606473413021621 0ustar00lordyestalordyesta/* * Library AES-XTS de/encryption testing program * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include #include #if defined( HAVE_STDLIB_H ) || defined( WINAPI ) #include #endif #include "caes_test_libcaes.h" #include "caes_test_libcerror.h" #include "caes_test_unused.h" /* Tests AES-XTS de/encryption * Returns 1 if successful, 0 if not or -1 on error */ int caes_test_crypt_xts( int mode, const uint8_t *key, size_t key_bit_size, const uint8_t *tweak_key, size_t tweak_key_bit_size, const uint8_t *tweak_value, size_t tweak_value_size, const uint8_t *input_data, size_t input_data_size, const uint8_t *expected_output_data, size_t expected_output_data_size ) { uint8_t output_data[ 32 ]; libcaes_tweaked_context_t *context = NULL; libcerror_error_t *error = NULL; static char *function = "caes_test_crypt_xts"; size_t output_data_size = 32; int result = 0; if( input_data_size > output_data_size ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_ARGUMENTS, LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS, "%s: invalid input data size value out of bounds.", function ); goto on_error; } if( libcaes_tweaked_context_initialize( &context, &error ) != 1 ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED, "%s: unable to create tweaked context.", function ); goto on_error; } if( libcaes_tweaked_context_set_keys( context, mode, key, key_bit_size, tweak_key, tweak_key_bit_size, &error ) != 1 ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_SET_FAILED, "%s: unable to set key in tweaked context.", function ); goto on_error; } if( libcaes_crypt_xts( context, mode, tweak_value, tweak_value_size, input_data, input_data_size, output_data, output_data_size, &error ) != 1 ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_ENCRYPTION, LIBCERROR_ENCRYPTION_ERROR_GENERIC, "%s: unable to de/encrypt data.", function ); goto on_error; } result = memory_compare( output_data, expected_output_data, expected_output_data_size ); if( libcaes_tweaked_context_free( &context, &error ) != 1 ) { libcerror_error_set( &error, LIBCERROR_ERROR_DOMAIN_RUNTIME, LIBCERROR_RUNTIME_ERROR_FINALIZE_FAILED, "%s: unable to free tweaked context.", function ); goto on_error; } if( result != 0 ) { return( 0 ); } return( 1 ); on_error: if( error != NULL ) { libcerror_error_backtrace_fprint( error, stdout ); libcerror_error_free( &error ); } if( context != NULL ) { libcaes_tweaked_context_free( &context, NULL ); } return( -1 ); } /* The main program */ #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) int wmain( int argc, wchar_t * const argv[] CAES_TEST_ATTRIBUTE_UNUSED ) #else int main( int argc, char * const argv[] CAES_TEST_ATTRIBUTE_UNUSED ) #endif { /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t keys1_128bit[ 100 ][ 32 ] = { { 0xc4, 0x3c, 0xd0, 0xb2, 0x37, 0x98, 0xee, 0x3d, 0xb0, 0x05, 0x3d, 0x1e, 0x4d, 0x18, 0x5e, 0x96, 0x5d, 0x67, 0xfd, 0xda, 0x8c, 0x53, 0x25, 0xcc, 0x70, 0x9f, 0xc3, 0x97, 0x3f, 0x05, 0xcd, 0x17 }, { 0x9a, 0x13, 0x1b, 0xcb, 0xde, 0xbf, 0x2b, 0xa2, 0xef, 0xc2, 0x51, 0x32, 0x45, 0x20, 0x34, 0x21, 0x31, 0x56, 0x36, 0xac, 0x24, 0xf5, 0x92, 0xe1, 0xd2, 0xb5, 0x95, 0x40, 0x51, 0x16, 0x50, 0xbe }, { 0xfd, 0x56, 0x22, 0x25, 0x5e, 0x4b, 0x21, 0xe3, 0xee, 0x6c, 0x4f, 0x1f, 0x35, 0x4a, 0x23, 0x77, 0xa6, 0x8b, 0x07, 0x58, 0xbc, 0x3a, 0xca, 0x3f, 0x32, 0xaa, 0x0f, 0xd8, 0x99, 0xd1, 0x6f, 0x11 }, { 0x4e, 0x31, 0x35, 0xee, 0x51, 0x67, 0xab, 0x65, 0x8b, 0x46, 0x94, 0xfb, 0xb7, 0xb0, 0x21, 0x79, 0x1d, 0xe4, 0x1e, 0xd6, 0x76, 0xc8, 0xc4, 0x08, 0xc5, 0x1e, 0xcf, 0xfb, 0x19, 0x00, 0xc0, 0x7e }, { 0x23, 0x9b, 0x56, 0x5a, 0xc7, 0x10, 0xfe, 0x74, 0x2c, 0x43, 0xff, 0x15, 0x6f, 0xf9, 0xfa, 0x73, 0x72, 0xef, 0xde, 0xa3, 0x38, 0x03, 0xbd, 0x8b, 0x88, 0x3f, 0x77, 0x81, 0x49, 0x72, 0x69, 0x20 }, { 0xda, 0x33, 0x73, 0xe2, 0x5d, 0x76, 0xd1, 0x6b, 0x53, 0xe4, 0xdd, 0xa3, 0x68, 0x66, 0x9c, 0xb0, 0xd9, 0xb8, 0x51, 0x75, 0x0b, 0x96, 0x24, 0xc6, 0x5c, 0xd7, 0xd7, 0x93, 0x3c, 0xf4, 0x62, 0xa8 }, { 0x1d, 0xbb, 0x08, 0x81, 0x54, 0x2c, 0x6d, 0x67, 0x8e, 0x8a, 0x00, 0x40, 0xc2, 0x20, 0x34, 0x0e, 0xd4, 0x88, 0x4e, 0x1a, 0x81, 0xb2, 0x3f, 0x43, 0xd9, 0x67, 0x3b, 0x4a, 0xc5, 0xe2, 0x95, 0xd6 }, { 0x60, 0xd2, 0xe7, 0x18, 0x98, 0xb3, 0x41, 0x35, 0x7b, 0x91, 0x50, 0xa5, 0x16, 0x3a, 0x2b, 0xe0, 0x56, 0xf5, 0xda, 0x2c, 0xed, 0xc4, 0xac, 0x70, 0x8e, 0xb4, 0x3d, 0x92, 0xba, 0x40, 0xe0, 0x01 }, { 0xdc, 0xe7, 0xd0, 0x83, 0xc3, 0xad, 0x40, 0x20, 0x29, 0xf1, 0xed, 0x40, 0x07, 0x4f, 0xf2, 0xf4, 0x2e, 0x9e, 0x14, 0x09, 0x1d, 0x09, 0xdd, 0xb6, 0x80, 0x95, 0xeb, 0x94, 0x5b, 0xf3, 0x43, 0xb7 }, { 0x8f, 0x8e, 0x47, 0x35, 0x64, 0xfa, 0x63, 0x26, 0x84, 0xd0, 0x40, 0x51, 0xca, 0xc1, 0xf1, 0x29, 0xc1, 0xd6, 0x12, 0x9b, 0x64, 0x70, 0x04, 0x29, 0xb8, 0xb1, 0x0c, 0xf3, 0x00, 0x03, 0x36, 0x38 }, { 0x49, 0x45, 0xeb, 0xf4, 0xde, 0xd6, 0xf4, 0x97, 0xc9, 0xd7, 0x36, 0x1d, 0x87, 0x17, 0x46, 0x43, 0xf9, 0xcf, 0x59, 0x09, 0x29, 0x4f, 0x6a, 0x23, 0xa8, 0x2a, 0x53, 0xbe, 0xfc, 0x6a, 0x58, 0xc6 }, { 0xb0, 0x89, 0xbc, 0x48, 0xbf, 0xa1, 0x1c, 0x49, 0x36, 0x87, 0x57, 0xf0, 0x2d, 0x30, 0x95, 0x04, 0xa3, 0x0a, 0xfe, 0xd1, 0x2c, 0xe5, 0xc6, 0x3a, 0x18, 0xa3, 0xe2, 0xeb, 0x3c, 0x04, 0x15, 0x3f }, { 0xb7, 0x09, 0xf1, 0x8e, 0xef, 0x3d, 0x86, 0xd8, 0x54, 0x70, 0x2f, 0x20, 0x07, 0xf9, 0xdd, 0x13, 0x46, 0x3f, 0xda, 0x8f, 0x07, 0x0f, 0xf0, 0x2e, 0xeb, 0x7e, 0x8f, 0xb5, 0x4e, 0x00, 0x9f, 0xf8 }, { 0x07, 0xfd, 0xe9, 0x47, 0xd9, 0xd0, 0xc0, 0x7b, 0x81, 0xa8, 0x24, 0xd5, 0x3e, 0x33, 0xe2, 0x52, 0x72, 0x65, 0x53, 0xcd, 0x3e, 0xcd, 0xff, 0xaf, 0x02, 0x34, 0xd1, 0x61, 0x84, 0x3c, 0x11, 0x2b }, { 0x58, 0xf6, 0xe7, 0x13, 0xc6, 0x70, 0xff, 0xfa, 0x62, 0xb2, 0xe7, 0x46, 0x59, 0x24, 0x0f, 0xa8, 0x4c, 0x44, 0x64, 0x46, 0x14, 0xcb, 0xf7, 0xad, 0x33, 0xa9, 0x91, 0x45, 0x7b, 0x90, 0x41, 0xdd }, { 0xb2, 0xd4, 0x7e, 0x6b, 0xa0, 0x56, 0xb6, 0x7a, 0xff, 0x50, 0x99, 0x39, 0xd3, 0x02, 0x87, 0xe4, 0x89, 0xa7, 0x1b, 0xbd, 0xa6, 0xc3, 0x1b, 0x63, 0x9f, 0x8d, 0xe5, 0xe2, 0x50, 0x8b, 0x8b, 0xe0 }, { 0x81, 0xb1, 0x9f, 0x35, 0xf4, 0x5b, 0x4e, 0x45, 0x9d, 0x88, 0xe9, 0x5e, 0x3a, 0x49, 0x64, 0x2c, 0x51, 0x27, 0x09, 0x8c, 0xcb, 0xa6, 0xa5, 0x0e, 0xf4, 0xb2, 0xf8, 0x75, 0xed, 0x20, 0xb9, 0xe5 }, { 0x68, 0xcb, 0xd5, 0xe7, 0xe9, 0xec, 0xfc, 0x60, 0x31, 0xa2, 0xc6, 0x3a, 0xd1, 0xf9, 0x5d, 0xc8, 0xba, 0x5f, 0xaa, 0x3d, 0x3b, 0x7f, 0xba, 0x1b, 0x1e, 0xf2, 0x17, 0x6f, 0x82, 0x65, 0xfb, 0xdb }, { 0x3b, 0xd5, 0x7d, 0x47, 0xe1, 0x3e, 0xa3, 0x9f, 0x1c, 0xf5, 0xf3, 0x3c, 0x8b, 0xa0, 0x29, 0xfb, 0x20, 0xf0, 0xd3, 0x38, 0x63, 0x90, 0x16, 0xf9, 0x86, 0xb7, 0x79, 0x78, 0x53, 0x37, 0x01, 0xfe }, { 0xab, 0x46, 0xc3, 0x06, 0xa2, 0x50, 0x3f, 0xcc, 0x94, 0x80, 0xad, 0x96, 0x01, 0x87, 0x91, 0x67, 0x49, 0x70, 0x93, 0x7f, 0x73, 0xac, 0xa9, 0x0a, 0x5f, 0xd0, 0x5d, 0x84, 0x20, 0xe7, 0xbd, 0xc2 }, { 0x1b, 0x09, 0x12, 0x1d, 0x93, 0x45, 0x82, 0x79, 0x01, 0x3d, 0xf1, 0x2b, 0x26, 0xe7, 0xb2, 0xa1, 0x5c, 0x28, 0xc4, 0x4f, 0x93, 0xf9, 0x7e, 0xa6, 0x38, 0xb0, 0x56, 0x17, 0x7d, 0xea, 0xfa, 0xb0 }, { 0xd0, 0x23, 0x80, 0xe8, 0x4e, 0x40, 0xf6, 0x89, 0x15, 0xed, 0x27, 0x6c, 0x2e, 0xfa, 0x48, 0x2c, 0x90, 0xb0, 0x98, 0x46, 0x70, 0x27, 0xfc, 0x3f, 0x0a, 0x16, 0xe8, 0xa3, 0x27, 0xb5, 0x23, 0xc9 }, { 0x22, 0x4d, 0xec, 0xbf, 0x90, 0x01, 0x4e, 0x6f, 0xc9, 0xbc, 0xe6, 0x83, 0x07, 0x2c, 0x9a, 0xce, 0x10, 0x89, 0x33, 0xb9, 0x2e, 0xba, 0xc4, 0x9b, 0xce, 0xea, 0x98, 0x26, 0x17, 0x16, 0xc4, 0xae }, { 0x67, 0x5f, 0xf2, 0x63, 0x7f, 0xcc, 0xd2, 0x28, 0x90, 0x65, 0xa6, 0x42, 0xdc, 0xfc, 0x54, 0x8d, 0xb7, 0x58, 0x2a, 0x04, 0x0d, 0x3a, 0xb7, 0x09, 0xd5, 0x2b, 0x03, 0x51, 0x2d, 0x5e, 0x6a, 0x08 }, { 0xbd, 0x0e, 0x95, 0x72, 0x29, 0x8b, 0x6a, 0xf2, 0x0d, 0xdc, 0x07, 0x92, 0xef, 0xa2, 0xa6, 0xc5, 0x0c, 0xb3, 0xe0, 0x8f, 0x75, 0xb5, 0x55, 0x0e, 0x60, 0x73, 0x18, 0xac, 0x18, 0x08, 0xbb, 0x93 }, { 0x62, 0x78, 0x42, 0xbf, 0xaa, 0xb7, 0xd8, 0xe6, 0xe7, 0x26, 0x81, 0xac, 0x4e, 0x5b, 0xf9, 0x91, 0x5f, 0x82, 0xe8, 0x56, 0x1b, 0x04, 0x0c, 0xca, 0xab, 0xec, 0x9e, 0x70, 0x34, 0x3a, 0x94, 0xe5 }, { 0x1f, 0x0a, 0xb8, 0xd1, 0xe1, 0x53, 0x65, 0xe3, 0x92, 0x2e, 0xc9, 0x14, 0xe9, 0xad, 0x68, 0x09, 0x7f, 0x39, 0x07, 0xb3, 0x81, 0x2b, 0x90, 0x05, 0x2d, 0x7c, 0x6a, 0x6d, 0xaf, 0x43, 0x9c, 0x61 }, { 0xe1, 0x97, 0x71, 0x29, 0xe2, 0x9c, 0x76, 0x17, 0x5e, 0x7f, 0xd1, 0x70, 0x71, 0x0f, 0xaf, 0x9f, 0x60, 0xc8, 0xb0, 0x2d, 0x03, 0xb4, 0x0c, 0xe6, 0x8b, 0x0c, 0xae, 0xe8, 0x72, 0x37, 0x7d, 0xe4 }, { 0xfc, 0xcb, 0x6e, 0x7b, 0x4c, 0x91, 0x2d, 0x41, 0x7d, 0x30, 0x34, 0x7b, 0xae, 0x86, 0xe5, 0x54, 0xec, 0xb2, 0xd0, 0x50, 0x57, 0xb2, 0x7c, 0xc4, 0xf3, 0x82, 0x45, 0x56, 0x7c, 0xd8, 0xaf, 0x9e }, { 0x1d, 0xc9, 0x48, 0xc4, 0x8d, 0xfe, 0x02, 0x7a, 0x62, 0xbe, 0x79, 0xf1, 0x0b, 0x4b, 0xe2, 0x13, 0xd6, 0x2b, 0xdc, 0x5b, 0x78, 0x45, 0x59, 0x35, 0x6c, 0x9b, 0xc9, 0xc6, 0x59, 0x73, 0xf7, 0xf4 }, { 0x6c, 0x3b, 0x93, 0x4f, 0x37, 0x78, 0xde, 0xd2, 0x8c, 0x4a, 0x5b, 0xa1, 0xd2, 0x18, 0x56, 0x21, 0xf5, 0xe9, 0x46, 0xc1, 0x09, 0x96, 0x29, 0x59, 0xdc, 0x0b, 0x8f, 0x7a, 0xb4, 0x01, 0x94, 0x4b }, { 0x51, 0x69, 0x68, 0x79, 0xee, 0x8b, 0x77, 0xf3, 0x72, 0x4c, 0x62, 0x89, 0xf3, 0xa2, 0x73, 0xa3, 0x46, 0xd9, 0xd0, 0x38, 0x07, 0xdc, 0x0b, 0x82, 0x67, 0x0f, 0x3c, 0x2b, 0x37, 0x8a, 0x79, 0x35 }, { 0x4d, 0x2b, 0x83, 0x55, 0x1a, 0xc5, 0xcb, 0x8c, 0x4b, 0xb4, 0x34, 0x57, 0x7d, 0x36, 0x4d, 0xac, 0x70, 0x3f, 0x7f, 0xe7, 0x5f, 0x74, 0xc7, 0x9f, 0xbf, 0x1a, 0x79, 0x63, 0x71, 0x1f, 0xdd, 0x53 }, { 0x35, 0xd7, 0xa7, 0x74, 0x84, 0x82, 0x59, 0x76, 0x0d, 0x32, 0xf4, 0x6c, 0x7a, 0x01, 0x3d, 0x79, 0x1b, 0xab, 0xd3, 0xb8, 0x98, 0x31, 0x6d, 0xfb, 0x00, 0xc6, 0x68, 0xc5, 0x52, 0x8b, 0xc3, 0xf3 }, { 0xe5, 0xd6, 0x08, 0xc5, 0xcb, 0x8c, 0x2c, 0x3d, 0x72, 0x6b, 0xb4, 0xf4, 0xa8, 0x02, 0x38, 0x31, 0xb9, 0x33, 0x5d, 0x00, 0x5c, 0xc2, 0xdf, 0x3b, 0xd7, 0x0d, 0x9f, 0x7e, 0x71, 0x25, 0x0c, 0x6a }, { 0x0a, 0x18, 0x0b, 0xd9, 0x0b, 0xa2, 0x06, 0xa7, 0xbf, 0x2c, 0xc8, 0x2a, 0x2f, 0x5f, 0xdd, 0xf9, 0x22, 0x40, 0xe0, 0x87, 0x11, 0xba, 0x02, 0xa4, 0x92, 0x5f, 0x90, 0xa0, 0x90, 0xb9, 0xca, 0x68 }, { 0xa8, 0x87, 0xa0, 0x96, 0x99, 0xa2, 0x68, 0x5d, 0xbe, 0xf3, 0x06, 0xd0, 0x90, 0x15, 0xf8, 0x38, 0x97, 0xa7, 0xf5, 0x99, 0xbd, 0xcb, 0x3b, 0x7f, 0x64, 0xe3, 0x46, 0x45, 0xcb, 0x6f, 0xaf, 0xcf }, { 0xef, 0xe9, 0x34, 0xcb, 0x1a, 0x60, 0xb2, 0x92, 0x8b, 0xf4, 0xdc, 0xa8, 0x43, 0x64, 0x95, 0x8d, 0x6a, 0x2b, 0x5b, 0x69, 0x86, 0xdb, 0x3e, 0x63, 0x16, 0x2a, 0x65, 0xd3, 0x77, 0xbe, 0xca, 0xcc }, { 0x43, 0x22, 0x8d, 0xdf, 0x51, 0x8e, 0xa7, 0x67, 0x5d, 0x9c, 0xa6, 0x39, 0x4f, 0x3e, 0x89, 0x44, 0x42, 0x2f, 0xa3, 0x44, 0x9e, 0x8f, 0xa8, 0x04, 0xfb, 0x42, 0x22, 0x8f, 0x55, 0xb9, 0x7b, 0xc2 }, { 0xb1, 0x3e, 0x6a, 0xf1, 0xd5, 0x9e, 0x3d, 0x82, 0x84, 0x27, 0x03, 0xd1, 0x03, 0xc1, 0x03, 0x8d, 0x3d, 0x05, 0x2a, 0xee, 0x03, 0x47, 0xa9, 0x71, 0x67, 0xb8, 0x78, 0x6a, 0xaa, 0xf0, 0xb8, 0xfe }, { 0xd4, 0xda, 0xc4, 0xb8, 0x8c, 0x97, 0x8d, 0x82, 0xf0, 0xd8, 0xd0, 0xd8, 0xb4, 0x4f, 0x69, 0xc9, 0x1e, 0xee, 0x87, 0x35, 0xf1, 0x2f, 0x0a, 0xb5, 0xa9, 0x74, 0x58, 0xab, 0x72, 0xe4, 0x62, 0x68 }, { 0x2b, 0xfa, 0xfb, 0x74, 0xd1, 0x92, 0xd5, 0x06, 0xa5, 0x0c, 0xf8, 0xce, 0x28, 0xb7, 0x9c, 0x15, 0x5a, 0x35, 0x59, 0x0b, 0x92, 0x5d, 0x79, 0x51, 0x02, 0xb7, 0xa1, 0x85, 0x08, 0x0e, 0x0a, 0x3f }, { 0x3f, 0xe0, 0x24, 0xe9, 0xb4, 0x6c, 0x0a, 0x72, 0x62, 0xce, 0x04, 0x31, 0xe8, 0x11, 0x42, 0x44, 0x3a, 0x4e, 0xb0, 0x1f, 0xb8, 0x2d, 0x30, 0x1e, 0x9b, 0x8b, 0x5f, 0x7e, 0xbf, 0xe2, 0xcf, 0x4c }, { 0x89, 0x0d, 0x5c, 0xbb, 0x10, 0xd8, 0xc7, 0xf6, 0x5e, 0x7a, 0x95, 0x81, 0xc2, 0xc0, 0xa4, 0x59, 0xa8, 0x4e, 0x2e, 0x80, 0xee, 0x90, 0xd4, 0x64, 0x99, 0x58, 0x1c, 0x5b, 0x8a, 0xb2, 0x74, 0x6c }, { 0x9a, 0x41, 0x78, 0x4e, 0x49, 0x53, 0x1d, 0xc4, 0x75, 0xb7, 0x6d, 0x96, 0x9a, 0x42, 0x96, 0x51, 0x0f, 0x88, 0xaf, 0x19, 0x25, 0xc8, 0x32, 0x3c, 0x38, 0xf6, 0xe8, 0xe1, 0x1a, 0x9b, 0x0a, 0x33 }, { 0x98, 0x85, 0xc0, 0x35, 0xf7, 0x14, 0x56, 0x32, 0x75, 0x9b, 0x5d, 0xf6, 0xc1, 0x1f, 0xab, 0x9a, 0x2b, 0x8d, 0xa8, 0x5a, 0x8e, 0xfa, 0x7a, 0x9b, 0xc9, 0x12, 0x1a, 0x59, 0xe4, 0x54, 0xda, 0x94 }, { 0x25, 0x94, 0xe2, 0xd7, 0x25, 0x5a, 0x6c, 0x99, 0xae, 0x3b, 0xe1, 0x20, 0xf7, 0xcc, 0x6c, 0xa1, 0x83, 0x5b, 0x56, 0x43, 0xfc, 0x28, 0xc1, 0x24, 0x5e, 0x2d, 0x88, 0x13, 0x73, 0x08, 0xe9, 0xac }, { 0x48, 0xe4, 0xa7, 0x71, 0x86, 0xbd, 0xf2, 0x95, 0xbf, 0x1c, 0xaf, 0x07, 0x65, 0x95, 0xb3, 0x49, 0x7a, 0x6d, 0x6d, 0x6d, 0x91, 0x82, 0x04, 0x52, 0xce, 0xfd, 0xfa, 0x2d, 0x22, 0x1a, 0xf5, 0xaa }, { 0xe6, 0xc1, 0x5e, 0x17, 0x79, 0x3d, 0xe5, 0x4e, 0xdc, 0x96, 0xec, 0x29, 0x42, 0xc2, 0x69, 0x34, 0x27, 0x80, 0x09, 0x2b, 0x70, 0x97, 0x7b, 0xf5, 0x25, 0x61, 0x6d, 0x80, 0xe6, 0xad, 0xa3, 0x6b }, { 0x23, 0xf9, 0x8e, 0x3a, 0xac, 0xb0, 0xc5, 0x9f, 0x85, 0x32, 0xdc, 0x09, 0xb4, 0xcd, 0xa9, 0xbc, 0x69, 0x25, 0x48, 0x1a, 0x14, 0x0c, 0x98, 0xbe, 0x78, 0xab, 0x34, 0x24, 0x2d, 0xd6, 0x7b, 0xfe }, { 0xa0, 0x68, 0xe2, 0x24, 0x5d, 0xed, 0xdb, 0x8f, 0x42, 0x2d, 0x1a, 0xbe, 0x3f, 0x34, 0x7a, 0x7e, 0xe4, 0x55, 0x63, 0xce, 0x97, 0x84, 0xfd, 0xb5, 0xda, 0x64, 0x52, 0xd4, 0x18, 0x59, 0x6c, 0x18 }, { 0xd6, 0xcd, 0x85, 0x83, 0x64, 0xf4, 0x72, 0x39, 0x57, 0x26, 0xf5, 0x59, 0x96, 0x11, 0x47, 0x55, 0xf3, 0xfc, 0xa7, 0x39, 0x20, 0x15, 0xba, 0xc5, 0x8f, 0x0e, 0x60, 0x65, 0xda, 0x32, 0xeb, 0x94 }, { 0x94, 0x6b, 0x38, 0x8e, 0xfb, 0xf5, 0x94, 0x68, 0x02, 0xb0, 0xc5, 0x57, 0x20, 0x91, 0x0a, 0x2a, 0x71, 0xf7, 0x50, 0x85, 0xa5, 0x65, 0x47, 0x2f, 0x2f, 0xca, 0x09, 0x1e, 0xec, 0x6c, 0x4e, 0x9c }, { 0x2e, 0xd1, 0x16, 0x61, 0x24, 0x99, 0x1c, 0xe6, 0xd3, 0xc0, 0x92, 0x1a, 0x25, 0xf5, 0x0a, 0x4c, 0x99, 0x00, 0x8c, 0x26, 0x98, 0xe8, 0x01, 0x28, 0x68, 0xdb, 0x6a, 0x30, 0x71, 0xe1, 0x53, 0xc7 }, { 0x64, 0xec, 0x33, 0xf6, 0xf5, 0x81, 0x14, 0x31, 0x8c, 0xf8, 0x8f, 0x2c, 0x86, 0xf6, 0x9e, 0xa5, 0xa7, 0x85, 0x94, 0xf9, 0x54, 0x75, 0x88, 0x44, 0x04, 0xad, 0xd2, 0x61, 0x07, 0x40, 0xcf, 0x49 }, { 0xba, 0x0f, 0x08, 0x8a, 0x69, 0x7a, 0xd3, 0x78, 0x29, 0xe2, 0x0c, 0xdc, 0xd5, 0x35, 0xca, 0x3a, 0x17, 0x80, 0xa1, 0x20, 0xd0, 0x7a, 0xd8, 0x8c, 0x7a, 0x23, 0x69, 0xec, 0xe3, 0x7d, 0x42, 0x51 }, { 0x02, 0x66, 0x9a, 0x84, 0x4e, 0x5d, 0x4f, 0xdd, 0x66, 0x28, 0x7c, 0xd8, 0xb2, 0xe1, 0x16, 0xa3, 0xeb, 0x47, 0xf3, 0x39, 0x1a, 0x1c, 0xaf, 0x3a, 0x58, 0xfd, 0xbf, 0xab, 0xbe, 0x34, 0x70, 0x8d }, { 0x31, 0xff, 0x2c, 0x6e, 0x5c, 0xc7, 0xda, 0xb6, 0x6e, 0xe7, 0x81, 0x1c, 0xcf, 0xb3, 0x6d, 0x95, 0x46, 0xd8, 0x1a, 0xc0, 0xb8, 0x57, 0x55, 0x0c, 0xf9, 0x38, 0xb9, 0x45, 0xda, 0x72, 0xa4, 0xe5 }, { 0x36, 0x7d, 0xd3, 0x17, 0xca, 0x33, 0xaf, 0x76, 0x88, 0x0b, 0x3a, 0x1c, 0x01, 0x94, 0x58, 0x2f, 0xb7, 0x52, 0xc9, 0xdc, 0x4d, 0x5e, 0xdf, 0x98, 0x3e, 0x6a, 0x67, 0xe7, 0xd7, 0x90, 0x28, 0x1e }, { 0xfd, 0x00, 0xd6, 0x28, 0xc1, 0x12, 0x19, 0x1d, 0xba, 0x79, 0x29, 0x78, 0x0c, 0xfb, 0x5b, 0xe8, 0xdf, 0x9e, 0x0a, 0x99, 0x83, 0x0f, 0x02, 0x82, 0x18, 0x10, 0x8a, 0x58, 0x00, 0xc1, 0x49, 0xbb }, { 0x02, 0x57, 0x9c, 0x69, 0x1f, 0x09, 0x88, 0x02, 0xd5, 0x94, 0x71, 0x25, 0x23, 0x89, 0x78, 0x9a, 0xc0, 0x49, 0xfc, 0xe8, 0x58, 0x83, 0x9d, 0xeb, 0x68, 0x5f, 0x15, 0xfc, 0x21, 0xe8, 0x2f, 0xa8 }, { 0x96, 0x85, 0x97, 0xe8, 0x0a, 0x2e, 0x16, 0x2e, 0x4d, 0x43, 0xe6, 0x76, 0xaa, 0xcc, 0x4b, 0xf7, 0x07, 0x57, 0xa3, 0x35, 0xc0, 0x4c, 0xba, 0x26, 0xfd, 0x0f, 0xfb, 0x5f, 0xf0, 0xdb, 0x01, 0x49 }, { 0xa2, 0xa8, 0xba, 0x81, 0x5d, 0x0b, 0x4c, 0x04, 0xdc, 0x74, 0x20, 0x4e, 0x8a, 0x5a, 0x4b, 0x45, 0x9a, 0x11, 0xc1, 0x1a, 0x2e, 0x3b, 0x59, 0xc0, 0xa6, 0x0e, 0x7b, 0x5a, 0xa5, 0xed, 0x63, 0x16 }, { 0x08, 0xd8, 0x6e, 0x27, 0xb9, 0x02, 0xaa, 0x49, 0x1a, 0x22, 0xa0, 0xd8, 0xd5, 0x41, 0x04, 0xbf, 0xa2, 0x9b, 0xf4, 0xaf, 0xf2, 0x32, 0x28, 0x59, 0x0b, 0xcb, 0xca, 0x10, 0xaf, 0x64, 0xe5, 0x21 }, { 0x2e, 0x13, 0x80, 0x7f, 0xf0, 0x45, 0x01, 0xd8, 0x99, 0xe9, 0xd1, 0x95, 0x24, 0x4c, 0x1a, 0x8e, 0xd4, 0xaa, 0x80, 0x22, 0xb9, 0xd6, 0x99, 0x94, 0xc6, 0x5a, 0x65, 0x69, 0xbb, 0x63, 0xff, 0x3f }, { 0x7a, 0xa1, 0xe6, 0xc2, 0x0f, 0xdd, 0x27, 0x55, 0xe5, 0x0f, 0x55, 0x37, 0x51, 0x5f, 0xa7, 0x49, 0xd0, 0x3a, 0x14, 0xc4, 0x1a, 0xc8, 0x45, 0xd7, 0x2e, 0x59, 0xe1, 0x66, 0xe0, 0x6d, 0x7e, 0x82 }, { 0xa6, 0xca, 0xad, 0xe6, 0x62, 0xb7, 0x0b, 0xd1, 0x79, 0xd2, 0x95, 0xef, 0xa4, 0xcc, 0x29, 0xc7, 0x5b, 0x24, 0x05, 0x33, 0xc7, 0x7b, 0x1b, 0x54, 0x5c, 0x02, 0x47, 0x7a, 0x16, 0x04, 0x19, 0x15 }, { 0xb4, 0xc0, 0xae, 0x25, 0xfe, 0x1b, 0xb2, 0x22, 0x81, 0xa2, 0x7f, 0x93, 0x55, 0xc7, 0x91, 0x70, 0x1a, 0xb7, 0x08, 0x64, 0x87, 0xd2, 0x97, 0x1f, 0xbc, 0x00, 0x8a, 0x71, 0xef, 0x49, 0x8c, 0x42 }, { 0xe9, 0x6f, 0x4f, 0xd8, 0x5c, 0x51, 0x27, 0x64, 0x91, 0x2e, 0x2a, 0x2a, 0xf4, 0xa2, 0xac, 0x23, 0x34, 0x25, 0x9b, 0x79, 0xc8, 0x97, 0x1c, 0x68, 0xf2, 0x8c, 0x4e, 0x6c, 0x4c, 0xdc, 0x8d, 0xfb }, { 0x2a, 0x5c, 0xa9, 0x93, 0x90, 0x0f, 0x10, 0x8d, 0x83, 0xfe, 0xc3, 0xbc, 0x6a, 0xb4, 0xe7, 0x4f, 0xd5, 0xbc, 0x2a, 0xd9, 0x81, 0x2c, 0x31, 0x15, 0x4b, 0x80, 0xf4, 0x8b, 0x2c, 0x43, 0x72, 0x29 }, { 0x5b, 0x3e, 0xd2, 0x66, 0xe3, 0x51, 0x31, 0x67, 0x8b, 0x5f, 0xc1, 0xb4, 0xf3, 0x59, 0xbb, 0xa0, 0x1f, 0x15, 0x39, 0xd1, 0x88, 0xb6, 0x63, 0x1e, 0xa6, 0xa7, 0x4d, 0xc8, 0xb5, 0x89, 0x5e, 0x12 }, { 0x08, 0xfd, 0x05, 0x09, 0xef, 0xb8, 0xd9, 0x17, 0x1e, 0xa3, 0xad, 0x3e, 0xc9, 0xbb, 0xbe, 0xdd, 0x9d, 0xbe, 0xdd, 0xe9, 0x71, 0xcc, 0x75, 0x7a, 0xee, 0x34, 0x9c, 0x9d, 0xb1, 0x81, 0xd5, 0x69 }, { 0x10, 0x01, 0x57, 0x1a, 0x70, 0xf8, 0xd7, 0xb3, 0x41, 0x48, 0xc1, 0x40, 0x23, 0xe5, 0xf3, 0x07, 0x31, 0xc6, 0x90, 0x3b, 0xd8, 0x7d, 0xe3, 0xac, 0xf5, 0x5a, 0x00, 0x17, 0x52, 0x91, 0xfa, 0xac }, { 0xeb, 0x52, 0x16, 0x33, 0x26, 0xd2, 0x5b, 0x59, 0x77, 0x28, 0x60, 0x06, 0x5c, 0xc6, 0x8f, 0x0f, 0x5c, 0x05, 0xf5, 0x8a, 0x41, 0xe7, 0x60, 0x8d, 0x92, 0x48, 0xb9, 0x86, 0x5b, 0xcc, 0x6a, 0x54 }, { 0x45, 0xda, 0x2e, 0xac, 0xe7, 0xd9, 0xb1, 0x5e, 0xfb, 0xed, 0xac, 0x13, 0x73, 0xf4, 0x12, 0x0e, 0xeb, 0x1b, 0x36, 0x1f, 0x2a, 0x5c, 0xf8, 0xf8, 0x28, 0xf0, 0xbe, 0x86, 0xf9, 0x42, 0x17, 0xcc }, { 0xec, 0x79, 0xdf, 0x9e, 0xb4, 0xb6, 0xae, 0xb8, 0x01, 0x6d, 0x4f, 0x31, 0x6b, 0xe7, 0xfc, 0x6d, 0xb4, 0x2c, 0x22, 0x95, 0x5f, 0x6e, 0x43, 0x27, 0x44, 0xa4, 0x8a, 0x1f, 0x18, 0x16, 0x39, 0x20 }, { 0x63, 0x2f, 0x8e, 0xab, 0x45, 0xcd, 0x9b, 0x6f, 0x6a, 0x24, 0xb4, 0x67, 0xac, 0x80, 0x4f, 0x4e, 0xc7, 0xdc, 0x65, 0x67, 0x72, 0x5d, 0xf0, 0x2e, 0x40, 0x52, 0x50, 0xf1, 0xda, 0x07, 0x87, 0x95 }, { 0xdb, 0x6a, 0x32, 0xd2, 0xa0, 0x26, 0x2d, 0x61, 0x52, 0x51, 0xd0, 0xaa, 0x9d, 0x6a, 0x36, 0xd1, 0x54, 0xe9, 0x6d, 0x86, 0x6c, 0x0b, 0xae, 0x2b, 0x2a, 0xbf, 0x89, 0x10, 0xa3, 0x31, 0xd4, 0x9e }, { 0xc6, 0xad, 0x2c, 0xca, 0x0d, 0x5d, 0xa1, 0x91, 0x80, 0xd1, 0x77, 0xd8, 0x1c, 0x50, 0x2d, 0xa9, 0x4e, 0x3b, 0x9e, 0x89, 0xa5, 0x17, 0x76, 0x8d, 0x8e, 0x1c, 0x5c, 0xcd, 0x8a, 0x39, 0x6f, 0xaa }, { 0x92, 0x68, 0x83, 0x00, 0xd4, 0x00, 0x1d, 0xa8, 0xaa, 0x8b, 0xc6, 0xfa, 0xbc, 0x63, 0x7a, 0x96, 0x31, 0x5e, 0xe4, 0xec, 0x18, 0xdc, 0xab, 0x01, 0x0c, 0x44, 0xaf, 0x72, 0x12, 0x3a, 0x7e, 0x01 }, { 0x1a, 0x01, 0xa9, 0x6c, 0x83, 0x2f, 0x38, 0xb1, 0xa0, 0x44, 0x7d, 0x82, 0xc9, 0xbe, 0xc7, 0x60, 0xcc, 0x34, 0x01, 0xf0, 0x15, 0x9c, 0xc0, 0xf6, 0xd4, 0xb6, 0x70, 0x3e, 0xaa, 0x16, 0xf0, 0x7c }, { 0x47, 0x29, 0xc7, 0xb7, 0xe7, 0xc6, 0x14, 0x56, 0x01, 0x86, 0xfd, 0xd7, 0xba, 0xdb, 0x0a, 0x9a, 0x1f, 0x9a, 0x96, 0x38, 0x93, 0xba, 0x19, 0x1e, 0xf4, 0xac, 0xf5, 0xfe, 0x33, 0xad, 0xf8, 0xaa }, { 0x4d, 0xda, 0x94, 0x1e, 0x40, 0x08, 0xf5, 0x99, 0x9e, 0x5e, 0x0b, 0x63, 0x99, 0x23, 0x7b, 0xaa, 0xf3, 0x71, 0xb4, 0xf3, 0xfa, 0x97, 0x73, 0x7e, 0x71, 0x4f, 0x46, 0x07, 0x21, 0x82, 0x5d, 0xdc }, { 0x63, 0xdc, 0xc1, 0x07, 0x5b, 0x20, 0x31, 0x73, 0x00, 0x17, 0xc6, 0x8a, 0x41, 0x28, 0x74, 0xdd, 0x1e, 0x26, 0x59, 0x7b, 0x23, 0xc1, 0xd0, 0x2f, 0x1a, 0x9f, 0x24, 0xbe, 0x3b, 0xa0, 0x21, 0xa4 }, { 0x10, 0x14, 0xb5, 0xd1, 0xec, 0x8a, 0x23, 0x5b, 0x85, 0x2f, 0x38, 0x66, 0x8a, 0x0a, 0x36, 0x79, 0xbc, 0x68, 0xd2, 0x19, 0xb8, 0x2d, 0x95, 0xea, 0x68, 0xfe, 0x06, 0x50, 0x04, 0x85, 0x1a, 0x77 }, { 0xea, 0x8b, 0x81, 0x47, 0x56, 0x23, 0x39, 0xe9, 0x00, 0xb0, 0x41, 0x3e, 0x58, 0xd7, 0x58, 0x9e, 0x60, 0xac, 0xb5, 0xa5, 0xa5, 0xd3, 0x12, 0x42, 0xed, 0x01, 0x37, 0x62, 0xb0, 0xc6, 0x87, 0x20 }, { 0xc9, 0x3d, 0x58, 0x70, 0xfd, 0x5f, 0xc6, 0x06, 0xf9, 0x01, 0xbc, 0x71, 0x55, 0x6c, 0x6e, 0x04, 0xfc, 0x05, 0xd6, 0xa1, 0xbe, 0x0c, 0x78, 0x32, 0x05, 0x74, 0xf4, 0xdf, 0xcb, 0x69, 0x95, 0xa4 }, { 0x3c, 0x35, 0x59, 0x45, 0xb6, 0x83, 0x49, 0x1d, 0x70, 0xc4, 0x87, 0x12, 0x58, 0x64, 0xe6, 0xb5, 0xd2, 0x94, 0x1b, 0xce, 0xfe, 0xf9, 0xca, 0x11, 0x72, 0xf0, 0x5f, 0xd5, 0xb5, 0xd5, 0x6a, 0x31 }, { 0xf4, 0x22, 0x91, 0x8b, 0x58, 0x3e, 0xbe, 0x25, 0xae, 0x90, 0x62, 0x62, 0xf8, 0x82, 0x26, 0x6b, 0x8d, 0x5c, 0x68, 0x56, 0xec, 0xff, 0x6d, 0x07, 0x0b, 0xed, 0xf2, 0x18, 0x4b, 0x1c, 0xdb, 0xec }, { 0x02, 0x58, 0x29, 0xbe, 0x53, 0x4d, 0x9b, 0xd3, 0xb8, 0x36, 0x7d, 0x8b, 0x73, 0x2a, 0x11, 0x11, 0x4b, 0xcb, 0xb0, 0x94, 0x1f, 0x6c, 0xe2, 0x77, 0x13, 0x70, 0xaf, 0x65, 0x4d, 0xed, 0x40, 0xa5 }, { 0x12, 0x2e, 0x55, 0x0c, 0xe6, 0x02, 0xc9, 0x43, 0x95, 0x1b, 0x4f, 0xc2, 0xea, 0x26, 0x34, 0x17, 0x46, 0x5c, 0x53, 0x90, 0xf0, 0xf9, 0x31, 0x6b, 0x1b, 0x12, 0xff, 0x40, 0x6e, 0xd2, 0x50, 0x75 }, { 0xfc, 0x58, 0xa8, 0xdf, 0x74, 0xba, 0x83, 0x17, 0xcf, 0xe3, 0x43, 0x22, 0xe8, 0x83, 0x66, 0x4d, 0xf7, 0x66, 0x3f, 0x7f, 0x5a, 0x1a, 0x13, 0x3e, 0x37, 0x5d, 0x41, 0x90, 0x20, 0x0c, 0x48, 0xac }, { 0x40, 0xf2, 0x58, 0x58, 0x6e, 0xfe, 0xf9, 0xcb, 0x9d, 0xfb, 0xf7, 0x6b, 0x4e, 0x6e, 0xaf, 0xf6, 0x1e, 0x30, 0x32, 0xe8, 0x43, 0x19, 0xcc, 0x97, 0x8e, 0x0d, 0xbf, 0x3c, 0xcd, 0x62, 0xaf, 0xc9 }, { 0x6e, 0xb9, 0xd0, 0x05, 0x90, 0x99, 0x0a, 0xec, 0x1a, 0xec, 0x6e, 0x19, 0xab, 0x66, 0xec, 0xf3, 0xde, 0x19, 0xeb, 0x4a, 0x32, 0xf7, 0x0d, 0xa4, 0x78, 0xce, 0x4e, 0xd7, 0x44, 0x07, 0xd0, 0xab }, { 0xd0, 0x1a, 0xb2, 0x51, 0xb0, 0xa7, 0x54, 0x54, 0xde, 0x30, 0x47, 0xce, 0xe9, 0xa4, 0x65, 0x85, 0x0b, 0x57, 0x35, 0x20, 0x4d, 0x7c, 0xef, 0xe0, 0x89, 0x06, 0x94, 0x67, 0x0c, 0xeb, 0x1c, 0xd4 }, { 0x6a, 0x1a, 0xb8, 0x33, 0x68, 0x78, 0x02, 0x2a, 0xe3, 0x25, 0xdf, 0x5c, 0x64, 0xfd, 0x10, 0xed, 0x32, 0xb8, 0xca, 0xd2, 0x6a, 0xe7, 0xfe, 0xeb, 0x95, 0x32, 0x15, 0x3c, 0x7c, 0x4e, 0x9d, 0x86 }, { 0xe5, 0x2d, 0x42, 0x59, 0xc4, 0x05, 0x50, 0x89, 0x44, 0xba, 0x59, 0x3b, 0x6c, 0xdc, 0x2b, 0x4b, 0x95, 0x9c, 0xc7, 0xc4, 0xad, 0x05, 0x04, 0xf9, 0x81, 0x9f, 0xe9, 0xdd, 0x98, 0xe8, 0xa9, 0x00 }, { 0x5b, 0x4b, 0x43, 0xe4, 0xa9, 0xa5, 0x1b, 0x84, 0x62, 0xbe, 0x36, 0x60, 0x52, 0x92, 0xb4, 0x96, 0x54, 0xc9, 0x1b, 0x32, 0x63, 0xdd, 0x4a, 0xeb, 0x4b, 0x38, 0x2c, 0x4f, 0x76, 0x71, 0x7e, 0xa8 }, { 0x2a, 0x3a, 0x18, 0x09, 0x23, 0x38, 0x7e, 0x99, 0xff, 0x7d, 0x8c, 0xb3, 0xa4, 0x93, 0xe9, 0x4c, 0xee, 0xff, 0x5e, 0x99, 0xf4, 0x00, 0x39, 0xdf, 0x16, 0xb8, 0x64, 0xc9, 0xc7, 0xaf, 0x7d, 0x8d }, { 0xd1, 0x39, 0x10, 0x81, 0xc8, 0xec, 0x4f, 0x3e, 0xe4, 0xc1, 0xb5, 0xf2, 0x4c, 0x48, 0xd6, 0xa4, 0x7c, 0xab, 0xea, 0x73, 0xfe, 0x49, 0x19, 0xc8, 0xd2, 0x84, 0x90, 0x92, 0x21, 0xe0, 0x51, 0x1a } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t keys2_128bit[ 100 ][ 32 ] = { { 0x04, 0x42, 0x83, 0x61, 0x6d, 0xfb, 0xe7, 0x55, 0xa7, 0xbf, 0x69, 0xee, 0xc1, 0x8d, 0x79, 0xa0, 0xfb, 0xbd, 0x3e, 0x7a, 0x70, 0x2e, 0xac, 0xc3, 0x26, 0x1b, 0xc4, 0x18, 0xb8, 0x05, 0xe8, 0x85 }, { 0x5d, 0x24, 0x19, 0xfa, 0xd1, 0xa2, 0x2c, 0x32, 0x2d, 0x92, 0xe7, 0x62, 0x27, 0xed, 0xd3, 0x48, 0x8e, 0x52, 0xe1, 0xe9, 0x8c, 0x67, 0xb5, 0xa2, 0x5f, 0x89, 0x4a, 0x2f, 0x3a, 0x95, 0x47, 0x0b }, { 0x3a, 0xce, 0x4e, 0x72, 0xa9, 0x7f, 0x75, 0xa5, 0x33, 0x7b, 0xeb, 0x8a, 0xdb, 0xa2, 0x24, 0xb8, 0xec, 0x7d, 0x62, 0x5f, 0x0c, 0xe4, 0x6c, 0xe0, 0x11, 0x4f, 0x53, 0x59, 0x4b, 0x9a, 0xdf, 0x0a }, { 0xaa, 0x4f, 0x7e, 0x9b, 0x2a, 0x9d, 0x3a, 0xb5, 0xfc, 0x11, 0x88, 0x8d, 0xfd, 0xcf, 0xa1, 0x3b, 0x19, 0xa2, 0x1f, 0xe1, 0x22, 0xfc, 0x18, 0x33, 0x1b, 0x95, 0x48, 0x88, 0x32, 0xdd, 0xe9, 0x73 }, { 0x02, 0x19, 0xbf, 0xf8, 0xa6, 0x1a, 0x52, 0xff, 0xcb, 0x5a, 0xcb, 0xe1, 0x88, 0xea, 0xb0, 0x95, 0xd2, 0x10, 0xa9, 0xed, 0x0d, 0x18, 0xa4, 0xf7, 0x0f, 0x8e, 0xed, 0x0c, 0x36, 0x90, 0x1e, 0x8a }, { 0x67, 0x3f, 0x0a, 0x6b, 0x2a, 0x88, 0x9a, 0x8f, 0xb9, 0xfb, 0x1f, 0xde, 0xa1, 0x35, 0xfa, 0x7b, 0x0f, 0xbb, 0x54, 0xd3, 0x93, 0x21, 0xfa, 0xdc, 0xa8, 0x47, 0xe7, 0xce, 0x4d, 0x13, 0x24, 0xc5 }, { 0xf2, 0xbc, 0xab, 0x3e, 0xad, 0xa0, 0x4a, 0xef, 0x3a, 0x35, 0x2b, 0x2c, 0xd4, 0xbe, 0x83, 0xb2, 0x3c, 0xc5, 0x2c, 0xc8, 0x70, 0x79, 0x8e, 0x31, 0x27, 0x02, 0x5b, 0x2c, 0x88, 0x55, 0x5e, 0x51 }, { 0xad, 0x05, 0x2d, 0x63, 0x3b, 0xf3, 0xeb, 0xae, 0xf1, 0x9a, 0x32, 0x1f, 0xf9, 0xed, 0x9e, 0x58, 0x21, 0x79, 0x24, 0xc3, 0x9d, 0xc7, 0x3e, 0x74, 0x81, 0x42, 0x0f, 0xa3, 0x60, 0xa8, 0xc3, 0x48 }, { 0x1b, 0xdb, 0x3c, 0xd4, 0xfe, 0x6a, 0x1b, 0x8c, 0x2f, 0x10, 0x83, 0x7d, 0xe1, 0x65, 0x21, 0x01, 0x70, 0x8d, 0x1a, 0x86, 0x9d, 0x99, 0x51, 0x30, 0x41, 0xfe, 0x64, 0x44, 0xad, 0x06, 0x5e, 0x30 }, { 0xa5, 0xb7, 0x4d, 0x3b, 0xb5, 0x8c, 0xa8, 0x39, 0xf6, 0x20, 0xb5, 0x50, 0x4a, 0xe9, 0x2a, 0xa9, 0x9a, 0x40, 0x65, 0xd8, 0x1a, 0x49, 0x63, 0x57, 0x34, 0x06, 0x17, 0x08, 0xef, 0x5a, 0x2c, 0x56 }, { 0xb1, 0xeb, 0xc8, 0xc5, 0xbd, 0xc0, 0x18, 0xef, 0x3d, 0x12, 0xc1, 0x5f, 0xfd, 0x4b, 0x5e, 0x1d, 0xd6, 0x51, 0x2c, 0xbe, 0x42, 0xbb, 0x13, 0x52, 0x8d, 0xd0, 0xc7, 0x54, 0x39, 0x76, 0x41, 0xd0 }, { 0x8e, 0xe4, 0xf0, 0x15, 0x0c, 0x23, 0xeb, 0xac, 0xa1, 0x27, 0xbd, 0x6c, 0x52, 0xca, 0x3d, 0x53, 0xda, 0xf6, 0xf9, 0x13, 0x5b, 0x32, 0x3b, 0xcb, 0x86, 0xf5, 0xde, 0x2f, 0xc4, 0xed, 0xd8, 0xbe }, { 0xfd, 0xd4, 0xf1, 0x69, 0xb4, 0x84, 0x17, 0x7d, 0xce, 0xe1, 0xf4, 0xf1, 0x39, 0x98, 0x0a, 0x52, 0x26, 0xd1, 0xad, 0x77, 0x8f, 0xdc, 0x59, 0x1b, 0x6d, 0x56, 0xd0, 0xe4, 0x56, 0xd9, 0xeb, 0x8a }, { 0x9d, 0x87, 0x3c, 0x9d, 0x56, 0x1c, 0x1b, 0x45, 0x6b, 0x23, 0x25, 0xe7, 0xf7, 0x39, 0x68, 0x0d, 0xc8, 0x80, 0x9a, 0x99, 0x59, 0x75, 0x34, 0x94, 0x1f, 0xcc, 0xc0, 0x74, 0x9d, 0xb4, 0x76, 0x37 }, { 0xb9, 0x34, 0x85, 0xc5, 0x41, 0x9f, 0xb4, 0x06, 0x5b, 0x1e, 0xb1, 0xcd, 0x66, 0xd3, 0x5b, 0x40, 0xc4, 0x59, 0xcd, 0x80, 0xff, 0x63, 0x63, 0x64, 0x3b, 0x9a, 0x7d, 0x11, 0x9f, 0x86, 0xdb, 0x35 }, { 0x4b, 0xf3, 0x86, 0x53, 0xc1, 0x38, 0x4a, 0xdd, 0xa2, 0xaf, 0xa5, 0x60, 0x06, 0x4e, 0x84, 0xb7, 0xd2, 0x20, 0x8d, 0xe9, 0x69, 0xa0, 0x66, 0x83, 0xcb, 0xfc, 0x3d, 0xd6, 0x18, 0xa0, 0x7e, 0xba }, { 0xd2, 0x37, 0x3c, 0x8c, 0x62, 0x66, 0xb1, 0x14, 0xfd, 0x42, 0xe4, 0x38, 0xe8, 0x36, 0x03, 0xcf, 0xdb, 0x73, 0x16, 0x0e, 0x4a, 0xbd, 0x42, 0xf2, 0x1b, 0x31, 0x03, 0x9d, 0x39, 0x43, 0x7d, 0x5e }, { 0x45, 0x16, 0xf9, 0xb1, 0x56, 0x92, 0x3a, 0x70, 0x18, 0xb8, 0x49, 0x09, 0x44, 0xb7, 0xf5, 0x9f, 0x07, 0x30, 0x78, 0x7e, 0xe7, 0x7f, 0xed, 0x4a, 0xa5, 0x42, 0x80, 0x24, 0xd5, 0xb2, 0x3c, 0x61 }, { 0x19, 0xb0, 0x9b, 0xc8, 0xcd, 0x5d, 0xed, 0x96, 0xb9, 0xd4, 0xa6, 0x8f, 0xb5, 0x95, 0xf6, 0x95, 0x2e, 0x68, 0x3b, 0x6a, 0x96, 0x29, 0x7f, 0xb3, 0x2f, 0xfe, 0xc0, 0x6e, 0x2b, 0xba, 0x1f, 0xf1 }, { 0x2c, 0x07, 0xd8, 0xb8, 0x4e, 0xc3, 0x48, 0x53, 0x28, 0x3f, 0xde, 0xcf, 0x6a, 0x77, 0xd4, 0xa9, 0x3a, 0x53, 0xd3, 0x64, 0x87, 0x32, 0x26, 0x35, 0x2b, 0x57, 0x04, 0x37, 0xf8, 0x61, 0xd2, 0x90 }, { 0x2c, 0x3b, 0x55, 0x2d, 0x43, 0xf0, 0x1f, 0x1d, 0xc8, 0x2e, 0xad, 0x0c, 0xb0, 0xd4, 0x3f, 0xa7, 0x46, 0xd1, 0xb8, 0x3e, 0x10, 0x04, 0x47, 0x74, 0xcc, 0x0e, 0xa0, 0xc9, 0xe8, 0x83, 0x0d, 0xe3 }, { 0xc1, 0x4a, 0x66, 0xb3, 0x27, 0xb4, 0x55, 0x4e, 0xc0, 0xf2, 0x85, 0xc6, 0xd7, 0x10, 0x0e, 0x72, 0xdd, 0x8a, 0xff, 0x50, 0xe7, 0x7f, 0xc6, 0x74, 0xda, 0x88, 0xf8, 0xb8, 0x09, 0x2e, 0xc5, 0x66 }, { 0x2e, 0xd8, 0x89, 0x3a, 0xde, 0x98, 0xf9, 0xaf, 0xd2, 0x91, 0x16, 0x17, 0xad, 0x34, 0x6d, 0x6f, 0xd5, 0xd2, 0x58, 0xce, 0x1b, 0x6f, 0x37, 0xd3, 0x2c, 0xc5, 0x81, 0x53, 0x81, 0x03, 0x36, 0x01 }, { 0x9e, 0xe3, 0x08, 0x03, 0x54, 0x0c, 0x35, 0x38, 0x8c, 0xf0, 0x44, 0x78, 0xe4, 0x80, 0x90, 0x18, 0x3c, 0x1a, 0x0f, 0x1b, 0x7e, 0x8c, 0x1c, 0x9b, 0x2a, 0x67, 0x4d, 0x65, 0xf4, 0x8b, 0xca, 0x8d }, { 0x67, 0x4f, 0xa1, 0x16, 0x62, 0xf1, 0xf2, 0x20, 0xc1, 0xbd, 0x6b, 0x59, 0x52, 0x3d, 0x84, 0xfa, 0x72, 0x41, 0xf9, 0xda, 0xbf, 0x37, 0x82, 0x7e, 0x82, 0x70, 0x19, 0x83, 0x43, 0x12, 0x19, 0x7c }, { 0x39, 0x25, 0x79, 0x05, 0xdf, 0xcc, 0x77, 0x76, 0x6c, 0x87, 0x0a, 0x80, 0x6a, 0x60, 0xe3, 0xc0, 0x93, 0xd1, 0x2a, 0xcf, 0xcb, 0x51, 0x42, 0xfa, 0x09, 0x69, 0x89, 0x62, 0x5b, 0x60, 0xdb, 0x16 }, { 0xe6, 0xe8, 0x72, 0x8f, 0x52, 0x0a, 0xff, 0xb5, 0xc5, 0xb2, 0xc6, 0x5e, 0x58, 0x9d, 0xf2, 0x5e, 0xd0, 0x00, 0x68, 0xb7, 0x18, 0xbb, 0xb0, 0x0a, 0x79, 0xd4, 0xec, 0x05, 0x5e, 0x1c, 0xc3, 0x2a }, { 0xe1, 0x6a, 0x2f, 0xb3, 0x8a, 0x83, 0xcb, 0xb5, 0x0b, 0x9b, 0x73, 0xbf, 0xf9, 0x79, 0x87, 0x86, 0x7b, 0xb2, 0xc5, 0xdd, 0xe2, 0x0e, 0xe6, 0x6e, 0x8b, 0xc1, 0x93, 0xbb, 0x20, 0x30, 0x30, 0x44 }, { 0x05, 0x4f, 0xa8, 0x05, 0xcd, 0x6e, 0xd4, 0xd7, 0x2c, 0x6c, 0xf5, 0x17, 0x5b, 0x07, 0x2c, 0x94, 0x6b, 0x52, 0x71, 0xe3, 0x62, 0x6d, 0x2e, 0xce, 0x43, 0x08, 0x18, 0x5b, 0x2a, 0x41, 0x3a, 0xc7 }, { 0x26, 0x95, 0xe7, 0xeb, 0x00, 0x09, 0x27, 0x7f, 0x24, 0x63, 0xa6, 0xda, 0x8a, 0x57, 0xcc, 0xbb, 0xb2, 0x44, 0xb2, 0xbd, 0x09, 0xab, 0xe5, 0xf2, 0xda, 0x53, 0x80, 0x25, 0xc7, 0x51, 0x6b, 0x80 }, { 0x85, 0x57, 0xca, 0x8c, 0x4e, 0x7a, 0x95, 0x60, 0xf7, 0x5d, 0x2c, 0x41, 0xea, 0xaa, 0x2a, 0x4e, 0xcf, 0x7b, 0x4b, 0xc5, 0x02, 0x12, 0x7f, 0x7e, 0x71, 0x7f, 0x01, 0x8d, 0xe1, 0x61, 0x65, 0x28 }, { 0x35, 0x04, 0xf8, 0x16, 0x72, 0x15, 0x0d, 0xb2, 0x4a, 0x61, 0x56, 0xa8, 0x99, 0x51, 0x12, 0x48, 0x63, 0xba, 0xa3, 0x05, 0x58, 0xe2, 0xf1, 0xa0, 0xf5, 0x1c, 0x3c, 0x6c, 0xf8, 0x09, 0x03, 0xa2 }, { 0x49, 0x92, 0x63, 0xa6, 0x3c, 0x49, 0x17, 0xf4, 0xb4, 0x4f, 0x6a, 0xdb, 0x00, 0x8b, 0xf1, 0x99, 0x74, 0xb2, 0x9c, 0x2c, 0x9e, 0x02, 0x18, 0x6c, 0xfc, 0x9c, 0xd0, 0xa8, 0xa0, 0x5e, 0xc7, 0x31 }, { 0x06, 0x9f, 0x57, 0x77, 0xde, 0x49, 0x63, 0x2b, 0x67, 0xce, 0xf4, 0x12, 0x14, 0x19, 0x48, 0xfa, 0x68, 0xd4, 0xc5, 0x46, 0x5c, 0xd3, 0xb8, 0xbe, 0x59, 0x65, 0x9c, 0x29, 0xb7, 0x6f, 0x53, 0x15 }, { 0x08, 0x96, 0x81, 0x8d, 0x81, 0xfb, 0xb8, 0x4c, 0xeb, 0x0b, 0xea, 0x5a, 0xc9, 0x3c, 0x09, 0xca, 0xec, 0xfa, 0x92, 0xce, 0x0a, 0xfd, 0x0b, 0xed, 0xfe, 0xac, 0x9c, 0xec, 0xb8, 0xba, 0x8c, 0x55 }, { 0xa2, 0x59, 0x38, 0x9b, 0xe3, 0x6d, 0x64, 0x56, 0x8c, 0x05, 0x3c, 0x63, 0x94, 0x67, 0xbe, 0x0e, 0x26, 0xd3, 0xc0, 0xeb, 0x62, 0x82, 0x79, 0x03, 0xd4, 0x82, 0x6e, 0xfa, 0x53, 0x17, 0x16, 0x16 }, { 0x73, 0x3e, 0xb1, 0x25, 0x41, 0x3c, 0x57, 0x0b, 0x9a, 0xdb, 0xda, 0xec, 0xbd, 0x9b, 0xda, 0x1c, 0x13, 0xa1, 0xbc, 0x28, 0x60, 0x81, 0x04, 0x1a, 0xa0, 0x69, 0xe5, 0x2b, 0xb7, 0x22, 0x91, 0x4f }, { 0x07, 0xe4, 0x37, 0x8b, 0xf7, 0xe5, 0x14, 0xe2, 0x87, 0x50, 0x86, 0xff, 0x56, 0x7f, 0xee, 0x96, 0x21, 0xc4, 0x5f, 0x6f, 0xf3, 0x6d, 0xb4, 0x5f, 0x1c, 0x0f, 0x70, 0x6b, 0x1a, 0x9e, 0x02, 0x8b }, { 0x0e, 0x17, 0x1e, 0x22, 0x5c, 0xbd, 0xe4, 0x08, 0x73, 0xdb, 0xf6, 0x86, 0xb2, 0x97, 0xb2, 0xb6, 0xd4, 0xed, 0x08, 0x47, 0x6d, 0xd6, 0x92, 0x36, 0x22, 0x4f, 0x0e, 0xe1, 0xbf, 0x30, 0x43, 0x82 }, { 0xe8, 0x56, 0x11, 0x7e, 0xc0, 0x53, 0x86, 0x43, 0xe8, 0x27, 0x69, 0x19, 0x7e, 0x4a, 0x4c, 0x0a, 0x26, 0xae, 0x60, 0xf3, 0xf8, 0xde, 0x16, 0x50, 0x02, 0xba, 0x34, 0x74, 0x44, 0xcb, 0xa0, 0x6f }, { 0xc5, 0xb4, 0x9e, 0x5f, 0xca, 0xc9, 0x23, 0x6c, 0xaf, 0x72, 0x42, 0x16, 0x05, 0xbe, 0x6d, 0xc5, 0x31, 0x77, 0x40, 0x0f, 0x8d, 0x3e, 0xe3, 0xe8, 0x77, 0xfa, 0x55, 0x59, 0x2c, 0xcf, 0x2a, 0x83 }, { 0xd2, 0x9c, 0xeb, 0x27, 0x4a, 0x3f, 0xe2, 0x0b, 0x9c, 0xd3, 0x72, 0xc3, 0xef, 0x26, 0x4d, 0xf3, 0x69, 0x90, 0xd6, 0xd2, 0x0e, 0xde, 0x69, 0x91, 0x50, 0xbc, 0x8a, 0x01, 0x3a, 0x16, 0x7a, 0x4b }, { 0xcc, 0xd3, 0x76, 0x2a, 0x06, 0x16, 0xcd, 0xa5, 0xc4, 0xa4, 0x70, 0xf6, 0xfa, 0x81, 0xa9, 0xaf, 0x77, 0x7b, 0xa5, 0x9e, 0xe8, 0x78, 0x8b, 0xd7, 0xea, 0x9e, 0xc1, 0x17, 0xf2, 0x5a, 0x75, 0xc4 }, { 0xb9, 0xfa, 0x2f, 0xc6, 0x03, 0x70, 0x0e, 0x6f, 0xe7, 0x88, 0xf7, 0x1f, 0xa0, 0x06, 0x4f, 0x4c, 0x5a, 0x84, 0x61, 0x88, 0xfe, 0x6d, 0xa4, 0x62, 0xf0, 0x9b, 0x9a, 0x8f, 0x15, 0xcf, 0xd7, 0x09 }, { 0xed, 0xe7, 0x35, 0xce, 0x9a, 0x45, 0x6b, 0xd7, 0x95, 0xab, 0xbd, 0x65, 0x67, 0x1e, 0x64, 0xf6, 0x21, 0xec, 0xe0, 0x65, 0x20, 0xc2, 0xb6, 0x32, 0xa4, 0xaa, 0x87, 0x53, 0xe6, 0xaf, 0xe7, 0x4b }, { 0xf6, 0x9b, 0xd6, 0x71, 0x6c, 0xce, 0xee, 0x47, 0xa1, 0x8c, 0x1b, 0xa9, 0x18, 0xce, 0x1c, 0xe5, 0x94, 0x56, 0x8a, 0xcb, 0x1c, 0xd5, 0x96, 0xc1, 0x49, 0x64, 0xfb, 0xf7, 0xcb, 0xf8, 0x38, 0x12 }, { 0x02, 0x55, 0xdf, 0x03, 0x39, 0x93, 0x6b, 0x44, 0xe3, 0xf0, 0xce, 0x4f, 0x13, 0x0f, 0x52, 0x02, 0xe1, 0x9d, 0x2f, 0x18, 0x17, 0xbb, 0x0c, 0x94, 0xc4, 0x40, 0x48, 0x34, 0x19, 0xfd, 0x4e, 0xd9 }, { 0xcc, 0x36, 0xbc, 0x7d, 0xa2, 0x27, 0x4c, 0x36, 0x3d, 0x45, 0x6e, 0x6e, 0x81, 0x8c, 0x55, 0x73, 0x36, 0xe5, 0x30, 0x23, 0x92, 0xa2, 0x31, 0xb7, 0xfd, 0xf5, 0xed, 0x6c, 0x38, 0xd9, 0xdc, 0x90 }, { 0xac, 0x58, 0x7d, 0xc5, 0x88, 0xd4, 0x39, 0x22, 0x30, 0xa8, 0x1e, 0xfd, 0xcb, 0x4b, 0xa8, 0xe0, 0x15, 0xea, 0xe3, 0x61, 0xfa, 0x5c, 0x56, 0x69, 0xe8, 0x9c, 0xea, 0xe7, 0x74, 0x2c, 0x5e, 0x6e }, { 0xe8, 0xc7, 0xbc, 0x3c, 0xf6, 0x4b, 0x16, 0x34, 0x94, 0x36, 0xfd, 0x72, 0x8b, 0x48, 0xd8, 0xfd, 0x84, 0xd7, 0xf2, 0x35, 0xda, 0xb6, 0x21, 0xb1, 0xcc, 0x93, 0xb4, 0xa5, 0xf0, 0x66, 0x69, 0x8c }, { 0x8f, 0x71, 0x7c, 0xbd, 0x0d, 0x82, 0x73, 0xf3, 0x14, 0x43, 0x71, 0xf1, 0xe5, 0xa0, 0x32, 0x84, 0x30, 0xca, 0xa8, 0xd2, 0x68, 0x31, 0xf0, 0x3f, 0xe0, 0x39, 0xfe, 0x11, 0x33, 0x15, 0x6a, 0x0b }, { 0xeb, 0x0a, 0x46, 0x3b, 0xb2, 0x14, 0x83, 0x17, 0x54, 0xad, 0xd0, 0x39, 0x88, 0xaa, 0xe7, 0x34, 0xd5, 0x8d, 0xe3, 0x28, 0xb0, 0x7e, 0x6f, 0x13, 0x51, 0x90, 0x5a, 0x37, 0x62, 0xfe, 0xeb, 0xe0 }, { 0x66, 0x93, 0x47, 0xef, 0xc2, 0xc9, 0x11, 0x1b, 0xbc, 0xe1, 0xd4, 0x97, 0x25, 0x60, 0xec, 0x21, 0xae, 0x71, 0x53, 0x27, 0xc1, 0x32, 0x57, 0x15, 0x18, 0xa0, 0xd0, 0xff, 0x69, 0x7a, 0x07, 0xcd }, { 0xc9, 0x9e, 0x3e, 0xf1, 0x45, 0x5e, 0x28, 0x56, 0xf5, 0xef, 0x07, 0xd6, 0x22, 0x7b, 0x1a, 0x37, 0xed, 0xa6, 0x52, 0xdb, 0x8f, 0x50, 0xea, 0x4b, 0xcb, 0x95, 0x25, 0x02, 0x76, 0xee, 0x3b, 0x0e }, { 0x48, 0x68, 0x3f, 0xf1, 0x93, 0x9b, 0x4e, 0x78, 0x17, 0x9b, 0x18, 0xd8, 0x1d, 0xab, 0x05, 0xe7, 0xdc, 0x46, 0xd8, 0x5e, 0xb3, 0x56, 0x59, 0xb4, 0xf7, 0x14, 0x5b, 0xc3, 0x38, 0x19, 0x90, 0x11 }, { 0x92, 0xd3, 0x39, 0xd3, 0x78, 0x85, 0x5a, 0x78, 0xb3, 0xaa, 0x7b, 0xe9, 0x6e, 0xf3, 0x66, 0xb8, 0x72, 0x03, 0x1b, 0x09, 0x93, 0xae, 0x15, 0xf3, 0x5b, 0xc7, 0xd4, 0x8e, 0x88, 0xf2, 0xdb, 0x69 }, { 0x38, 0xde, 0xa4, 0x2a, 0x9f, 0x43, 0x83, 0x3b, 0xc6, 0x31, 0x28, 0x42, 0xe3, 0xa3, 0xcb, 0x4b, 0x6f, 0xb4, 0xb2, 0xfa, 0x96, 0xd4, 0x62, 0x32, 0x85, 0xb5, 0xa1, 0x36, 0x7c, 0xa8, 0xea, 0x11 }, { 0x6c, 0xe0, 0x00, 0x8f, 0xb8, 0x8d, 0xe2, 0xb5, 0x60, 0xec, 0x42, 0x6a, 0xce, 0x1f, 0xd7, 0xce, 0x40, 0xf9, 0x5d, 0xf7, 0x5e, 0xcd, 0x3b, 0x59, 0xa1, 0xa0, 0xb4, 0x32, 0x6b, 0x30, 0xce, 0x3e }, { 0x0f, 0x5e, 0x51, 0xd3, 0x7c, 0xbc, 0x39, 0x25, 0x5c, 0xe0, 0x50, 0x23, 0x5e, 0x15, 0x22, 0xcc, 0x17, 0x5a, 0xbf, 0xf1, 0xb2, 0x2f, 0x3b, 0x21, 0x1c, 0x2f, 0xb6, 0x52, 0xd7, 0x5d, 0x52, 0x0d }, { 0xba, 0x03, 0x41, 0xba, 0x66, 0xb3, 0x9d, 0x26, 0x94, 0xfb, 0xdd, 0x9b, 0xfc, 0xa9, 0xa7, 0x98, 0x52, 0x45, 0x02, 0x6a, 0xb3, 0xe5, 0xac, 0xfb, 0x6d, 0x2a, 0xf4, 0xb2, 0x7e, 0x3b, 0x4a, 0x80 }, { 0x35, 0x92, 0xcf, 0xcc, 0xbd, 0xb2, 0x6a, 0x95, 0x73, 0xec, 0x93, 0xc6, 0x71, 0xa6, 0x9c, 0x95, 0xea, 0x9c, 0x9e, 0x8a, 0x1c, 0x10, 0xbd, 0x73, 0x9d, 0x26, 0x74, 0xdb, 0x5b, 0x91, 0xd0, 0x39 }, { 0x51, 0xf0, 0x4e, 0x84, 0xa1, 0x77, 0x1e, 0x27, 0xbb, 0x2c, 0xea, 0x89, 0xed, 0x4c, 0x6d, 0x2e, 0x51, 0xfa, 0x1b, 0xb4, 0xa1, 0xa1, 0x92, 0xf4, 0x7e, 0x30, 0x6c, 0x61, 0xda, 0xc4, 0x5c, 0x3c }, { 0x42, 0xdc, 0x66, 0x44, 0xc1, 0xa5, 0x63, 0x9b, 0x50, 0xc0, 0x77, 0x8a, 0xd8, 0xc9, 0x8b, 0x5e, 0xb6, 0xaa, 0x9b, 0xd3, 0x47, 0x92, 0xcb, 0x06, 0x56, 0x7e, 0x15, 0xcc, 0x50, 0xe0, 0x36, 0x0c }, { 0xb6, 0x07, 0x96, 0x31, 0xdc, 0x85, 0xa7, 0xa6, 0xde, 0x4d, 0x35, 0x79, 0xbb, 0xc6, 0x25, 0xe4, 0x92, 0x8c, 0x35, 0x0f, 0x13, 0x13, 0xa9, 0x9e, 0x9b, 0xa4, 0x3c, 0x2e, 0xf8, 0x61, 0x40, 0x16 }, { 0xaf, 0xab, 0x45, 0x64, 0x69, 0x7d, 0xa7, 0x50, 0x9a, 0xa0, 0x44, 0x96, 0x1a, 0xa1, 0xd7, 0x91, 0x03, 0x4d, 0xc6, 0x3a, 0x2f, 0xa4, 0x12, 0x89, 0x02, 0x6d, 0x99, 0xd4, 0x5f, 0xae, 0xcb, 0xa1 }, { 0x26, 0x7e, 0x66, 0x7f, 0x3d, 0x98, 0x43, 0x41, 0x0d, 0xc5, 0x55, 0x87, 0x20, 0xc4, 0xed, 0x46, 0x06, 0x10, 0x20, 0x21, 0x2f, 0x36, 0x64, 0xd2, 0x7d, 0x8d, 0x00, 0xd4, 0x05, 0x89, 0x5e, 0x25 }, { 0x44, 0xe1, 0x94, 0xe2, 0xdf, 0x43, 0xa8, 0x31, 0xd7, 0x1f, 0xd8, 0xb4, 0x78, 0x30, 0x7d, 0xe7, 0xe5, 0x9f, 0x1c, 0xd2, 0x79, 0x43, 0xf8, 0x9d, 0x97, 0x0c, 0xaf, 0x8a, 0x9a, 0x7c, 0x2c, 0x90 }, { 0x79, 0xa4, 0x11, 0x74, 0x8c, 0xde, 0x56, 0x27, 0x41, 0x17, 0xc3, 0xbb, 0xa3, 0x2b, 0x51, 0x73, 0x11, 0xb2, 0x0e, 0x00, 0xbf, 0x42, 0x6e, 0xf0, 0x37, 0x7c, 0x56, 0x66, 0xfe, 0xbc, 0x7a, 0xe4 }, { 0x1e, 0xdd, 0x1d, 0xee, 0x26, 0xed, 0xa2, 0x49, 0x80, 0x1b, 0xc7, 0xe3, 0x64, 0xe3, 0xba, 0x7c, 0x4b, 0xd6, 0x45, 0xd9, 0x39, 0x0a, 0x23, 0x06, 0xa1, 0x29, 0x0c, 0x9f, 0x6e, 0xcb, 0xfa, 0xc9 }, { 0x4b, 0x23, 0x64, 0xb8, 0x86, 0x91, 0x89, 0x0e, 0x2c, 0x88, 0x96, 0x89, 0xdb, 0x7c, 0x6e, 0xeb, 0xb8, 0xc5, 0xaf, 0x8e, 0xbb, 0x33, 0x37, 0x2c, 0x0f, 0x16, 0xc8, 0x6a, 0x55, 0xfd, 0xe0, 0xb9 }, { 0xfe, 0xca, 0x1b, 0x2b, 0xd1, 0xf9, 0xfb, 0x8d, 0xa8, 0x11, 0x43, 0xa8, 0x67, 0xf5, 0x0a, 0xdc, 0xd2, 0x3e, 0x8e, 0x0c, 0x59, 0xf1, 0x69, 0xca, 0xf1, 0xbf, 0x21, 0xff, 0x6c, 0x84, 0xbb, 0xe1 }, { 0x7d, 0xa8, 0xb2, 0xf6, 0x62, 0x3c, 0x61, 0xd7, 0xf5, 0xb6, 0x64, 0x0b, 0xed, 0x42, 0x13, 0x6d, 0x94, 0x4e, 0xd1, 0x44, 0xdc, 0xea, 0x01, 0xb2, 0x83, 0x0f, 0xe0, 0xcc, 0x55, 0xcf, 0xda, 0x60 }, { 0x39, 0x1a, 0x7c, 0x85, 0xa1, 0x72, 0x5a, 0xa5, 0xd0, 0x60, 0x49, 0x9d, 0x3a, 0x9e, 0x25, 0x4a, 0x5f, 0x93, 0xec, 0x9d, 0x40, 0x4f, 0x68, 0xc4, 0x32, 0xca, 0xea, 0x3b, 0xd1, 0xbe, 0xc8, 0x36 }, { 0xfd, 0x13, 0xfa, 0x71, 0x27, 0x80, 0x83, 0xa7, 0x46, 0xc3, 0x9e, 0xff, 0xb7, 0x14, 0x0a, 0x0c, 0x3e, 0x81, 0xa8, 0x1c, 0x0c, 0xbb, 0x49, 0x36, 0x83, 0xbf, 0x7b, 0x58, 0x7c, 0x12, 0xe0, 0xa1 }, { 0xce, 0xa7, 0x0d, 0xba, 0xa9, 0xc1, 0xd6, 0xad, 0x18, 0x9b, 0x19, 0x94, 0x2e, 0xe2, 0xa6, 0xc8, 0x91, 0x6e, 0x4c, 0x67, 0xdb, 0x31, 0x51, 0xe4, 0xa4, 0x2c, 0x48, 0x97, 0x4f, 0x59, 0x13, 0xc0 }, { 0xe9, 0x7a, 0xfe, 0x2e, 0xef, 0x68, 0xf9, 0x43, 0x1a, 0x32, 0xc5, 0x4f, 0x5d, 0x29, 0x20, 0xee, 0xc8, 0xee, 0x14, 0x63, 0xf4, 0x82, 0x52, 0xf1, 0x15, 0x1a, 0x27, 0x6d, 0xe9, 0x4c, 0xd0, 0xe8 }, { 0x63, 0x90, 0xf9, 0x29, 0x10, 0x84, 0xbb, 0x68, 0x64, 0x6d, 0xf4, 0x44, 0x8a, 0xc9, 0x90, 0xd4, 0x9f, 0xe3, 0x12, 0x9a, 0x13, 0x4a, 0x6e, 0xcf, 0x16, 0x2b, 0x27, 0x50, 0xd5, 0x9f, 0x70, 0x92 }, { 0xdb, 0xe9, 0x07, 0x39, 0xbc, 0xff, 0xe5, 0x49, 0x70, 0x60, 0x5a, 0xaa, 0x4f, 0xf8, 0x7a, 0xa3, 0x47, 0x5f, 0x4b, 0xd8, 0xf8, 0x5d, 0x28, 0x34, 0x96, 0x88, 0x82, 0x35, 0x92, 0x3d, 0x60, 0x88 }, { 0xe3, 0x1f, 0xff, 0xe3, 0x41, 0x57, 0x6c, 0x3d, 0x89, 0xf9, 0x72, 0x34, 0x34, 0x58, 0x4e, 0xdd, 0x17, 0x32, 0xb5, 0xfc, 0x60, 0xcf, 0x95, 0xe3, 0xcb, 0xf5, 0x00, 0x40, 0x4c, 0xe7, 0x6a, 0x41 }, { 0x5d, 0x8b, 0x9c, 0x9c, 0x5c, 0x35, 0xf8, 0x46, 0x1c, 0x04, 0x41, 0x4f, 0x57, 0x6b, 0x1c, 0xe9, 0xcf, 0xcb, 0xfd, 0x9b, 0x3e, 0x88, 0xf1, 0x94, 0xa2, 0x25, 0x67, 0x52, 0xe4, 0xdd, 0x21, 0xde }, { 0x4e, 0x4d, 0xb8, 0xd4, 0x02, 0xc1, 0x29, 0x67, 0x67, 0x94, 0x84, 0xa2, 0x88, 0xb6, 0x40, 0x33, 0x56, 0xc5, 0x4f, 0xfe, 0x4c, 0x3b, 0xae, 0x1b, 0x40, 0xd3, 0xe0, 0x29, 0x27, 0xb2, 0x12, 0xb6 }, { 0xb1, 0xdc, 0x62, 0xf2, 0xdd, 0x58, 0x96, 0x55, 0x63, 0x16, 0x6b, 0x77, 0x9a, 0xe7, 0xb2, 0x26, 0x6a, 0xce, 0xb8, 0x5b, 0x87, 0x60, 0xa5, 0xd0, 0x9d, 0xd4, 0x50, 0x0b, 0x80, 0x73, 0x90, 0x3a }, { 0x70, 0xd3, 0xb7, 0x9d, 0x9e, 0x77, 0x81, 0xd3, 0x14, 0x3c, 0x13, 0x49, 0x51, 0xea, 0x21, 0x63, 0xe1, 0x3a, 0x5c, 0x93, 0xb1, 0x5d, 0xf9, 0xeb, 0x01, 0xe3, 0x85, 0x16, 0xc9, 0xea, 0x5f, 0xd6 }, { 0x6f, 0x5b, 0x8e, 0xec, 0x5c, 0xf9, 0x66, 0x21, 0xbf, 0x91, 0x24, 0xae, 0xee, 0xce, 0x5c, 0x7e, 0x58, 0x4d, 0x00, 0xac, 0x1f, 0x62, 0x2c, 0xdd, 0x60, 0x6c, 0xb4, 0x12, 0x49, 0x2b, 0xe3, 0x15 }, { 0x08, 0xc5, 0xeb, 0x90, 0x3f, 0x57, 0xbc, 0x70, 0xf6, 0xc7, 0xa1, 0x8f, 0xc8, 0x36, 0x61, 0xab, 0xe9, 0x7d, 0x3e, 0x4b, 0xbd, 0x9a, 0xf8, 0x1c, 0x66, 0xb3, 0x8b, 0x45, 0x02, 0x43, 0x0c, 0xc0 }, { 0xfe, 0xde, 0xaa, 0x11, 0x2c, 0x4f, 0x1f, 0x69, 0x36, 0x6e, 0xf6, 0x7d, 0xa3, 0x28, 0xd7, 0x82, 0xa2, 0x7a, 0x0e, 0x0a, 0x88, 0xa0, 0xf5, 0xe5, 0x3d, 0x9a, 0x8a, 0xe5, 0x86, 0x91, 0x60, 0x6b }, { 0xd0, 0xd0, 0x83, 0xd2, 0x86, 0x43, 0xb3, 0xde, 0x9c, 0xd7, 0x8c, 0x99, 0xb0, 0x14, 0xf2, 0x33, 0x39, 0xef, 0x1e, 0x8e, 0xe8, 0x2e, 0xa5, 0x02, 0x65, 0xc9, 0x4c, 0x85, 0xfb, 0x30, 0x8a, 0xd1 }, { 0x06, 0x14, 0x89, 0xa3, 0x69, 0xf1, 0x64, 0xaa, 0x16, 0xec, 0x74, 0x38, 0xaa, 0x89, 0xe8, 0x0c, 0x3a, 0x0c, 0x29, 0x5b, 0x9b, 0xc4, 0x6f, 0x8c, 0x4d, 0x44, 0x76, 0xe9, 0x4d, 0x57, 0x6a, 0x07 }, { 0xd9, 0xa8, 0x01, 0x4e, 0xa3, 0xb5, 0x94, 0xa3, 0x32, 0xbc, 0x97, 0x38, 0xfc, 0xae, 0x27, 0x79, 0xe2, 0x60, 0x41, 0x1e, 0x0b, 0x7e, 0x30, 0xad, 0x3e, 0xa4, 0x20, 0x99, 0x2a, 0x3b, 0x1a, 0xa5 }, { 0x14, 0x37, 0x4d, 0x46, 0xf0, 0xe6, 0xdb, 0x81, 0x9c, 0xeb, 0x4f, 0x56, 0xb7, 0x61, 0xef, 0x88, 0xbb, 0x76, 0xf9, 0x71, 0x42, 0xaa, 0xa6, 0x21, 0xe1, 0x54, 0x65, 0x4a, 0xbb, 0x95, 0xbb, 0x67 }, { 0xa3, 0x7b, 0x4c, 0x68, 0xb6, 0xd5, 0x66, 0xac, 0x64, 0x61, 0xe8, 0x63, 0xbf, 0x6d, 0x78, 0x08, 0xd7, 0xb7, 0x34, 0x25, 0xa3, 0x5a, 0xb5, 0x32, 0x57, 0x68, 0xf7, 0x94, 0x87, 0xc2, 0x96, 0x69 }, { 0xe1, 0x1c, 0xd1, 0xda, 0x19, 0x6b, 0x4d, 0x8c, 0xfe, 0x0b, 0xf3, 0x51, 0xaa, 0x31, 0x17, 0x93, 0xa4, 0x3c, 0x47, 0x26, 0xee, 0x14, 0xee, 0x86, 0x14, 0x09, 0x41, 0x1f, 0xf1, 0x4c, 0xd4, 0xf0 }, { 0xe3, 0x69, 0x88, 0x83, 0xf9, 0x71, 0x5f, 0x9f, 0xcb, 0xef, 0xeb, 0x78, 0x33, 0x90, 0x37, 0xf3, 0x5f, 0xf1, 0x43, 0xec, 0x0a, 0x4b, 0x95, 0xa0, 0x63, 0x77, 0x34, 0xa4, 0xd1, 0xb8, 0x56, 0x5c }, { 0x91, 0xec, 0x4e, 0x0d, 0x3f, 0x41, 0xdb, 0x57, 0xd5, 0x37, 0x2d, 0xc3, 0x5e, 0xb8, 0x8d, 0xbb, 0x7a, 0x81, 0x12, 0x9f, 0xfe, 0xf6, 0x11, 0x3f, 0xdb, 0x5a, 0x46, 0xab, 0xc4, 0x52, 0x5f, 0x8f }, { 0xb3, 0x6b, 0xca, 0x6c, 0x55, 0x48, 0xd7, 0x5d, 0xbc, 0xb4, 0x79, 0x02, 0x7f, 0xff, 0x82, 0x9d, 0xd7, 0xe3, 0x90, 0xe2, 0xa7, 0xa5, 0xac, 0xb5, 0x4f, 0xee, 0xb1, 0x69, 0x27, 0x5a, 0x8d, 0xeb }, { 0x66, 0x59, 0x23, 0xb5, 0x3e, 0xb8, 0x55, 0xcc, 0x0b, 0xfc, 0x7c, 0x7a, 0xac, 0x6a, 0xba, 0xcc, 0x21, 0x0c, 0x2f, 0x23, 0xda, 0x73, 0x64, 0x14, 0x8b, 0x1e, 0xe3, 0x2e, 0xa1, 0x06, 0xb6, 0xa3 }, { 0xed, 0x47, 0x77, 0xb9, 0x78, 0x54, 0x14, 0xa5, 0xc5, 0x87, 0xec, 0xba, 0x5f, 0xf2, 0x39, 0xf2, 0x1c, 0x33, 0xaa, 0x42, 0x7d, 0xcc, 0x00, 0xae, 0x65, 0x5e, 0x96, 0xc5, 0xff, 0x94, 0x95, 0x75 }, { 0x7b, 0xe9, 0x2c, 0xfe, 0x49, 0x56, 0xb5, 0x2d, 0x3d, 0xef, 0xbe, 0x52, 0x03, 0xb0, 0x3d, 0xfd, 0x36, 0x56, 0x4e, 0x4d, 0x22, 0xe5, 0x9f, 0xcf, 0xe3, 0x7f, 0x4f, 0xed, 0xa5, 0x82, 0x4e, 0xc5 }, { 0x05, 0x5c, 0xf1, 0xf3, 0xfb, 0x88, 0x06, 0xbe, 0x29, 0x43, 0x00, 0x26, 0xbb, 0xc5, 0x5f, 0x5b, 0x06, 0x24, 0x9d, 0x75, 0x38, 0x32, 0x21, 0xb5, 0x07, 0x43, 0xac, 0x33, 0xd8, 0xa2, 0x3d, 0x0f }, { 0x9c, 0x5c, 0x6e, 0x72, 0xcb, 0xb9, 0xff, 0xcb, 0x0c, 0x07, 0x4e, 0x1a, 0xb9, 0x41, 0x33, 0xa2, 0x07, 0xf2, 0x23, 0x1b, 0x55, 0x76, 0xda, 0x2f, 0x7c, 0xaa, 0xc1, 0xb8, 0xba, 0xcf, 0x2f, 0x93 } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t keys3_128bit[ 100 ][ 32 ] = { { 0xfb, 0xef, 0x31, 0xbf, 0x8a, 0xa7, 0x54, 0x6b, 0x52, 0x68, 0x6b, 0xe2, 0xa6, 0x60, 0x19, 0xa1, 0x5e, 0xa8, 0x38, 0x33, 0x65, 0x49, 0x01, 0xf6, 0xdc, 0x52, 0x60, 0x3a, 0xe6, 0x55, 0x79, 0xea }, { 0xd8, 0x06, 0xb8, 0x52, 0xed, 0xb2, 0x97, 0x07, 0xf3, 0xe9, 0x4a, 0xc5, 0x2f, 0x43, 0xd3, 0x5a, 0x23, 0xa9, 0xb4, 0xb3, 0xbe, 0x81, 0x71, 0xa4, 0x69, 0x05, 0x16, 0xda, 0x12, 0xb2, 0x04, 0x0a }, { 0xe4, 0xb9, 0x2f, 0xa6, 0x2c, 0x5f, 0x09, 0x39, 0x49, 0xd1, 0xdf, 0xd4, 0x9d, 0x30, 0x0e, 0x1b, 0x73, 0x41, 0x5a, 0x17, 0x63, 0x15, 0xb9, 0x21, 0xe7, 0x0f, 0xd4, 0x9e, 0x6b, 0xa6, 0x34, 0xe1 }, { 0xa0, 0x37, 0xca, 0x87, 0xa6, 0x44, 0xb5, 0xd3, 0x09, 0x27, 0xae, 0xff, 0x1b, 0x31, 0xf9, 0x7c, 0x5f, 0x19, 0xe4, 0x28, 0xe9, 0x72, 0xb8, 0xc6, 0x85, 0xc1, 0x9e, 0x17, 0x92, 0x47, 0x44, 0xf4 }, { 0x40, 0x4d, 0x27, 0x0f, 0x41, 0x5c, 0xfa, 0xba, 0xc6, 0x21, 0x47, 0x0b, 0x35, 0xd8, 0x7a, 0x27, 0xd4, 0x1e, 0x6b, 0x40, 0xbc, 0x5f, 0x4c, 0x4c, 0x9c, 0xba, 0x13, 0x55, 0x80, 0x47, 0xdc, 0x26 }, { 0xc3, 0x3c, 0x5f, 0x68, 0x88, 0xaf, 0x22, 0x8a, 0xf4, 0x0f, 0xcc, 0x92, 0x7f, 0x7c, 0xcf, 0x54, 0x80, 0xdd, 0xea, 0xc7, 0x91, 0x98, 0x36, 0x3e, 0xc2, 0x7a, 0x06, 0x77, 0x8c, 0x7e, 0x97, 0xd0 }, { 0xfc, 0xc2, 0x44, 0xbb, 0x1d, 0x01, 0xe3, 0x37, 0x6c, 0xe8, 0xc6, 0x78, 0x37, 0xec, 0x39, 0x26, 0xcb, 0x71, 0xad, 0x57, 0x27, 0x0a, 0xd7, 0x4e, 0xe0, 0x17, 0xa4, 0x3e, 0x44, 0x04, 0x8c, 0x68 }, { 0xe3, 0x47, 0xaa, 0x19, 0x83, 0x6f, 0xe5, 0x6b, 0x33, 0x3a, 0x1a, 0x3d, 0xcf, 0xcf, 0x38, 0xf9, 0xd3, 0xe6, 0xa8, 0xf6, 0x5e, 0x02, 0xbc, 0x15, 0x4e, 0x4c, 0x6e, 0x6e, 0xa5, 0x7f, 0x1b, 0x4a }, { 0xa9, 0x2d, 0x85, 0xc2, 0x91, 0x68, 0x73, 0x8c, 0xdc, 0xcc, 0x19, 0xb8, 0x34, 0x3c, 0x24, 0x14, 0x34, 0xd0, 0xe0, 0x05, 0x53, 0xb0, 0xe1, 0x4b, 0xba, 0x86, 0xc6, 0x23, 0x24, 0xd4, 0x3d, 0x61 }, { 0x2b, 0xbf, 0x7c, 0xdc, 0x0e, 0x46, 0x71, 0x66, 0x03, 0x7b, 0x99, 0x51, 0x01, 0xd6, 0xa4, 0xc2, 0x48, 0xe3, 0x85, 0xa5, 0x9d, 0xc5, 0x60, 0x1c, 0x64, 0x21, 0x2d, 0xff, 0x72, 0x24, 0x35, 0x78 }, { 0xe8, 0xdf, 0x65, 0xc6, 0x35, 0xda, 0xea, 0x1f, 0x8e, 0x16, 0x34, 0x4b, 0x7c, 0xb7, 0x20, 0xe5, 0x96, 0x26, 0x4e, 0x38, 0x63, 0xc3, 0x58, 0xbf, 0xc7, 0xaa, 0x47, 0xad, 0x99, 0x85, 0x16, 0xa5 }, { 0x17, 0xbe, 0xb5, 0x10, 0xf6, 0x84, 0xf6, 0x44, 0x84, 0x90, 0x4b, 0x1d, 0xde, 0x68, 0x03, 0x8d, 0xa6, 0xb6, 0xaa, 0xee, 0x61, 0x1b, 0xaf, 0xb4, 0x92, 0xed, 0x1c, 0x60, 0x85, 0x93, 0xb1, 0x18 }, { 0x6e, 0xfb, 0x57, 0x2d, 0xe4, 0xe6, 0xa5, 0x88, 0xc4, 0x3c, 0x7a, 0xfa, 0x9f, 0xc4, 0xf5, 0x86, 0x50, 0xbe, 0xa1, 0x5d, 0x71, 0x3f, 0x58, 0xfc, 0x27, 0x3c, 0x97, 0xd4, 0x92, 0x17, 0x7f, 0x2c }, { 0x2e, 0x52, 0xf5, 0x9e, 0xbe, 0xc3, 0x35, 0x06, 0x00, 0x0c, 0x2d, 0x05, 0xaa, 0x3b, 0xc8, 0x04, 0x7f, 0x57, 0x98, 0xfc, 0x07, 0x36, 0x45, 0x6a, 0x0d, 0x3e, 0xd0, 0x9d, 0x86, 0xb9, 0xc3, 0x6a }, { 0x13, 0xcb, 0xc3, 0xbb, 0xfa, 0x82, 0x16, 0xa7, 0xd9, 0x56, 0xb5, 0xf7, 0x39, 0x1e, 0x0a, 0x9d, 0x82, 0xcf, 0xf5, 0x59, 0x26, 0x3d, 0x3e, 0xc7, 0xe0, 0xd1, 0xe9, 0x8a, 0x5d, 0x0e, 0x3b, 0x94 }, { 0x93, 0xd5, 0xeb, 0x3e, 0x9b, 0x51, 0x3a, 0x5a, 0x86, 0xcf, 0x7a, 0x84, 0x22, 0xa4, 0x41, 0x1c, 0x16, 0x4d, 0x70, 0xd1, 0x81, 0x4c, 0x27, 0x5c, 0xae, 0x56, 0xde, 0x09, 0x95, 0xe2, 0xc3, 0x96 }, { 0x9e, 0x29, 0x15, 0x47, 0xfc, 0x0f, 0x7a, 0x31, 0xc6, 0x33, 0x0a, 0x34, 0x87, 0x1c, 0x49, 0xc7, 0x3e, 0xbc, 0x24, 0x5d, 0xdc, 0xb5, 0x0c, 0x07, 0x6c, 0xf5, 0x7a, 0x07, 0x9c, 0x84, 0x5f, 0x9c }, { 0xb3, 0x92, 0x08, 0xc7, 0xf5, 0x2f, 0x6d, 0xbe, 0x67, 0x81, 0x7d, 0x83, 0xa8, 0xb6, 0xa5, 0x39, 0xbb, 0xaa, 0xea, 0x87, 0x7f, 0x2e, 0xbc, 0xd1, 0x8d, 0x70, 0x21, 0xb3, 0x2f, 0xe7, 0xf6, 0x1e }, { 0x04, 0x1d, 0xc3, 0xf6, 0xba, 0x6c, 0x6a, 0x2f, 0xfb, 0x55, 0x4c, 0x61, 0xf0, 0xcf, 0x14, 0x52, 0x07, 0x1e, 0x0d, 0x84, 0xad, 0xeb, 0xa3, 0xd1, 0x6c, 0xfc, 0x86, 0x56, 0x4f, 0x47, 0xd0, 0x5f }, { 0xac, 0x4f, 0xc0, 0xdf, 0xc3, 0x16, 0xcb, 0x26, 0x8a, 0x2f, 0xad, 0xa3, 0x77, 0xb4, 0x33, 0xa6, 0xc4, 0xc1, 0x5d, 0xd2, 0x52, 0x14, 0x76, 0x2c, 0x7d, 0x5f, 0x4b, 0x8f, 0x30, 0x39, 0x70, 0x88 }, { 0xc8, 0xee, 0xe8, 0x09, 0x91, 0x01, 0x65, 0xfb, 0x5d, 0xd9, 0x7b, 0x96, 0xe8, 0xf7, 0x1e, 0x69, 0x57, 0xb0, 0xe5, 0x2d, 0x1f, 0x73, 0x36, 0x18, 0x57, 0x09, 0x06, 0xd1, 0x4c, 0x40, 0xec, 0x2f }, { 0x08, 0x8a, 0x93, 0x9d, 0x92, 0x14, 0xf5, 0x6b, 0x5d, 0xed, 0x3c, 0xad, 0xcb, 0x34, 0x5b, 0xbf, 0x83, 0x86, 0xaa, 0xb3, 0x9c, 0x66, 0xd3, 0x6a, 0xe7, 0x49, 0xb2, 0x8e, 0x0d, 0xc0, 0x24, 0x4e }, { 0xbf, 0xd3, 0x85, 0xf0, 0xc1, 0xf8, 0x2b, 0xee, 0xef, 0xda, 0x68, 0x22, 0x3e, 0x88, 0x66, 0xba, 0xd2, 0xa6, 0x9b, 0xe6, 0x6c, 0x32, 0xdf, 0x1e, 0x80, 0xee, 0x59, 0x85, 0x63, 0xaa, 0x7a, 0x47 }, { 0xee, 0x74, 0xd7, 0x21, 0xfb, 0x5a, 0xbd, 0x72, 0x37, 0x21, 0x3f, 0xfb, 0x32, 0x59, 0xe6, 0xd6, 0xd3, 0x71, 0xed, 0xd6, 0xbe, 0x98, 0x10, 0x2e, 0x7c, 0xdf, 0x9f, 0x38, 0x6b, 0x2c, 0x3c, 0xe8 }, { 0x48, 0xd1, 0x3c, 0x82, 0x59, 0xe9, 0x9e, 0xa6, 0x01, 0xb7, 0x8c, 0xbb, 0xc1, 0x03, 0x89, 0x98, 0x5f, 0x49, 0xf1, 0xc8, 0xcf, 0x83, 0x2f, 0xcb, 0xfa, 0x39, 0x85, 0xf8, 0x7b, 0xa8, 0xc0, 0x32 }, { 0x4e, 0xec, 0xca, 0xd5, 0x7d, 0x35, 0x0e, 0xc0, 0xe7, 0x04, 0x65, 0xa1, 0xcd, 0x7d, 0x8f, 0x1c, 0xd2, 0xbd, 0x71, 0x57, 0xb1, 0xde, 0xab, 0x22, 0x67, 0x5b, 0x60, 0x0c, 0x99, 0xb4, 0xcc, 0xf0 }, { 0xe7, 0x42, 0x94, 0xe1, 0x71, 0x3e, 0x59, 0x82, 0x21, 0x41, 0x85, 0x3a, 0x5e, 0xf8, 0xe9, 0xff, 0xdf, 0x98, 0xf4, 0xf4, 0x70, 0x64, 0x64, 0xbd, 0xa9, 0xb9, 0x75, 0x78, 0x7b, 0xb7, 0x89, 0xe9 }, { 0x10, 0x3d, 0xf8, 0x84, 0xb1, 0xcb, 0x8f, 0x24, 0x98, 0xde, 0x1e, 0x7f, 0x68, 0x1c, 0x44, 0x55, 0xdf, 0x56, 0xf7, 0x19, 0xc2, 0x06, 0xdd, 0x25, 0x0f, 0x83, 0xdc, 0x74, 0x50, 0x8c, 0x1a, 0x6a }, { 0x26, 0x24, 0x7d, 0x33, 0xf2, 0xb7, 0xe9, 0xe0, 0x6a, 0x2e, 0xe4, 0x83, 0x3e, 0x81, 0x4d, 0x99, 0x25, 0x73, 0xa8, 0x34, 0x3f, 0x47, 0x62, 0xe1, 0x45, 0x4b, 0x0b, 0xbb, 0xd1, 0x52, 0x5a, 0xe4 }, { 0x75, 0x79, 0x9c, 0xb6, 0x75, 0x9a, 0x2e, 0xdd, 0xfe, 0x99, 0x63, 0x97, 0x34, 0x91, 0x10, 0x2e, 0xe9, 0x65, 0x3b, 0xf0, 0x32, 0x0c, 0x1b, 0x32, 0x24, 0xfd, 0x4e, 0x7a, 0x30, 0x80, 0x88, 0xe3 }, { 0xb5, 0xcc, 0xec, 0xb5, 0x54, 0xfb, 0xa1, 0x09, 0x2b, 0xcc, 0x54, 0x6e, 0x03, 0x35, 0xa7, 0x5b, 0x07, 0xbd, 0xb2, 0x34, 0xc5, 0x52, 0xe4, 0x17, 0x2e, 0x73, 0x33, 0x15, 0x88, 0xd6, 0xa3, 0x14 }, { 0x9f, 0x94, 0xa3, 0x98, 0xe0, 0x32, 0xc2, 0x60, 0x81, 0x67, 0xad, 0x53, 0x8b, 0x7f, 0xaf, 0x92, 0xd0, 0x1f, 0xba, 0x0c, 0xbc, 0xe9, 0xb1, 0x38, 0x57, 0x36, 0xe3, 0x13, 0x72, 0x38, 0x9e, 0x10 }, { 0x5d, 0x3f, 0xb4, 0x68, 0xb2, 0x6e, 0xa0, 0x2e, 0x5f, 0xf7, 0x72, 0xb9, 0xdf, 0x6c, 0x6c, 0x98, 0xa7, 0xe2, 0x8c, 0x5e, 0x67, 0xa9, 0xb1, 0x6b, 0x8a, 0x44, 0xd2, 0xc6, 0x8e, 0x43, 0x6f, 0x8a }, { 0x9b, 0xde, 0x31, 0xa8, 0xf1, 0xa4, 0xa3, 0xb5, 0x46, 0xbb, 0x70, 0xc8, 0xd4, 0x99, 0x11, 0xf9, 0xa3, 0x2b, 0x75, 0x91, 0xb5, 0x51, 0xe5, 0xc9, 0xb8, 0x50, 0x6c, 0x33, 0xb2, 0x15, 0x2b, 0x68 }, { 0x1e, 0x10, 0x50, 0x65, 0x57, 0xa0, 0xa1, 0xc5, 0x39, 0x7d, 0x14, 0x16, 0xeb, 0x4d, 0x99, 0x4c, 0x90, 0x71, 0x61, 0x70, 0x1f, 0xce, 0x00, 0x15, 0x7a, 0xed, 0xe9, 0xd5, 0xab, 0x38, 0x15, 0x8d }, { 0x5d, 0x77, 0x3f, 0x41, 0x3d, 0xc5, 0x14, 0xf4, 0xe6, 0x44, 0x41, 0x97, 0x0a, 0x66, 0xac, 0x36, 0xdd, 0xc3, 0x52, 0x92, 0x42, 0x36, 0xc9, 0x48, 0x38, 0x4d, 0xd5, 0x11, 0x6e, 0xa7, 0x3b, 0x0f }, { 0x49, 0xe4, 0x63, 0x93, 0x10, 0xb6, 0xa2, 0xdd, 0x5e, 0xe9, 0x0b, 0x69, 0xed, 0x4d, 0xcf, 0xd7, 0x68, 0xd5, 0x14, 0x25, 0x4e, 0xeb, 0x7e, 0xd5, 0x59, 0xc8, 0x64, 0xd5, 0x67, 0xa6, 0xd1, 0xa9 }, { 0xe7, 0xb8, 0x27, 0xbc, 0xd5, 0x0c, 0x71, 0xb1, 0x98, 0x6a, 0x52, 0x67, 0x45, 0x84, 0x72, 0x81, 0xa4, 0xa7, 0xa6, 0x9a, 0x8d, 0x01, 0x90, 0x16, 0x41, 0x2f, 0xe2, 0xba, 0x74, 0xbc, 0xd3, 0xb7 }, { 0xab, 0x11, 0x93, 0xe2, 0x73, 0x7f, 0x28, 0x2d, 0x6a, 0x0d, 0x29, 0x93, 0x26, 0x00, 0xc4, 0xe4, 0x08, 0xc8, 0xf1, 0x94, 0x90, 0x69, 0x78, 0xfe, 0x2f, 0x9f, 0x56, 0xb2, 0xcb, 0x98, 0xea, 0x83 }, { 0x82, 0xbe, 0x68, 0x29, 0x8b, 0xde, 0xa7, 0x56, 0x25, 0x47, 0xe6, 0x8b, 0x9f, 0xba, 0xfd, 0x43, 0x06, 0xf5, 0x7d, 0x3d, 0xf9, 0xcd, 0x91, 0xa9, 0x32, 0x5b, 0x54, 0x09, 0x7d, 0x2d, 0x7f, 0x5b }, { 0xb7, 0xce, 0x95, 0x7c, 0x67, 0xac, 0xc5, 0x23, 0xf9, 0x63, 0xd0, 0x75, 0x32, 0xa9, 0xf8, 0x29, 0xef, 0x15, 0x3b, 0x03, 0x46, 0x26, 0x02, 0xaa, 0x9d, 0x57, 0x36, 0x7c, 0x96, 0xd6, 0x19, 0x41 }, { 0x44, 0x4b, 0xd7, 0xe1, 0x1e, 0xf0, 0x1e, 0x89, 0x0b, 0x32, 0x76, 0x43, 0x11, 0xd6, 0x45, 0x06, 0xc3, 0x60, 0xfd, 0xf4, 0x10, 0xef, 0x8a, 0x77, 0xf2, 0x67, 0x16, 0xb1, 0xd1, 0xbe, 0x43, 0xe4 }, { 0x5e, 0xaf, 0xe0, 0x53, 0x62, 0xed, 0xdd, 0x05, 0xef, 0xfc, 0xb2, 0x44, 0x78, 0x96, 0xe7, 0x44, 0x0f, 0x38, 0xc6, 0x55, 0x27, 0x6b, 0x6c, 0x7f, 0xba, 0xe0, 0x03, 0xa3, 0x87, 0xd1, 0x0c, 0x96 }, { 0x89, 0xda, 0xe9, 0x26, 0x21, 0xba, 0x5a, 0x25, 0x9c, 0x6b, 0xe4, 0xc8, 0x2d, 0x0e, 0xee, 0xb1, 0x18, 0x51, 0xce, 0x00, 0xeb, 0x37, 0xda, 0xdf, 0x77, 0x0f, 0x68, 0xf4, 0x4a, 0x31, 0x0a, 0x9c }, { 0x1f, 0xb0, 0x4d, 0xac, 0x75, 0xdf, 0x2a, 0x61, 0x6f, 0x49, 0x7f, 0xdd, 0x35, 0xce, 0x59, 0x29, 0xe6, 0x12, 0xf0, 0x51, 0x47, 0xdc, 0xa4, 0x18, 0x3e, 0x47, 0x86, 0xff, 0xd2, 0xae, 0x9b, 0x29 }, { 0x2f, 0xfe, 0x28, 0x66, 0xd6, 0xfa, 0x82, 0xa7, 0x5d, 0x2f, 0xcf, 0x25, 0x72, 0x57, 0x70, 0x83, 0x36, 0x77, 0x56, 0x84, 0xaa, 0xce, 0x66, 0x25, 0xac, 0xe0, 0xed, 0x4a, 0x8f, 0xd8, 0x9e, 0x67 }, { 0x77, 0x41, 0xd5, 0xc2, 0x1c, 0x34, 0xaf, 0x08, 0x30, 0x01, 0xdb, 0xde, 0x39, 0x22, 0xe7, 0x87, 0xb3, 0xd6, 0xed, 0x22, 0x42, 0xb8, 0x76, 0xfd, 0xae, 0x62, 0x66, 0xb7, 0xd7, 0xa9, 0x7c, 0x9b }, { 0xa4, 0x8e, 0x8b, 0x31, 0x88, 0x56, 0x24, 0x0f, 0x5f, 0x70, 0x3a, 0x0d, 0x92, 0xa1, 0x9f, 0x8b, 0x26, 0xb0, 0x60, 0xd1, 0x3d, 0xbd, 0x80, 0xdd, 0xda, 0x54, 0xba, 0xec, 0x71, 0xe9, 0x6e, 0xab }, { 0xaa, 0x13, 0xec, 0xf0, 0x99, 0xe5, 0x4e, 0x89, 0xa3, 0xac, 0x48, 0x61, 0x32, 0xa4, 0x1f, 0x57, 0x5e, 0x42, 0x22, 0x87, 0x72, 0x62, 0xaa, 0xc4, 0xf1, 0xef, 0xd1, 0x00, 0x55, 0xc8, 0x5e, 0xf2 }, { 0xe3, 0xcb, 0x68, 0x2b, 0x03, 0x70, 0x8d, 0x53, 0xe2, 0x92, 0x03, 0xf7, 0x22, 0x80, 0x47, 0x89, 0xa6, 0xbb, 0x01, 0xbd, 0x09, 0x75, 0xa9, 0x67, 0x9f, 0x0c, 0x7f, 0x7d, 0x86, 0x84, 0xda, 0x3c }, { 0x1a, 0xe5, 0x68, 0x06, 0xca, 0x98, 0x6f, 0xee, 0x10, 0x87, 0xce, 0xca, 0x88, 0xfc, 0x49, 0x52, 0x8a, 0xbe, 0x3b, 0x14, 0xdb, 0x9a, 0xc1, 0x08, 0x55, 0x55, 0x55, 0xc7, 0x87, 0x8e, 0xe7, 0xdb }, { 0x6b, 0x0e, 0x40, 0x79, 0xb7, 0xe5, 0x87, 0xd7, 0x8e, 0x9b, 0x0c, 0x16, 0x01, 0xca, 0x54, 0x03, 0xef, 0x6f, 0xff, 0x52, 0x5e, 0x92, 0x38, 0x13, 0x10, 0x33, 0x20, 0x68, 0x2e, 0x7f, 0x27, 0x51 }, { 0x67, 0x78, 0xbb, 0x3a, 0x3d, 0xef, 0x8c, 0x9f, 0xcf, 0xd0, 0x19, 0xce, 0x2f, 0x84, 0x02, 0x03, 0x94, 0x14, 0x61, 0xf3, 0xd1, 0x18, 0x91, 0x1e, 0xec, 0x77, 0xc7, 0x98, 0x6b, 0x44, 0x1c, 0xa1 }, { 0xdb, 0x15, 0xeb, 0xb2, 0xc4, 0x68, 0x37, 0x6a, 0xf9, 0xac, 0x8c, 0xac, 0xac, 0xb7, 0xd2, 0x31, 0x69, 0x20, 0xb1, 0x4b, 0xe7, 0x46, 0x62, 0xdc, 0xea, 0xaa, 0xfc, 0xe0, 0x45, 0x0a, 0xed, 0xca }, { 0xa0, 0xd2, 0x48, 0x0a, 0x7d, 0xd0, 0xc0, 0x02, 0xbb, 0xfa, 0xe6, 0x70, 0x61, 0x7a, 0x27, 0x73, 0x03, 0x1d, 0xe1, 0x28, 0x1f, 0xff, 0xcf, 0x8e, 0x44, 0x10, 0xe4, 0xf1, 0xc6, 0xce, 0x87, 0x38 }, { 0x4d, 0x39, 0x5d, 0xea, 0x25, 0xb7, 0x2b, 0x03, 0x4b, 0xd5, 0xc2, 0xba, 0x67, 0x42, 0x5c, 0x84, 0xc1, 0x37, 0x0c, 0x58, 0x72, 0x75, 0xb9, 0x48, 0x55, 0x8d, 0x05, 0xa0, 0xc7, 0x7d, 0x2e, 0x7c }, { 0xdc, 0x70, 0x60, 0x43, 0xcc, 0x23, 0x20, 0xd2, 0x20, 0x35, 0x79, 0x33, 0x44, 0xae, 0x01, 0xdd, 0x4d, 0x93, 0x67, 0x50, 0x6a, 0x5d, 0x07, 0xb6, 0xf6, 0x62, 0x7d, 0xe6, 0x13, 0xa0, 0xd2, 0x24 }, { 0x23, 0x3f, 0xa7, 0x76, 0xf0, 0xab, 0x4f, 0x0b, 0xc9, 0x27, 0x7c, 0x72, 0x77, 0x01, 0x74, 0xd1, 0xbe, 0x3c, 0xa3, 0x86, 0x21, 0x58, 0x23, 0xf3, 0x44, 0xcc, 0x51, 0x9b, 0x38, 0x46, 0x85, 0x85 }, { 0xb2, 0x58, 0x74, 0x64, 0xdb, 0x49, 0x2e, 0xec, 0x3c, 0x33, 0x03, 0x4a, 0x75, 0x4f, 0xc9, 0xcb, 0xd0, 0xb8, 0xff, 0xd4, 0xcd, 0x49, 0xd1, 0xbe, 0x50, 0x24, 0x94, 0x0c, 0xdb, 0xd3, 0x5c, 0x40 }, { 0x55, 0xc2, 0xa6, 0xe7, 0x16, 0x23, 0xe3, 0x24, 0x46, 0xa2, 0xaf, 0x66, 0xd1, 0x3e, 0xb1, 0x74, 0x35, 0x9f, 0xee, 0x87, 0xdf, 0xa7, 0x9f, 0x0c, 0xfd, 0x0c, 0xea, 0x89, 0xdd, 0x4b, 0x58, 0x2d }, { 0x62, 0x56, 0xed, 0xe6, 0x7e, 0x32, 0xe2, 0x23, 0x84, 0x5f, 0x10, 0xb8, 0xe1, 0xa0, 0x57, 0x0a, 0x9f, 0xeb, 0xe1, 0x01, 0x6a, 0x0c, 0x5b, 0x26, 0x5b, 0x3a, 0x03, 0x08, 0x20, 0x7d, 0xcc, 0xad }, { 0x52, 0x04, 0x30, 0xff, 0x9e, 0x70, 0x66, 0x5d, 0xb9, 0x55, 0x21, 0x6d, 0x56, 0x2e, 0x78, 0x8d, 0xc8, 0xb6, 0xcf, 0x6a, 0xd6, 0x4d, 0x17, 0x42, 0x65, 0xea, 0x0d, 0x0f, 0xc7, 0xc4, 0xd8, 0x88 }, { 0x49, 0x40, 0x4d, 0x86, 0xc6, 0xdf, 0x86, 0x53, 0x98, 0xeb, 0x5e, 0xef, 0xf3, 0xc5, 0x5e, 0x35, 0x3e, 0x7c, 0x61, 0x46, 0xbb, 0xc3, 0xf7, 0x5e, 0x63, 0xe9, 0xdd, 0x96, 0xd5, 0xfd, 0xb3, 0x40 }, { 0x4a, 0x39, 0xd3, 0x7e, 0x5c, 0xea, 0xd0, 0x02, 0x20, 0x9e, 0x1e, 0xcb, 0x7f, 0xac, 0x5d, 0xfe, 0x20, 0xb0, 0xd5, 0xda, 0xc4, 0x50, 0x52, 0xac, 0x8f, 0x22, 0xf8, 0x7e, 0x46, 0xbf, 0xe2, 0xa4 }, { 0x31, 0xd7, 0xde, 0x50, 0x4f, 0x3b, 0xc4, 0x41, 0x7a, 0x4d, 0xb9, 0x32, 0x23, 0x1b, 0x35, 0x09, 0x54, 0xa8, 0xe1, 0xec, 0x85, 0xa7, 0x99, 0xac, 0x1b, 0x16, 0x9a, 0x0e, 0xdb, 0xee, 0x24, 0xc8 }, { 0xa7, 0x83, 0xfc, 0x87, 0xe5, 0x5a, 0x7f, 0xca, 0x96, 0xc2, 0xce, 0x5a, 0xa2, 0x77, 0x36, 0x15, 0x65, 0x58, 0x27, 0x03, 0xdf, 0xd1, 0x8d, 0xc1, 0x5a, 0xfa, 0x98, 0xbb, 0x0b, 0x60, 0x6a, 0xc6 }, { 0x46, 0x01, 0xaa, 0x2b, 0xa0, 0xfa, 0x7e, 0x99, 0xc9, 0x3e, 0x0c, 0x9d, 0xbd, 0x44, 0x8f, 0xd1, 0xd9, 0x9c, 0xe5, 0x09, 0x8a, 0x6d, 0x1d, 0x8c, 0x9c, 0x21, 0x4d, 0xb6, 0x20, 0x6e, 0xd0, 0x52 }, { 0xb2, 0x38, 0x06, 0xed, 0x16, 0xe3, 0xb3, 0xa3, 0x5b, 0x30, 0x30, 0xc9, 0x2f, 0xb6, 0x8f, 0x27, 0x54, 0xc4, 0x32, 0xcd, 0x87, 0xfb, 0x1f, 0xc2, 0xb8, 0xa0, 0x9f, 0xd5, 0x2b, 0x89, 0x02, 0x14 }, { 0xf4, 0x33, 0x51, 0xde, 0x2b, 0x9b, 0xf9, 0x3f, 0x57, 0x35, 0xb1, 0x99, 0xf5, 0x6b, 0x7e, 0x10, 0xeb, 0x6b, 0x7a, 0x82, 0x40, 0xf9, 0x6a, 0xeb, 0x4b, 0x21, 0x34, 0x64, 0x86, 0x32, 0xe2, 0x8a }, { 0xc2, 0x95, 0x1a, 0x92, 0xb7, 0xbe, 0x8c, 0xda, 0xee, 0xbe, 0x9b, 0xa2, 0x71, 0xbf, 0xf0, 0xcc, 0xcd, 0x1d, 0x5b, 0x13, 0xec, 0xa4, 0x5b, 0x62, 0xcd, 0x69, 0x72, 0x8a, 0xdf, 0x27, 0x23, 0xf4 }, { 0x7b, 0x92, 0xa2, 0x1b, 0x33, 0x57, 0xbb, 0xcf, 0xa4, 0x2b, 0x33, 0x33, 0x88, 0xa4, 0x64, 0x78, 0xcd, 0x38, 0xef, 0xf6, 0x43, 0xeb, 0x5b, 0x81, 0x86, 0xdb, 0x23, 0x72, 0x82, 0x99, 0xe1, 0x5f }, { 0x6a, 0x95, 0xd5, 0x32, 0x61, 0xca, 0x62, 0x10, 0xd4, 0xf2, 0x97, 0x3d, 0x20, 0x4f, 0x18, 0x62, 0xa4, 0x78, 0xb9, 0x19, 0xb4, 0x52, 0x0e, 0x30, 0xd4, 0x5f, 0x3a, 0xea, 0xb0, 0xe6, 0xe9, 0x2b }, { 0x9e, 0x8a, 0xae, 0x70, 0x8a, 0xfd, 0x14, 0x89, 0x31, 0x88, 0x3f, 0xbb, 0xb2, 0x03, 0x60, 0xb5, 0xd4, 0x4a, 0xc7, 0xa3, 0x08, 0x3b, 0xaa, 0x3a, 0xfb, 0x53, 0xa4, 0xac, 0x0f, 0x2f, 0x47, 0x69 }, { 0x43, 0x84, 0x1b, 0xd9, 0x49, 0xbb, 0x30, 0xeb, 0x9d, 0x52, 0xd1, 0x3e, 0x5c, 0x34, 0x82, 0x03, 0x90, 0xc6, 0x69, 0x18, 0x0a, 0x5f, 0xd4, 0xb3, 0x07, 0x69, 0xac, 0xc6, 0x46, 0x74, 0x4e, 0x2b }, { 0x77, 0xfa, 0x5f, 0x7b, 0x82, 0xec, 0x32, 0xbe, 0x0b, 0x3d, 0xb9, 0xec, 0xee, 0x9e, 0x67, 0x44, 0x83, 0xed, 0x37, 0x0a, 0x43, 0x61, 0x6f, 0x81, 0xae, 0x19, 0x9c, 0xcb, 0x2f, 0xd2, 0x4c, 0x25 }, { 0x9d, 0x38, 0x2f, 0x84, 0xfb, 0x27, 0x5f, 0xf8, 0x98, 0x31, 0x12, 0x84, 0xad, 0xcd, 0xc7, 0x9f, 0x2a, 0xe3, 0x63, 0xd1, 0xc3, 0x92, 0xfb, 0xaf, 0x9f, 0x8f, 0x28, 0x6e, 0x7d, 0xd8, 0xf1, 0x46 }, { 0xc7, 0xe1, 0x2b, 0x52, 0x0a, 0xdf, 0xcd, 0x89, 0x65, 0xd4, 0xf0, 0x91, 0xaf, 0x25, 0x21, 0x7b, 0x31, 0xfb, 0xbb, 0xcc, 0xe7, 0x31, 0x53, 0x72, 0x15, 0xb7, 0x0b, 0xa5, 0x6e, 0x98, 0x3d, 0x50 }, { 0x14, 0xd2, 0xf7, 0x12, 0xbb, 0x2a, 0xac, 0x8a, 0x77, 0xcf, 0x07, 0x11, 0xa4, 0xb6, 0x4a, 0x72, 0x99, 0x6d, 0x7e, 0x30, 0x9a, 0x11, 0xa3, 0xd9, 0x00, 0xd1, 0x65, 0x8f, 0x63, 0x7d, 0x40, 0xdc }, { 0xa3, 0x85, 0x66, 0xd8, 0xc5, 0x83, 0xd7, 0xdf, 0x3b, 0x5a, 0x7a, 0x84, 0x68, 0x57, 0x62, 0xe9, 0x98, 0x24, 0x15, 0xfe, 0x31, 0x9d, 0x1d, 0x75, 0x77, 0xd9, 0xba, 0x0c, 0x94, 0x58, 0x46, 0xbb }, { 0xb3, 0x12, 0x32, 0x4a, 0x75, 0xbc, 0x7b, 0x24, 0xa6, 0xda, 0x68, 0xe3, 0x0e, 0xe0, 0xf4, 0x46, 0x3a, 0x78, 0xbc, 0xd6, 0x92, 0x2e, 0x4a, 0xa0, 0xc8, 0xe7, 0x4b, 0x05, 0x1a, 0xe1, 0xe0, 0xeb }, { 0x94, 0x40, 0x96, 0x72, 0x2c, 0x2a, 0x3e, 0x52, 0x13, 0xec, 0x70, 0x9f, 0xc5, 0xaa, 0x92, 0x91, 0x8f, 0x3f, 0x49, 0xc0, 0x4e, 0x3c, 0x75, 0x62, 0x3b, 0xb7, 0x88, 0x5f, 0xf6, 0x52, 0x9c, 0x56 }, { 0x38, 0x5a, 0x07, 0x65, 0x13, 0x62, 0xb5, 0x36, 0x4d, 0x82, 0x6c, 0xd5, 0xae, 0x1e, 0x96, 0xde, 0xb7, 0x54, 0x1c, 0x67, 0xb6, 0xf4, 0x01, 0x6c, 0x59, 0x08, 0x23, 0xbb, 0xe4, 0x2d, 0x01, 0x6b }, { 0xcd, 0x72, 0x7f, 0x71, 0xf2, 0x1a, 0x53, 0x72, 0x86, 0x0b, 0xe9, 0x71, 0x5a, 0x69, 0x90, 0xfd, 0x5b, 0x67, 0x0b, 0xe8, 0xae, 0x08, 0x31, 0x11, 0x95, 0x06, 0x2a, 0x12, 0x39, 0xe3, 0x20, 0x12 }, { 0xd0, 0xff, 0x00, 0x59, 0x42, 0x81, 0xc8, 0x08, 0xbb, 0xec, 0x5d, 0x1f, 0xd0, 0xcc, 0xc8, 0xb6, 0x71, 0x36, 0x0b, 0x95, 0x33, 0x84, 0x61, 0x7f, 0xad, 0xee, 0x42, 0xa9, 0xb5, 0xd9, 0x85, 0x7e }, { 0x55, 0x28, 0xe3, 0xd3, 0xd0, 0x58, 0x5d, 0x3f, 0xee, 0x3f, 0xcd, 0xe6, 0x75, 0xf3, 0x8c, 0x2d, 0x6d, 0x78, 0x91, 0xa9, 0xa8, 0xc4, 0x8e, 0x96, 0x95, 0x98, 0xdb, 0xfd, 0x71, 0x7e, 0x87, 0x49 }, { 0x96, 0xf1, 0xb3, 0x77, 0x29, 0xd9, 0x20, 0x68, 0xd7, 0xb7, 0xb6, 0x63, 0xed, 0xae, 0x42, 0xbd, 0xfb, 0xc4, 0x3f, 0x58, 0x29, 0xf2, 0x07, 0xa9, 0xdc, 0xaf, 0xe0, 0x02, 0x30, 0x35, 0xca, 0xfd }, { 0x6b, 0x11, 0x9a, 0x82, 0x4d, 0xf4, 0xe7, 0xea, 0x2a, 0x4b, 0x8f, 0x53, 0x5a, 0x46, 0x76, 0x5b, 0xbb, 0xaf, 0x93, 0xfe, 0x30, 0x4e, 0x78, 0x4c, 0xf4, 0xb8, 0x58, 0x59, 0x71, 0xa6, 0x39, 0x3a }, { 0xb4, 0x43, 0x49, 0x57, 0xd3, 0xdd, 0x0b, 0x9e, 0x4f, 0x86, 0xbe, 0x93, 0x82, 0xf3, 0x05, 0xb5, 0xd0, 0xf5, 0xc2, 0x31, 0xd9, 0xc7, 0xa9, 0xd7, 0x52, 0xd0, 0x34, 0x15, 0x35, 0xdb, 0x3e, 0x08 }, { 0xc2, 0xe4, 0xb8, 0xa4, 0x7e, 0xbc, 0x56, 0x86, 0x24, 0x6a, 0xcc, 0x32, 0xbb, 0xe1, 0x4c, 0x9d, 0xf8, 0x5d, 0x9e, 0xc4, 0x10, 0x9d, 0x94, 0xa8, 0xf0, 0x69, 0x7f, 0xc2, 0x6b, 0x65, 0xf4, 0x1e }, { 0xe0, 0x94, 0xef, 0x60, 0x05, 0x7a, 0x3f, 0xa2, 0x38, 0x5b, 0x00, 0xb4, 0x1f, 0x0f, 0x6f, 0x22, 0xff, 0x6a, 0xd8, 0xdc, 0x2f, 0x75, 0xda, 0xf1, 0x6c, 0x10, 0x95, 0xd6, 0x7d, 0x54, 0xe6, 0xbc }, { 0xbe, 0xf5, 0x75, 0xe3, 0xd2, 0x99, 0x92, 0x7d, 0x3f, 0x0a, 0x65, 0x6b, 0x29, 0xac, 0xf6, 0x41, 0x2f, 0x92, 0xf8, 0xc8, 0x60, 0x98, 0xba, 0xc1, 0x4d, 0xca, 0x9e, 0xa5, 0x3e, 0x38, 0x65, 0x72 }, { 0xb0, 0xab, 0xd7, 0x34, 0xd1, 0xfd, 0x91, 0xa7, 0xec, 0x4b, 0x31, 0xf1, 0x5a, 0x10, 0x94, 0x20, 0xd3, 0xdd, 0xfa, 0xef, 0xd5, 0x9f, 0x4c, 0xca, 0x50, 0x50, 0xc4, 0xbb, 0x8a, 0xd9, 0x77, 0xb9 }, { 0x6a, 0xfc, 0xf8, 0xe9, 0x65, 0x18, 0xc4, 0x8c, 0x7b, 0x40, 0xb1, 0x5e, 0x71, 0x79, 0xbe, 0xeb, 0xd3, 0xcc, 0x81, 0xf4, 0xe0, 0xd3, 0x6d, 0x5b, 0x97, 0x7a, 0xc6, 0x58, 0x74, 0x4e, 0x17, 0x80 }, { 0xd5, 0xbc, 0xc7, 0x49, 0x81, 0x54, 0x12, 0x5a, 0x4a, 0x12, 0x21, 0x3f, 0xcd, 0x2a, 0x1a, 0x83, 0xaf, 0xd5, 0xaa, 0x6f, 0x60, 0x2a, 0x61, 0x4c, 0xfb, 0xb8, 0xd4, 0xd0, 0xef, 0xd6, 0x1d, 0x33 }, { 0x54, 0x35, 0x28, 0x59, 0xc2, 0x1f, 0x76, 0x11, 0xae, 0xd8, 0x18, 0x70, 0xfe, 0x6a, 0x67, 0x5a, 0xf6, 0x46, 0x64, 0x3b, 0x2b, 0xe3, 0xeb, 0x4c, 0xf9, 0x4a, 0x19, 0x5e, 0xbe, 0x24, 0x96, 0x8b }, { 0x49, 0xa2, 0x0f, 0x03, 0xd5, 0x82, 0x63, 0x48, 0x2e, 0x28, 0xc4, 0x45, 0x0c, 0x85, 0xb0, 0xb2, 0x33, 0x22, 0xee, 0x47, 0x24, 0x3a, 0xaa, 0xfa, 0x45, 0x8d, 0x1b, 0x7d, 0x3e, 0xb5, 0x0b, 0xaf }, { 0x53, 0xc3, 0xe2, 0x0d, 0x72, 0xae, 0x95, 0xdd, 0x76, 0x68, 0xcd, 0xe4, 0xb4, 0x01, 0x06, 0x4b, 0x2e, 0x5c, 0xdc, 0xba, 0x84, 0xa5, 0x9e, 0x5e, 0x48, 0x0f, 0xc3, 0x42, 0x47, 0xeb, 0xeb, 0x2d }, { 0xea, 0x41, 0xd6, 0xe9, 0x12, 0x53, 0xb0, 0xae, 0xfc, 0x47, 0x6c, 0x87, 0xdc, 0xc7, 0x75, 0xc1, 0x40, 0x82, 0x9f, 0x71, 0x8f, 0xb3, 0x3a, 0x67, 0xf1, 0x7c, 0x29, 0x3a, 0x9f, 0x8d, 0x04, 0xcc }, { 0x99, 0x5c, 0xb6, 0xf4, 0x9a, 0x8b, 0xa5, 0x7a, 0x84, 0x1e, 0x0a, 0xa3, 0xc5, 0xbb, 0x04, 0xce, 0xf0, 0x1b, 0xd2, 0x8c, 0x3e, 0xc0, 0x7f, 0x0f, 0x6a, 0x9e, 0x86, 0xcc, 0xf0, 0x0e, 0x7d, 0x9f }, { 0x6b, 0xae, 0x70, 0x93, 0x48, 0x6c, 0xa9, 0xc4, 0x0f, 0xe0, 0x63, 0xf0, 0x1a, 0x66, 0x59, 0x20, 0xdc, 0x13, 0xac, 0xa9, 0x02, 0x98, 0x6e, 0x64, 0x10, 0xd1, 0x24, 0xec, 0x01, 0xe8, 0x70, 0x6a } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t keys4_128bit[ 100 ][ 32 ] = { { 0x66, 0xc2, 0x1c, 0x85, 0x9d, 0x40, 0xbc, 0x38, 0x47, 0x25, 0x62, 0x6c, 0x79, 0x3f, 0xe8, 0x82, 0xb0, 0xf1, 0x1a, 0x39, 0x7c, 0x63, 0xaa, 0xc2, 0x02, 0x6c, 0xc8, 0xda, 0x89, 0x16, 0xfb, 0xad }, { 0x6c, 0x92, 0x1b, 0x4a, 0x18, 0xcc, 0x84, 0xab, 0xca, 0xfc, 0xd9, 0x82, 0x56, 0x65, 0xc7, 0xa0, 0xfe, 0x5f, 0x36, 0x51, 0xd5, 0x10, 0x99, 0xd1, 0x68, 0x07, 0x6c, 0x43, 0x4b, 0x49, 0x5f, 0x9c }, { 0xb0, 0xcd, 0x92, 0x7d, 0xc5, 0x78, 0x48, 0x1b, 0x39, 0x17, 0x86, 0x38, 0xde, 0x7c, 0x87, 0x7a, 0xf7, 0xfe, 0x87, 0xa0, 0x4f, 0xfe, 0x7b, 0xfb, 0xcb, 0xf3, 0x31, 0xd1, 0x4f, 0x81, 0x7c, 0xa8 }, { 0xe7, 0x82, 0x4f, 0x44, 0x6f, 0xbd, 0x4d, 0xd4, 0xe0, 0xbb, 0x40, 0x24, 0x69, 0x3f, 0x25, 0xd8, 0xba, 0x7a, 0x3e, 0x4b, 0x50, 0x2f, 0x06, 0x1c, 0x4f, 0xed, 0xed, 0x1a, 0x32, 0x8c, 0x49, 0x15 }, { 0x83, 0xa2, 0x30, 0x39, 0xae, 0x08, 0xa9, 0xe1, 0x7b, 0x59, 0x63, 0xce, 0x9a, 0x90, 0x01, 0x54, 0xd5, 0xb0, 0x3f, 0xff, 0x19, 0xd0, 0xcb, 0xd9, 0x67, 0xe4, 0xe1, 0x47, 0xd5, 0x32, 0x16, 0x63 }, { 0xf9, 0x82, 0x5b, 0xfc, 0x9c, 0xee, 0xa1, 0x13, 0xce, 0x39, 0x94, 0x86, 0x29, 0xde, 0x52, 0xa4, 0xfb, 0x49, 0x4a, 0xd1, 0x13, 0xdf, 0x94, 0x54, 0xb2, 0x9d, 0xba, 0x67, 0xb9, 0xf2, 0x6f, 0x7e }, { 0x49, 0x34, 0xd6, 0xcc, 0xa2, 0x11, 0x80, 0x97, 0xa3, 0x84, 0xbf, 0x7f, 0x5f, 0x6b, 0x04, 0x5f, 0x02, 0x46, 0x77, 0x22, 0x37, 0x3a, 0x8c, 0x22, 0xb2, 0xed, 0x1c, 0xff, 0x0c, 0x4e, 0x3d, 0x04 }, { 0x2e, 0x6f, 0x04, 0x49, 0x67, 0x8d, 0x5a, 0xb6, 0x36, 0x2e, 0xc3, 0x91, 0xc4, 0x5e, 0xc5, 0x66, 0x7a, 0xd1, 0x44, 0x0a, 0xd6, 0x58, 0xee, 0x1e, 0x81, 0x33, 0xd1, 0xf1, 0x60, 0x0a, 0xb1, 0xea }, { 0x27, 0xea, 0x50, 0x14, 0x70, 0xb1, 0x97, 0x1e, 0xa9, 0x05, 0x8c, 0xb8, 0xf1, 0x0f, 0x81, 0x7c, 0xe0, 0xe5, 0xed, 0x13, 0x3a, 0x04, 0xbd, 0xa1, 0xd6, 0x22, 0xea, 0x23, 0x95, 0x90, 0xa2, 0xd5 }, { 0x30, 0x23, 0x33, 0xa6, 0x72, 0x4a, 0xc6, 0x20, 0xa7, 0xdd, 0x30, 0x83, 0x56, 0x32, 0xbc, 0x5f, 0xcf, 0xf2, 0x27, 0x7a, 0x1f, 0x24, 0x37, 0x5d, 0x55, 0x92, 0x2b, 0x36, 0x78, 0x0c, 0xf7, 0x09 }, { 0x88, 0xb1, 0x07, 0xde, 0xe1, 0x24, 0x93, 0x37, 0x9a, 0x03, 0x3b, 0xe0, 0xa4, 0x0f, 0xbe, 0xf0, 0x77, 0x51, 0x1a, 0xce, 0xf2, 0xc8, 0x53, 0x28, 0xe4, 0x09, 0x78, 0x67, 0xeb, 0xd2, 0xd9, 0x40 }, { 0xa8, 0xe3, 0xf1, 0x47, 0x5a, 0xb7, 0xa6, 0x2b, 0x4c, 0xbe, 0xca, 0x78, 0x2a, 0xf4, 0xbd, 0xf8, 0x24, 0x6c, 0x00, 0xfb, 0xde, 0xd3, 0x54, 0x82, 0x6f, 0x6b, 0x16, 0xff, 0xf4, 0xf1, 0x6d, 0x10 }, { 0xd3, 0x54, 0x63, 0xbd, 0x6e, 0xca, 0xd0, 0x3e, 0xad, 0x9a, 0x36, 0x63, 0x81, 0x7d, 0x62, 0x66, 0xa0, 0xdc, 0xf2, 0x4b, 0x2a, 0x17, 0x2e, 0x03, 0xa6, 0x1f, 0xd8, 0x65, 0x10, 0x4e, 0xef, 0xb8 }, { 0x29, 0xed, 0x68, 0x97, 0x59, 0x11, 0xf8, 0xe4, 0x19, 0x69, 0x4f, 0xdf, 0x95, 0xb6, 0x28, 0xba, 0xc4, 0xb9, 0xc3, 0x26, 0xd7, 0xbc, 0x1a, 0x39, 0x8d, 0x32, 0x29, 0xe5, 0xa6, 0x32, 0x00, 0x05 }, { 0xb3, 0xdc, 0xeb, 0x73, 0x2e, 0x60, 0x67, 0x05, 0x8e, 0x83, 0xe3, 0xc1, 0x5f, 0x8b, 0x15, 0x75, 0xaa, 0x1b, 0xf6, 0xce, 0x7b, 0xf4, 0x5e, 0x98, 0xf8, 0x19, 0x33, 0xeb, 0xb7, 0x15, 0xfb, 0x5d }, { 0x68, 0xae, 0x99, 0x72, 0xfc, 0xa9, 0xdf, 0x71, 0x52, 0x3d, 0xbf, 0xe2, 0x5b, 0xca, 0x93, 0x5d, 0x0e, 0x50, 0x51, 0x67, 0xca, 0x93, 0x09, 0x14, 0xba, 0xb2, 0x2e, 0x94, 0xe7, 0xdd, 0xe5, 0x07 }, { 0xce, 0x98, 0xcf, 0x88, 0xbd, 0xcf, 0x3f, 0x46, 0xe2, 0x33, 0x22, 0x24, 0x88, 0xcf, 0x76, 0x45, 0x7f, 0xff, 0x23, 0x4f, 0x9d, 0x3e, 0x81, 0xbb, 0xf4, 0xb3, 0x2c, 0x86, 0x23, 0x23, 0x37, 0x7e }, { 0x71, 0xeb, 0x59, 0x75, 0xe7, 0x1f, 0xd9, 0xe6, 0x0a, 0xc9, 0x8c, 0xc2, 0x4c, 0x51, 0xaa, 0x7d, 0x5c, 0xd3, 0x54, 0x81, 0xec, 0xe1, 0x20, 0x8b, 0x82, 0xf6, 0x40, 0x06, 0xfd, 0x6c, 0xa3, 0x0b }, { 0x45, 0x8b, 0x60, 0x27, 0x13, 0xba, 0x0a, 0x0e, 0x77, 0xb5, 0x80, 0xf0, 0x34, 0x7a, 0xd1, 0x77, 0xf9, 0xda, 0x3e, 0x02, 0xea, 0xbf, 0xc3, 0xfc, 0x25, 0x9c, 0x1e, 0x0e, 0xcc, 0xb7, 0x0e, 0xc1 }, { 0xe7, 0xc5, 0x92, 0x65, 0x97, 0x1f, 0x52, 0xce, 0xb4, 0x24, 0x19, 0xd1, 0x1d, 0xcd, 0x3c, 0xa4, 0x26, 0x00, 0x7e, 0x00, 0x90, 0x85, 0x54, 0xed, 0x0a, 0x4f, 0x66, 0x4f, 0x8b, 0x57, 0xb9, 0xd3 }, { 0xdc, 0x6e, 0x16, 0x0d, 0x75, 0x07, 0x70, 0x74, 0xc0, 0x29, 0xa0, 0x85, 0x0b, 0x19, 0xf1, 0x55, 0x74, 0x3b, 0x29, 0x54, 0x58, 0x4e, 0xfa, 0xca, 0x1f, 0x3f, 0x87, 0xa5, 0xe0, 0xbb, 0x2c, 0x40 }, { 0x18, 0x65, 0xff, 0x2c, 0x5a, 0xa7, 0x5a, 0x2a, 0xb4, 0x1c, 0x75, 0x25, 0x18, 0xb9, 0xcb, 0x19, 0x34, 0x0d, 0xd3, 0x78, 0x5c, 0xc7, 0x26, 0xc6, 0xb6, 0x49, 0xf2, 0x8e, 0xe6, 0x19, 0xc8, 0x7a }, { 0xde, 0x5c, 0xd9, 0xbe, 0x60, 0x43, 0x52, 0x01, 0x83, 0x81, 0x7e, 0xed, 0xfa, 0x97, 0x03, 0xa9, 0xdb, 0xba, 0x13, 0xfc, 0x08, 0xca, 0x63, 0x76, 0xb0, 0xbc, 0x60, 0x1a, 0x8f, 0x2d, 0x12, 0x87 }, { 0x55, 0x8f, 0x8c, 0xd8, 0x31, 0x44, 0xe5, 0x43, 0x98, 0xab, 0xad, 0xbc, 0xa6, 0xbb, 0x38, 0x60, 0xca, 0x21, 0xc1, 0x2c, 0x7b, 0xaf, 0x0e, 0xd3, 0xcb, 0x7f, 0xa7, 0xff, 0xf8, 0x82, 0xc4, 0x64 }, { 0x97, 0x51, 0x7a, 0xe1, 0xc7, 0x80, 0x09, 0x0b, 0x39, 0x3e, 0xd4, 0x89, 0x80, 0xb9, 0xde, 0x5a, 0xc6, 0xf2, 0xfa, 0x82, 0x21, 0x0f, 0xdd, 0x1c, 0xde, 0xeb, 0xfd, 0xd8, 0x7e, 0xf4, 0x98, 0x6b }, { 0xf6, 0x96, 0x8f, 0x71, 0x19, 0x68, 0x2d, 0xda, 0x3a, 0xf9, 0x45, 0xe5, 0xbc, 0x4c, 0x88, 0xdc, 0x3e, 0x38, 0xa2, 0x06, 0x93, 0x80, 0x9f, 0x08, 0x1d, 0x43, 0x65, 0xc3, 0xdc, 0x92, 0x20, 0xcb }, { 0xb9, 0xb9, 0xb7, 0x72, 0x4b, 0x42, 0xab, 0xed, 0xf2, 0x1a, 0x1a, 0xa5, 0x0c, 0xf9, 0x9d, 0xe0, 0xb2, 0x50, 0x22, 0xcc, 0x55, 0xe5, 0x41, 0x89, 0xf1, 0xf4, 0xb0, 0x98, 0x2c, 0x21, 0x2a, 0xf1 }, { 0xff, 0xe2, 0x9c, 0x15, 0x31, 0xde, 0x9f, 0x1e, 0x53, 0xf8, 0x02, 0xb4, 0x38, 0x66, 0x34, 0x46, 0x0c, 0xdd, 0x10, 0x77, 0xb8, 0x30, 0x18, 0xa3, 0xf2, 0x83, 0x4e, 0x9e, 0x55, 0x95, 0x81, 0x33 }, { 0x01, 0x7f, 0x16, 0xff, 0xce, 0x63, 0x2b, 0xf3, 0xef, 0x31, 0xde, 0x37, 0x31, 0xc1, 0xfc, 0x66, 0x9a, 0x01, 0x46, 0xe9, 0x39, 0x4a, 0xf5, 0x64, 0xe4, 0x20, 0x01, 0x59, 0x29, 0x9e, 0x87, 0xc3 }, { 0x82, 0x51, 0xf4, 0xa5, 0x4e, 0x02, 0x66, 0x81, 0x9c, 0x65, 0x38, 0xe8, 0xad, 0xc2, 0xb0, 0xb4, 0x95, 0x90, 0x69, 0xd5, 0x7e, 0x7f, 0xb1, 0x21, 0x78, 0xa2, 0x21, 0xd2, 0x34, 0xad, 0x69, 0xdc }, { 0xb6, 0xcb, 0xdd, 0x64, 0xd6, 0x19, 0x13, 0xf9, 0x05, 0x40, 0x2b, 0xf5, 0x9e, 0x7c, 0x24, 0x38, 0x37, 0x3c, 0xca, 0xf6, 0x97, 0xc7, 0xaf, 0x93, 0x45, 0x80, 0x85, 0x7a, 0x9d, 0x3b, 0x86, 0xf3 }, { 0xa2, 0x9a, 0xcc, 0x4a, 0x74, 0xef, 0x70, 0x44, 0xf5, 0x25, 0xa1, 0x61, 0xe4, 0x3f, 0xa9, 0x6c, 0x30, 0x19, 0x96, 0xc3, 0xd6, 0x56, 0xac, 0x50, 0xe2, 0xff, 0x69, 0x07, 0xf0, 0x54, 0x8c, 0xc9 }, { 0x3b, 0xec, 0x22, 0x04, 0x0d, 0x78, 0xe4, 0xeb, 0x50, 0xfe, 0x12, 0x12, 0x03, 0x2b, 0xb5, 0x52, 0x52, 0x29, 0x7a, 0xc6, 0x7d, 0xc0, 0x26, 0x4c, 0x13, 0x24, 0x58, 0xb5, 0x76, 0x18, 0xa8, 0x5d }, { 0x0b, 0x8e, 0x6a, 0x32, 0xa9, 0x70, 0x9b, 0x77, 0xea, 0xd7, 0x82, 0xeb, 0x1a, 0x5f, 0x09, 0x6d, 0x53, 0x15, 0xe3, 0xae, 0xe9, 0xe2, 0xa7, 0x2a, 0x1b, 0x55, 0x2a, 0x77, 0x19, 0xa1, 0x32, 0xef }, { 0xd8, 0x6e, 0x38, 0xf2, 0xf2, 0xac, 0x28, 0xf5, 0xd2, 0x1d, 0xe9, 0x8d, 0xeb, 0x90, 0x8a, 0xff, 0xac, 0xd6, 0x02, 0x45, 0x6a, 0x1c, 0x06, 0xe6, 0x4c, 0x1f, 0x7a, 0x00, 0xdf, 0x1f, 0x62, 0xfe }, { 0x57, 0x02, 0x7d, 0xde, 0x15, 0x77, 0x2e, 0x4e, 0x8d, 0xe7, 0x31, 0xd4, 0x1c, 0xa4, 0xc6, 0xbd, 0xb5, 0x8b, 0xf8, 0x20, 0x6f, 0x5d, 0xd1, 0x8e, 0xf8, 0xff, 0x0c, 0x7c, 0xfe, 0xa0, 0xfa, 0x2c }, { 0x9b, 0x59, 0x60, 0x6f, 0xf3, 0x63, 0x74, 0x86, 0x6a, 0xc6, 0x69, 0xde, 0x69, 0x33, 0xd3, 0x9b, 0xaf, 0x3c, 0x36, 0xba, 0x46, 0xda, 0xf2, 0xdb, 0xdb, 0x58, 0x48, 0x70, 0x44, 0xec, 0x70, 0xc0 }, { 0xb2, 0x9f, 0xa8, 0xfd, 0xe6, 0xef, 0xc2, 0xf6, 0x6d, 0xf9, 0xe5, 0xe5, 0x91, 0xba, 0x81, 0x8c, 0x15, 0xa8, 0x23, 0x58, 0xd6, 0x36, 0x5c, 0x4f, 0x58, 0xfd, 0x2f, 0x31, 0xf2, 0x54, 0xbc, 0xd9 }, { 0x80, 0x59, 0x38, 0x64, 0x1a, 0xb6, 0xdb, 0xb6, 0x8e, 0xd1, 0x5c, 0xb0, 0x89, 0x6f, 0x29, 0x01, 0x09, 0x06, 0x4e, 0xec, 0x64, 0x17, 0xfc, 0x0b, 0xa8, 0xdc, 0xb4, 0x83, 0x43, 0xa1, 0xa8, 0xe7 }, { 0x91, 0x63, 0x9e, 0xf6, 0x65, 0x1a, 0x2d, 0xbb, 0x25, 0x0b, 0x81, 0xc8, 0x65, 0x01, 0x0a, 0xc8, 0xf2, 0x11, 0x62, 0xfe, 0x56, 0x8d, 0x0d, 0x63, 0x3d, 0x0e, 0x92, 0xa4, 0xd5, 0x56, 0x5e, 0x29 }, { 0x15, 0x13, 0x49, 0x76, 0x5b, 0x21, 0x1a, 0xa4, 0x1a, 0xbf, 0x33, 0x42, 0x20, 0xa2, 0xc6, 0xcc, 0x8d, 0x04, 0xa4, 0x52, 0xa3, 0x5e, 0x4f, 0x3f, 0x69, 0x96, 0x46, 0x58, 0x44, 0x56, 0x8e, 0x89 }, { 0xb4, 0xb0, 0xdc, 0x42, 0xb4, 0x21, 0x78, 0x9a, 0x68, 0xb4, 0xc8, 0x49, 0x1d, 0xda, 0x3c, 0x21, 0xe1, 0x3e, 0x0b, 0x5a, 0x1b, 0xa6, 0xd1, 0x52, 0x35, 0x96, 0x9b, 0x14, 0xeb, 0x3c, 0x47, 0x8e }, { 0x76, 0x8c, 0x72, 0xe3, 0xe8, 0x6e, 0xec, 0x02, 0x11, 0x0d, 0xb6, 0xc7, 0x1a, 0x2b, 0xf0, 0xdc, 0x9b, 0xaf, 0xa0, 0x05, 0x39, 0x26, 0x4b, 0xd8, 0x76, 0x41, 0x0e, 0x56, 0x10, 0xd2, 0xfc, 0xea }, { 0x4a, 0x59, 0xa6, 0x12, 0x08, 0xa6, 0x2a, 0xa7, 0x56, 0x1c, 0x01, 0xec, 0xef, 0x00, 0xf1, 0x50, 0x03, 0xa8, 0xa5, 0x5a, 0x9c, 0x1c, 0xed, 0x6c, 0x54, 0x94, 0x6c, 0x1a, 0xc4, 0x70, 0x22, 0x94 }, { 0x3f, 0xd8, 0x1a, 0x57, 0x4f, 0xc6, 0x8a, 0x8a, 0x1e, 0x4a, 0xe7, 0x32, 0xf6, 0xb8, 0x17, 0x8f, 0x42, 0x6c, 0x98, 0x11, 0x40, 0xa9, 0xbf, 0x5f, 0x0b, 0x04, 0x4b, 0x84, 0x8f, 0xb5, 0x9f, 0xc2 }, { 0xfa, 0x7c, 0x43, 0x4a, 0x32, 0x16, 0xe9, 0x05, 0x5f, 0xbb, 0x38, 0x24, 0x12, 0x37, 0x88, 0x51, 0x16, 0xa9, 0xf1, 0x2e, 0xbf, 0xe1, 0x94, 0x4a, 0x3d, 0x92, 0x7b, 0xb8, 0x80, 0xbe, 0x92, 0x80 }, { 0x30, 0x11, 0xd3, 0x36, 0x2d, 0xbd, 0xa3, 0x76, 0x84, 0x49, 0x12, 0x82, 0xfd, 0xa9, 0xa3, 0x23, 0x85, 0xcb, 0xc9, 0x45, 0x22, 0xb7, 0x24, 0x24, 0xf4, 0xb2, 0xbe, 0x81, 0x71, 0x4c, 0x6c, 0x80 }, { 0x87, 0x71, 0x49, 0x40, 0xa5, 0x1d, 0xfc, 0x50, 0x8e, 0x5c, 0x27, 0x23, 0xbe, 0x59, 0xd0, 0x08, 0xc7, 0xa3, 0xed, 0x32, 0xe1, 0x1b, 0xca, 0xb7, 0x0a, 0xca, 0x32, 0x44, 0x0d, 0x40, 0x1f, 0x5f }, { 0x91, 0x65, 0x26, 0x88, 0xae, 0x04, 0x9f, 0x61, 0xe7, 0x42, 0x07, 0x5a, 0xb7, 0x7d, 0x16, 0xa8, 0xb3, 0xcb, 0x10, 0x43, 0xc1, 0x57, 0xef, 0x35, 0x77, 0xc3, 0x18, 0x91, 0x71, 0x30, 0x58, 0x9b }, { 0x53, 0xc6, 0x94, 0x9a, 0xc9, 0xaa, 0x4a, 0x6f, 0x0a, 0x9b, 0x8a, 0xe3, 0xe9, 0xf5, 0x0f, 0x95, 0xb9, 0xe2, 0x0c, 0x72, 0xbe, 0x61, 0x7f, 0x89, 0x5a, 0x4b, 0x0a, 0x13, 0x2d, 0x77, 0x21, 0xd0 }, { 0xc9, 0x99, 0x2c, 0xe9, 0x80, 0x71, 0xa5, 0xfe, 0x5a, 0x8a, 0xa6, 0xd1, 0x01, 0xc9, 0xcb, 0x18, 0xea, 0x7b, 0x1f, 0xfd, 0x00, 0xbc, 0x65, 0xf8, 0xbe, 0xa7, 0xbc, 0x8e, 0x08, 0xe7, 0xda, 0x03 }, { 0xcb, 0xb0, 0xc1, 0x89, 0x73, 0x90, 0xf7, 0x27, 0x30, 0x3e, 0x3d, 0xc7, 0xfe, 0xef, 0xd1, 0x7c, 0x5e, 0x34, 0x34, 0x62, 0xc5, 0x45, 0x66, 0x21, 0xe2, 0x87, 0x21, 0x84, 0xd9, 0x2d, 0x78, 0xbe }, { 0xae, 0x85, 0xc9, 0x23, 0x7a, 0xff, 0xeb, 0xe6, 0x5f, 0xb8, 0x8c, 0xdd, 0x98, 0x37, 0x90, 0xb1, 0x92, 0x84, 0x17, 0x87, 0xb5, 0xf7, 0x53, 0x6d, 0x3f, 0x27, 0x77, 0xee, 0x7b, 0x9a, 0xdf, 0x01 }, { 0x9c, 0x18, 0xfd, 0x6d, 0x4b, 0x35, 0xad, 0x0b, 0x17, 0x94, 0x81, 0xd3, 0x09, 0xf1, 0xcb, 0xd0, 0xd0, 0x31, 0xf4, 0x8b, 0xa8, 0x46, 0x97, 0x16, 0x5f, 0x2b, 0xd9, 0xdc, 0xa5, 0xb8, 0x36, 0x77 }, { 0x12, 0x09, 0x1a, 0x52, 0xac, 0x13, 0x70, 0x30, 0x67, 0x33, 0xe5, 0x8e, 0xc4, 0x24, 0x14, 0x27, 0x7e, 0x78, 0x38, 0xdd, 0x16, 0x18, 0x44, 0x50, 0x47, 0x5a, 0x6c, 0xc4, 0x4a, 0x6e, 0x84, 0xac }, { 0x0d, 0x3c, 0x11, 0x8c, 0x02, 0x5b, 0xed, 0x7f, 0x73, 0xea, 0xd5, 0x1c, 0xe8, 0xa2, 0x33, 0xda, 0xb5, 0x9b, 0xfb, 0xc9, 0x16, 0xd0, 0x78, 0xa2, 0x0c, 0x8f, 0x76, 0x8b, 0x05, 0x4d, 0xef, 0xbb }, { 0xe1, 0xf0, 0x1b, 0xc4, 0x5a, 0xd8, 0x77, 0x17, 0xd8, 0x9b, 0xbf, 0xde, 0x15, 0x5d, 0xaa, 0x3e, 0xdd, 0x8f, 0x66, 0x79, 0x3a, 0xe2, 0x05, 0xcb, 0x79, 0xf6, 0xab, 0xc5, 0x8f, 0x90, 0xe4, 0x18 }, { 0xcb, 0x33, 0x43, 0xbf, 0x74, 0x9f, 0xfe, 0x1f, 0x18, 0x29, 0x19, 0x56, 0xb2, 0x2e, 0x7f, 0x2e, 0xe5, 0x8e, 0x7f, 0x1b, 0x3c, 0x35, 0x1a, 0x33, 0x61, 0xb3, 0x26, 0xef, 0x73, 0xd5, 0xd2, 0x63 }, { 0xe2, 0xa0, 0xff, 0x54, 0x17, 0x9e, 0x85, 0xa0, 0xdb, 0x18, 0xa4, 0x21, 0xf8, 0xc6, 0x0e, 0x57, 0xdb, 0x39, 0x03, 0xc0, 0x9e, 0x47, 0x62, 0x28, 0xc1, 0xb5, 0x8e, 0xd1, 0x5c, 0xe3, 0xfc, 0xa8 }, { 0xba, 0xfd, 0x1d, 0x16, 0x99, 0x37, 0x45, 0x67, 0xb0, 0x88, 0xc3, 0xd9, 0x76, 0x31, 0x5b, 0x75, 0x16, 0x1a, 0x57, 0x38, 0xff, 0x53, 0x7a, 0x86, 0x8a, 0x3f, 0xfd, 0x88, 0x01, 0x68, 0x73, 0xd3 }, { 0x9c, 0xc0, 0x6d, 0x59, 0x2c, 0x3d, 0xf5, 0x30, 0x97, 0xff, 0xcd, 0x75, 0x55, 0xd4, 0xf2, 0x8d, 0xec, 0x1b, 0x56, 0xe4, 0xd6, 0xbd, 0x70, 0xcb, 0xea, 0x85, 0x40, 0x6e, 0xbe, 0x87, 0x7d, 0xf0 }, { 0xc4, 0x79, 0x95, 0x56, 0xed, 0xf5, 0x23, 0x1e, 0x46, 0xf6, 0x48, 0x18, 0x2b, 0x38, 0x66, 0xe9, 0x25, 0x7c, 0xd1, 0x66, 0x10, 0x01, 0x31, 0xa0, 0x79, 0x6b, 0x4c, 0x20, 0x4c, 0x96, 0xaa, 0x15 }, { 0x1a, 0x67, 0x43, 0x9e, 0xb0, 0x5b, 0xef, 0x08, 0x6b, 0x57, 0xdf, 0xf8, 0xf7, 0x9a, 0x09, 0xcb, 0xac, 0x98, 0x2d, 0xaa, 0xfa, 0x8f, 0x69, 0x7d, 0x25, 0x0c, 0x5a, 0xff, 0xc4, 0x3f, 0x44, 0x66 }, { 0xbd, 0x63, 0xa6, 0x71, 0x80, 0xa0, 0x25, 0xaa, 0xc2, 0x5c, 0x73, 0x81, 0xea, 0xb4, 0xd6, 0x77, 0xa5, 0x9b, 0x6c, 0x22, 0x3d, 0xc8, 0x56, 0x88, 0x47, 0x17, 0x9d, 0xcb, 0x49, 0x16, 0x93, 0xdf }, { 0xa7, 0x3f, 0xaf, 0x2a, 0x96, 0x8b, 0xc0, 0x87, 0x45, 0x98, 0x8a, 0x54, 0xc9, 0x46, 0x49, 0xcc, 0xb1, 0x49, 0xde, 0x0e, 0x52, 0x2e, 0x31, 0x6a, 0x0b, 0x04, 0x6b, 0xed, 0x45, 0x3d, 0xd5, 0xcf }, { 0xb0, 0x24, 0x35, 0xad, 0x97, 0xba, 0x36, 0xea, 0x88, 0x55, 0x38, 0x32, 0xe7, 0x6b, 0xc2, 0xfc, 0xa7, 0x54, 0xb9, 0x86, 0x9f, 0xb5, 0x13, 0x91, 0x15, 0xff, 0xbc, 0x02, 0xeb, 0x57, 0xf2, 0x83 }, { 0x1d, 0xc8, 0x36, 0x90, 0xaa, 0xf4, 0x30, 0x46, 0x6c, 0xe0, 0xb1, 0xda, 0x4b, 0x1a, 0x7c, 0x45, 0xdb, 0xb6, 0x98, 0x70, 0xc2, 0x00, 0x66, 0x20, 0xb5, 0x2c, 0x7a, 0xe9, 0x0d, 0x56, 0xca, 0xab }, { 0x0b, 0xde, 0x61, 0xa2, 0x5c, 0x97, 0x12, 0x71, 0x88, 0xfc, 0x41, 0xbc, 0x2f, 0xe1, 0x34, 0xea, 0x90, 0x4c, 0x48, 0xb2, 0xc3, 0x50, 0xf9, 0x5a, 0x75, 0x24, 0xd2, 0x2b, 0x5c, 0xed, 0x1a, 0x1a }, { 0x8c, 0x8a, 0x18, 0xeb, 0x06, 0xc5, 0xa6, 0x7a, 0xf2, 0x8d, 0x7c, 0x93, 0x54, 0x14, 0x32, 0x42, 0x64, 0xa9, 0x52, 0xba, 0xd1, 0x95, 0xc8, 0x28, 0x1d, 0x7c, 0x5a, 0xf2, 0xa4, 0x2f, 0x3b, 0xc1 }, { 0x78, 0x7d, 0x59, 0xd0, 0xaa, 0x52, 0x85, 0x51, 0x75, 0xb4, 0xe8, 0x55, 0xef, 0x72, 0xea, 0x33, 0x1d, 0x79, 0xe1, 0x9f, 0xe3, 0xfa, 0x8d, 0x4b, 0xd8, 0xba, 0x2c, 0x0b, 0x8a, 0x47, 0x34, 0x4d }, { 0x00, 0x27, 0x9a, 0x16, 0x17, 0x4d, 0x2a, 0x2f, 0x34, 0x38, 0x8a, 0x9e, 0x68, 0x5c, 0xf0, 0xc7, 0x94, 0x95, 0xab, 0x57, 0xed, 0x7c, 0x6f, 0x33, 0xda, 0xa1, 0x77, 0x37, 0xd8, 0x7e, 0x5d, 0xa0 }, { 0x0c, 0xdb, 0x4d, 0xa7, 0x2e, 0x0c, 0x99, 0xca, 0xb4, 0xd8, 0x20, 0x3c, 0x48, 0xf7, 0x4f, 0xec, 0x64, 0x41, 0xcf, 0xf0, 0x20, 0x77, 0x0f, 0xfe, 0x3e, 0xeb, 0x91, 0x39, 0x40, 0x6e, 0x29, 0x4c }, { 0x85, 0xe0, 0x08, 0xce, 0x75, 0xb9, 0x04, 0x3a, 0x20, 0x67, 0x92, 0x6b, 0xfe, 0xb6, 0x36, 0xcd, 0xe9, 0x01, 0x90, 0x09, 0x2a, 0xef, 0x04, 0xc1, 0x9b, 0x3f, 0x00, 0x91, 0x83, 0x9e, 0xe9, 0x74 }, { 0xe1, 0xd1, 0x3a, 0x25, 0x25, 0x4f, 0x02, 0x58, 0xb7, 0x7d, 0xe2, 0x56, 0xb3, 0x32, 0x83, 0x67, 0x62, 0xf3, 0x6e, 0xa9, 0xbc, 0x5b, 0x95, 0x3f, 0x7c, 0xee, 0xa8, 0x9e, 0x3b, 0xf3, 0x69, 0xd1 }, { 0xa6, 0xb5, 0x39, 0x28, 0x36, 0x4a, 0xbd, 0x3e, 0x57, 0x2f, 0x53, 0x4c, 0xb5, 0x0e, 0x7c, 0x3e, 0xb8, 0x7a, 0x56, 0x02, 0xe1, 0xcf, 0xda, 0xbb, 0x59, 0x45, 0x37, 0xb8, 0x07, 0xb4, 0x18, 0x54 }, { 0x83, 0x14, 0xa8, 0xb3, 0x3c, 0xde, 0xb8, 0x9c, 0xeb, 0xc2, 0x98, 0xd3, 0x05, 0x1c, 0xa8, 0xb7, 0xf9, 0xf7, 0x43, 0x67, 0x67, 0xfa, 0xa1, 0x95, 0xfc, 0xbf, 0xef, 0x26, 0x34, 0x1d, 0x4e, 0x79 }, { 0xdc, 0x90, 0x7c, 0xbd, 0x96, 0x3b, 0x7a, 0x71, 0xe4, 0xe4, 0xf9, 0x77, 0x08, 0x36, 0xb5, 0xdc, 0xa0, 0x05, 0xc8, 0x85, 0x0d, 0xf0, 0x35, 0xb3, 0xdb, 0x83, 0x96, 0xd3, 0x73, 0xf4, 0x9e, 0xdc }, { 0x71, 0x48, 0x7f, 0x76, 0xa3, 0xdd, 0x10, 0xfd, 0xda, 0xa5, 0x48, 0xe8, 0xb0, 0x40, 0x08, 0x84, 0xd4, 0x7e, 0x12, 0x1d, 0xe4, 0xc8, 0x01, 0xc1, 0x84, 0x37, 0x8d, 0x2a, 0xed, 0x6d, 0xce, 0x2b }, { 0x00, 0xeb, 0x1b, 0xd4, 0x69, 0xc8, 0x75, 0x76, 0x4f, 0xea, 0x1b, 0xe8, 0x7f, 0x1b, 0x8f, 0xc6, 0xfe, 0xf1, 0x02, 0x38, 0xd0, 0x72, 0x68, 0xcc, 0x3e, 0xff, 0x5b, 0xab, 0x54, 0x25, 0x88, 0x4c }, { 0x79, 0xd4, 0x42, 0x77, 0xee, 0x9d, 0x9c, 0xf7, 0x5b, 0x5a, 0x6b, 0x5b, 0x4d, 0xe2, 0xb4, 0x0f, 0x37, 0xf9, 0xdc, 0x69, 0x73, 0x75, 0x69, 0xb5, 0x0c, 0x69, 0x70, 0xa5, 0x7e, 0x25, 0x15, 0x0e }, { 0x3b, 0xb8, 0x24, 0xa6, 0x05, 0xeb, 0x8a, 0x86, 0xc7, 0x6d, 0xd1, 0xfe, 0xec, 0x68, 0x7d, 0xfa, 0x76, 0x2d, 0x8c, 0xee, 0xd8, 0xd8, 0xf7, 0x55, 0x55, 0x47, 0x91, 0xee, 0x72, 0xa1, 0xfa, 0xd7 }, { 0xc0, 0x7f, 0x4e, 0xf1, 0x09, 0x7c, 0xdf, 0xc0, 0x80, 0x40, 0xf9, 0x23, 0xb4, 0x96, 0x57, 0x51, 0xbd, 0x1f, 0xdc, 0xab, 0x7f, 0x75, 0x81, 0x44, 0xf6, 0x5c, 0x9c, 0xbb, 0x42, 0x41, 0xc7, 0x82 }, { 0x7c, 0x41, 0x87, 0x9b, 0xc7, 0x21, 0xd9, 0x5f, 0x30, 0xd1, 0x04, 0x95, 0x79, 0xd4, 0xa4, 0xc5, 0x47, 0xd7, 0x55, 0xea, 0x5b, 0xbc, 0x56, 0xad, 0x06, 0x35, 0xba, 0x6f, 0x2a, 0xe9, 0xd8, 0xdb }, { 0x9f, 0x8f, 0x6a, 0x66, 0xcc, 0x63, 0x57, 0x62, 0xab, 0x9f, 0x4e, 0xc6, 0xda, 0x60, 0x46, 0x22, 0xca, 0x44, 0xc7, 0x46, 0x37, 0xa3, 0xd8, 0x5e, 0x21, 0x8a, 0x59, 0x85, 0x12, 0x21, 0xfc, 0xd0 }, { 0x2b, 0x11, 0x4d, 0x9e, 0xae, 0xd8, 0xc0, 0x0f, 0x40, 0xaa, 0x00, 0x0a, 0x75, 0x13, 0x99, 0xb8, 0xde, 0x58, 0x0b, 0x46, 0x74, 0xf3, 0xfd, 0xb5, 0x74, 0xc1, 0x80, 0xfc, 0x7e, 0x38, 0xed, 0x31 }, { 0x40, 0x73, 0xc0, 0x03, 0xc7, 0xfd, 0x55, 0x8b, 0x26, 0x27, 0xc9, 0xd0, 0x91, 0xdb, 0x85, 0x13, 0x16, 0xd7, 0x43, 0xb9, 0x19, 0x1b, 0xa9, 0x70, 0x05, 0x33, 0x47, 0x57, 0x0f, 0xa2, 0xbb, 0xa0 }, { 0xbf, 0xda, 0xeb, 0xb9, 0x88, 0x70, 0x23, 0xd3, 0x89, 0xc9, 0x04, 0x3d, 0x3a, 0x37, 0x09, 0x3a, 0xc3, 0x88, 0xb7, 0x1d, 0x25, 0x58, 0xdd, 0x2f, 0x28, 0xb6, 0x5f, 0x08, 0xd6, 0x21, 0x09, 0xcb }, { 0x39, 0x4d, 0xeb, 0x25, 0x2b, 0x48, 0x82, 0xae, 0x84, 0x74, 0x13, 0xa0, 0x47, 0xbf, 0x2b, 0xe0, 0x29, 0xc5, 0x75, 0x77, 0x8f, 0xbf, 0x1f, 0x16, 0x2d, 0x2e, 0xe2, 0xa6, 0x95, 0x0b, 0xf1, 0x05 }, { 0xe9, 0x6f, 0x5b, 0xb4, 0x37, 0x00, 0x1f, 0xe2, 0x4e, 0xa6, 0x1e, 0xdb, 0x54, 0xc5, 0x8f, 0x0c, 0xff, 0xe9, 0x26, 0x2a, 0x6a, 0xcf, 0x10, 0x4a, 0xf6, 0xb6, 0xab, 0x57, 0x9f, 0x7c, 0x93, 0x53 }, { 0xd1, 0x42, 0x9d, 0x81, 0xef, 0x10, 0x84, 0xf7, 0xe8, 0x97, 0x4a, 0x07, 0x0f, 0xb5, 0x1d, 0xea, 0xfe, 0x08, 0x84, 0x62, 0x31, 0x32, 0xb6, 0xe1, 0x3d, 0x3e, 0x0e, 0x0a, 0x93, 0xb6, 0x66, 0xe3 }, { 0x1c, 0x20, 0x02, 0x2a, 0x80, 0xe9, 0x7c, 0xc3, 0x86, 0xe1, 0xc2, 0x71, 0x70, 0x3f, 0x92, 0x70, 0x2e, 0xe8, 0xdf, 0x21, 0x48, 0x9f, 0xdc, 0x41, 0x0f, 0xf6, 0x12, 0xd6, 0x7c, 0x9d, 0x9d, 0x1e }, { 0x7f, 0x2c, 0x19, 0x02, 0xbd, 0xda, 0x3d, 0xf6, 0x99, 0x41, 0x5f, 0x6a, 0x9f, 0xb2, 0x19, 0x4a, 0x18, 0x6b, 0x93, 0xa9, 0x94, 0x18, 0xbd, 0x99, 0x45, 0xc1, 0xca, 0x6b, 0x35, 0x60, 0x25, 0xec }, { 0x6c, 0xd6, 0x80, 0xb7, 0x7d, 0x32, 0x44, 0x51, 0x4f, 0xa3, 0x1c, 0x3a, 0x9b, 0xb7, 0x70, 0x8c, 0x45, 0xd0, 0x6f, 0x44, 0xb4, 0x57, 0x15, 0xdc, 0x2e, 0xd7, 0xc7, 0x4c, 0x70, 0xce, 0xcc, 0x04 }, { 0x8e, 0xaa, 0x33, 0xfb, 0x8f, 0x4d, 0xbf, 0x3f, 0x6b, 0x3c, 0x9d, 0x36, 0x0b, 0xdf, 0xfb, 0x6b, 0xbc, 0x48, 0xf3, 0xb3, 0x96, 0x02, 0x8f, 0x12, 0x2d, 0x07, 0xdc, 0xb5, 0x0f, 0x90, 0x89, 0x32 }, { 0x38, 0xbb, 0x05, 0xb1, 0x11, 0xbf, 0x21, 0x97, 0x54, 0x14, 0x5a, 0x63, 0xec, 0x43, 0x99, 0x6f, 0x25, 0x32, 0xfe, 0x9d, 0x82, 0xd8, 0x09, 0xce, 0x40, 0xbd, 0x5f, 0x11, 0x77, 0x87, 0x57, 0x82 }, { 0xfd, 0x53, 0xc1, 0xba, 0x88, 0xb8, 0x54, 0x52, 0xc3, 0x4d, 0x92, 0xd1, 0xcb, 0xaa, 0xad, 0xa1, 0x33, 0x43, 0x1b, 0xc6, 0xd8, 0xd6, 0x58, 0xdc, 0x86, 0x0f, 0x88, 0xd5, 0x27, 0x59, 0x0d, 0x9f }, { 0x16, 0xd6, 0x78, 0xac, 0xc1, 0x01, 0x0c, 0x87, 0xfe, 0x10, 0x4a, 0xbf, 0x88, 0xef, 0x4e, 0xc9, 0x81, 0x93, 0x78, 0x03, 0xeb, 0x85, 0x04, 0x61, 0x78, 0xf4, 0x5d, 0x3a, 0x9b, 0xf3, 0xff, 0xe6 }, { 0x1c, 0x30, 0xbe, 0xe1, 0xed, 0x70, 0xb7, 0x7a, 0x87, 0x13, 0x1e, 0x46, 0x30, 0x89, 0x75, 0xbf, 0xa2, 0x7a, 0x1e, 0xcb, 0xa8, 0xa0, 0x7c, 0x28, 0x6b, 0x11, 0xee, 0x29, 0x2e, 0x5f, 0x43, 0x71 }, { 0xa4, 0xba, 0x40, 0xd9, 0x8b, 0x83, 0x97, 0xe5, 0x25, 0xeb, 0x76, 0x81, 0xf5, 0xc5, 0x45, 0xda, 0x43, 0x26, 0x19, 0xe2, 0x3a, 0x06, 0x74, 0x21, 0x17, 0x1d, 0x95, 0x1e, 0xd0, 0x18, 0xd1, 0x0e }, { 0xbf, 0x14, 0xb2, 0x98, 0xe9, 0xc7, 0x2c, 0xa7, 0x36, 0x76, 0x91, 0x5a, 0x80, 0xfa, 0x2f, 0xac, 0x4f, 0xe2, 0xb5, 0x6e, 0xbc, 0x4d, 0xf5, 0x7e, 0x30, 0x28, 0xfd, 0x4a, 0x41, 0xac, 0x9e, 0x1c } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t tweak_value1_128bit[ 100 ][ 32 ] = { { 0x79, 0x00, 0x43, 0x2e, 0x60, 0x21, 0xbc, 0x0e, 0x62, 0x7c, 0x7b, 0x96, 0xca, 0x08, 0xb4, 0xd0 }, { 0x8c, 0xfb, 0x87, 0xd6, 0x1f, 0x9c, 0x41, 0xad, 0x3c, 0xbe, 0x38, 0xcf, 0x81, 0xd4, 0xa3, 0xea }, { 0xd6, 0xa2, 0x7b, 0x8d, 0xde, 0x6d, 0xff, 0xfa, 0x7d, 0x4c, 0xa4, 0x36, 0x44, 0x19, 0x78, 0xb0 }, { 0x7d, 0x68, 0xf0, 0xf5, 0x3d, 0x3c, 0xe0, 0x15, 0xef, 0x8f, 0x44, 0x2b, 0x40, 0x9d, 0x82, 0xb1 }, { 0xba, 0x15, 0x46, 0xff, 0xa9, 0xbf, 0x8e, 0x19, 0x4c, 0x99, 0x21, 0x1a, 0x3d, 0x62, 0x0a, 0x92 }, { 0x8d, 0x24, 0xb5, 0x79, 0xf0, 0x44, 0x83, 0x36, 0x55, 0x0d, 0x37, 0x2c, 0x72, 0x28, 0xfa, 0x1b }, { 0xd0, 0x97, 0x87, 0x71, 0x7b, 0x3c, 0xb4, 0x1a, 0x68, 0x89, 0x88, 0x23, 0xb6, 0x15, 0xa7, 0x5a }, { 0x0a, 0xda, 0xa6, 0xe0, 0xff, 0x4b, 0x0a, 0x04, 0xdf, 0xbf, 0x22, 0x47, 0xf6, 0x4a, 0x26, 0x08 }, { 0xca, 0xa8, 0x83, 0xe2, 0x75, 0x97, 0x66, 0x1d, 0x8e, 0x72, 0x58, 0x2e, 0xd3, 0x46, 0x24, 0xa4 }, { 0x39, 0x1b, 0x14, 0xe2, 0xf8, 0xcc, 0x21, 0x11, 0xbb, 0x01, 0x47, 0xa3, 0xba, 0xa0, 0x40, 0xe8 }, { 0x29, 0x76, 0xc2, 0xe8, 0x25, 0xc6, 0x1b, 0x83, 0x60, 0x40, 0x2b, 0xe3, 0x99, 0xfb, 0xea, 0x20 }, { 0xb7, 0x9e, 0x31, 0x47, 0xe9, 0x48, 0xa8, 0x44, 0x13, 0xf5, 0x45, 0x6e, 0xf0, 0x1b, 0x7f, 0xb6 }, { 0x47, 0x9c, 0xd8, 0xe9, 0xae, 0xfa, 0x5c, 0xfe, 0xc1, 0x25, 0xa1, 0x10, 0xf1, 0x1d, 0xfe, 0xcf }, { 0x42, 0x1a, 0x91, 0x2b, 0x68, 0x5a, 0xb7, 0x6b, 0x80, 0x0e, 0x9c, 0xf1, 0x56, 0xf2, 0x33, 0xb5 }, { 0xb2, 0x20, 0xa3, 0xd0, 0x90, 0x7e, 0xc1, 0xb5, 0x6f, 0x36, 0xb3, 0x8b, 0x0f, 0xdb, 0x51, 0xa6 }, { 0x4e, 0xd7, 0xea, 0x04, 0x03, 0x2c, 0x82, 0xf6, 0x12, 0xad, 0x0b, 0x26, 0x54, 0xcc, 0x9b, 0x7e }, { 0x40, 0x27, 0xcf, 0x67, 0x80, 0xa3, 0xaf, 0xc3, 0xd9, 0x9c, 0x3d, 0x2f, 0xe4, 0x6c, 0x57, 0x51 }, { 0x8a, 0x0e, 0xfa, 0xaf, 0xf0, 0x9c, 0x3a, 0xb2, 0xa3, 0xb2, 0x02, 0xa7, 0xcb, 0x67, 0x36, 0x79 }, { 0x7d, 0x9e, 0x26, 0x6a, 0xba, 0x87, 0xee, 0x2a, 0xf4, 0xab, 0x7a, 0x22, 0x75, 0x74, 0x21, 0x89 }, { 0x92, 0xe8, 0x29, 0x56, 0x31, 0xbd, 0x60, 0x8c, 0x0a, 0x53, 0xa3, 0xf2, 0x6f, 0x90, 0x7a, 0x7a }, { 0xbf, 0x96, 0x2d, 0x31, 0xbd, 0x58, 0xa1, 0xf8, 0x9e, 0x3d, 0xb4, 0x57, 0x2c, 0xfc, 0xd8, 0xdd }, { 0x6d, 0x1b, 0xaf, 0x4e, 0x86, 0xbb, 0xd5, 0xdf, 0xd8, 0xcf, 0xa3, 0x4b, 0x16, 0x96, 0x68, 0x20 }, { 0xf1, 0x7f, 0x43, 0x40, 0xdf, 0x27, 0x1f, 0xa5, 0xea, 0x5f, 0xec, 0xec, 0x58, 0xf9, 0x90, 0xbe }, { 0x05, 0xf1, 0x5b, 0x65, 0x4a, 0x7c, 0x3c, 0x8b, 0x71, 0x68, 0xab, 0xa1, 0xab, 0xef, 0xd3, 0x8a }, { 0x8f, 0xf4, 0x26, 0xa0, 0x47, 0x1d, 0x85, 0x46, 0xd5, 0x71, 0x15, 0x44, 0xa6, 0x54, 0x0b, 0x0b }, { 0x7a, 0x9f, 0x9a, 0x41, 0x82, 0xbd, 0xf2, 0x8e, 0x4d, 0x36, 0x4d, 0xb9, 0xb6, 0x7a, 0x8b, 0x0b }, { 0x88, 0xfd, 0x39, 0x1a, 0xa1, 0xf3, 0xbb, 0x6b, 0x7c, 0xee, 0x85, 0xb5, 0x37, 0x68, 0xfc, 0x76 }, { 0x57, 0xcb, 0xc8, 0xbd, 0x44, 0x06, 0x53, 0x20, 0x23, 0x19, 0xf7, 0xc9, 0x32, 0xcb, 0x95, 0x89 }, { 0x40, 0x2b, 0xe8, 0xfb, 0x1c, 0x78, 0xc0, 0x19, 0x4d, 0xe0, 0xf0, 0xbe, 0xb9, 0x0c, 0xcc, 0x98 }, { 0xad, 0x52, 0x91, 0xd8, 0x68, 0x0e, 0x2d, 0x60, 0x3c, 0xa2, 0x7d, 0xa0, 0x84, 0xd5, 0x6a, 0x78 }, { 0x92, 0x0b, 0xa4, 0x67, 0x00, 0x42, 0x87, 0x32, 0x19, 0x43, 0xcb, 0xd1, 0x32, 0x16, 0x6c, 0x20 }, { 0x93, 0x52, 0x32, 0x95, 0x8b, 0x22, 0x36, 0x95, 0xc4, 0x86, 0x5c, 0x8c, 0x09, 0x76, 0x77, 0xe7 }, { 0xfc, 0x69, 0x6d, 0x41, 0x90, 0xa3, 0xfc, 0x62, 0x73, 0xca, 0xa1, 0xa0, 0x70, 0xe5, 0xbb, 0xfc }, { 0xf1, 0x54, 0x0d, 0xcc, 0x89, 0x7f, 0x03, 0xb8, 0xa7, 0x0d, 0x7b, 0xa4, 0x50, 0x6a, 0x11, 0x15 }, { 0x14, 0xd8, 0x30, 0xf7, 0x1e, 0x15, 0xe8, 0x94, 0x53, 0x80, 0xa6, 0xe7, 0xf5, 0x33, 0xa5, 0x32 }, { 0xe7, 0xcf, 0x2a, 0x79, 0xfa, 0xb3, 0x0a, 0x2d, 0x0e, 0x46, 0x1f, 0xbb, 0x64, 0x7d, 0xde, 0xe3 }, { 0x13, 0xc3, 0x83, 0x75, 0x4d, 0x39, 0x41, 0x19, 0x43, 0x57, 0x6e, 0x45, 0xdf, 0xb7, 0x77, 0x63 }, { 0x70, 0xa0, 0x6d, 0xcf, 0x80, 0x44, 0xb9, 0x08, 0x8c, 0x00, 0xf9, 0xbb, 0x91, 0x01, 0x4c, 0x89 }, { 0x20, 0x2f, 0x6f, 0x09, 0x0d, 0x29, 0x5e, 0x11, 0x8d, 0x1c, 0xe5, 0x01, 0xad, 0xd6, 0x9e, 0xe8 }, { 0xfa, 0x02, 0xf1, 0xdf, 0x19, 0x56, 0xfb, 0x9b, 0x11, 0xac, 0x59, 0x93, 0x3d, 0xfc, 0x0e, 0x67 }, { 0x51, 0x5e, 0xc6, 0x65, 0x7d, 0x39, 0x23, 0xc5, 0x68, 0xa3, 0xf7, 0x50, 0x3f, 0x46, 0x16, 0x63 }, { 0x4b, 0x5f, 0x1b, 0x93, 0x8b, 0xd9, 0x14, 0x5c, 0x5a, 0x0c, 0x27, 0xd5, 0x51, 0xa0, 0xd8, 0xb2 }, { 0xa4, 0xa5, 0x90, 0x5f, 0xa0, 0xb1, 0x06, 0x5a, 0xf6, 0xbf, 0xbe, 0xea, 0xc9, 0x57, 0x83, 0x79 }, { 0x00, 0xf9, 0x9c, 0xfd, 0xea, 0x2b, 0x04, 0x5c, 0x5b, 0x8e, 0x29, 0xae, 0x80, 0x13, 0x68, 0xcc }, { 0x84, 0x2d, 0x10, 0x8a, 0x3c, 0xd4, 0x48, 0xbf, 0x50, 0x5c, 0xda, 0x8b, 0x37, 0x56, 0x26, 0xec }, { 0x93, 0x5d, 0xb9, 0x5d, 0x74, 0xd2, 0x04, 0x46, 0x34, 0xa4, 0x26, 0x53, 0x3a, 0x3f, 0x19, 0x1d }, { 0x3f, 0x0a, 0xef, 0x56, 0x62, 0xd5, 0xf2, 0xe4, 0x0d, 0x33, 0xf1, 0x71, 0x2a, 0xea, 0x39, 0x2a }, { 0xab, 0xff, 0x43, 0xaa, 0x43, 0xc2, 0xbe, 0x70, 0xae, 0xd5, 0xc9, 0x11, 0xf5, 0x36, 0x1d, 0xe1 }, { 0x89, 0x84, 0x93, 0xe8, 0xce, 0x34, 0x3b, 0x40, 0x0e, 0x4e, 0x2a, 0xb9, 0xc6, 0x5d, 0x45, 0xc0 }, { 0xd5, 0xa8, 0xb6, 0xd4, 0xb5, 0x1b, 0xac, 0xa7, 0x49, 0x5e, 0xce, 0x35, 0xb9, 0x11, 0xc3, 0x61 }, { 0xde, 0x75, 0x4c, 0x60, 0x85, 0xaf, 0xf2, 0xe6, 0xd7, 0x59, 0xcb, 0xb5, 0x21, 0x4e, 0xbc, 0x8a }, { 0x96, 0x78, 0xbf, 0x96, 0x46, 0xf9, 0x1f, 0xf5, 0xbe, 0x8e, 0x5c, 0xe7, 0xd5, 0xb9, 0x79, 0xaf }, { 0x34, 0x19, 0x22, 0x27, 0x36, 0x16, 0x56, 0xb6, 0xfb, 0xf9, 0x86, 0xd1, 0x05, 0x0c, 0x33, 0xa1 }, { 0x5b, 0x8b, 0x3b, 0x04, 0x0d, 0x78, 0xf5, 0xcf, 0x32, 0x75, 0x08, 0xe1, 0x80, 0xed, 0xc1, 0x52 }, { 0x1f, 0xb5, 0xf8, 0xe0, 0x5c, 0x76, 0x30, 0x2a, 0x24, 0x61, 0x2c, 0xb3, 0xe5, 0x85, 0xc8, 0xf0 }, { 0x6b, 0xf9, 0xa3, 0xe6, 0x4b, 0x2f, 0x89, 0x3a, 0x40, 0xd0, 0x12, 0x65, 0x1d, 0x2b, 0xd7, 0xf1 }, { 0x70, 0x2c, 0xc1, 0xb2, 0x51, 0x55, 0x9b, 0xa3, 0x6c, 0x97, 0xff, 0x62, 0xff, 0xbf, 0xd5, 0x10 }, { 0x10, 0x0a, 0xec, 0x34, 0x7f, 0x62, 0xe5, 0xbf, 0x01, 0xa8, 0xd4, 0xf2, 0x79, 0xbd, 0x57, 0x40 }, { 0x15, 0xb8, 0xb4, 0x71, 0x97, 0x9e, 0xb2, 0x20, 0x86, 0xf2, 0xc3, 0x4f, 0xba, 0x7a, 0x0c, 0x71 }, { 0xe6, 0xea, 0xb2, 0x57, 0x34, 0x12, 0xad, 0xc1, 0xa8, 0x51, 0x7d, 0x57, 0xbb, 0x6c, 0x99, 0x3c }, { 0x72, 0x09, 0x48, 0xa8, 0x4a, 0x9c, 0x52, 0xbe, 0xff, 0x58, 0x4a, 0xf9, 0xac, 0xe6, 0xee, 0x9e }, { 0xdc, 0x7c, 0x32, 0xc7, 0x12, 0xf5, 0xea, 0x13, 0x63, 0xb8, 0x04, 0xa4, 0xfa, 0xa9, 0xc6, 0xee }, { 0xe1, 0x61, 0x80, 0x26, 0x35, 0x53, 0xad, 0x75, 0x9c, 0xce, 0xe4, 0x51, 0xe3, 0x2a, 0x9b, 0x25 }, { 0x67, 0xc0, 0x5b, 0xeb, 0x83, 0x78, 0x76, 0x0d, 0xe1, 0x2f, 0xb2, 0x2c, 0x1a, 0xb6, 0x68, 0x39 }, { 0x03, 0x7f, 0xd7, 0x82, 0x31, 0xd2, 0x7b, 0x3a, 0x3b, 0xc4, 0x19, 0xdd, 0xfd, 0x04, 0x68, 0x3d }, { 0x58, 0x9d, 0xd4, 0x83, 0xfe, 0xda, 0x2c, 0x6d, 0x49, 0xd3, 0xd9, 0xdd, 0x68, 0x38, 0xb2, 0xc5 }, { 0x0e, 0x3c, 0xd2, 0x60, 0x86, 0xd7, 0xde, 0xeb, 0x3f, 0xde, 0x71, 0xb2, 0xf8, 0xbd, 0xf5, 0x2b }, { 0x0b, 0x24, 0x98, 0x65, 0xb5, 0xe1, 0x47, 0xcd, 0x40, 0xe6, 0x53, 0x12, 0x99, 0xda, 0x33, 0xc5 }, { 0xb6, 0xb5, 0x7c, 0x53, 0xf0, 0x5d, 0xcc, 0x76, 0x68, 0x07, 0x8b, 0x0d, 0x9d, 0x3e, 0x45, 0x35 }, { 0x36, 0x88, 0x54, 0xa6, 0x93, 0x93, 0x00, 0x29, 0x29, 0xac, 0x54, 0xe1, 0xfa, 0xb7, 0xfb, 0x60 }, { 0x77, 0x95, 0x25, 0xbd, 0x7e, 0x5c, 0x47, 0xd6, 0x04, 0xda, 0x70, 0x9e, 0x76, 0x70, 0x57, 0x16 }, { 0x06, 0x07, 0xeb, 0x14, 0x3a, 0x6f, 0x1a, 0x29, 0x4b, 0x6b, 0xd3, 0x51, 0x7c, 0x75, 0x8a, 0xe5 }, { 0x00, 0xdd, 0x2e, 0x50, 0x13, 0xb0, 0x3a, 0x90, 0x01, 0xc9, 0xa2, 0x24, 0x09, 0x91, 0xcf, 0xe1 }, { 0xa2, 0xa7, 0x2f, 0xf8, 0x71, 0xe9, 0xa9, 0x01, 0x1e, 0xc2, 0xdc, 0x4b, 0x79, 0xc3, 0x63, 0x22 }, { 0xaa, 0xcb, 0xb6, 0x0c, 0xa2, 0x6f, 0x89, 0xce, 0xd0, 0x75, 0xe9, 0x7c, 0x73, 0x25, 0x76, 0xab }, { 0xf8, 0x43, 0x86, 0x8e, 0xfe, 0xef, 0xf8, 0x6f, 0x35, 0x8d, 0xba, 0xab, 0x04, 0x44, 0xa8, 0x00 }, { 0xf5, 0x48, 0xa3, 0x34, 0xc9, 0x18, 0xb1, 0xa2, 0xe3, 0xf1, 0x18, 0x1c, 0x1a, 0x7e, 0x26, 0x3c }, { 0xa2, 0x0d, 0x33, 0xc2, 0xdb, 0x13, 0x2a, 0x5f, 0xea, 0x42, 0x87, 0xf4, 0x71, 0xef, 0x94, 0xdf }, { 0x03, 0x25, 0xd5, 0xca, 0xb4, 0x85, 0x11, 0x0f, 0x23, 0x70, 0x3a, 0xb1, 0x85, 0xc9, 0x8a, 0xf3 }, { 0x53, 0xc4, 0xd4, 0x10, 0x1a, 0x49, 0x75, 0x86, 0x3f, 0xfc, 0xb8, 0x57, 0xfb, 0x5c, 0x12, 0xf2 }, { 0xe9, 0xae, 0x4c, 0x86, 0x4f, 0xb0, 0x5b, 0xe2, 0x60, 0x60, 0x35, 0xc0, 0xae, 0xbb, 0x85, 0x80 }, { 0xd1, 0x7b, 0x19, 0x0f, 0xb3, 0xe1, 0x29, 0xbc, 0x4f, 0x44, 0x48, 0xd7, 0xa6, 0xbd, 0x5e, 0x46 }, { 0x49, 0x1a, 0x76, 0xae, 0xb6, 0x6f, 0xaf, 0x23, 0x28, 0xc9, 0xbb, 0x7e, 0x9c, 0xcd, 0x21, 0x22 }, { 0x35, 0x6e, 0x3e, 0xa6, 0xf1, 0x0a, 0xfa, 0x89, 0x35, 0x84, 0x34, 0x5e, 0x6d, 0x2d, 0x02, 0x82 }, { 0x98, 0x8d, 0x16, 0x21, 0xa4, 0x68, 0x13, 0x7f, 0x3a, 0x6d, 0x88, 0xe6, 0xc1, 0x98, 0xd0, 0xa9 }, { 0x3b, 0x26, 0x2c, 0xe6, 0x39, 0xc0, 0x6a, 0x7c, 0x1a, 0x46, 0x29, 0x01, 0x0a, 0xeb, 0xd6, 0x77 }, { 0x44, 0x0f, 0x5b, 0x3b, 0x83, 0xda, 0x79, 0xd5, 0xc6, 0x0a, 0x23, 0x6a, 0x51, 0xf2, 0x1f, 0xae }, { 0x74, 0xab, 0xc0, 0x01, 0x8c, 0xd6, 0xb5, 0x22, 0x70, 0x45, 0x42, 0xbc, 0x65, 0xae, 0x54, 0x99 }, { 0xc3, 0xdf, 0x1b, 0xb1, 0x3b, 0xee, 0x0c, 0x55, 0xc8, 0xc0, 0x6b, 0x61, 0x60, 0xf3, 0x6a, 0xee }, { 0xcd, 0xd7, 0x33, 0x42, 0x1c, 0x22, 0x5a, 0x98, 0x8a, 0xdc, 0xe4, 0x8e, 0x3b, 0x9f, 0x9b, 0x6c }, { 0xec, 0x81, 0x29, 0x1a, 0xd8, 0x65, 0xe7, 0x4a, 0xd5, 0x32, 0xb7, 0xba, 0x5f, 0x7f, 0x74, 0x35 }, { 0x90, 0x35, 0xd4, 0x24, 0x7d, 0xde, 0x48, 0xc8, 0xb9, 0x73, 0xe7, 0x7f, 0x5b, 0x83, 0x66, 0xd0 }, { 0xbb, 0x81, 0x9e, 0x43, 0xed, 0x93, 0x35, 0xc4, 0x7a, 0xb2, 0xc7, 0x10, 0xee, 0x45, 0x46, 0xed }, { 0xba, 0x70, 0xeb, 0xb0, 0xd3, 0x88, 0xc8, 0xec, 0x10, 0xa5, 0x79, 0xac, 0xb3, 0xfd, 0x19, 0x30 }, { 0xa2, 0x48, 0x50, 0xa9, 0xe8, 0xc0, 0xc7, 0x73, 0x36, 0x07, 0xfc, 0x10, 0x43, 0xa7, 0x62, 0xf7 }, { 0xf8, 0xc5, 0x30, 0xc8, 0x34, 0x44, 0x77, 0x13, 0xf0, 0x41, 0xc1, 0xb7, 0xfa, 0x24, 0x3b, 0xc8 }, { 0xa1, 0x89, 0xe7, 0xd6, 0x67, 0x8d, 0x41, 0xb0, 0x2d, 0xde, 0x8f, 0xbf, 0xdb, 0x90, 0x18, 0x7f }, { 0xec, 0x1e, 0x5f, 0xed, 0x86, 0x77, 0x05, 0x60, 0x31, 0x0b, 0x1a, 0x60, 0xbc, 0x78, 0x5c, 0xc4 }, { 0x4b, 0x5e, 0x84, 0xd6, 0xe3, 0x24, 0x24, 0x08, 0x64, 0x7d, 0x92, 0x4f, 0x71, 0x84, 0x8a, 0x0e }, { 0x0b, 0x67, 0x91, 0xa9, 0x3c, 0x2e, 0xf8, 0x4a, 0xff, 0x52, 0xb6, 0x3f, 0xe6, 0x2a, 0xb9, 0x77 } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t tweak_value2_128bit[ 100 ][ 32 ] = { { 0x53, 0x19, 0xfb, 0x90, 0xe1, 0x36, 0xc7, 0xd0, 0x25, 0xe3, 0x76, 0x54, 0x32, 0xe6, 0xd4, 0x13 }, { 0x57, 0x6c, 0x5c, 0x41, 0x6f, 0x26, 0x7f, 0xa4, 0x61, 0x74, 0x26, 0xdc, 0x71, 0xb6, 0xbe, 0x24 }, { 0x7d, 0x4b, 0xd1, 0x03, 0x7b, 0xf2, 0x6d, 0x79, 0x3a, 0x09, 0xdc, 0x06, 0x42, 0x06, 0x02, 0x46 }, { 0x33, 0xb9, 0x15, 0xfc, 0xe7, 0xea, 0x20, 0x53, 0x3f, 0xf0, 0xbe, 0x2d, 0x69, 0x70, 0x64, 0xac }, { 0x8e, 0xde, 0xb6, 0x5d, 0x5b, 0xe1, 0x9b, 0x19, 0x43, 0x53, 0x87, 0x52, 0xb8, 0x85, 0xe3, 0xf9 }, { 0x32, 0x1c, 0x76, 0xa9, 0x1a, 0x1b, 0x19, 0x08, 0xc5, 0x21, 0xd8, 0x68, 0xb2, 0x91, 0x4e, 0xef }, { 0xbe, 0x79, 0x5b, 0xa1, 0x4b, 0xa6, 0x61, 0x52, 0x47, 0x92, 0xe3, 0xca, 0xbd, 0xb8, 0xf9, 0x7a }, { 0x0e, 0xed, 0x58, 0xf5, 0xc2, 0x7f, 0xb9, 0x14, 0x19, 0xea, 0x3b, 0x23, 0xff, 0x87, 0xb1, 0x62 }, { 0x76, 0x9b, 0x82, 0x3a, 0x46, 0x0a, 0x08, 0xd3, 0xa3, 0x5a, 0x0a, 0x8b, 0x98, 0x31, 0x63, 0xe7 }, { 0xfa, 0xe3, 0xd8, 0x3c, 0x2e, 0xe4, 0x9c, 0x12, 0x2c, 0x1d, 0x58, 0x86, 0xaf, 0x4f, 0xc3, 0x64 }, { 0x02, 0x57, 0xc5, 0xa4, 0x77, 0x8e, 0xca, 0xc7, 0x25, 0x33, 0xab, 0xbc, 0x51, 0x3e, 0xfd, 0x92 }, { 0xc2, 0xc8, 0xef, 0xef, 0x4b, 0x98, 0x05, 0x5c, 0x04, 0x65, 0x78, 0x15, 0xfd, 0x26, 0x3a, 0x94 }, { 0x14, 0xc2, 0x6a, 0xed, 0xba, 0xa6, 0x30, 0x9e, 0xde, 0x93, 0xdc, 0x6f, 0x96, 0xaf, 0xa5, 0x4e }, { 0x1d, 0x25, 0x2f, 0xe6, 0x7b, 0xc7, 0xa5, 0x40, 0x44, 0xcf, 0xa6, 0xb9, 0xdb, 0x14, 0x14, 0x9f }, { 0x92, 0x2e, 0x9a, 0x6e, 0x66, 0x9b, 0xb3, 0x2e, 0xda, 0xf3, 0xe4, 0x5c, 0x44, 0x2e, 0x07, 0xbc }, { 0x4e, 0x05, 0xee, 0xa6, 0xbe, 0x3b, 0x3e, 0xe6, 0xbb, 0x5b, 0x0e, 0x8f, 0x86, 0xa4, 0xab, 0x12 }, { 0xd6, 0xc9, 0x9f, 0x58, 0x9a, 0x7c, 0x9e, 0x09, 0xe7, 0x6c, 0x0c, 0xbe, 0xe9, 0x3f, 0xdc, 0x97 }, { 0x4c, 0x0b, 0xc7, 0xaf, 0xae, 0x44, 0xf2, 0xb0, 0x23, 0xdc, 0x33, 0x7c, 0xec, 0xe4, 0x79, 0xd1 }, { 0xd0, 0xd7, 0x1e, 0x9b, 0x46, 0x4f, 0x6a, 0x55, 0x1a, 0x27, 0x50, 0xb0, 0x37, 0xfb, 0x7e, 0x82 }, { 0x32, 0xda, 0xce, 0x1c, 0x2c, 0xb2, 0x82, 0xb7, 0xe8, 0x33, 0x49, 0xca, 0x0a, 0xa3, 0xb0, 0x2e }, { 0x5f, 0x61, 0x9d, 0xa3, 0x2f, 0x6a, 0x83, 0xc6, 0xe2, 0x71, 0x6d, 0xda, 0xf5, 0x28, 0x2d, 0x94 }, { 0x72, 0x06, 0x6f, 0x46, 0x27, 0x97, 0x8f, 0xfb, 0xc2, 0xef, 0xc3, 0xf4, 0x1f, 0x62, 0x80, 0x0d }, { 0x0d, 0xe9, 0x33, 0xe4, 0x36, 0x42, 0xc5, 0x78, 0x8c, 0x77, 0x0a, 0x48, 0x6a, 0x2e, 0xcc, 0xc6 }, { 0xfa, 0xd0, 0x2f, 0x96, 0x04, 0xc1, 0x6e, 0x3b, 0x7e, 0xee, 0x1d, 0xb6, 0xf5, 0x46, 0x60, 0x96 }, { 0x9c, 0x02, 0x7a, 0x2a, 0xc9, 0x13, 0xa0, 0xa8, 0xb0, 0xb0, 0xa4, 0x8c, 0x6b, 0x13, 0xbf, 0xd2 }, { 0x5c, 0xf7, 0x9d, 0xb6, 0xc5, 0xcd, 0x99, 0x1a, 0x1c, 0x78, 0x81, 0x42, 0x24, 0x95, 0x1e, 0x84 }, { 0xa1, 0x15, 0x9c, 0xfc, 0xfa, 0x67, 0x81, 0xe1, 0x61, 0x7f, 0xc1, 0xf8, 0xf6, 0x11, 0x0e, 0xea }, { 0x34, 0x23, 0x2e, 0x6b, 0x98, 0x30, 0xa0, 0x3c, 0x97, 0x0b, 0xc7, 0xc8, 0x78, 0x4f, 0x6f, 0x99 }, { 0x2a, 0x7f, 0x2d, 0xba, 0x78, 0x60, 0x5b, 0x7d, 0x44, 0x6d, 0xa4, 0x48, 0x4b, 0xe7, 0xdb, 0x25 }, { 0x45, 0x8c, 0x11, 0x97, 0x21, 0x5f, 0x3e, 0x52, 0xc3, 0x45, 0xba, 0xc4, 0x8d, 0xed, 0x0c, 0x89 }, { 0x25, 0x4b, 0x67, 0x26, 0xfd, 0x24, 0x76, 0x9f, 0xc7, 0xda, 0x30, 0xa3, 0xfe, 0xc8, 0x23, 0xd7 }, { 0x4f, 0x54, 0xf2, 0x05, 0xd6, 0x1a, 0x71, 0xfa, 0x94, 0x29, 0x37, 0x98, 0x52, 0xee, 0x05, 0xa3 }, { 0xc5, 0x68, 0x00, 0xac, 0x94, 0xf5, 0x72, 0x05, 0x8c, 0xd0, 0xa6, 0x3c, 0x7e, 0x9e, 0xa4, 0x5e }, { 0x1a, 0x0d, 0xa4, 0x1c, 0xd4, 0x78, 0xb5, 0xbb, 0xd5, 0xc2, 0x41, 0xb5, 0x6b, 0xc3, 0x58, 0x5c }, { 0x9b, 0x70, 0xa5, 0x20, 0x6d, 0xbc, 0xe1, 0xc3, 0xef, 0x42, 0xc0, 0x59, 0x10, 0x35, 0x61, 0x85 }, { 0xa0, 0xd5, 0x74, 0x60, 0xa4, 0x38, 0x8e, 0xf3, 0x98, 0x80, 0xce, 0xa4, 0x35, 0x09, 0x5e, 0xe7 }, { 0xbe, 0x9f, 0x2c, 0xda, 0x02, 0xf1, 0xe3, 0x5b, 0x15, 0x5f, 0xc0, 0x4a, 0x7f, 0x3e, 0x95, 0x57 }, { 0x86, 0x46, 0xc5, 0x3c, 0x9e, 0x2e, 0x47, 0xb2, 0x98, 0x48, 0x6e, 0xb9, 0x2a, 0xb7, 0x4c, 0x30 }, { 0x14, 0xed, 0xbb, 0x75, 0x5a, 0xb9, 0xdf, 0xe2, 0xe3, 0x70, 0x54, 0x6a, 0x1d, 0xa9, 0xe6, 0xf6 }, { 0xcb, 0x38, 0xd1, 0xa1, 0xdd, 0x9c, 0x57, 0xaa, 0x06, 0x73, 0x08, 0xee, 0x91, 0xe9, 0x04, 0x19 }, { 0x8b, 0x66, 0x0f, 0xe9, 0xa5, 0xe3, 0xd3, 0x9e, 0x5f, 0x82, 0x0a, 0xdb, 0x2f, 0x21, 0xd8, 0x3a }, { 0x51, 0xaf, 0xad, 0xac, 0xe8, 0x42, 0x0b, 0x51, 0x6c, 0xf5, 0xe8, 0xce, 0x06, 0x36, 0x83, 0x93 }, { 0x42, 0x5a, 0x4b, 0x30, 0xa4, 0xcd, 0x0b, 0xad, 0x3c, 0x75, 0xc7, 0xda, 0xf0, 0xb3, 0x1a, 0xc8 }, { 0x6b, 0x2f, 0xd2, 0xd2, 0x5d, 0x6a, 0x68, 0x0a, 0xbe, 0xaa, 0x4e, 0xdb, 0x22, 0x96, 0xff, 0x3d }, { 0xa4, 0x2c, 0x61, 0x92, 0xf0, 0x6d, 0x2d, 0xdc, 0x9a, 0x55, 0x1b, 0xc9, 0x09, 0x8d, 0xfe, 0x12 }, { 0x3f, 0x99, 0xde, 0x81, 0x3e, 0xed, 0x13, 0x8e, 0x02, 0x9a, 0xcd, 0x2d, 0xe7, 0x59, 0x3c, 0x28 }, { 0x7f, 0x35, 0x73, 0xb7, 0xb1, 0x47, 0xcf, 0x47, 0x33, 0x36, 0x57, 0xc8, 0x73, 0xaf, 0xff, 0xf5 }, { 0x29, 0x15, 0xe3, 0x7a, 0xbd, 0x33, 0x46, 0x24, 0x34, 0x96, 0x4d, 0x38, 0x01, 0xe0, 0x0a, 0x34 }, { 0x74, 0xd0, 0x1c, 0xc8, 0xcf, 0xc0, 0x95, 0xfd, 0xd6, 0x69, 0xf3, 0xe4, 0x20, 0x1d, 0x77, 0x74 }, { 0x71, 0x50, 0x0c, 0xe1, 0x00, 0xb1, 0xc6, 0x62, 0x68, 0x41, 0x57, 0x11, 0x7c, 0xe1, 0x6e, 0x53 }, { 0x0e, 0x54, 0x45, 0xe0, 0x60, 0x62, 0x85, 0x75, 0xae, 0xf9, 0xbf, 0xfd, 0x99, 0xd9, 0x06, 0x72 }, { 0x9c, 0xde, 0x2a, 0x35, 0xad, 0x64, 0x40, 0xc4, 0xbc, 0x14, 0x8c, 0xa0, 0xc7, 0x8b, 0x05, 0x6a }, { 0xe0, 0xf6, 0x1c, 0xb7, 0xf2, 0x36, 0xee, 0x8b, 0x44, 0x41, 0xa6, 0xa5, 0xfa, 0xa6, 0x43, 0x9b }, { 0x00, 0x6f, 0xd6, 0xa7, 0x44, 0xe0, 0x59, 0x8f, 0x85, 0x69, 0xfe, 0x19, 0x31, 0x7b, 0xab, 0xc4 }, { 0x5d, 0x43, 0xb9, 0x7d, 0xc5, 0xc4, 0x4c, 0x61, 0xc7, 0xe9, 0xc6, 0xa6, 0x21, 0x4a, 0x97, 0x0a }, { 0x48, 0xe0, 0xf7, 0xba, 0xf7, 0x67, 0x67, 0xea, 0x56, 0xc1, 0xf9, 0xe1, 0x4c, 0xab, 0x12, 0x0f }, { 0x4e, 0x25, 0x74, 0xd3, 0x1f, 0x9b, 0x60, 0x2c, 0xdf, 0xe6, 0x3d, 0x45, 0xc1, 0x05, 0x7d, 0x31 }, { 0xcf, 0xe0, 0x86, 0x2c, 0x45, 0xfc, 0x27, 0x50, 0x74, 0xd4, 0x14, 0xdf, 0x2b, 0xf8, 0x7c, 0x74 }, { 0xda, 0x68, 0x78, 0x7d, 0x75, 0xdf, 0xbb, 0x4b, 0xe1, 0x4a, 0x39, 0x07, 0x0f, 0xb5, 0x39, 0x23 }, { 0xde, 0x23, 0x46, 0x8a, 0xc5, 0xa8, 0xaf, 0x13, 0x58, 0x3e, 0x04, 0x24, 0xb3, 0x37, 0x02, 0x14 }, { 0x67, 0x07, 0x37, 0x6c, 0xee, 0x14, 0xfa, 0xf5, 0x0f, 0xe9, 0x8c, 0x15, 0x3b, 0x11, 0x2e, 0xb8 }, { 0xd5, 0x14, 0x3c, 0x2f, 0x1c, 0xc1, 0xfd, 0x05, 0x2d, 0x86, 0xa6, 0xb3, 0x40, 0x49, 0x44, 0xab }, { 0xe0, 0x9c, 0xb4, 0x39, 0xd7, 0x0d, 0x9e, 0x55, 0xc7, 0x4b, 0x51, 0x3f, 0x95, 0x40, 0x93, 0xb2 }, { 0x12, 0x3e, 0xee, 0x6c, 0xbd, 0x27, 0x36, 0xf9, 0x06, 0xaf, 0xb8, 0x71, 0x10, 0x30, 0xac, 0x18 }, { 0x23, 0xb9, 0x2f, 0x2e, 0xc6, 0x2b, 0x87, 0x58, 0xad, 0x67, 0xff, 0x77, 0xc3, 0x3a, 0x92, 0xfe }, { 0x9b, 0xcb, 0xd6, 0xca, 0x75, 0xe2, 0x9a, 0x74, 0xd3, 0x70, 0x7a, 0xb4, 0x07, 0x48, 0x12, 0x73 }, { 0xfd, 0xeb, 0x2c, 0x91, 0x81, 0x45, 0x04, 0x56, 0x3d, 0xe7, 0xbb, 0x0b, 0x25, 0xa8, 0xbe, 0xb6 }, { 0x7b, 0x45, 0x88, 0x42, 0x8f, 0x97, 0xa0, 0x74, 0xc8, 0x31, 0x70, 0x3e, 0xf6, 0x7a, 0xae, 0x48 }, { 0xc6, 0x51, 0x51, 0x7a, 0x45, 0x5f, 0x01, 0xef, 0xd5, 0x10, 0x51, 0x9c, 0xbc, 0xac, 0x8f, 0x10 }, { 0x9f, 0x1d, 0x3d, 0x84, 0x4b, 0x60, 0xbf, 0x8d, 0x5c, 0xee, 0x7f, 0xae, 0x53, 0x2c, 0x5a, 0x5f }, { 0x55, 0xbe, 0x12, 0xa0, 0x1a, 0x7b, 0xaf, 0xf9, 0x37, 0x93, 0x77, 0xe9, 0xc9, 0x59, 0x57, 0x46 }, { 0xa2, 0x39, 0xe1, 0xf6, 0xf0, 0x9c, 0x90, 0x07, 0x73, 0x0b, 0xcd, 0x43, 0x8c, 0x68, 0x1b, 0xab }, { 0x96, 0x16, 0xb7, 0x7c, 0x5e, 0xae, 0x8b, 0xfa, 0x6b, 0x2a, 0x8c, 0x0c, 0x66, 0x26, 0xc6, 0x85 }, { 0x7d, 0xd6, 0xb0, 0x34, 0x1e, 0xc1, 0x0f, 0xbe, 0x22, 0xac, 0x77, 0x84, 0x01, 0x66, 0x66, 0x54 }, { 0x0c, 0x0b, 0xc9, 0xf5, 0xed, 0xbc, 0x4d, 0xf9, 0x04, 0x3b, 0x4c, 0x0e, 0x4c, 0x7e, 0x7d, 0x07 }, { 0xb7, 0x95, 0xe4, 0x03, 0x75, 0xa1, 0x5c, 0xcd, 0xe2, 0x1b, 0xa8, 0x70, 0xa9, 0xe4, 0xe2, 0x2e }, { 0xd6, 0xc4, 0x6b, 0x9c, 0x5e, 0x08, 0x5a, 0x18, 0x92, 0x9a, 0xce, 0xca, 0x53, 0xe5, 0xa9, 0xc7 }, { 0xd4, 0x8c, 0xfa, 0xc7, 0x6b, 0xae, 0xa7, 0xca, 0x5d, 0x31, 0xbd, 0x2b, 0x6f, 0x90, 0x8a, 0x2a }, { 0xb5, 0xec, 0xf5, 0xae, 0xdd, 0x2f, 0xbe, 0x0f, 0x47, 0x66, 0x1f, 0xb0, 0xe2, 0x12, 0x7e, 0x74 }, { 0xb2, 0xdc, 0x9f, 0x62, 0x6c, 0x36, 0xd4, 0xf0, 0xe3, 0x26, 0xb5, 0xda, 0x36, 0xe7, 0xf4, 0x1e }, { 0xcc, 0xa7, 0x7f, 0xc7, 0xc6, 0x89, 0x1b, 0x7c, 0x4f, 0xcc, 0x4f, 0x46, 0x62, 0x15, 0xaf, 0xe6 }, { 0x79, 0xa8, 0x14, 0x0a, 0xd7, 0x1f, 0xbc, 0xbe, 0xc1, 0x9d, 0x90, 0x2b, 0x81, 0xf0, 0x96, 0x8f }, { 0xd4, 0xa9, 0x98, 0x5b, 0x87, 0x5f, 0xe4, 0x80, 0x0e, 0x95, 0xd1, 0x98, 0x8f, 0x6c, 0xa9, 0xe1 }, { 0x32, 0x04, 0x40, 0x4a, 0x2d, 0xc6, 0x51, 0x5f, 0x2d, 0x80, 0x4d, 0x77, 0xb1, 0x39, 0xbb, 0x1c }, { 0xb5, 0x12, 0x45, 0x80, 0x16, 0xc1, 0x06, 0xb6, 0x04, 0x77, 0xff, 0xb0, 0xe6, 0xe5, 0x77, 0xe9 }, { 0x67, 0x96, 0x64, 0x42, 0x34, 0x21, 0xfc, 0xbf, 0x13, 0x6a, 0x84, 0x67, 0x7c, 0xc7, 0xcc, 0x26 }, { 0x4e, 0xae, 0x7e, 0xb0, 0x66, 0xb9, 0x09, 0xb0, 0xdf, 0xc3, 0xd9, 0x7c, 0x64, 0x89, 0x84, 0xc3 }, { 0xe6, 0x08, 0xed, 0x8d, 0x0e, 0x42, 0x90, 0xdd, 0x8c, 0xea, 0xc0, 0x4c, 0xad, 0x45, 0xe3, 0x0d }, { 0x20, 0xbd, 0x32, 0x2a, 0x26, 0xff, 0x06, 0x5f, 0x0f, 0xd1, 0xe3, 0x98, 0x53, 0xb0, 0x4b, 0x2e }, { 0x3e, 0xee, 0xb4, 0x38, 0x1a, 0x36, 0x46, 0x36, 0x5b, 0x58, 0x09, 0xa7, 0xe3, 0x92, 0xd2, 0xec }, { 0x88, 0xeb, 0x8e, 0xf0, 0x50, 0xea, 0xd3, 0x88, 0x60, 0x26, 0x49, 0x8b, 0xf0, 0xcf, 0x31, 0x20 }, { 0xbc, 0xee, 0x9c, 0xe6, 0x8b, 0x99, 0xcc, 0x1a, 0xa0, 0xf4, 0xcd, 0x3f, 0xeb, 0x76, 0x87, 0x92 }, { 0xc8, 0xde, 0xa6, 0x2b, 0x20, 0x96, 0x7f, 0xbf, 0xd0, 0x05, 0xcb, 0x44, 0xdc, 0x2d, 0x2c, 0x29 }, { 0x41, 0x9e, 0x25, 0x07, 0x47, 0xf5, 0xc6, 0x49, 0xf3, 0x3c, 0xe8, 0xc1, 0x4e, 0xf4, 0x09, 0x1f }, { 0x75, 0x34, 0xb3, 0xa4, 0x99, 0x02, 0xc6, 0x77, 0x19, 0x6c, 0xa8, 0xf2, 0x77, 0x59, 0x79, 0x10 }, { 0xcf, 0x5c, 0xa0, 0xf7, 0xaf, 0x99, 0x53, 0x6f, 0xc4, 0x01, 0x88, 0x3e, 0x5d, 0xf6, 0x05, 0x04 }, { 0x7c, 0x85, 0x34, 0x54, 0x91, 0xf8, 0x75, 0x9e, 0x08, 0x5e, 0xfd, 0xfe, 0xbd, 0x67, 0xb7, 0x0d }, { 0xe0, 0x68, 0x63, 0x50, 0x89, 0x66, 0x40, 0x9d, 0x63, 0xdc, 0xf0, 0x91, 0x2f, 0x0c, 0xc6, 0x08 }, { 0xb3, 0x8a, 0x84, 0xe3, 0xbe, 0x18, 0xf1, 0xc7, 0xce, 0xb8, 0x25, 0x57, 0xbb, 0xf3, 0x36, 0x61 }, { 0xdc, 0xf7, 0x21, 0xca, 0xc1, 0xce, 0x6b, 0xb3, 0xaf, 0x57, 0x9d, 0xf8, 0x8a, 0x12, 0x52, 0x95 } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t tweak_value3_128bit[ 100 ][ 32 ] = { { 0x23, 0x79, 0xd5, 0xa6, 0x85, 0x0e, 0xc7, 0x4e, 0x74, 0x57, 0xf5, 0xa3, 0xad, 0x43, 0xaf, 0x40 }, { 0x9f, 0xa4, 0x1b, 0x79, 0xea, 0x18, 0xdc, 0xd6, 0xdd, 0x2c, 0x1d, 0x8c, 0xb0, 0x00, 0x6d, 0x28 }, { 0x9d, 0x85, 0xe0, 0xc9, 0xe1, 0xac, 0x1e, 0xec, 0xd0, 0x12, 0xd3, 0x02, 0xc7, 0xda, 0x2e, 0x3d }, { 0xef, 0xb1, 0x61, 0x41, 0x0b, 0x02, 0x13, 0x84, 0x67, 0x4f, 0xf1, 0xf5, 0x0b, 0x29, 0x87, 0xc4 }, { 0x38, 0x19, 0x3d, 0x9a, 0xb8, 0x94, 0x57, 0xe1, 0x17, 0x38, 0xe9, 0x40, 0xbd, 0x08, 0xf1, 0x1b }, { 0x3a, 0xce, 0x69, 0x70, 0x1c, 0x34, 0x0d, 0xf5, 0x8f, 0x49, 0xca, 0x0b, 0xa8, 0xca, 0x7a, 0x9a }, { 0xe5, 0x8e, 0x13, 0x58, 0x20, 0x3b, 0x92, 0x98, 0x99, 0x81, 0x43, 0xfb, 0xfe, 0x61, 0xaf, 0x7e }, { 0x82, 0x2e, 0xe7, 0x5f, 0x22, 0x3b, 0xe8, 0xbd, 0x7c, 0x1b, 0xb5, 0x15, 0xe4, 0x1c, 0x87, 0x23 }, { 0x7e, 0x1b, 0x80, 0xb3, 0xb5, 0x65, 0xd9, 0xb1, 0xd0, 0xb7, 0xfe, 0x9f, 0x24, 0xd5, 0x2f, 0x82 }, { 0xe6, 0x28, 0x44, 0x9b, 0x7f, 0x63, 0x17, 0x89, 0x9a, 0x8f, 0x87, 0xf8, 0x70, 0xef, 0x59, 0x3b }, { 0x2f, 0xca, 0xdf, 0x36, 0x15, 0xe6, 0x3e, 0x8a, 0xee, 0x82, 0x2b, 0x03, 0x9a, 0xfb, 0x19, 0x8d }, { 0x07, 0x82, 0x5d, 0xee, 0xd3, 0xb0, 0x28, 0x42, 0x5d, 0xf2, 0xc8, 0x8e, 0xad, 0x6a, 0x33, 0x0a }, { 0x92, 0x44, 0xfd, 0xf8, 0xb6, 0xf8, 0x3f, 0xb4, 0x25, 0xe5, 0x06, 0x6d, 0x5a, 0xbe, 0x38, 0x62 }, { 0x1e, 0x30, 0x22, 0xee, 0xb3, 0xa8, 0x32, 0x90, 0x9b, 0xee, 0xcf, 0x9a, 0xe6, 0x32, 0xa1, 0x3f }, { 0xb1, 0xfe, 0xdd, 0x54, 0x0d, 0x12, 0xdb, 0x05, 0xfc, 0xa0, 0x3e, 0x69, 0x71, 0xcd, 0x93, 0xb0 }, { 0x01, 0x12, 0x09, 0x1c, 0xa7, 0xb7, 0x75, 0x46, 0x12, 0x99, 0x8d, 0xda, 0x5a, 0xde, 0x48, 0x82 }, { 0xd0, 0xae, 0x20, 0x89, 0x50, 0x52, 0xd6, 0xb6, 0xfd, 0x53, 0x50, 0x8c, 0xd6, 0x87, 0xc6, 0x42 }, { 0x6f, 0x38, 0x1a, 0x59, 0x55, 0x94, 0xfa, 0x45, 0x3e, 0x95, 0x3f, 0xf7, 0xb4, 0x90, 0x34, 0x82 }, { 0x6e, 0x2c, 0x3a, 0xa1, 0xdd, 0x00, 0xfa, 0x16, 0xd8, 0x83, 0x1d, 0x26, 0x39, 0x32, 0xae, 0xb8 }, { 0xba, 0x1a, 0x0d, 0xdc, 0x15, 0x2f, 0x49, 0x19, 0xb2, 0x17, 0xdf, 0x37, 0x73, 0x03, 0x16, 0x94 }, { 0x5c, 0x22, 0x40, 0x10, 0xc5, 0x4f, 0x12, 0x8a, 0x54, 0x53, 0x0b, 0xaa, 0xfb, 0x5c, 0x30, 0x44 }, { 0x82, 0xe5, 0x5b, 0xdc, 0x60, 0x2a, 0x52, 0x28, 0x0c, 0x52, 0x19, 0x0f, 0x69, 0x36, 0x62, 0xef }, { 0x26, 0x18, 0xb0, 0x1f, 0xb8, 0xf6, 0xc8, 0x23, 0xf4, 0x5a, 0xb0, 0x75, 0x51, 0xe5, 0xed, 0x17 }, { 0xb8, 0xb6, 0xd1, 0xd6, 0x40, 0x93, 0x42, 0x97, 0x1d, 0x1b, 0x62, 0xd9, 0xb2, 0x2c, 0x1b, 0xc9 }, { 0xa5, 0xd1, 0xba, 0xd7, 0xb4, 0x46, 0xb9, 0x7a, 0xb2, 0xa3, 0xc8, 0xba, 0xa3, 0xaa, 0xbb, 0x48 }, { 0x17, 0x28, 0xd6, 0x22, 0x93, 0xe7, 0x61, 0xd1, 0x48, 0x0a, 0x01, 0xf4, 0x59, 0x6b, 0x0e, 0x32 }, { 0x9e, 0x1f, 0xd8, 0xb5, 0x05, 0x93, 0x2b, 0x26, 0x8f, 0x79, 0x2b, 0x83, 0x16, 0x93, 0x69, 0xa5 }, { 0xac, 0x7b, 0xf8, 0x39, 0x53, 0xd8, 0xfd, 0x93, 0x8e, 0x12, 0x92, 0x6c, 0xe1, 0xe2, 0xe7, 0x88 }, { 0xcf, 0xf4, 0xf8, 0x42, 0x25, 0xd0, 0xbb, 0xaa, 0x75, 0x03, 0xa4, 0xd6, 0x61, 0x7e, 0x75, 0x66 }, { 0x30, 0x00, 0xf2, 0xef, 0x64, 0x20, 0x65, 0x77, 0x55, 0x5a, 0x1f, 0xe4, 0x86, 0xf6, 0xb6, 0x09 }, { 0x35, 0x6a, 0x7b, 0xb2, 0xa2, 0xbd, 0x57, 0x12, 0x8b, 0x2b, 0x79, 0x38, 0xbc, 0xb0, 0x20, 0xcd }, { 0xcc, 0x40, 0xc7, 0xb1, 0xc0, 0x9e, 0xdf, 0x02, 0x17, 0xe0, 0x1e, 0x09, 0xc1, 0x07, 0xea, 0x7c }, { 0x83, 0xe6, 0xca, 0x85, 0xfe, 0x7e, 0xc0, 0x93, 0x79, 0x4f, 0x90, 0x2d, 0x45, 0xe0, 0xf2, 0x10 }, { 0x28, 0x0d, 0xcf, 0xd9, 0x09, 0x1f, 0x01, 0x3f, 0xa5, 0x4f, 0x68, 0x25, 0x22, 0x92, 0x35, 0xb4 }, { 0x2d, 0xdd, 0x0e, 0xf0, 0x0f, 0x8d, 0x0c, 0x45, 0x15, 0x55, 0xca, 0x4a, 0x6f, 0xe4, 0xad, 0x2c }, { 0x25, 0xb3, 0xae, 0x87, 0x79, 0xb8, 0x39, 0x90, 0x97, 0xa3, 0xea, 0xd7, 0xc4, 0xa4, 0xb7, 0xc1 }, { 0x4b, 0x19, 0xdf, 0x03, 0x74, 0x0b, 0x52, 0xd3, 0x7c, 0x98, 0xfe, 0xdf, 0x26, 0xcf, 0x0b, 0xff }, { 0xc0, 0xf6, 0x6b, 0xf0, 0xbd, 0x3f, 0x3d, 0x3f, 0x63, 0x0e, 0x15, 0xcc, 0x5e, 0xf4, 0xbc, 0xce }, { 0xfd, 0x7d, 0x92, 0x1b, 0xae, 0xc3, 0x62, 0x23, 0x9e, 0xb3, 0xcf, 0xa1, 0x91, 0x64, 0xd0, 0x71 }, { 0x9b, 0x6e, 0xb0, 0xc0, 0x0c, 0xd6, 0xb1, 0x32, 0x64, 0xc0, 0x69, 0xd7, 0x42, 0xd2, 0x95, 0x83 }, { 0xcb, 0x5c, 0xe7, 0xc0, 0x66, 0xb8, 0x94, 0x58, 0x1f, 0x11, 0x36, 0xa1, 0xa0, 0x0f, 0x50, 0xf8 }, { 0x41, 0xda, 0x2c, 0x52, 0xd2, 0xbe, 0x94, 0xff, 0x35, 0x92, 0xae, 0x05, 0x4e, 0x2d, 0xac, 0x3c }, { 0x21, 0x9d, 0xf9, 0xc3, 0xfe, 0xce, 0xa9, 0x11, 0x48, 0x4e, 0x9b, 0x15, 0x25, 0x8d, 0x76, 0xac }, { 0xcc, 0xe0, 0xab, 0x67, 0x78, 0xb1, 0x9d, 0xfb, 0x7f, 0x3d, 0xe4, 0x5d, 0x97, 0xca, 0xab, 0x65 }, { 0xd4, 0xfd, 0x5c, 0x75, 0x80, 0xb1, 0x06, 0x8a, 0xb0, 0xdf, 0xd9, 0x0f, 0x79, 0x73, 0x3f, 0xf2 }, { 0xb5, 0x42, 0x95, 0x85, 0xdf, 0xcd, 0x80, 0xf8, 0xe1, 0x4b, 0x48, 0xc8, 0x6f, 0x11, 0xd1, 0xd9 }, { 0x3c, 0xc1, 0xd2, 0x68, 0xfe, 0x62, 0x1c, 0x5d, 0x40, 0x52, 0x91, 0x9b, 0xf6, 0xf3, 0x07, 0xdb }, { 0x10, 0x8b, 0x6e, 0x49, 0x06, 0x24, 0xf9, 0x9e, 0x92, 0xf8, 0x65, 0x2f, 0xac, 0x05, 0x69, 0x06 }, { 0x12, 0x75, 0x91, 0xc1, 0x0b, 0x0f, 0x2a, 0x88, 0xf7, 0x26, 0x13, 0x2b, 0xa1, 0x0f, 0x80, 0xc9 }, { 0xec, 0xc2, 0xed, 0xf7, 0xec, 0x7b, 0x0f, 0xf5, 0x29, 0x3c, 0xf6, 0x36, 0x85, 0x22, 0x20, 0xf2 }, { 0x77, 0xac, 0xdd, 0xd8, 0x4b, 0x31, 0xae, 0xd0, 0xf9, 0x08, 0x17, 0x75, 0x1d, 0x02, 0x37, 0x30 }, { 0x44, 0xb0, 0xa0, 0x05, 0x19, 0xa4, 0x71, 0x2a, 0xaa, 0xbd, 0xf6, 0x6d, 0xc1, 0x33, 0xa5, 0x1c }, { 0x8b, 0x09, 0x7e, 0x2f, 0x87, 0x1a, 0x28, 0x90, 0x78, 0x5d, 0x3b, 0x6d, 0x74, 0x03, 0x75, 0x16 }, { 0x14, 0x7a, 0x13, 0x9b, 0x50, 0xee, 0xd6, 0x6d, 0x77, 0x4e, 0xdc, 0xdf, 0xde, 0x8b, 0x17, 0x18 }, { 0x12, 0x16, 0x1a, 0xc7, 0x07, 0xeb, 0x8b, 0xd6, 0x29, 0x09, 0x12, 0x99, 0x83, 0x12, 0x1a, 0x54 }, { 0x69, 0xb1, 0x2f, 0x9f, 0xcf, 0x71, 0x61, 0x19, 0xe4, 0xa4, 0x27, 0x2e, 0x3b, 0x17, 0x42, 0xe8 }, { 0x53, 0x50, 0xa5, 0xc6, 0x9e, 0x4f, 0xf9, 0x6a, 0xfd, 0x98, 0xea, 0x14, 0x62, 0xd2, 0x5e, 0xd9 }, { 0xdd, 0x37, 0x69, 0x10, 0xb7, 0x9b, 0x3e, 0x9c, 0x30, 0xb6, 0x2f, 0xbf, 0x5d, 0x5c, 0xed, 0x26 }, { 0x52, 0x2e, 0x83, 0xe7, 0xab, 0xa5, 0x7e, 0xe4, 0x7c, 0x43, 0xcc, 0x04, 0x05, 0xd6, 0xc1, 0xff }, { 0xb0, 0x4b, 0xdb, 0x4a, 0xab, 0xf4, 0x2b, 0x0b, 0xad, 0x6a, 0xed, 0xb8, 0x16, 0x52, 0x85, 0x26 }, { 0x93, 0x13, 0xfc, 0xad, 0x3d, 0x37, 0x71, 0x18, 0x63, 0x3c, 0xb6, 0xe4, 0xff, 0x9c, 0x7c, 0xab }, { 0x08, 0x68, 0x40, 0x71, 0x08, 0xc1, 0x08, 0x69, 0xf0, 0x43, 0xbb, 0x01, 0xcc, 0xf5, 0x37, 0xe7 }, { 0x22, 0xf6, 0x3a, 0x00, 0x72, 0x9d, 0xd9, 0xc6, 0x43, 0x6b, 0xc5, 0x1b, 0x25, 0x28, 0x3b, 0x1d }, { 0xe9, 0xaa, 0x23, 0x8c, 0xb9, 0x22, 0x33, 0x7e, 0x4e, 0x5d, 0x16, 0x8f, 0x8a, 0x79, 0x7e, 0x77 }, { 0xe3, 0x1c, 0x3d, 0xee, 0x11, 0xb9, 0xd5, 0x26, 0xeb, 0xa8, 0x65, 0x74, 0x2e, 0x82, 0x5b, 0x65 }, { 0xd2, 0x55, 0xa5, 0xd7, 0xe6, 0xc9, 0x59, 0x06, 0x06, 0x1d, 0xe6, 0x54, 0xd1, 0x9e, 0xdc, 0x79 }, { 0x55, 0x5b, 0x0a, 0x07, 0x58, 0xbe, 0x0b, 0x3e, 0xa2, 0xd6, 0x7a, 0x86, 0xe2, 0x84, 0xee, 0x04 }, { 0x64, 0xf6, 0xdb, 0xde, 0xc3, 0xf9, 0x64, 0x26, 0xaf, 0x25, 0x2c, 0xe1, 0xba, 0x81, 0x9f, 0xd0 }, { 0x65, 0xa0, 0x34, 0x35, 0x83, 0xb5, 0x80, 0x9c, 0xcc, 0xc5, 0x88, 0x76, 0xf2, 0x12, 0x00, 0x16 }, { 0xce, 0x0e, 0x30, 0xed, 0xca, 0x64, 0x7a, 0x60, 0xe6, 0x7b, 0xec, 0x3e, 0x23, 0x6c, 0x09, 0xaf }, { 0x86, 0xc7, 0x44, 0x09, 0x22, 0xe7, 0x62, 0x0e, 0xb5, 0xab, 0x5c, 0xe5, 0x25, 0xdf, 0x9b, 0x08 }, { 0x2a, 0x55, 0x7c, 0x02, 0x14, 0x3c, 0x00, 0xeb, 0xc9, 0x27, 0x32, 0x51, 0x6c, 0x54, 0x52, 0xf7 }, { 0xd9, 0xbc, 0x4f, 0xc7, 0xfd, 0x21, 0x77, 0x3b, 0xe0, 0x35, 0x2a, 0xaf, 0x99, 0xe2, 0xd3, 0x82 }, { 0xfd, 0xae, 0x2f, 0xf6, 0x40, 0x8e, 0x09, 0x5e, 0xf4, 0xf3, 0xcf, 0xaf, 0xb8, 0x4f, 0xa9, 0x93 }, { 0x9d, 0xbb, 0x74, 0xad, 0x0a, 0x77, 0x5f, 0x94, 0x0e, 0xa3, 0xee, 0xe5, 0x19, 0x0a, 0x26, 0xab }, { 0xaf, 0xf1, 0x21, 0xd2, 0xd8, 0x5c, 0x12, 0x0b, 0xe9, 0x71, 0x8d, 0x30, 0x34, 0xce, 0xe8, 0x23 }, { 0xb9, 0x03, 0x65, 0x36, 0xb9, 0xf8, 0xbc, 0xf4, 0xf8, 0xdf, 0xf5, 0xed, 0x19, 0x40, 0x6f, 0x8b }, { 0x2a, 0x29, 0xb9, 0x39, 0xc7, 0xb6, 0x12, 0x79, 0x6c, 0xca, 0x4e, 0xbc, 0x1f, 0xf0, 0x3e, 0x45 }, { 0xe5, 0xfa, 0x93, 0x9d, 0x81, 0x20, 0x78, 0x4e, 0xb5, 0x1f, 0xae, 0xbe, 0x29, 0xb4, 0x05, 0xb4 }, { 0xb3, 0x25, 0xc5, 0x37, 0x8a, 0xde, 0xc8, 0xee, 0x71, 0xd1, 0xd3, 0x10, 0x95, 0x66, 0x9b, 0x1a }, { 0x98, 0x3e, 0xbc, 0xb9, 0xac, 0x2b, 0x2e, 0x4e, 0x95, 0x5f, 0x61, 0x3a, 0x42, 0x4f, 0xe8, 0x0a }, { 0xc3, 0x34, 0x11, 0xa2, 0x2a, 0xc9, 0xc0, 0xd3, 0x98, 0x6e, 0x9a, 0x51, 0xfc, 0x32, 0x5d, 0x6b }, { 0x59, 0xdc, 0x13, 0x9d, 0x7b, 0xce, 0x49, 0x7c, 0xe4, 0x91, 0x95, 0xd1, 0x6e, 0x59, 0xf4, 0xf7 }, { 0x42, 0x5e, 0x7c, 0x32, 0x23, 0x8b, 0xe5, 0xc1, 0x99, 0xa1, 0x55, 0xde, 0x00, 0x78, 0x46, 0x3d }, { 0x73, 0x4c, 0xdf, 0xc6, 0x2f, 0xd7, 0x19, 0x76, 0xed, 0xc8, 0x2e, 0xb7, 0xf3, 0x3d, 0x37, 0x00 }, { 0xdf, 0xd6, 0x67, 0x3b, 0x7a, 0xf5, 0x34, 0xa4, 0xcd, 0x80, 0xf5, 0x5f, 0xfb, 0x57, 0x7a, 0x9b }, { 0x33, 0x9c, 0xe2, 0xa6, 0xfe, 0x1a, 0x6e, 0xa7, 0x41, 0xc7, 0xaa, 0xed, 0x4e, 0xba, 0xd4, 0xe1 }, { 0x4c, 0xa5, 0xd1, 0x58, 0x64, 0x50, 0xa4, 0xc5, 0x00, 0xa5, 0x57, 0xfa, 0x78, 0x37, 0xd5, 0xe8 }, { 0x8d, 0x9a, 0x4e, 0x5c, 0xc9, 0x20, 0x10, 0x77, 0x1a, 0xae, 0xa2, 0x1a, 0x08, 0xe8, 0x3a, 0x52 }, { 0x87, 0x4d, 0x2e, 0xc0, 0x2b, 0x41, 0xa0, 0x38, 0x8f, 0x35, 0x0a, 0x07, 0x89, 0x64, 0xc1, 0x1f }, { 0xeb, 0x12, 0xfd, 0xe7, 0xd3, 0xf6, 0x33, 0x82, 0xfc, 0xec, 0x95, 0xaf, 0x1e, 0x33, 0x31, 0xd6 }, { 0x49, 0xfe, 0x95, 0x76, 0x34, 0xc5, 0xa5, 0x84, 0x1c, 0x51, 0x49, 0x6e, 0x7b, 0x6b, 0x66, 0x5c }, { 0xab, 0x36, 0x01, 0x29, 0x1e, 0xac, 0xb1, 0x9e, 0xff, 0x20, 0x72, 0x29, 0x7d, 0x35, 0x34, 0xe2 }, { 0x0c, 0x73, 0x75, 0x22, 0xda, 0x7f, 0x9e, 0x04, 0x2c, 0xdc, 0x46, 0x18, 0xd5, 0x0a, 0x5c, 0x40 }, { 0x70, 0x38, 0x62, 0x4c, 0x1f, 0x4e, 0xd2, 0x35, 0x1d, 0x25, 0x98, 0x23, 0xe3, 0xca, 0x3f, 0xda }, { 0x9c, 0xf5, 0x69, 0x07, 0xb8, 0xc4, 0x76, 0x14, 0xf9, 0x13, 0xb9, 0x97, 0xaf, 0xa6, 0x0d, 0x9f }, { 0x53, 0x83, 0x76, 0xda, 0x07, 0x2b, 0x5c, 0x7c, 0x1e, 0x6d, 0x66, 0x2e, 0xac, 0x0e, 0xc3, 0xdb }, { 0xe1, 0x58, 0x58, 0x63, 0xe7, 0x55, 0x06, 0x7b, 0xc2, 0x66, 0x5e, 0xaf, 0x8a, 0x52, 0xf1, 0x75 }, { 0x19, 0x2b, 0xcd, 0x4d, 0xa7, 0x8c, 0xf5, 0x97, 0x12, 0x01, 0xc0, 0x6c, 0x43, 0x67, 0x50, 0xed }, { 0x2f, 0xa8, 0x41, 0xc5, 0x62, 0xe7, 0x70, 0xad, 0xe4, 0x39, 0xd6, 0xab, 0x93, 0x6e, 0xda, 0xf8 } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t tweak_value4_128bit[ 100 ][ 32 ] = { { 0x68, 0x86, 0xce, 0x72, 0x37, 0x03, 0x1d, 0x39, 0x63, 0xaf, 0x24, 0xef, 0x3d, 0x20, 0xf7, 0xed }, { 0xa4, 0x6f, 0xad, 0xbd, 0x1e, 0x92, 0x40, 0x6c, 0x42, 0x2d, 0x7f, 0x02, 0xeb, 0x28, 0x10, 0xff }, { 0x5e, 0x04, 0xca, 0x16, 0xe6, 0x75, 0x88, 0x2b, 0x3d, 0x38, 0x6c, 0x99, 0xd2, 0xf5, 0x08, 0x63 }, { 0x3d, 0xdd, 0xff, 0x05, 0x58, 0x66, 0xae, 0x70, 0xf3, 0x18, 0x38, 0x4c, 0x04, 0x8f, 0xcf, 0x94 }, { 0x0d, 0x05, 0xcf, 0x88, 0xef, 0x98, 0x84, 0xf6, 0x4a, 0xd0, 0x67, 0x00, 0xc9, 0x06, 0xe7, 0x60 }, { 0xb6, 0xef, 0x5f, 0x57, 0x76, 0xc7, 0x93, 0x62, 0x2f, 0xd1, 0x90, 0x77, 0xa2, 0xa1, 0x73, 0x22 }, { 0x94, 0x4c, 0x4b, 0x8f, 0x03, 0xf5, 0x0e, 0x83, 0x31, 0xd3, 0x83, 0xc1, 0x0d, 0x89, 0xf0, 0x14 }, { 0x0a, 0xce, 0xa6, 0xf4, 0x5d, 0x6b, 0x40, 0xc7, 0x58, 0x93, 0x7c, 0x37, 0x1e, 0x04, 0x7c, 0xc5 }, { 0xef, 0x06, 0x32, 0x61, 0xc4, 0xbe, 0x4c, 0x9b, 0xde, 0x14, 0xd8, 0xe4, 0x35, 0xdf, 0x29, 0x52 }, { 0x98, 0x26, 0x24, 0x18, 0x30, 0x6e, 0x22, 0xf8, 0x64, 0x63, 0x4c, 0x57, 0xe9, 0xb5, 0xa8, 0x15 }, { 0xda, 0xb4, 0x84, 0xb0, 0xe9, 0x42, 0x74, 0xb3, 0x6b, 0xef, 0x33, 0x9e, 0x5f, 0x2e, 0x20, 0x92 }, { 0xd9, 0x45, 0xed, 0x0e, 0x1c, 0x80, 0x54, 0x4f, 0x3e, 0xff, 0xd5, 0x32, 0x16, 0x25, 0xce, 0x48 }, { 0x71, 0x67, 0xec, 0x38, 0xb3, 0xdc, 0x39, 0xe6, 0x05, 0x5c, 0x00, 0x88, 0x17, 0x23, 0xdc, 0xcf }, { 0xed, 0x93, 0xd3, 0xdb, 0xc5, 0x74, 0x22, 0xdd, 0x13, 0x22, 0x5d, 0xd7, 0x88, 0x6d, 0xea, 0x41 }, { 0xce, 0xdc, 0x28, 0xa1, 0xea, 0x5a, 0x3e, 0x12, 0xf8, 0x73, 0x6d, 0x46, 0x50, 0x66, 0x79, 0xbd }, { 0x85, 0xbd, 0xc6, 0x03, 0xaf, 0x4d, 0x82, 0x07, 0x13, 0xbc, 0xe0, 0x69, 0x64, 0x7b, 0x12, 0xc7 }, { 0x86, 0xad, 0x8c, 0xb7, 0x0c, 0x4f, 0x91, 0xae, 0x2f, 0x6e, 0x47, 0xc3, 0xb2, 0xc1, 0x0f, 0xd1 }, { 0x36, 0x16, 0x6a, 0x67, 0x9d, 0x1a, 0xe9, 0x56, 0x4b, 0x68, 0x50, 0x26, 0x7a, 0x11, 0x73, 0x79 }, { 0x8e, 0xb0, 0x80, 0xe7, 0x1a, 0xfa, 0xa2, 0x83, 0x63, 0xdc, 0xeb, 0x57, 0xc5, 0xff, 0xb3, 0x45 }, { 0xb0, 0x23, 0x10, 0xbc, 0x11, 0xea, 0xb0, 0xe5, 0xf3, 0xb3, 0x3a, 0x4b, 0xa4, 0xc3, 0xc3, 0x56 }, { 0x99, 0x89, 0x21, 0xc5, 0x14, 0x66, 0xe4, 0xc6, 0xa0, 0x1f, 0x65, 0xb6, 0x84, 0xaa, 0xeb, 0xef }, { 0xfa, 0x7c, 0x95, 0xde, 0xce, 0xfd, 0xad, 0x91, 0x2b, 0xa3, 0xc6, 0x47, 0x48, 0xde, 0x87, 0x0e }, { 0x6d, 0x52, 0xee, 0xa3, 0xe1, 0x17, 0x4d, 0x24, 0x5a, 0x91, 0x24, 0x3e, 0x16, 0x5d, 0x4f, 0xdf }, { 0xe2, 0x78, 0x5b, 0x96, 0x76, 0x50, 0xc0, 0xde, 0x9d, 0x38, 0xfb, 0x90, 0x9d, 0x2d, 0xdf, 0x0e }, { 0xe1, 0x41, 0x11, 0x44, 0x14, 0x51, 0xd4, 0x7f, 0x95, 0x34, 0x08, 0xf8, 0x2c, 0x93, 0xa7, 0x1b }, { 0x56, 0xcd, 0x77, 0x2e, 0x83, 0x6b, 0xde, 0x44, 0xf2, 0xb9, 0x04, 0x0e, 0x0a, 0x58, 0x34, 0xc1 }, { 0x57, 0xb6, 0xc7, 0x66, 0x9d, 0xfe, 0x3f, 0xb8, 0x64, 0xe0, 0x17, 0x0b, 0x36, 0x08, 0x2a, 0x25 }, { 0x25, 0xca, 0x3d, 0x3e, 0x9d, 0x24, 0xfb, 0xfa, 0x50, 0xa9, 0x38, 0xf4, 0xcd, 0xa8, 0x60, 0xb1 }, { 0x2a, 0x82, 0xce, 0xdf, 0x4e, 0x5b, 0x65, 0xde, 0x34, 0x04, 0x78, 0x34, 0xb1, 0x33, 0xba, 0xd7 }, { 0xc6, 0x65, 0x99, 0x53, 0xc7, 0x29, 0xc0, 0x23, 0x80, 0x92, 0xa5, 0x81, 0xaa, 0x02, 0x13, 0x86 }, { 0xe7, 0x1f, 0x0b, 0x94, 0x41, 0x94, 0x94, 0x0c, 0x30, 0xa3, 0x39, 0xc6, 0x44, 0xd5, 0xcf, 0x69 }, { 0xf9, 0xb0, 0x4d, 0x5d, 0x03, 0xc8, 0x87, 0x54, 0x62, 0xf8, 0x52, 0xfc, 0x1a, 0x43, 0x8f, 0x9d }, { 0xf8, 0x9f, 0x80, 0x54, 0x56, 0xb6, 0x42, 0x05, 0x9e, 0x28, 0xf7, 0xde, 0xcb, 0x20, 0x2f, 0xaa }, { 0xc0, 0x15, 0x71, 0x01, 0x3e, 0xdc, 0xe1, 0xc9, 0xd4, 0x8a, 0x54, 0x31, 0xb6, 0xbd, 0x79, 0x76 }, { 0x1b, 0x47, 0xfb, 0x74, 0x16, 0xd8, 0x6f, 0xee, 0x2d, 0xda, 0xcb, 0x82, 0x94, 0x06, 0xf0, 0xf3 }, { 0x17, 0xf3, 0x8c, 0x8f, 0x98, 0x66, 0x57, 0x90, 0x4c, 0x3b, 0x2f, 0x1d, 0x6c, 0x93, 0x40, 0x7b }, { 0xc7, 0xfb, 0x5c, 0x36, 0x83, 0x08, 0x2d, 0x5d, 0x69, 0xf8, 0x36, 0x1e, 0xc0, 0x54, 0xef, 0x04 }, { 0xf9, 0xb1, 0x5d, 0x6f, 0xae, 0x9a, 0x53, 0x38, 0xb8, 0x4c, 0xba, 0xe0, 0x5f, 0xac, 0xec, 0x40 }, { 0x8c, 0x72, 0xc6, 0x06, 0xde, 0xbf, 0xf5, 0x6d, 0x89, 0xc9, 0x68, 0xad, 0xae, 0xc4, 0xb0, 0xf8 }, { 0xaa, 0xaf, 0xec, 0xa1, 0xf2, 0x5a, 0x6b, 0x82, 0xf8, 0xaa, 0x68, 0xc3, 0x09, 0x19, 0x3e, 0x60 }, { 0x67, 0x4f, 0xdd, 0x74, 0x4b, 0x17, 0x13, 0x61, 0xa1, 0x91, 0xd5, 0xbc, 0x87, 0xb1, 0xa7, 0xd3 }, { 0xcf, 0xee, 0x85, 0x7e, 0x13, 0xba, 0x52, 0xc8, 0xea, 0x86, 0xed, 0x88, 0x36, 0xe4, 0xeb, 0x93 }, { 0xc6, 0xdb, 0x3e, 0xbd, 0xb4, 0xa7, 0xfa, 0xb9, 0x7b, 0x95, 0xf3, 0xc2, 0x3e, 0xa3, 0x12, 0x2c }, { 0x3d, 0x90, 0xc3, 0x70, 0xdf, 0x4c, 0x4a, 0x4a, 0x72, 0x5c, 0x9b, 0x6c, 0xf6, 0xb2, 0x78, 0xe0 }, { 0xe4, 0x79, 0xb1, 0xe4, 0x21, 0xcf, 0x93, 0x5a, 0x7c, 0x95, 0x08, 0x51, 0xf3, 0xec, 0x5b, 0x35 }, { 0x76, 0xe4, 0xf0, 0x01, 0xc6, 0x61, 0x9c, 0x76, 0xfb, 0x2b, 0x3b, 0x19, 0x1a, 0xed, 0x57, 0xe2 }, { 0x83, 0xbb, 0xb1, 0x8b, 0xdf, 0xbe, 0x44, 0x60, 0xa5, 0x79, 0xff, 0xbc, 0xf9, 0x7b, 0x0e, 0xe8 }, { 0x41, 0x81, 0x95, 0xd8, 0x83, 0xd1, 0xe2, 0x4c, 0xe9, 0x0c, 0x06, 0xea, 0xb3, 0x25, 0xa2, 0x33 }, { 0x86, 0x6f, 0x8c, 0xf3, 0x99, 0xec, 0x7b, 0x00, 0x63, 0x75, 0x4f, 0x27, 0x52, 0x8b, 0x64, 0x01 }, { 0x0e, 0x76, 0xcd, 0x3d, 0x76, 0xd5, 0xc9, 0xf7, 0xc2, 0x84, 0x28, 0x8d, 0x51, 0x95, 0x5b, 0x30 }, { 0x67, 0x86, 0xea, 0xcd, 0x8f, 0xf9, 0x54, 0xfd, 0x9c, 0x74, 0xe9, 0x21, 0x3b, 0x00, 0x8b, 0x20 }, { 0x72, 0xd9, 0xe2, 0x22, 0x13, 0x35, 0xcb, 0x69, 0x31, 0xc7, 0x7c, 0x08, 0xf9, 0xce, 0xa6, 0x26 }, { 0xc8, 0x9d, 0xb2, 0xc8, 0x61, 0x81, 0x49, 0x79, 0x5f, 0x19, 0xb7, 0xa4, 0x1f, 0x74, 0x86, 0xbd }, { 0x72, 0x84, 0xd5, 0x17, 0x18, 0x76, 0xb6, 0xb7, 0x12, 0x08, 0xda, 0x30, 0xce, 0x7b, 0xe0, 0x15 }, { 0x7c, 0x29, 0x52, 0xc9, 0xeb, 0x9c, 0xa4, 0x54, 0x6b, 0xfd, 0x2d, 0x12, 0x76, 0xf9, 0x85, 0xd4 }, { 0x28, 0x05, 0x5b, 0x96, 0x0d, 0xe4, 0x78, 0xc8, 0xc7, 0x46, 0xaa, 0xbe, 0x2d, 0xe0, 0xd9, 0x62 }, { 0x2f, 0x28, 0x31, 0xd0, 0xfd, 0x73, 0x19, 0x18, 0xbd, 0xe6, 0xcb, 0x0f, 0x35, 0x69, 0x7e, 0x16 }, { 0xce, 0x0b, 0x8c, 0xba, 0x0c, 0x91, 0x87, 0xe8, 0xdd, 0x1f, 0xa4, 0x19, 0x65, 0x45, 0xd6, 0x52 }, { 0xe6, 0x38, 0x0d, 0xea, 0xb6, 0x33, 0x1d, 0xb9, 0x8a, 0x8a, 0x2e, 0xc2, 0x15, 0xd1, 0x8a, 0x8d }, { 0xa6, 0xcc, 0xbb, 0xd3, 0x9f, 0x0f, 0x0f, 0x34, 0xe0, 0xfa, 0xd7, 0xf4, 0x59, 0x96, 0x76, 0xe4 }, { 0xe3, 0x8a, 0x80, 0xe5, 0x71, 0xe0, 0x0c, 0xcd, 0xb2, 0x28, 0x4e, 0x8c, 0xcf, 0x56, 0xb9, 0x5e }, { 0xe1, 0xcb, 0xea, 0x55, 0x94, 0x8c, 0x7c, 0xcb, 0x0d, 0x51, 0x91, 0x05, 0xc3, 0xa9, 0x9e, 0xb2 }, { 0x6c, 0xe3, 0x03, 0x8d, 0x2f, 0xf7, 0xbd, 0xbd, 0xa2, 0x47, 0xc8, 0x36, 0x4b, 0xc9, 0x21, 0xe5 }, { 0xde, 0xd0, 0x7c, 0xf0, 0x30, 0xdd, 0xd2, 0x35, 0xef, 0x71, 0x82, 0x03, 0x2f, 0xe7, 0x4d, 0x4b }, { 0xd5, 0x0c, 0x76, 0xe0, 0xb7, 0x32, 0x3b, 0x4e, 0xe4, 0xb9, 0x45, 0xa0, 0xd8, 0xcd, 0x4b, 0x50 }, { 0xd4, 0xd7, 0x95, 0x13, 0x03, 0x9a, 0x96, 0xba, 0xd0, 0x6f, 0xa8, 0xa7, 0x53, 0x1e, 0xcd, 0xa3 }, { 0x9c, 0xbd, 0x4b, 0xef, 0xc3, 0xbe, 0xb8, 0xf9, 0x62, 0x82, 0x57, 0x85, 0xa2, 0x88, 0xba, 0x84 }, { 0x3e, 0x64, 0x3c, 0x25, 0x94, 0xc8, 0xd9, 0x6e, 0xce, 0x8b, 0xca, 0x2e, 0xb8, 0xe1, 0x2a, 0x97 }, { 0x57, 0xed, 0x57, 0x50, 0xb9, 0x7f, 0x13, 0x19, 0x49, 0x4d, 0x38, 0xb1, 0x62, 0xdb, 0x5a, 0x90 }, { 0xb4, 0x14, 0x28, 0x76, 0x6d, 0x95, 0x00, 0x00, 0x1a, 0xd3, 0x43, 0x9f, 0x82, 0x3b, 0x41, 0x20 }, { 0xcf, 0xde, 0xb1, 0xdd, 0x87, 0x5d, 0xf2, 0x63, 0xc6, 0x78, 0xb2, 0x1e, 0xe2, 0x38, 0x2a, 0xf2 }, { 0x05, 0x70, 0xd4, 0xfd, 0x8d, 0x25, 0x36, 0xb5, 0x8f, 0xdb, 0xef, 0xfc, 0x49, 0xd6, 0x3c, 0x60 }, { 0x11, 0x85, 0xbf, 0xf8, 0x6b, 0x66, 0xe0, 0xef, 0xfa, 0x7d, 0x28, 0x44, 0x7f, 0xaf, 0x2d, 0x51 }, { 0x39, 0x60, 0x1d, 0x5e, 0x21, 0x8d, 0x7f, 0x5f, 0x3c, 0xe7, 0xfc, 0x45, 0xf0, 0x57, 0x6f, 0x3d }, { 0x11, 0xa9, 0x1c, 0xe8, 0x3d, 0x32, 0x4a, 0x10, 0x37, 0x7f, 0x70, 0xac, 0x37, 0x5f, 0x01, 0xdf }, { 0xaa, 0xf0, 0xd6, 0xb1, 0x9c, 0x4e, 0x42, 0xa9, 0x8c, 0xc8, 0x84, 0x70, 0x99, 0x81, 0xd0, 0x8b }, { 0x6d, 0x9b, 0x0f, 0xce, 0x7d, 0x9c, 0x3a, 0x9c, 0x64, 0x17, 0xcc, 0x66, 0x7d, 0xed, 0x90, 0x11 }, { 0x48, 0x34, 0x6e, 0x22, 0xe3, 0x4f, 0x56, 0xcb, 0x47, 0xe8, 0x4e, 0x5d, 0xf1, 0xc4, 0x90, 0xa8 }, { 0x24, 0x54, 0xb1, 0x8d, 0x3a, 0x4d, 0x16, 0x0c, 0x4b, 0xd4, 0xa0, 0x85, 0x5a, 0x32, 0x38, 0xf6 }, { 0x5c, 0x65, 0x35, 0xb1, 0x25, 0xd1, 0x2d, 0xbc, 0xee, 0x40, 0x1f, 0x77, 0x23, 0x9d, 0x6c, 0x38 }, { 0xd3, 0x3b, 0x97, 0xc4, 0x32, 0x80, 0xbe, 0xf9, 0xee, 0x27, 0x64, 0x4c, 0x5f, 0xc9, 0x19, 0x78 }, { 0x6c, 0x90, 0xe5, 0x7c, 0x76, 0x7e, 0xab, 0x9f, 0x74, 0x7e, 0xb8, 0x08, 0x62, 0xea, 0x0e, 0x0e }, { 0xee, 0x12, 0xa5, 0x59, 0x8d, 0x2c, 0x28, 0xe3, 0x21, 0xc4, 0xd4, 0xa2, 0x13, 0x03, 0x90, 0x9b }, { 0x69, 0x07, 0x73, 0xe0, 0x98, 0xb7, 0xba, 0xeb, 0xf9, 0xa2, 0x3a, 0x49, 0xf2, 0x94, 0x43, 0x3e }, { 0xf5, 0xdd, 0xfe, 0x7d, 0x66, 0xda, 0xb5, 0x2b, 0x9f, 0x52, 0xa5, 0x35, 0xc6, 0x5a, 0xe3, 0x24 }, { 0x2d, 0x8b, 0xd1, 0xe6, 0x81, 0x5b, 0x89, 0xc5, 0x3e, 0xbd, 0x31, 0xc3, 0x98, 0x3d, 0x3f, 0xf4 }, { 0xee, 0x36, 0x2d, 0x96, 0xde, 0xad, 0x91, 0x52, 0xfc, 0x26, 0x84, 0x64, 0x2e, 0xd8, 0x81, 0x56 }, { 0x39, 0x53, 0x48, 0x57, 0x87, 0x2f, 0xb9, 0x5b, 0xcf, 0x23, 0x36, 0x07, 0x03, 0x04, 0xeb, 0xf5 }, { 0x7e, 0xa8, 0xd0, 0x1b, 0x59, 0x4f, 0x82, 0x3a, 0x53, 0xc2, 0x13, 0x8a, 0xd1, 0x37, 0x9f, 0x75 }, { 0xb3, 0x22, 0xe8, 0x43, 0x69, 0x67, 0xeb, 0xb3, 0x11, 0xfb, 0x59, 0x61, 0xab, 0xcc, 0x98, 0xdd }, { 0xe4, 0xb6, 0xcc, 0x44, 0xc0, 0x51, 0xec, 0x11, 0x4b, 0xc3, 0x3e, 0xe7, 0xeb, 0x12, 0xa0, 0xcc }, { 0x0c, 0xb8, 0x5a, 0x0d, 0x33, 0xc6, 0xb8, 0xe0, 0xc1, 0x9b, 0x8c, 0x21, 0x52, 0xaa, 0x00, 0x38 }, { 0x78, 0x19, 0xb6, 0x00, 0xb9, 0xca, 0x2a, 0x3a, 0x72, 0x9b, 0x12, 0x5b, 0x66, 0x2c, 0x01, 0x53 }, { 0x04, 0x35, 0xf9, 0x62, 0x9b, 0x44, 0x0c, 0xd7, 0x57, 0xc2, 0x6c, 0x2c, 0x5d, 0x6c, 0x57, 0x2a }, { 0xcb, 0x38, 0x5e, 0x13, 0xc3, 0xae, 0xd7, 0x2d, 0xa6, 0x23, 0xed, 0x71, 0x7e, 0xa5, 0xc1, 0xd8 }, { 0x22, 0xf3, 0xfe, 0xab, 0xf8, 0xf5, 0xab, 0x7a, 0x6b, 0xa3, 0x0b, 0x4c, 0x48, 0x45, 0x4c, 0xdb }, { 0xb5, 0xd6, 0x25, 0xb0, 0x2f, 0x05, 0xb7, 0xc0, 0x67, 0x08, 0x59, 0xa8, 0xf7, 0x1d, 0xf5, 0xf0 }, { 0x6f, 0xf7, 0xbc, 0xf3, 0x3b, 0x6f, 0xf7, 0x7b, 0x11, 0x66, 0x10, 0xfd, 0x39, 0xf4, 0xf6, 0xae }, { 0xdd, 0xbf, 0xcc, 0x25, 0xe2, 0x1a, 0xd7, 0xbd, 0xf6, 0x6a, 0x1b, 0x35, 0x13, 0xa0, 0x30, 0x18 }, { 0x5e, 0x49, 0x26, 0x3e, 0xfa, 0xc5, 0x45, 0x1e, 0xe3, 0x95, 0x08, 0x3c, 0x25, 0xde, 0x2c, 0x13 } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t cipher_texts1_128bit[ 100 ][ 16 ] = { { 0x34, 0x54, 0xf7, 0xd3, 0x4c, 0x0c, 0xaf, 0xfa, 0x12, 0xe9, 0xd2, 0x85, 0x0b, 0x03, 0x7f, 0xff }, { 0x10, 0x70, 0xb7, 0xc1, 0x7d, 0x34, 0x74, 0x28, 0x1a, 0xd0, 0x1f, 0xc0, 0xad, 0x89, 0xcd, 0x8b }, { 0x2f, 0xb9, 0x7e, 0x97, 0x9f, 0xb1, 0x07, 0xbc, 0xc1, 0x3b, 0x57, 0x7f, 0x0f, 0x1e, 0xa2, 0x03 }, { 0xcf, 0xf1, 0x5a, 0x80, 0x92, 0x20, 0xb4, 0x06, 0x7c, 0x7c, 0x02, 0x66, 0xbb, 0xcb, 0x32, 0x48 }, { 0x83, 0x72, 0x5e, 0xec, 0xbc, 0xdf, 0xa8, 0xeb, 0xde, 0xc2, 0xf4, 0x0b, 0xa4, 0xb1, 0x57, 0xed }, { 0xa7, 0x93, 0x1f, 0xf1, 0x18, 0xdb, 0x06, 0xcb, 0x44, 0x09, 0x7b, 0xca, 0xc1, 0xfa, 0xd1, 0xaf }, { 0x33, 0x19, 0x60, 0xc2, 0x50, 0xeb, 0x49, 0x88, 0xc7, 0x5c, 0x0d, 0x53, 0x2e, 0x20, 0x6e, 0x5c }, { 0x36, 0x9a, 0xd5, 0xf8, 0xfb, 0x83, 0xa0, 0xdf, 0x64, 0x9c, 0x89, 0x9b, 0x49, 0xef, 0x74, 0x59 }, { 0x4a, 0xe7, 0xa4, 0xac, 0x80, 0x02, 0x34, 0x05, 0xac, 0x25, 0xbc, 0x49, 0x7d, 0x65, 0x41, 0xfb }, { 0xc0, 0xf6, 0xf4, 0x4c, 0x03, 0xd1, 0xcb, 0xe6, 0x68, 0xc0, 0x34, 0x56, 0x2e, 0xa3, 0xd8, 0x04 }, { 0xdc, 0xff, 0x3e, 0x38, 0xdf, 0xea, 0x1d, 0x3e, 0xb7, 0x81, 0x82, 0x32, 0x6d, 0x7d, 0x68, 0xab }, { 0x26, 0x33, 0x94, 0x12, 0xd7, 0xac, 0x11, 0x3b, 0x31, 0x90, 0x88, 0x15, 0x3e, 0x13, 0xe1, 0xac }, { 0x29, 0xc3, 0x61, 0x67, 0x14, 0xbf, 0x80, 0x76, 0xab, 0x19, 0x5e, 0x5e, 0x0d, 0x6c, 0xc0, 0xd7 }, { 0x88, 0x50, 0xa5, 0xb5, 0x01, 0x1c, 0x0b, 0x49, 0xb4, 0x44, 0xda, 0xa5, 0xcb, 0xd0, 0x4a, 0xba }, { 0x2f, 0xba, 0xad, 0xd1, 0xb4, 0x7f, 0x72, 0x6d, 0xce, 0x3f, 0x7d, 0x4c, 0x03, 0x58, 0xfd, 0x99 }, { 0x6d, 0xf4, 0xbe, 0xeb, 0xbe, 0x92, 0xec, 0x8a, 0x42, 0x73, 0x36, 0xb0, 0xca, 0xec, 0x1e, 0xc6 }, { 0x94, 0x58, 0x64, 0xf9, 0x19, 0x0e, 0xa8, 0xc1, 0x19, 0x43, 0xdf, 0x25, 0x10, 0xf9, 0x44, 0x21 }, { 0xa8, 0x56, 0x59, 0x41, 0x79, 0x84, 0x5a, 0x87, 0x85, 0x5e, 0xa1, 0x6d, 0xd0, 0x39, 0x16, 0xbe }, { 0xd1, 0x3a, 0xb1, 0x1d, 0x38, 0x34, 0xd7, 0x33, 0xea, 0x5d, 0xd6, 0xdb, 0xf7, 0x9a, 0xc9, 0x2b }, { 0x51, 0xb9, 0xc9, 0x27, 0xea, 0xd5, 0xfa, 0xda, 0xd5, 0x6c, 0x3e, 0xb1, 0xa2, 0x20, 0xee, 0xc7 }, { 0xd8, 0x3d, 0xdc, 0x00, 0x6d, 0xee, 0xee, 0x4c, 0xc2, 0xb4, 0xc4, 0x95, 0x83, 0x0d, 0xdd, 0xc3 }, { 0x6d, 0x24, 0x6f, 0x57, 0xb5, 0xd6, 0x92, 0x20, 0x5f, 0x2b, 0x97, 0x0d, 0xcf, 0x8e, 0xd6, 0xf8 }, { 0xa8, 0xb8, 0x32, 0x6c, 0xc5, 0x12, 0x6a, 0x92, 0x6c, 0xf4, 0x14, 0xb4, 0x71, 0xab, 0xd1, 0xb2 }, { 0x47, 0xb7, 0x51, 0xad, 0xee, 0xcc, 0xd4, 0x47, 0x51, 0x63, 0x23, 0x96, 0x10, 0x79, 0x7d, 0x4b }, { 0xe8, 0xc6, 0x47, 0xee, 0x74, 0x88, 0xad, 0xc4, 0x09, 0x0e, 0x08, 0xa9, 0x69, 0x65, 0xcc, 0xed }, { 0x1c, 0x98, 0x0f, 0xd7, 0x98, 0xb9, 0x16, 0x32, 0x6c, 0x52, 0x56, 0x32, 0xe2, 0x15, 0xc4, 0xec }, { 0x90, 0xf3, 0xc9, 0x99, 0xcb, 0x07, 0x45, 0x87, 0xf8, 0x75, 0x56, 0x1d, 0x04, 0x16, 0x0c, 0x6c }, { 0xcf, 0xa1, 0xf3, 0xa9, 0xa1, 0x52, 0xc4, 0x87, 0x51, 0x00, 0xad, 0x48, 0x07, 0xb3, 0xb0, 0x9c }, { 0xb0, 0x4e, 0xa8, 0xcd, 0x83, 0xae, 0xa2, 0x58, 0x93, 0xac, 0x2a, 0x62, 0x18, 0x79, 0xa4, 0xcd }, { 0xb1, 0xac, 0x6e, 0xca, 0x72, 0x17, 0x09, 0xa5, 0x27, 0x59, 0x8d, 0x1d, 0xc7, 0xfa, 0x36, 0x5e }, { 0x98, 0xf2, 0x14, 0x26, 0xb7, 0x14, 0x80, 0x82, 0xb4, 0xee, 0x4a, 0x80, 0x74, 0x67, 0x2a, 0x10 }, { 0x22, 0xf8, 0xc0, 0x63, 0x73, 0x27, 0xb1, 0x12, 0x30, 0x67, 0xe7, 0x30, 0xc3, 0xbe, 0x4a, 0x01 }, { 0x87, 0x04, 0x55, 0x2b, 0x90, 0x00, 0x9e, 0xc3, 0x32, 0x4a, 0xdb, 0xf2, 0x84, 0xdb, 0xd5, 0x1e }, { 0xc5, 0xf6, 0x67, 0x3c, 0xbc, 0xea, 0xe8, 0x23, 0x6f, 0xa2, 0x36, 0x79, 0x82, 0x61, 0xee, 0xc1 }, { 0x91, 0xee, 0xcd, 0x8b, 0xbd, 0x0f, 0xf7, 0xcf, 0xe4, 0xb3, 0x3d, 0x8e, 0x99, 0x92, 0x43, 0x68 }, { 0x86, 0xd6, 0xbf, 0x32, 0x4b, 0xcc, 0x29, 0x10, 0x81, 0x6a, 0xbb, 0xf5, 0x5f, 0x3b, 0xa4, 0x5d }, { 0x5b, 0x0a, 0x85, 0xe3, 0x76, 0xa6, 0x36, 0xd1, 0x13, 0x36, 0x6e, 0xc8, 0x2a, 0x2c, 0x03, 0xf8 }, { 0x9b, 0x3a, 0x03, 0x64, 0x36, 0xa2, 0x46, 0x36, 0x29, 0x0c, 0x96, 0x9e, 0x9d, 0x97, 0xcf, 0x8b }, { 0xf5, 0x15, 0xb3, 0xd5, 0x0e, 0x99, 0x1d, 0x55, 0xa3, 0xe0, 0xfc, 0xb0, 0x93, 0x08, 0x5a, 0x10 }, { 0x4b, 0x20, 0xfc, 0xe1, 0xff, 0xac, 0xc7, 0x55, 0x3a, 0xfa, 0x3a, 0x6a, 0xc9, 0x4e, 0x59, 0x66 }, { 0xca, 0xed, 0x5c, 0x73, 0x8a, 0x8d, 0xc3, 0x01, 0x55, 0x52, 0x28, 0x64, 0xf9, 0x28, 0x9e, 0x61 }, { 0x63, 0xa8, 0x81, 0x84, 0x18, 0x6f, 0xa7, 0x97, 0xd2, 0x64, 0xa0, 0x52, 0x8f, 0x39, 0x70, 0x9f }, { 0xba, 0xa4, 0x95, 0xce, 0x83, 0x09, 0xa6, 0xc8, 0x8a, 0xd8, 0x55, 0xf9, 0x7a, 0x77, 0x41, 0x13 }, { 0x68, 0xc5, 0x29, 0x58, 0x64, 0x35, 0x37, 0x4c, 0xfb, 0xad, 0xb1, 0x7b, 0x9b, 0x89, 0x5a, 0x4d }, { 0x71, 0xf0, 0x51, 0x9b, 0x7a, 0x6a, 0xee, 0x11, 0x6d, 0x48, 0x1f, 0x31, 0xb9, 0x65, 0xfc, 0x2d }, { 0xe9, 0xc6, 0x80, 0x83, 0x84, 0x84, 0x71, 0x4f, 0x38, 0xc5, 0x9f, 0xdb, 0xfa, 0xf4, 0x9a, 0x5e }, { 0xac, 0xa4, 0x3e, 0x27, 0xd8, 0xcf, 0xfc, 0x6d, 0x27, 0x3a, 0x90, 0xf3, 0x43, 0xc9, 0xac, 0xce }, { 0x8f, 0xd8, 0x6c, 0x04, 0x89, 0x94, 0x4d, 0x43, 0x50, 0xb2, 0x23, 0x29, 0x58, 0x01, 0x66, 0x68 }, { 0x3f, 0x06, 0x9d, 0x49, 0x97, 0xa1, 0xdd, 0x7e, 0xa4, 0x21, 0x5c, 0xf1, 0xd9, 0x56, 0x83, 0x95 }, { 0xb7, 0x97, 0x2c, 0x5f, 0x6a, 0x48, 0x8d, 0xce, 0x95, 0xeb, 0x46, 0xa8, 0x55, 0xa1, 0x05, 0xa5 }, { 0x80, 0x47, 0x95, 0xbc, 0x58, 0x8a, 0xa0, 0x48, 0x89, 0x4a, 0x18, 0x4c, 0x60, 0x0a, 0xc7, 0x5f }, { 0x4d, 0xcd, 0xab, 0xef, 0xbf, 0x99, 0xb4, 0xf4, 0x94, 0xfa, 0x83, 0xb9, 0x1f, 0x0e, 0x97, 0xa7 }, { 0xa4, 0x32, 0x14, 0x72, 0xfc, 0xa0, 0x2d, 0x86, 0x94, 0x32, 0x58, 0x5a, 0x43, 0x80, 0xbe, 0x30 }, { 0x62, 0x54, 0x38, 0x70, 0x0a, 0x4d, 0x15, 0x38, 0x11, 0xdc, 0x26, 0xf6, 0x88, 0xb1, 0xf8, 0x2e }, { 0x56, 0x5f, 0xa6, 0x39, 0x0a, 0x7a, 0x37, 0x7b, 0x90, 0x33, 0x0b, 0xa0, 0x93, 0x91, 0xa7, 0xd6 }, { 0x7d, 0x18, 0x0b, 0x8a, 0xe1, 0x43, 0x61, 0x73, 0x69, 0x23, 0x9a, 0x60, 0x6c, 0x69, 0x3d, 0x1f }, { 0xe5, 0x67, 0xf6, 0xd2, 0x72, 0x76, 0x22, 0x27, 0x8b, 0x93, 0x10, 0xe9, 0x1e, 0xce, 0x01, 0x65 }, { 0x5c, 0xe1, 0x56, 0x2f, 0x45, 0xda, 0x9d, 0xad, 0x24, 0x8b, 0xb7, 0xac, 0x2a, 0xab, 0xe2, 0xb4 }, { 0x97, 0x74, 0xeb, 0xd7, 0xb0, 0x8c, 0xc8, 0x7f, 0xdf, 0x70, 0xc9, 0xd4, 0xf7, 0x46, 0xf2, 0xf4 }, { 0xe7, 0x27, 0x46, 0xc7, 0x43, 0xf8, 0x4e, 0x32, 0xee, 0xd8, 0x1b, 0x8d, 0xd5, 0x1b, 0x6f, 0xea }, { 0x48, 0x21, 0x0d, 0xf8, 0x64, 0x1e, 0x31, 0x03, 0x9d, 0x06, 0xf0, 0xe7, 0xdc, 0x1a, 0xd9, 0x7f }, { 0x94, 0x4f, 0x66, 0xbb, 0x9c, 0xb9, 0xc0, 0xda, 0x59, 0x11, 0x18, 0x75, 0xbd, 0x8a, 0x83, 0xed }, { 0x6b, 0x62, 0x95, 0xca, 0x7b, 0x81, 0xd5, 0x21, 0x6c, 0xc2, 0x51, 0xea, 0xd4, 0x6c, 0x70, 0xbb }, { 0x09, 0xbe, 0xa3, 0xcc, 0xa2, 0x0b, 0x8f, 0x95, 0x44, 0xe6, 0x24, 0x30, 0x81, 0x9d, 0x90, 0xcc }, { 0xae, 0x58, 0xfb, 0xd4, 0x10, 0x58, 0xbd, 0x60, 0xb5, 0x46, 0x37, 0x9c, 0x83, 0x6a, 0xda, 0x28 }, { 0x2c, 0x11, 0xe9, 0x97, 0x30, 0x68, 0xab, 0xcf, 0xf0, 0xb7, 0x5c, 0xb1, 0xb0, 0x02, 0x25, 0x21 }, { 0x6f, 0xfd, 0xbb, 0x7b, 0x11, 0xbc, 0x41, 0xa6, 0x8b, 0xb4, 0x39, 0x80, 0xb4, 0xd5, 0x04, 0x5a }, { 0x55, 0xbc, 0x20, 0x96, 0x21, 0x9a, 0x93, 0x0b, 0x9a, 0x12, 0xe2, 0x21, 0x4c, 0x51, 0x47, 0xef }, { 0xeb, 0x68, 0xe4, 0x75, 0xbf, 0xf2, 0xbd, 0xf3, 0xa1, 0x51, 0xb0, 0x7e, 0x38, 0x86, 0x0d, 0x03 }, { 0xd4, 0x47, 0x5d, 0xa4, 0x8f, 0x24, 0xba, 0x75, 0x95, 0x31, 0xbf, 0x30, 0xa5, 0xbc, 0xd4, 0x30 }, { 0xd1, 0x4d, 0x7b, 0x02, 0x62, 0x73, 0xdf, 0xf3, 0x3b, 0x09, 0xe7, 0x0d, 0xb4, 0x5d, 0x31, 0x40 }, { 0x93, 0xf3, 0x95, 0x26, 0x56, 0xb4, 0x3f, 0x66, 0x3e, 0x02, 0x28, 0xed, 0x74, 0xcb, 0xab, 0x0f }, { 0x98, 0x7d, 0x38, 0xaf, 0xcf, 0xbc, 0x37, 0xb2, 0x54, 0xef, 0x41, 0xb6, 0x28, 0x38, 0x13, 0xe5 }, { 0xbc, 0x0b, 0xbd, 0x16, 0xa2, 0x1b, 0xaf, 0xca, 0x60, 0x58, 0x8e, 0x3f, 0x67, 0x0f, 0xff, 0xb9 }, { 0x60, 0x69, 0x8b, 0x82, 0x3b, 0xeb, 0x2d, 0x9d, 0x08, 0x3d, 0xbe, 0x2e, 0x7d, 0x1a, 0xd2, 0x43 }, { 0xa3, 0xed, 0x3b, 0x90, 0x52, 0xe7, 0x63, 0xb7, 0x49, 0x13, 0xcb, 0xdf, 0x1f, 0x71, 0xfa, 0xfd }, { 0x5d, 0x8b, 0x27, 0xda, 0x95, 0xb0, 0x73, 0xb9, 0x3f, 0xb1, 0x55, 0xed, 0xd2, 0xc8, 0x8f, 0xea }, { 0xb5, 0x45, 0x8a, 0xfa, 0x62, 0x68, 0xd1, 0x47, 0x4a, 0x93, 0x6d, 0xdf, 0x84, 0xb6, 0x3b, 0x05 }, { 0xb0, 0x40, 0x45, 0x86, 0xc6, 0x31, 0x3e, 0xf7, 0x7e, 0x24, 0x65, 0x0f, 0xa4, 0x8d, 0xa1, 0x31 }, { 0x61, 0xeb, 0xad, 0x87, 0xdf, 0x8c, 0x35, 0xe4, 0x59, 0xeb, 0x31, 0x5e, 0x27, 0xbc, 0x47, 0xf3 }, { 0xf1, 0x13, 0x01, 0x6f, 0x74, 0x69, 0x8d, 0x5f, 0x1e, 0x68, 0x07, 0x88, 0xdd, 0xcb, 0x56, 0xd0 }, { 0xfd, 0x8f, 0x5f, 0xa1, 0x62, 0x82, 0x05, 0x85, 0xf7, 0x7b, 0x25, 0x0e, 0xfb, 0xb5, 0x0f, 0x1c }, { 0x65, 0x51, 0xd6, 0x91, 0x0a, 0xe9, 0xe2, 0x97, 0x7f, 0x09, 0xbd, 0x29, 0x64, 0xd0, 0xfa, 0x2b }, { 0xca, 0xf9, 0x6f, 0x61, 0xfa, 0x32, 0xef, 0x7c, 0x5d, 0xf6, 0x61, 0x03, 0xaf, 0xac, 0x84, 0x95 }, { 0x35, 0x18, 0x77, 0x87, 0x06, 0xa0, 0xa0, 0xb1, 0xba, 0xac, 0x40, 0xdf, 0xd8, 0x18, 0x16, 0x1d }, { 0x69, 0x20, 0xc0, 0xc3, 0xa8, 0xe2, 0x3b, 0xbe, 0xb8, 0x5b, 0x52, 0x58, 0x8a, 0xbd, 0x97, 0xb6 }, { 0x69, 0xcc, 0x1f, 0x1d, 0x1c, 0xcb, 0x57, 0xdf, 0x6a, 0xde, 0x53, 0x02, 0x95, 0x9b, 0x17, 0x46 }, { 0x70, 0x30, 0xb6, 0x12, 0x2c, 0x32, 0x29, 0xaf, 0xc6, 0xd1, 0x2d, 0x8e, 0xb2, 0xc2, 0x9b, 0x99 }, { 0xc9, 0xac, 0x91, 0x09, 0x5d, 0xbc, 0xea, 0x52, 0xd5, 0xfc, 0xb5, 0x8b, 0x57, 0x87, 0x14, 0x41 }, { 0xee, 0x28, 0x6b, 0x71, 0x48, 0x4a, 0x9d, 0x05, 0x56, 0xe1, 0xc0, 0x42, 0xd8, 0x86, 0x6d, 0x8f }, { 0xfe, 0x89, 0xcc, 0xbb, 0x39, 0x97, 0xf4, 0x75, 0xe4, 0x7d, 0x55, 0x24, 0x82, 0x88, 0xa3, 0x24 }, { 0xc3, 0xc7, 0xd4, 0x9f, 0x3c, 0x42, 0xa8, 0x4e, 0x28, 0x3e, 0xcb, 0xd8, 0xb2, 0xbe, 0x81, 0xd2 }, { 0x7a, 0x70, 0xfd, 0x4d, 0xed, 0x65, 0xcd, 0x2c, 0xfc, 0xf1, 0x5e, 0xc3, 0x8b, 0x2e, 0x87, 0x9b }, { 0x97, 0x5e, 0xa3, 0x66, 0xab, 0x8e, 0xc3, 0xcd, 0x35, 0xfd, 0xda, 0x91, 0xdf, 0xb1, 0xaf, 0xd6 }, { 0x46, 0x0c, 0x04, 0x6e, 0x6e, 0x3b, 0x97, 0xe2, 0x35, 0x65, 0xbc, 0xe7, 0xb9, 0x22, 0x4e, 0x97 }, { 0xef, 0xcc, 0xaa, 0xae, 0x45, 0x81, 0x7c, 0xbc, 0x61, 0x25, 0xc6, 0x20, 0x84, 0xc7, 0x05, 0xec }, { 0xb0, 0x23, 0x8d, 0x6d, 0x1f, 0x37, 0x95, 0x3e, 0x70, 0xd3, 0xdc, 0xf3, 0xcd, 0xd3, 0x28, 0xa1 }, { 0x7e, 0xd0, 0xd2, 0x5f, 0x0d, 0x1d, 0x1b, 0x7e, 0x62, 0xfa, 0xcf, 0xe3, 0x6e, 0x46, 0x8c, 0x5d }, { 0x00, 0xe8, 0x40, 0x63, 0x07, 0xb7, 0x98, 0xd4, 0x3f, 0xdf, 0xf7, 0x77, 0x25, 0x65, 0xd5, 0xf9 }, { 0xec, 0xc0, 0x38, 0x12, 0x5f, 0xdb, 0x26, 0x76, 0x62, 0xa5, 0x7d, 0xc9, 0xac, 0xc0, 0x64, 0x39 } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t cipher_texts2_128bit[ 100 ][ 32 ] = { { 0x78, 0x96, 0xce, 0x48, 0x49, 0xa6, 0x03, 0xdc, 0xf0, 0x1e, 0x62, 0x2d, 0x68, 0x20, 0xf4, 0x25, 0xe7, 0xde, 0x24, 0x85, 0xd2, 0x47, 0x21, 0x05, 0xbb, 0xf5, 0xf1, 0x1c, 0x5d, 0xc5, 0x8e, 0xe1 }, { 0x7c, 0xf2, 0x51, 0x99, 0xfc, 0xec, 0xb9, 0x7e, 0xf2, 0xa6, 0xb8, 0x41, 0x66, 0x77, 0xc1, 0xad, 0x15, 0xf4, 0xa6, 0xcf, 0x78, 0xf0, 0x2b, 0x42, 0x0b, 0xb8, 0xce, 0x95, 0xbd, 0x5c, 0xdb, 0xb5 }, { 0x4c, 0xc9, 0x66, 0xf4, 0x22, 0x77, 0xf1, 0xcc, 0xcc, 0x68, 0xa8, 0x86, 0xfb, 0x14, 0x9b, 0xb4, 0x57, 0xdc, 0xa7, 0x13, 0xe6, 0x5b, 0x51, 0xc3, 0x15, 0x6a, 0x12, 0xd4, 0x70, 0x9b, 0x0f, 0x76 }, { 0x26, 0xfa, 0xdd, 0x2d, 0x11, 0xfb, 0x2a, 0x1f, 0x98, 0x3d, 0x41, 0x99, 0x59, 0xf8, 0xa0, 0x35, 0x27, 0x35, 0x16, 0x03, 0x28, 0xe0, 0xfd, 0xb3, 0x7b, 0x80, 0x0f, 0xa2, 0x2e, 0x3f, 0x51, 0xf5 }, { 0xe3, 0x3e, 0x93, 0x6b, 0x3f, 0xfe, 0x75, 0xd5, 0x6e, 0x00, 0xa4, 0xc7, 0x57, 0x77, 0x51, 0x75, 0x09, 0xe6, 0xd2, 0xfb, 0xb0, 0x46, 0xbf, 0x4b, 0x7f, 0xb6, 0xb8, 0x7b, 0x40, 0x32, 0x11, 0x2d }, { 0x1a, 0x1a, 0x46, 0xee, 0x17, 0x73, 0xc9, 0xce, 0xf9, 0x27, 0x49, 0xc4, 0xef, 0x3b, 0x55, 0x2f, 0xe2, 0xe0, 0x46, 0x58, 0x29, 0x3a, 0x5a, 0x60, 0xc6, 0x0c, 0x2e, 0x35, 0x0b, 0x37, 0x23, 0xc3 }, { 0xb2, 0x93, 0x7e, 0x87, 0x99, 0x98, 0x78, 0x4c, 0x74, 0xcc, 0x6a, 0x48, 0x79, 0x02, 0xd1, 0x96, 0xd6, 0xa3, 0x28, 0xf0, 0x7a, 0xfe, 0x23, 0x81, 0x32, 0x4c, 0xf2, 0x73, 0x01, 0x31, 0xf0, 0xb5 }, { 0xd0, 0x9e, 0xbe, 0x78, 0x35, 0x1e, 0x03, 0x20, 0x1a, 0xed, 0x53, 0xba, 0x22, 0x15, 0x7a, 0xf7, 0x75, 0x2c, 0x45, 0xf9, 0x4e, 0xe2, 0x83, 0x38, 0x20, 0x22, 0x91, 0x20, 0xa6, 0x0e, 0x05, 0x94 }, { 0xe4, 0x0f, 0x5f, 0x03, 0x2a, 0xe2, 0x0a, 0x1d, 0x06, 0xb8, 0x17, 0xd5, 0x01, 0x6e, 0x2a, 0x35, 0xfb, 0x25, 0x9c, 0x87, 0x99, 0x77, 0xb8, 0x99, 0xc9, 0x95, 0x0d, 0xd2, 0x12, 0xd7, 0xb5, 0x33 }, { 0x09, 0x25, 0x17, 0xad, 0xac, 0x8b, 0xef, 0x1a, 0x33, 0xcc, 0x31, 0x08, 0x42, 0x07, 0x51, 0x98, 0x38, 0xf3, 0x14, 0x82, 0xa6, 0x0e, 0x8c, 0xbe, 0xaf, 0x86, 0xd0, 0xba, 0xe6, 0x17, 0xa8, 0x72 }, { 0x69, 0x46, 0xdf, 0xdf, 0x79, 0x15, 0x1e, 0x6e, 0x2c, 0xfc, 0xc5, 0x4e, 0x0b, 0x52, 0xaf, 0x6d, 0xe1, 0x78, 0x40, 0xf8, 0x34, 0x66, 0x25, 0x70, 0x22, 0x0a, 0xd8, 0x49, 0x87, 0x5c, 0xe7, 0xa5 }, { 0x7a, 0x51, 0xb3, 0x39, 0x66, 0x25, 0x5e, 0x2c, 0xa3, 0x25, 0xbe, 0xa9, 0xde, 0x4a, 0xaa, 0xcb, 0x22, 0xe9, 0x35, 0x9b, 0x82, 0xff, 0x0c, 0xa3, 0x4b, 0x5b, 0x39, 0xf8, 0x08, 0x05, 0xa6, 0xb7 }, { 0x30, 0x6b, 0xf2, 0xc4, 0xcc, 0x85, 0xa7, 0xec, 0x8f, 0xe6, 0xc6, 0x69, 0xbc, 0x10, 0x0c, 0x4f, 0xa9, 0x2a, 0xf9, 0x93, 0x42, 0x8f, 0x80, 0xe2, 0x24, 0x25, 0xa9, 0xe6, 0x30, 0xc2, 0x29, 0x50 }, { 0x80, 0x98, 0xed, 0x2f, 0x12, 0x90, 0xf3, 0xd6, 0xbb, 0x21, 0x68, 0xa9, 0xda, 0x96, 0xf0, 0x81, 0xd1, 0x84, 0xc7, 0x22, 0xec, 0xe4, 0xbb, 0xed, 0x52, 0x8a, 0x8f, 0x00, 0x39, 0x2a, 0x3c, 0x03 }, { 0xa3, 0xb6, 0xba, 0x39, 0x51, 0xba, 0x20, 0x3a, 0x59, 0x82, 0x7c, 0xb5, 0x97, 0x62, 0xd4, 0x0a, 0x3c, 0x5a, 0x91, 0xd5, 0xd5, 0xbf, 0x86, 0x2a, 0x38, 0xb7, 0x5f, 0xc3, 0x5d, 0x4f, 0xb2, 0xde }, { 0x22, 0x96, 0x65, 0xa0, 0xc4, 0x40, 0xe4, 0x6d, 0x7d, 0x79, 0x09, 0x1f, 0xf9, 0xf0, 0x0d, 0xcf, 0x60, 0x48, 0x2b, 0xdd, 0x1c, 0x98, 0x82, 0x19, 0x72, 0x1f, 0x73, 0x89, 0xf1, 0x29, 0xc0, 0xa4 }, { 0xca, 0xfe, 0x8b, 0x63, 0x42, 0x69, 0x9f, 0x00, 0x1e, 0x81, 0x68, 0x8d, 0xd8, 0xfa, 0x5c, 0x52, 0x03, 0x8d, 0xee, 0xa6, 0xd3, 0xf5, 0xa2, 0xde, 0xb3, 0xb4, 0xe5, 0x2c, 0xdf, 0x1c, 0x2f, 0xcb }, { 0x3e, 0x6c, 0xe9, 0x34, 0x3e, 0xd6, 0xcc, 0x3f, 0x50, 0x09, 0xb9, 0x79, 0x4a, 0x48, 0xd7, 0x9b, 0x05, 0xb9, 0x34, 0x26, 0xbc, 0xf6, 0x24, 0xd0, 0x62, 0x98, 0x74, 0x1a, 0xb7, 0xaf, 0x4b, 0xa1 }, { 0x63, 0x94, 0x75, 0xe5, 0x68, 0x6c, 0x8c, 0x30, 0x0e, 0x6d, 0x21, 0xe3, 0x6c, 0x82, 0xd2, 0x4f, 0xab, 0xc2, 0x1c, 0x8a, 0x74, 0xe3, 0xea, 0xd0, 0x2a, 0x91, 0xae, 0xc4, 0x64, 0x11, 0x96, 0x8d }, { 0x02, 0x2f, 0x0f, 0xe4, 0x81, 0xa8, 0xe7, 0x02, 0xc3, 0x31, 0xbd, 0x11, 0x95, 0x9d, 0xd2, 0x5e, 0x14, 0x9f, 0xde, 0x8e, 0x3b, 0xc4, 0xb3, 0x39, 0x20, 0x52, 0xa7, 0xfa, 0x04, 0x38, 0x7a, 0x26 }, { 0x11, 0x9a, 0xd8, 0x70, 0xe6, 0x39, 0x97, 0xb0, 0xa7, 0x58, 0x52, 0x4a, 0xa8, 0x96, 0xa6, 0x5f, 0x40, 0x29, 0x9b, 0x01, 0xb8, 0x41, 0x81, 0xf5, 0x27, 0x30, 0x13, 0x4a, 0xac, 0x0d, 0x22, 0xd6 }, { 0x19, 0x35, 0x41, 0x24, 0x54, 0x91, 0x35, 0xa5, 0x13, 0xfb, 0x92, 0xbc, 0x94, 0xc5, 0x52, 0xd0, 0x4a, 0x83, 0x60, 0xdf, 0x74, 0xe3, 0x4c, 0x7e, 0x9c, 0x61, 0x6f, 0xe5, 0x9c, 0x5e, 0xa6, 0x83 }, { 0xf5, 0x89, 0xaa, 0xe6, 0xaf, 0x88, 0x5a, 0xd0, 0x1b, 0xe8, 0x32, 0xaf, 0xab, 0xf6, 0x5d, 0xde, 0xe4, 0xb6, 0xed, 0xa3, 0x36, 0xa1, 0x9c, 0xa3, 0x0e, 0x26, 0x46, 0xac, 0x3a, 0x85, 0x64, 0x19 }, { 0x37, 0x1d, 0xfd, 0xac, 0x45, 0x3c, 0x96, 0x0f, 0xc7, 0xd5, 0x30, 0x75, 0xad, 0x57, 0xe2, 0xda, 0x81, 0x1c, 0x0d, 0x7a, 0xc0, 0xb6, 0x0c, 0xe0, 0x4e, 0x6a, 0xf6, 0x8b, 0x9a, 0xaf, 0x72, 0x41 }, { 0xd9, 0xf8, 0x1d, 0xa9, 0x96, 0xb9, 0x58, 0xa2, 0xce, 0xf8, 0x77, 0x6d, 0x0d, 0xd4, 0x76, 0x30, 0xa1, 0x35, 0x5e, 0x95, 0xee, 0x26, 0x7c, 0xb8, 0xb8, 0x41, 0x33, 0x1c, 0xbb, 0x3c, 0x0f, 0x3e }, { 0xd6, 0xbe, 0x04, 0x6d, 0x41, 0xf2, 0x3b, 0x5e, 0xd7, 0x0b, 0x6b, 0x3d, 0x5c, 0x8e, 0x66, 0x23, 0x2b, 0xe6, 0xb8, 0x07, 0xd4, 0xdc, 0xc6, 0x0e, 0xff, 0x8d, 0xbc, 0x1d, 0x9f, 0x7f, 0xc8, 0x22 }, { 0x1e, 0x98, 0x04, 0x73, 0xc2, 0x3d, 0x1e, 0x6d, 0xb5, 0xb8, 0x3a, 0x34, 0x88, 0x73, 0x0e, 0xe6, 0x44, 0x4f, 0x6a, 0x7d, 0x3d, 0xb0, 0x75, 0x15, 0x83, 0xfb, 0x4b, 0x07, 0x38, 0x47, 0x32, 0x22 }, { 0xcb, 0x89, 0x00, 0x9d, 0x41, 0x49, 0xe2, 0xd5, 0xbc, 0x90, 0x55, 0x39, 0x55, 0x90, 0xb9, 0xa4, 0x17, 0xc9, 0x95, 0xfb, 0xa3, 0x01, 0xdc, 0x5c, 0x61, 0x82, 0x82, 0x63, 0x71, 0x67, 0xd9, 0x05 }, { 0x86, 0x91, 0xb8, 0x3a, 0xfc, 0xe5, 0x8b, 0x52, 0xa6, 0x57, 0x56, 0x18, 0xb7, 0xf8, 0xb6, 0x8a, 0x40, 0x8a, 0xcc, 0x86, 0x63, 0x76, 0xad, 0xad, 0x22, 0xc7, 0xb7, 0x49, 0x45, 0x28, 0x3d, 0x1e }, { 0xce, 0xd6, 0x42, 0x91, 0x6a, 0xf8, 0xc5, 0x8d, 0xb8, 0x57, 0xf8, 0x8f, 0x1b, 0x8c, 0x8a, 0x47, 0x87, 0x60, 0xdf, 0x75, 0x83, 0x4f, 0x8b, 0x77, 0xce, 0x2f, 0x1d, 0x31, 0x20, 0x54, 0xf7, 0x6a }, { 0x0c, 0xaf, 0x12, 0xff, 0x57, 0x84, 0xff, 0x49, 0xdc, 0x88, 0xea, 0xf0, 0xee, 0x96, 0x09, 0x7f, 0x6b, 0xd1, 0xa0, 0x05, 0xad, 0xe1, 0x8b, 0x9e, 0xa7, 0x3b, 0x6e, 0xad, 0xd0, 0x5b, 0xc5, 0x49 }, { 0xff, 0x49, 0xaa, 0x42, 0x37, 0x87, 0x1f, 0x91, 0xd5, 0x4a, 0xe1, 0x87, 0x7a, 0x27, 0xd8, 0xda, 0x87, 0x7e, 0x98, 0x67, 0xcb, 0x2f, 0x69, 0x33, 0x0d, 0x22, 0xe9, 0xc2, 0x73, 0xa4, 0x49, 0xd9 }, { 0xc1, 0xcb, 0x16, 0x89, 0x1d, 0x30, 0xff, 0x0e, 0x05, 0xe2, 0x4b, 0x95, 0x7d, 0x57, 0xc3, 0xe4, 0x0d, 0xad, 0xfa, 0x2c, 0x7c, 0x27, 0x37, 0x8c, 0xbe, 0x8a, 0x16, 0x76, 0xf1, 0x12, 0x86, 0x15 }, { 0x15, 0xc9, 0xd8, 0xdd, 0x95, 0x6d, 0x73, 0x9a, 0xac, 0x35, 0x41, 0xa4, 0xe2, 0x91, 0x2e, 0xd4, 0x7d, 0xf5, 0xd1, 0x93, 0xc0, 0xbf, 0xc7, 0xeb, 0x24, 0x36, 0xef, 0x75, 0x6e, 0x3b, 0x82, 0xe8 }, { 0xa5, 0x51, 0xce, 0xe3, 0x57, 0x2d, 0xc8, 0x53, 0xd9, 0x0b, 0x21, 0x57, 0x60, 0xda, 0x63, 0x22, 0x06, 0xe3, 0x69, 0xa3, 0x56, 0x42, 0x33, 0x46, 0xc7, 0xc4, 0x92, 0x4d, 0x57, 0xd0, 0xa9, 0x42 }, { 0x9d, 0x27, 0x17, 0xab, 0x39, 0xb9, 0xcb, 0xd4, 0xb6, 0x2a, 0xcd, 0xf7, 0xf5, 0x6a, 0x8a, 0xe2, 0x34, 0xf8, 0xd2, 0x32, 0x32, 0xbb, 0x71, 0x34, 0x8c, 0xa0, 0x39, 0xa8, 0x83, 0x98, 0xbf, 0xab }, { 0x93, 0x32, 0xc3, 0xfa, 0xcd, 0x20, 0xf6, 0xad, 0x6e, 0xbc, 0x02, 0xb9, 0x44, 0xe8, 0x18, 0x9e, 0x10, 0xb1, 0x2b, 0xe7, 0x4a, 0x74, 0x29, 0x81, 0x00, 0x01, 0x5c, 0x88, 0xd1, 0x5b, 0x2b, 0xc4 }, { 0xd0, 0x8a, 0x0d, 0x05, 0x2f, 0x00, 0xc4, 0x46, 0x04, 0xed, 0x31, 0x34, 0x8c, 0xdf, 0xa8, 0x6e, 0x4d, 0xbc, 0xe7, 0x1b, 0xad, 0x4d, 0xb8, 0x8d, 0xb9, 0xcc, 0x27, 0xce, 0xa5, 0x0d, 0x7f, 0xde }, { 0xf0, 0x81, 0x3a, 0x6d, 0x4c, 0xeb, 0x96, 0xaf, 0x1a, 0x92, 0x0f, 0x8a, 0x06, 0x6c, 0x96, 0xd8, 0x79, 0x9a, 0x34, 0x33, 0x8a, 0xc8, 0xd4, 0x6d, 0xeb, 0x6a, 0x65, 0x1a, 0xd9, 0x27, 0xd5, 0x3f }, { 0x69, 0x81, 0x55, 0x0e, 0x1c, 0x53, 0x5e, 0x10, 0x21, 0x8e, 0x61, 0x20, 0xce, 0xe3, 0xb1, 0x59, 0xf5, 0x6b, 0x1b, 0xb4, 0x92, 0xc6, 0xbf, 0x18, 0x1b, 0x69, 0x4c, 0x24, 0x96, 0xf7, 0x1f, 0xb8 }, { 0xf6, 0xa2, 0x66, 0xdd, 0xd6, 0x84, 0xf0, 0x24, 0xeb, 0x08, 0x0c, 0x9b, 0x58, 0xf8, 0x17, 0xae, 0x2d, 0x24, 0xf3, 0x14, 0x33, 0x50, 0xb4, 0xd3, 0xe2, 0x7a, 0x13, 0x09, 0xcd, 0xf1, 0xa3, 0xe0 }, { 0xa6, 0x23, 0x56, 0x93, 0xbb, 0x98, 0xa4, 0x7a, 0xbf, 0x6d, 0xd7, 0xef, 0xc2, 0x0e, 0xd8, 0x71, 0x8e, 0xb9, 0x6d, 0x46, 0xe8, 0xed, 0x53, 0xbb, 0xc6, 0xae, 0xf2, 0x62, 0x03, 0x91, 0xaa, 0x78 }, { 0xc2, 0x9e, 0x8e, 0xe3, 0x47, 0x52, 0x8d, 0x3d, 0x16, 0x0d, 0x28, 0xae, 0xd9, 0xb5, 0xcb, 0x13, 0x09, 0xd7, 0xb0, 0xb7, 0x06, 0xa0, 0x1a, 0x2e, 0x2a, 0xef, 0xdd, 0x94, 0x53, 0xd3, 0xd1, 0x3f }, { 0x6d, 0x59, 0x8f, 0x53, 0xdf, 0x02, 0x28, 0x53, 0xe0, 0x5f, 0xe7, 0x04, 0xef, 0x8f, 0x1f, 0x6c, 0xf5, 0xdd, 0x6e, 0x88, 0xda, 0x57, 0xd3, 0xf2, 0x9c, 0xe7, 0xee, 0x39, 0x2f, 0x01, 0xde, 0x2a }, { 0x8d, 0x31, 0x6d, 0x02, 0x01, 0x76, 0xd5, 0x1b, 0x42, 0xf6, 0xc2, 0xa5, 0xcc, 0x58, 0x11, 0x58, 0xeb, 0x67, 0x4d, 0x99, 0x10, 0xf4, 0x6e, 0x20, 0xb7, 0x56, 0x79, 0x0d, 0x64, 0x91, 0xf7, 0xab }, { 0xcc, 0x58, 0xb6, 0x71, 0x80, 0xa3, 0xbb, 0xea, 0x94, 0x4c, 0xba, 0xaa, 0x66, 0xe8, 0xe3, 0x7e, 0xe2, 0x58, 0xf8, 0xf2, 0x74, 0xcd, 0xd6, 0x20, 0x28, 0x15, 0x36, 0x8e, 0x3b, 0xf1, 0xcf, 0xcb }, { 0xa0, 0x31, 0x58, 0x6a, 0xba, 0x1f, 0x82, 0x33, 0xfc, 0x30, 0x3c, 0x1c, 0x5e, 0xef, 0x63, 0x98, 0xb5, 0x97, 0x9f, 0x54, 0x09, 0xa4, 0x55, 0x3a, 0x32, 0x82, 0xa2, 0xe8, 0x13, 0xa6, 0x09, 0x44 }, { 0x41, 0x49, 0x96, 0xef, 0x10, 0x18, 0x5f, 0xc3, 0x5a, 0xa9, 0x50, 0x3c, 0xe7, 0xbf, 0x56, 0xf6, 0xad, 0xcb, 0x82, 0x10, 0xe9, 0xde, 0xd0, 0x26, 0xb9, 0x3a, 0x24, 0xee, 0x48, 0x4d, 0x7c, 0xd8 }, { 0xd0, 0x25, 0x33, 0x76, 0x5e, 0x11, 0xe7, 0x1d, 0xda, 0xf2, 0xeb, 0x26, 0x33, 0x33, 0x91, 0xbe, 0x17, 0x1f, 0x49, 0x2c, 0xf8, 0x8e, 0x3a, 0x48, 0x02, 0xa9, 0x66, 0xe9, 0x2b, 0x03, 0x23, 0x1b }, { 0xfd, 0xfa, 0x02, 0x07, 0x42, 0x91, 0x86, 0x6f, 0xf7, 0xf6, 0xd3, 0xfc, 0x9b, 0x16, 0xa2, 0x2a, 0x74, 0x38, 0xe8, 0xd6, 0x9a, 0x24, 0x68, 0x95, 0x18, 0xac, 0x96, 0x80, 0x76, 0x8e, 0x95, 0xa6 }, { 0xf8, 0xd4, 0x23, 0x66, 0x2e, 0x31, 0x5b, 0xe3, 0xee, 0x5c, 0xfc, 0x7f, 0x0b, 0x50, 0x9d, 0xf2, 0xe6, 0x4f, 0x57, 0xb1, 0xf2, 0xc1, 0xf4, 0xa8, 0xcd, 0xab, 0x5e, 0xcf, 0x95, 0xa7, 0x63, 0xfd }, { 0x2a, 0x3d, 0x5d, 0x94, 0xb3, 0xd4, 0xe3, 0x62, 0xcc, 0x9c, 0xa1, 0xd4, 0x3d, 0xb1, 0xc2, 0x7e, 0xa6, 0xab, 0xf5, 0xd4, 0x20, 0x84, 0xe7, 0x8c, 0xc8, 0xfb, 0xd9, 0x09, 0x62, 0x76, 0x93, 0x70 }, { 0x5f, 0xf9, 0x65, 0x2b, 0x49, 0x5f, 0x76, 0x66, 0xb7, 0x2f, 0xe9, 0x0d, 0x2e, 0x60, 0xfa, 0xf6, 0xc7, 0xf6, 0xb5, 0x27, 0x24, 0x1f, 0x2e, 0x7a, 0x25, 0xe7, 0x69, 0x5c, 0x14, 0x0b, 0x12, 0x9a }, { 0xa8, 0x89, 0xc2, 0xcb, 0x9e, 0x79, 0x69, 0x8a, 0xbe, 0x34, 0x86, 0xd0, 0xc0, 0x9d, 0xa3, 0x95, 0x24, 0xdc, 0xee, 0x74, 0xc2, 0x14, 0x08, 0x94, 0x5a, 0x25, 0x3e, 0x0a, 0x8b, 0x41, 0x83, 0x5c }, { 0xfe, 0x6c, 0x08, 0xf4, 0x7b, 0xb5, 0x81, 0xac, 0xde, 0x23, 0x0f, 0x9c, 0x74, 0xdd, 0x70, 0x98, 0x31, 0x17, 0xeb, 0x3e, 0xb1, 0x16, 0xd1, 0x92, 0xe7, 0x1c, 0x97, 0x44, 0xc8, 0xa5, 0xab, 0x09 }, { 0x48, 0xc1, 0x7f, 0x35, 0xb4, 0x8f, 0x78, 0x45, 0x6b, 0xb3, 0x6b, 0xe8, 0xb6, 0x08, 0x0e, 0x4d, 0x41, 0x9a, 0x53, 0xaa, 0x94, 0x23, 0x20, 0x24, 0xa8, 0xa8, 0xdb, 0xcd, 0x88, 0x0b, 0x4c, 0x8f }, { 0x9c, 0x11, 0x8b, 0x07, 0x22, 0xeb, 0x85, 0xbe, 0xd7, 0xeb, 0x7e, 0xb0, 0x0f, 0x2f, 0x76, 0x35, 0x26, 0x39, 0x57, 0xaa, 0x65, 0x4c, 0x2d, 0x38, 0x24, 0x41, 0xf8, 0xb4, 0x2a, 0x25, 0x19, 0x16 }, { 0xaf, 0x99, 0x29, 0xef, 0x02, 0xd9, 0x04, 0x0d, 0xb0, 0x1d, 0x29, 0xbc, 0x14, 0x6b, 0x10, 0xd5, 0xe2, 0xf3, 0xba, 0x40, 0x1f, 0x0a, 0x5e, 0xc5, 0x27, 0x4f, 0x94, 0x2e, 0x52, 0x2b, 0xea, 0xfa }, { 0x35, 0x77, 0x9b, 0x9b, 0x79, 0x34, 0xc8, 0x59, 0xf4, 0xec, 0x75, 0x66, 0x86, 0xaa, 0x52, 0xe7, 0x1f, 0x62, 0x00, 0x44, 0x01, 0x1e, 0x34, 0x60, 0x67, 0x3a, 0xdc, 0x98, 0xaf, 0xb9, 0xdd, 0x12 }, { 0x5f, 0x89, 0x52, 0x12, 0xb2, 0x1d, 0x1b, 0x10, 0x96, 0x02, 0xc0, 0x38, 0x8b, 0xcd, 0x61, 0x41, 0x59, 0x95, 0x82, 0x57, 0xdd, 0x07, 0xe2, 0x12, 0xe5, 0x56, 0x01, 0x24, 0xbd, 0x12, 0x5a, 0x7d }, { 0x63, 0xb8, 0xd5, 0x8c, 0x7a, 0x99, 0x34, 0x4b, 0xd2, 0xd2, 0x4e, 0x88, 0x4e, 0x46, 0x71, 0x2e, 0xd4, 0xd7, 0xca, 0xeb, 0x4b, 0x7c, 0xed, 0x6f, 0xe7, 0x27, 0x8f, 0xe1, 0xee, 0x3e, 0xf5, 0x8b }, { 0xa0, 0xff, 0x0b, 0x77, 0x93, 0x6d, 0xbb, 0xef, 0x98, 0xd7, 0x4c, 0x4b, 0x90, 0x92, 0x6c, 0x9d, 0x0e, 0x2c, 0x34, 0xf7, 0x8e, 0x5a, 0x41, 0x01, 0xe6, 0x04, 0x69, 0x3e, 0x0f, 0x81, 0x0b, 0xb8 }, { 0xe7, 0x57, 0x3b, 0x16, 0xbd, 0xd6, 0x0e, 0xc9, 0x7e, 0xa4, 0x16, 0x67, 0x9b, 0x53, 0x97, 0xc8, 0x2b, 0xa5, 0x18, 0xaa, 0x4f, 0x57, 0xc3, 0x53, 0x02, 0x6f, 0x42, 0x46, 0x4e, 0xda, 0x87, 0x69 }, { 0x90, 0xaa, 0x84, 0x71, 0x68, 0x26, 0x34, 0x3d, 0x1b, 0x1a, 0x0d, 0xa5, 0x39, 0xaa, 0x2b, 0x95, 0xee, 0x9d, 0xd9, 0x2a, 0x94, 0xd1, 0xa8, 0x67, 0xe3, 0xcf, 0x58, 0x22, 0xf0, 0xc5, 0xe5, 0x2a }, { 0x5b, 0x3c, 0x9d, 0xbe, 0xe7, 0xde, 0x68, 0x50, 0x68, 0xfd, 0xc2, 0x33, 0x36, 0xaf, 0x6b, 0xb0, 0x91, 0xf4, 0xb6, 0x5c, 0x14, 0x2c, 0x17, 0xfa, 0x46, 0x8b, 0xdd, 0x05, 0x68, 0x0a, 0x30, 0x4b }, { 0x25, 0xb5, 0xcb, 0xc2, 0x36, 0x0b, 0x95, 0x02, 0xf4, 0x52, 0x1b, 0x6a, 0x76, 0xc1, 0x39, 0x70, 0xa9, 0x9d, 0x30, 0x61, 0xa6, 0xf3, 0x98, 0xcf, 0xb5, 0x7b, 0x0b, 0x7c, 0x92, 0xe9, 0x80, 0x93 }, { 0x45, 0x14, 0x40, 0x40, 0x1c, 0x3d, 0x12, 0x1d, 0x7d, 0xa7, 0x3c, 0xef, 0x54, 0xf3, 0xd0, 0x21, 0x14, 0x74, 0x55, 0x39, 0x0e, 0x93, 0xc7, 0xe2, 0xf1, 0x6e, 0x5d, 0xe6, 0x51, 0xdc, 0x34, 0x3c }, { 0x52, 0x99, 0x85, 0x24, 0xd9, 0x67, 0xb2, 0x8c, 0x64, 0x6b, 0xa6, 0x25, 0xfb, 0x3f, 0x9a, 0x8d, 0x1b, 0xe8, 0x65, 0x29, 0xd3, 0x85, 0x70, 0x2a, 0x2e, 0x67, 0x6c, 0xfe, 0xa2, 0x6d, 0x88, 0xe5 }, { 0x8d, 0x1a, 0x06, 0x6f, 0xb0, 0x6e, 0xec, 0x35, 0x82, 0x5a, 0x1d, 0x50, 0x4c, 0x38, 0x15, 0x71, 0xaa, 0x3d, 0x6c, 0x65, 0xbb, 0x58, 0x4f, 0xc4, 0x44, 0x87, 0x37, 0x0e, 0x29, 0x87, 0x2e, 0x96 }, { 0xba, 0x1d, 0x0c, 0x4b, 0x89, 0x51, 0xc4, 0xd3, 0x6a, 0x1e, 0x8f, 0x75, 0x48, 0xab, 0x37, 0x03, 0xd3, 0xdc, 0x07, 0x72, 0xe0, 0xc7, 0x52, 0xe9, 0x6d, 0xd5, 0xd1, 0x92, 0x6f, 0x33, 0x9e, 0xfb }, { 0x2c, 0x3d, 0xa3, 0x16, 0x66, 0xf7, 0x78, 0x51, 0xef, 0x74, 0xcd, 0x4c, 0x3a, 0x9c, 0xb4, 0x7b, 0xa6, 0xf0, 0x6a, 0x8c, 0x0f, 0x7f, 0x9b, 0xd4, 0xc6, 0xa8, 0x5c, 0xd8, 0x65, 0x91, 0x0d, 0x70 }, { 0xb2, 0xc4, 0x5d, 0xd6, 0x1e, 0xae, 0x5a, 0x19, 0x5e, 0x51, 0xcf, 0xe1, 0xa9, 0x43, 0xe7, 0x57, 0x7f, 0x97, 0x15, 0xf9, 0x31, 0x08, 0x61, 0xb7, 0x32, 0x0b, 0x60, 0xee, 0x46, 0x96, 0x48, 0xb5 }, { 0x4d, 0xe5, 0x23, 0x6f, 0xa0, 0xe2, 0x29, 0x1d, 0x5b, 0xc2, 0xc0, 0xa5, 0x36, 0x8d, 0xfe, 0xe2, 0x87, 0xc0, 0x89, 0x69, 0xd0, 0x51, 0xf8, 0xe0, 0x61, 0xb5, 0x1a, 0x1a, 0xd4, 0x27, 0x99, 0x2a }, { 0xe6, 0xb6, 0x4a, 0xf6, 0x64, 0x66, 0xc2, 0xb4, 0x0b, 0x53, 0xc7, 0x85, 0x9b, 0x32, 0x06, 0x11, 0x07, 0x88, 0xa7, 0x71, 0x7e, 0xe1, 0xb1, 0x62, 0x8c, 0xa8, 0x43, 0x33, 0x68, 0xdb, 0xaf, 0xa9 }, { 0x78, 0x4b, 0x11, 0xe1, 0x2f, 0x9e, 0xb1, 0x4c, 0x6a, 0x1b, 0xb4, 0x48, 0x71, 0xa6, 0x8a, 0x03, 0x09, 0x0d, 0xbd, 0x1c, 0x85, 0x8b, 0x51, 0x6c, 0xd8, 0x17, 0xf0, 0xc5, 0xdb, 0x07, 0x05, 0xde }, { 0x3b, 0xf8, 0xe4, 0xc8, 0x7d, 0x6e, 0x92, 0x38, 0xdc, 0x2c, 0x9a, 0xd8, 0x0d, 0xd8, 0xb4, 0x56, 0xf0, 0x19, 0x46, 0xb9, 0xde, 0x87, 0xbd, 0x3c, 0x7f, 0xef, 0x47, 0x30, 0x36, 0x90, 0xa5, 0x68 }, { 0x7d, 0xc2, 0x3f, 0x89, 0xc3, 0xf7, 0x40, 0x10, 0x3e, 0xdd, 0x77, 0xc8, 0x3f, 0x33, 0x02, 0xc9, 0x12, 0x56, 0x48, 0x63, 0x63, 0xed, 0xbe, 0x33, 0x1b, 0x97, 0x94, 0x64, 0x09, 0xa8, 0x27, 0xd2 }, { 0x68, 0xfb, 0x3c, 0x4f, 0x6e, 0x30, 0xa9, 0xe8, 0xb6, 0xca, 0xe6, 0xb4, 0x91, 0x30, 0xc4, 0x33, 0xef, 0x5f, 0x9a, 0xf0, 0x12, 0xd0, 0x02, 0x1a, 0xce, 0x4a, 0xd8, 0x4a, 0x3e, 0x53, 0x29, 0x26 }, { 0xa9, 0x2a, 0xdc, 0x72, 0xcf, 0xce, 0x95, 0xb3, 0x49, 0x65, 0xb5, 0x29, 0x30, 0x28, 0x66, 0x6c, 0x2f, 0x2b, 0x9f, 0x6a, 0x8e, 0xc1, 0x3f, 0x90, 0x00, 0x77, 0xb1, 0x01, 0x8b, 0x4b, 0x0e, 0x7b }, { 0xed, 0xfc, 0xe1, 0xf8, 0xb6, 0x01, 0x6c, 0x79, 0xb5, 0x98, 0x53, 0xb5, 0x47, 0x18, 0x03, 0xd6, 0x22, 0x24, 0xf1, 0xfa, 0x37, 0xaa, 0x5c, 0xbf, 0xf2, 0x87, 0x47, 0xa0, 0x66, 0x68, 0x9d, 0x5b }, { 0x55, 0xa0, 0x0c, 0x1f, 0x81, 0x4b, 0xdf, 0x1e, 0xeb, 0x2c, 0xe0, 0xff, 0x0c, 0x60, 0xeb, 0xf7, 0xb5, 0xdd, 0x7a, 0xcf, 0x63, 0xce, 0x44, 0x17, 0xf2, 0xba, 0x14, 0x3a, 0x7d, 0x51, 0x06, 0x6e }, { 0x24, 0x07, 0x54, 0x11, 0x41, 0x57, 0xc3, 0xb7, 0x9d, 0x0a, 0xbe, 0x9b, 0xfc, 0x22, 0xa9, 0x19, 0x84, 0x46, 0x2e, 0xb9, 0x2f, 0x98, 0x30, 0xb5, 0x52, 0x5b, 0x3f, 0x7e, 0x19, 0xb3, 0xfb, 0x55 }, { 0x51, 0xd8, 0x24, 0x17, 0x6a, 0x47, 0xda, 0x46, 0x8b, 0xe7, 0x5f, 0x6b, 0xf1, 0x9a, 0x09, 0x1a, 0x55, 0x5b, 0x9a, 0xf8, 0xf4, 0xbf, 0xb0, 0xe0, 0x44, 0x8c, 0xc2, 0x3c, 0x99, 0x33, 0x1f, 0x05 }, { 0xdc, 0x41, 0x0f, 0x8b, 0xcc, 0x92, 0x2e, 0x96, 0x63, 0x4d, 0xb1, 0x23, 0xd5, 0xe2, 0xf4, 0x66, 0x15, 0x0d, 0x08, 0xdc, 0x0b, 0x2d, 0xa1, 0x9a, 0x8c, 0x6b, 0x1b, 0x3a, 0x39, 0x5b, 0xab, 0xad }, { 0xb4, 0xff, 0xa1, 0x15, 0x54, 0x41, 0x29, 0x16, 0xbb, 0xe8, 0x45, 0x88, 0xd4, 0x98, 0xff, 0xb7, 0x56, 0x17, 0xae, 0xda, 0x49, 0x61, 0x8f, 0x27, 0x91, 0xdc, 0xe4, 0xff, 0x22, 0xbc, 0x0a, 0xcf }, { 0x8b, 0xd8, 0xb5, 0x47, 0x0d, 0x36, 0x46, 0xfd, 0xe2, 0x94, 0xf0, 0x48, 0xf2, 0xe8, 0xa0, 0xf0, 0x12, 0x9b, 0x74, 0x5c, 0x53, 0xf5, 0xe8, 0x98, 0xf8, 0x0f, 0x14, 0x62, 0xad, 0x79, 0x89, 0x38 }, { 0xa3, 0x85, 0xdc, 0x6e, 0x2c, 0xec, 0x08, 0xae, 0xdd, 0x4f, 0xed, 0xb7, 0x53, 0x6a, 0xe7, 0xf4, 0xbb, 0x77, 0xf1, 0x39, 0x69, 0xce, 0x59, 0x5d, 0x3e, 0x36, 0x7c, 0xd8, 0x3b, 0x6b, 0xe4, 0xc4 }, { 0x30, 0x03, 0xfb, 0xe4, 0x97, 0x7e, 0xb6, 0x3a, 0x3c, 0x58, 0x98, 0x1d, 0x1f, 0xb4, 0xea, 0xc2, 0xba, 0xc3, 0x82, 0xe8, 0xbc, 0xf9, 0x38, 0x9e, 0xcb, 0x5a, 0x37, 0x2f, 0x13, 0x49, 0xb8, 0x84 }, { 0xd0, 0x4e, 0xcf, 0x6b, 0x79, 0x21, 0x00, 0x02, 0xa7, 0x78, 0xad, 0x2a, 0x33, 0x14, 0xd9, 0x0f, 0xb2, 0x70, 0x7c, 0xe3, 0xcd, 0x91, 0x3e, 0x58, 0x13, 0x47, 0xdb, 0x2c, 0xdf, 0x61, 0xd6, 0x98 }, { 0xd5, 0xe1, 0xfa, 0x40, 0xb4, 0x76, 0x45, 0xe5, 0x92, 0x47, 0x17, 0xb5, 0x3b, 0xfb, 0x62, 0x90, 0x38, 0xc6, 0x6e, 0x06, 0x5f, 0x71, 0x06, 0xb6, 0xb6, 0xc6, 0x42, 0x6e, 0x5d, 0x5c, 0xba, 0x19 }, { 0xad, 0x64, 0x77, 0xdd, 0x9d, 0x9c, 0x3a, 0xa4, 0x0c, 0x28, 0xe4, 0x55, 0xf1, 0xbd, 0x16, 0x93, 0x24, 0xe5, 0x15, 0xb5, 0xd1, 0x63, 0x94, 0x70, 0x2e, 0x7a, 0x19, 0x37, 0xee, 0x29, 0xfe, 0xe7 }, { 0xe6, 0x1c, 0x7b, 0xa1, 0xcf, 0xd2, 0x29, 0x12, 0x07, 0xa0, 0xda, 0x83, 0x6a, 0xa8, 0xca, 0x91, 0x25, 0x49, 0x83, 0xd1, 0xa7, 0xee, 0xa6, 0x9d, 0x1e, 0x25, 0x28, 0xde, 0x1c, 0xd3, 0x38, 0x9f }, { 0x55, 0x91, 0xdc, 0x08, 0xa6, 0x33, 0x64, 0xdd, 0xfc, 0xb1, 0x82, 0x39, 0x0a, 0xfc, 0x85, 0xb2, 0xb2, 0x75, 0x9f, 0xeb, 0xc4, 0x94, 0x81, 0x27, 0x39, 0xac, 0x8b, 0x44, 0x47, 0xc6, 0xc8, 0x92 }, { 0xfd, 0x29, 0x6a, 0x1d, 0x64, 0x85, 0x98, 0x14, 0x3d, 0xc4, 0xc1, 0x05, 0x51, 0xb6, 0x9e, 0xab, 0x17, 0xde, 0x74, 0xfa, 0xcf, 0x01, 0x59, 0xd5, 0xa5, 0x39, 0xc3, 0x4a, 0x92, 0x17, 0x45, 0x95 }, { 0xdc, 0x17, 0xca, 0xcd, 0x5e, 0x10, 0xd1, 0x3c, 0x03, 0x24, 0xbf, 0xe8, 0x0f, 0x00, 0x06, 0x6a, 0x78, 0x2a, 0x2b, 0xfb, 0x28, 0x40, 0x41, 0x31, 0x62, 0x86, 0xbc, 0x85, 0xba, 0xc2, 0x84, 0x79 }, { 0x05, 0x99, 0x08, 0xc4, 0xd5, 0x31, 0x3c, 0xfd, 0x84, 0x7c, 0xd2, 0xb1, 0xfb, 0x5d, 0x85, 0x70, 0xea, 0x65, 0x92, 0x8f, 0x0b, 0x31, 0x8e, 0x5a, 0x2c, 0x48, 0xc3, 0x82, 0x7b, 0xee, 0xd8, 0x60 }, { 0x2e, 0x12, 0x55, 0xdb, 0x34, 0xa1, 0x37, 0xdb, 0xf6, 0xda, 0x59, 0x41, 0x37, 0xa0, 0x3b, 0xfa, 0xe6, 0x76, 0xb5, 0xe9, 0x43, 0xa0, 0xc1, 0xbe, 0xf1, 0xcf, 0x28, 0x47, 0xdf, 0xa2, 0xb1, 0x72 }, { 0x14, 0xf7, 0xb4, 0x1f, 0x7d, 0xca, 0x28, 0xec, 0xda, 0xd8, 0xa8, 0x0a, 0xab, 0xe1, 0xa2, 0x62, 0x23, 0xce, 0x3a, 0x3d, 0x58, 0x3d, 0xb3, 0xb1, 0x43, 0xfd, 0x94, 0xf2, 0xf2, 0x10, 0xe4, 0x1e }, { 0xd4, 0x91, 0x5d, 0x2f, 0xa9, 0xe2, 0x19, 0x10, 0x54, 0xad, 0xdb, 0x63, 0xb8, 0x16, 0xbe, 0x05, 0xc0, 0xdc, 0x0e, 0x65, 0x51, 0x5f, 0xa0, 0x5c, 0xb9, 0x5c, 0x1a, 0xb8, 0xdf, 0xf3, 0x56, 0xab }, { 0x59, 0x3c, 0xb7, 0x36, 0xf6, 0x4c, 0x9e, 0x83, 0x8f, 0x0a, 0x88, 0x02, 0x29, 0xa7, 0x24, 0x50, 0x2d, 0x16, 0xa4, 0xaa, 0x3b, 0xa8, 0x0b, 0x2a, 0x35, 0x15, 0x54, 0x2d, 0x3a, 0xce, 0x49, 0x9c } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t cipher_texts3_128bit[ 100 ][ 25 ] = { { 0x23, 0xd5, 0x6c, 0x45, 0xe6, 0xca, 0x04, 0xbc, 0x1f, 0xea, 0x40, 0x24, 0xf8, 0xf1, 0x13, 0xfa, 0x3f, 0x63, 0x4f, 0xc3, 0xe5, 0x0d, 0x33, 0x05, 0xe4 }, { 0x60, 0x29, 0x61, 0x8d, 0x91, 0x2f, 0x8e, 0x54, 0xe5, 0xcf, 0x6b, 0xaa, 0x9c, 0x34, 0x7a, 0x9d, 0x70, 0x64, 0xff, 0x19, 0x5a, 0xa2, 0x26, 0xed, 0x6b }, { 0xc7, 0x27, 0x3e, 0x5b, 0xbf, 0x32, 0x0c, 0x13, 0x0e, 0xd8, 0xc1, 0x58, 0xa0, 0x75, 0xd3, 0x55, 0x3a, 0x2d, 0xa1, 0x9d, 0xb0, 0xae, 0x3d, 0x11, 0x98 }, { 0x07, 0xac, 0x68, 0x5b, 0xaa, 0x21, 0x22, 0x72, 0x06, 0x8e, 0xde, 0xbd, 0xd6, 0xa6, 0x2b, 0xdf, 0xc2, 0xfc, 0x0d, 0x71, 0xab, 0x57, 0x39, 0xe3, 0xb3 }, { 0x58, 0xcc, 0x33, 0x2b, 0x30, 0xa2, 0xc7, 0x50, 0xcc, 0x9c, 0x52, 0xb7, 0x67, 0x0b, 0xb1, 0x5c, 0xb7, 0xe9, 0xcb, 0xde, 0x95, 0x3d, 0xf7, 0x3b, 0xb2 }, { 0x16, 0x45, 0x01, 0x5b, 0x34, 0x2b, 0x14, 0xaf, 0x82, 0xee, 0xe3, 0xd4, 0x9c, 0xa6, 0x6e, 0xe4, 0xa5, 0x43, 0x46, 0xeb, 0x13, 0xd9, 0x27, 0xe7, 0x36 }, { 0x2f, 0x08, 0x06, 0x21, 0xa4, 0x0e, 0x74, 0x92, 0x06, 0xaf, 0x07, 0x9d, 0x6e, 0x93, 0x90, 0x3d, 0x4c, 0x2d, 0x40, 0xf6, 0x67, 0xfd, 0xfa, 0x9b, 0x5d }, { 0x74, 0x49, 0xe3, 0x7f, 0x74, 0x11, 0xd5, 0x61, 0x56, 0xc4, 0x5b, 0x91, 0x61, 0x27, 0xfb, 0x16, 0x3c, 0x2b, 0x09, 0xea, 0x03, 0x87, 0x4d, 0x82, 0x07 }, { 0x6b, 0x0b, 0x61, 0x28, 0xf7, 0xe3, 0x38, 0x40, 0x08, 0xda, 0x26, 0xb1, 0x75, 0x41, 0x41, 0xfd, 0xf3, 0x41, 0xe8, 0x6e, 0x70, 0x39, 0x6f, 0x5c, 0x3a }, { 0x86, 0x5a, 0xc2, 0x6b, 0x6a, 0xc1, 0xed, 0x29, 0xff, 0xb3, 0x9f, 0xca, 0xbb, 0x9c, 0xba, 0x74, 0xeb, 0xed, 0xac, 0xfd, 0xb4, 0xc7, 0x03, 0x19, 0x3b }, { 0x86, 0x33, 0x12, 0x74, 0x3a, 0x00, 0x6c, 0x48, 0x49, 0xb7, 0x11, 0x57, 0xf1, 0xca, 0x10, 0x83, 0xcf, 0xa1, 0xb2, 0x65, 0x4b, 0xa3, 0x7e, 0xa4, 0x4f }, { 0x37, 0x0d, 0xda, 0x94, 0x47, 0xcb, 0xe2, 0x65, 0xeb, 0x1c, 0x39, 0x1a, 0x89, 0xa1, 0xc8, 0xaa, 0xf7, 0x5d, 0x44, 0x25, 0xab, 0x29, 0x63, 0x0a, 0x7f }, { 0x25, 0x3c, 0x0d, 0x5c, 0xb7, 0x26, 0x80, 0x54, 0xfe, 0xa1, 0xc8, 0xff, 0xc6, 0x8e, 0xc7, 0xdd, 0xe3, 0x63, 0x62, 0x68, 0xdb, 0x54, 0xce, 0xff, 0x2e }, { 0x26, 0x71, 0x19, 0xf9, 0x19, 0xb4, 0x90, 0xec, 0x4d, 0x3b, 0xd7, 0x2c, 0xec, 0x3a, 0x71, 0x7f, 0x8e, 0x9e, 0xc7, 0x07, 0xaa, 0xbe, 0x98, 0x4b, 0xd6 }, { 0xfa, 0x35, 0x4c, 0xbf, 0xce, 0x18, 0x2e, 0xd0, 0x71, 0x0d, 0x60, 0x07, 0xe9, 0x44, 0xd1, 0xa8, 0xb2, 0x99, 0xde, 0x93, 0x20, 0xce, 0x77, 0x5d, 0xb2 }, { 0xd6, 0x76, 0x93, 0x34, 0xe9, 0x0a, 0x0f, 0xaa, 0x02, 0xe2, 0xf9, 0x52, 0x20, 0x8a, 0xca, 0x06, 0x62, 0x13, 0xdb, 0x8d, 0xca, 0x05, 0x0b, 0x52, 0x8a }, { 0x3e, 0xcd, 0xef, 0xcf, 0x57, 0xf1, 0xb5, 0xa7, 0xc1, 0xd2, 0x75, 0xaa, 0xc3, 0x31, 0xcc, 0xd2, 0x25, 0x5c, 0x08, 0x9e, 0x54, 0x44, 0xb1, 0x6a, 0x51 }, { 0x30, 0xb0, 0x6d, 0x11, 0xfe, 0x83, 0xe9, 0xa4, 0x71, 0xb1, 0x20, 0x58, 0x99, 0x06, 0xc0, 0xa8, 0x18, 0xac, 0x3d, 0x9f, 0xf0, 0x3f, 0x62, 0x0f, 0x07 }, { 0x30, 0x86, 0x46, 0x09, 0x34, 0xd7, 0xa7, 0xed, 0x6b, 0x37, 0x98, 0xc1, 0x22, 0xfc, 0x8c, 0x0e, 0x1e, 0xc6, 0xa3, 0xa0, 0x76, 0x05, 0xfc, 0xd3, 0x27 }, { 0x37, 0xcd, 0x1b, 0x9b, 0x77, 0x9c, 0xd4, 0x05, 0x1a, 0xf3, 0x97, 0x54, 0xd9, 0x7b, 0xcb, 0x44, 0x80, 0x5d, 0x8c, 0x72, 0x64, 0x50, 0x63, 0x34, 0x7c }, { 0xea, 0x66, 0x32, 0xf9, 0xd6, 0xd5, 0x52, 0xb4, 0x14, 0xed, 0xe1, 0xa5, 0xd2, 0xa5, 0x54, 0x50, 0x5f, 0x8d, 0x2e, 0x22, 0xff, 0xea, 0x69, 0x2e, 0x53 }, { 0x8c, 0x7b, 0x4e, 0x51, 0xeb, 0x88, 0xaa, 0xe2, 0x71, 0xe2, 0xd1, 0xfb, 0xe4, 0x52, 0x2f, 0xa9, 0xd1, 0x28, 0xdd, 0x4b, 0xc2, 0xe3, 0x6e, 0xfd, 0xc4 }, { 0xc8, 0x65, 0x39, 0x64, 0x2f, 0x08, 0xcc, 0x95, 0x9d, 0x90, 0x6d, 0x85, 0x91, 0x03, 0x21, 0x02, 0x9e, 0x14, 0x84, 0xfe, 0xd4, 0x19, 0xda, 0xea, 0x69 }, { 0xd7, 0x68, 0xba, 0xd0, 0x59, 0xb0, 0xc9, 0x4f, 0xf3, 0xaa, 0x95, 0xe2, 0x74, 0x25, 0x72, 0xbd, 0x44, 0xd7, 0xbf, 0x05, 0xdc, 0x9a, 0x1d, 0x3e, 0x29 }, { 0x9c, 0x42, 0x64, 0x65, 0xcd, 0x3d, 0x94, 0x58, 0xbf, 0x3f, 0x8e, 0x3f, 0xc2, 0x63, 0x6d, 0xdc, 0xbc, 0x7f, 0xb4, 0xb5, 0x74, 0x28, 0xbd, 0x6e, 0xa2 }, { 0xc1, 0x5d, 0x7e, 0x9d, 0x1a, 0xc5, 0x79, 0x27, 0x7f, 0x78, 0xf0, 0xa3, 0xae, 0x8d, 0xd9, 0xd2, 0x9e, 0xd5, 0x5b, 0x90, 0xa9, 0x4e, 0x86, 0x50, 0xd0 }, { 0x55, 0xb1, 0x8c, 0xed, 0x64, 0x08, 0x60, 0xd4, 0x80, 0xf6, 0x30, 0xa6, 0xb7, 0x1f, 0x7f, 0x5a, 0xea, 0x29, 0x26, 0xd5, 0xb4, 0xe4, 0xfb, 0x30, 0x97 }, { 0xb5, 0xb3, 0x38, 0xfd, 0x3d, 0xc8, 0xe5, 0x65, 0xfb, 0x61, 0x2c, 0xd5, 0xae, 0xf6, 0xaf, 0x4a, 0x80, 0x4d, 0x8c, 0xa0, 0x09, 0x0d, 0xe9, 0xb2, 0x0f }, { 0xa3, 0xcf, 0x15, 0x8e, 0x19, 0x01, 0x0a, 0x9b, 0x8d, 0xd8, 0x60, 0x5d, 0x5c, 0xff, 0x1b, 0xe2, 0xc5, 0x02, 0xa1, 0xc0, 0xad, 0x32, 0x55, 0x43, 0xb0 }, { 0xb1, 0x43, 0xb0, 0x59, 0xff, 0x94, 0x5c, 0xc2, 0x8b, 0x3c, 0x1c, 0x32, 0x03, 0xed, 0x7e, 0x7e, 0x7e, 0xbe, 0x33, 0xad, 0x13, 0x45, 0x25, 0x89, 0x63 }, { 0x8a, 0x0b, 0x4f, 0x8d, 0x62, 0x17, 0x43, 0x4b, 0xfb, 0xe5, 0xcf, 0xd8, 0x0c, 0x08, 0xe7, 0x06, 0x6f, 0xe0, 0xc4, 0x7b, 0xaf, 0x6c, 0x2a, 0x3a, 0x7c }, { 0xb3, 0x11, 0xba, 0x6e, 0x52, 0x2f, 0x18, 0xca, 0x1d, 0x13, 0xf1, 0xfd, 0x42, 0x69, 0x18, 0xee, 0x83, 0xef, 0xcf, 0xa8, 0x73, 0x90, 0xef, 0xc4, 0x0e }, { 0xed, 0x47, 0x71, 0x98, 0x47, 0xd7, 0x3e, 0x0e, 0x12, 0x70, 0x7a, 0x27, 0x7e, 0xc4, 0x7a, 0x9c, 0xc8, 0x09, 0x67, 0x91, 0xa8, 0x23, 0x8d, 0xae, 0xbd }, { 0x23, 0xe7, 0x98, 0x73, 0xe3, 0x26, 0x9f, 0x9d, 0xc4, 0x2b, 0x6d, 0x9b, 0x71, 0x20, 0xcf, 0xb1, 0xc9, 0xe4, 0x5a, 0xe8, 0x0e, 0xbe, 0x16, 0x6c, 0xad }, { 0xef, 0xe2, 0x40, 0x78, 0xd3, 0x6a, 0x8c, 0xf1, 0x55, 0xdd, 0x95, 0xbd, 0xd5, 0x32, 0x1c, 0x6a, 0xcb, 0x26, 0xff, 0x60, 0x7b, 0x3b, 0x19, 0xbc, 0xa5 }, { 0x24, 0x5d, 0x25, 0x28, 0xb7, 0xe1, 0x60, 0x8a, 0x18, 0x6f, 0x6e, 0x8d, 0x62, 0x18, 0xee, 0x0b, 0x7a, 0x73, 0xed, 0x97, 0x96, 0x58, 0x24, 0x19, 0xd7 }, { 0x3e, 0xb3, 0x8e, 0x02, 0xe7, 0x03, 0x72, 0xb2, 0xa4, 0x1f, 0x27, 0xc6, 0x8e, 0x4e, 0xdd, 0x7b, 0x8e, 0xa1, 0x96, 0xa1, 0xa3, 0x8b, 0x28, 0x5f, 0xa3 }, { 0x1b, 0xdd, 0xe7, 0x4c, 0xaa, 0xbc, 0x38, 0xb3, 0x73, 0x83, 0xb0, 0x72, 0xd2, 0xae, 0xb4, 0x0c, 0xb2, 0x1f, 0xb2, 0x94, 0x01, 0xf1, 0x10, 0xac, 0x0c }, { 0xec, 0x08, 0xaf, 0xe7, 0xa0, 0xb6, 0x45, 0x03, 0xe0, 0x3a, 0x75, 0x7b, 0xa0, 0xba, 0xa8, 0xcd, 0x28, 0x5c, 0xc3, 0xfe, 0x74, 0xa6, 0x9f, 0x65, 0xa5 }, { 0xea, 0xd2, 0x9b, 0x33, 0x51, 0x9f, 0xa0, 0x10, 0xe1, 0xb4, 0x57, 0xd3, 0xa5, 0x1b, 0x71, 0x45, 0x2f, 0xb4, 0x86, 0xb1, 0xee, 0x37, 0x99, 0x65, 0x3c }, { 0x32, 0x1d, 0x47, 0x47, 0x95, 0x37, 0xf2, 0x38, 0x1f, 0x5d, 0x33, 0xec, 0xe6, 0x6c, 0xd1, 0x73, 0x68, 0xbc, 0xab, 0xc2, 0xea, 0x90, 0xf3, 0xbd, 0x2c }, { 0x34, 0xa0, 0x2a, 0xe1, 0x9d, 0xd3, 0x9e, 0x76, 0xda, 0x25, 0x6d, 0x32, 0x70, 0xaa, 0xa2, 0x57, 0x25, 0xc7, 0x46, 0x11, 0x3b, 0xb2, 0xe5, 0xd9, 0xc4 }, { 0x0a, 0x6a, 0xaf, 0xd3, 0x37, 0x50, 0x14, 0x4f, 0x38, 0x8b, 0xc7, 0x7c, 0xcd, 0xfa, 0x40, 0xc9, 0x47, 0x11, 0x7c, 0x3a, 0x7e, 0x1f, 0xed, 0x53, 0xbf }, { 0xce, 0xd7, 0x2e, 0x95, 0x6b, 0xa6, 0x9f, 0xfa, 0x14, 0x4b, 0xf8, 0x1a, 0x2a, 0x99, 0x46, 0x2f, 0x3d, 0x47, 0x4f, 0x62, 0xcc, 0x46, 0xa9, 0xf1, 0xdd }, { 0x65, 0x99, 0x15, 0xe3, 0x42, 0x74, 0xff, 0x7f, 0x72, 0xc9, 0xfe, 0x55, 0xc3, 0xfa, 0x4e, 0xa5, 0x5c, 0xb9, 0xa0, 0x21, 0xff, 0xcc, 0x9f, 0x13, 0x67 }, { 0xa3, 0xa0, 0x63, 0x80, 0x05, 0x6b, 0x3f, 0x15, 0x58, 0x92, 0xfb, 0x01, 0x03, 0xaa, 0xc6, 0x66, 0xea, 0x19, 0x20, 0x5f, 0xa3, 0xfa, 0xe9, 0x4f, 0x78 }, { 0x40, 0xd9, 0xf9, 0xdc, 0x7a, 0xc2, 0x26, 0x24, 0xc0, 0xa4, 0x50, 0xd2, 0x76, 0x89, 0x8f, 0x62, 0x2e, 0xbd, 0x05, 0x86, 0xec, 0x2c, 0x48, 0x37, 0x2b }, { 0x9b, 0xe5, 0xb4, 0x9d, 0x8e, 0x8b, 0x87, 0x40, 0x16, 0x90, 0xd2, 0x40, 0x47, 0x97, 0xf0, 0x58, 0x4d, 0xe8, 0x88, 0xd0, 0x2b, 0x1f, 0x90, 0xd6, 0x1d }, { 0xcb, 0x83, 0x3d, 0x27, 0xf1, 0xbc, 0xe1, 0xa6, 0x55, 0x4b, 0x15, 0xdf, 0xa0, 0xae, 0x87, 0x40, 0x2f, 0x5d, 0x9d, 0x2e, 0x0c, 0x52, 0x18, 0xc1, 0xcd }, { 0x95, 0x46, 0x84, 0xc0, 0xb4, 0x7d, 0xe9, 0x8b, 0xd2, 0xbd, 0xae, 0xad, 0x68, 0x0a, 0x36, 0x81, 0x57, 0x94, 0xd7, 0xac, 0x6d, 0x1e, 0xde, 0x17, 0xc7 }, { 0x6f, 0x8c, 0xb3, 0x80, 0x86, 0x32, 0x21, 0x61, 0xf6, 0x4a, 0x2c, 0xa4, 0x94, 0x73, 0x8b, 0xbc, 0x0c, 0x89, 0xc8, 0xb7, 0x0c, 0x4f, 0x53, 0x25, 0xc1 }, { 0x57, 0xb9, 0x22, 0x4a, 0x61, 0xe6, 0x90, 0x4e, 0x5b, 0x4e, 0xb0, 0xf9, 0x81, 0x83, 0xe6, 0x0e, 0xc4, 0x66, 0x8b, 0xd5, 0xe5, 0x35, 0x6b, 0x73, 0xa1 }, { 0xea, 0xd6, 0xb8, 0x9e, 0x0d, 0x2d, 0x9f, 0xbb, 0xf6, 0x64, 0x92, 0x4b, 0x82, 0xe8, 0x72, 0xf2, 0x28, 0x6d, 0x5f, 0x34, 0x9b, 0x83, 0xc3, 0x39, 0x9f }, { 0xc9, 0x5d, 0xbd, 0xf3, 0xba, 0x97, 0xd3, 0xc2, 0xa5, 0x95, 0xc5, 0xd6, 0xeb, 0x5f, 0xcc, 0xa1, 0x02, 0x15, 0xc6, 0xb7, 0x8d, 0xde, 0x68, 0xda, 0xe9 }, { 0x0f, 0x88, 0xaf, 0x95, 0x2d, 0x2e, 0x50, 0x75, 0xba, 0xeb, 0x06, 0xd1, 0x15, 0x13, 0x1b, 0x19, 0x0d, 0xce, 0xc3, 0x8b, 0x98, 0x75, 0xf4, 0x6b, 0x32 }, { 0xe2, 0x58, 0xfc, 0x02, 0x79, 0x68, 0x7f, 0x49, 0xe4, 0x73, 0xca, 0xa1, 0x39, 0xc8, 0x8e, 0x4d, 0xd1, 0x36, 0xce, 0x4c, 0xc1, 0x37, 0x81, 0xa4, 0xee }, { 0x56, 0xfe, 0x0a, 0x99, 0x86, 0x75, 0xcc, 0x6e, 0x91, 0xb0, 0x9e, 0x07, 0xc9, 0x4d, 0x56, 0x78, 0x19, 0x65, 0x7d, 0x9c, 0x7b, 0x01, 0xb4, 0x0d, 0x16 }, { 0xbe, 0xba, 0xbb, 0x62, 0x6e, 0x38, 0x70, 0x06, 0x51, 0xf1, 0xf6, 0x52, 0xdb, 0x7f, 0x35, 0x53, 0xb0, 0xb7, 0x6c, 0xd4, 0x5a, 0xa8, 0xdb, 0xec, 0x28 }, { 0x03, 0xc3, 0xc3, 0x04, 0xf0, 0x9d, 0xcc, 0x39, 0x72, 0x15, 0xae, 0x2e, 0x0b, 0xf1, 0x90, 0x0e, 0x6b, 0xb0, 0x88, 0xa8, 0xd1, 0x57, 0xe3, 0x74, 0x78 }, { 0xec, 0x97, 0x5d, 0xb7, 0x3e, 0x5c, 0x47, 0x90, 0x4e, 0x8c, 0x37, 0x18, 0x6f, 0x69, 0x17, 0x1e, 0x2f, 0xf8, 0x7b, 0x17, 0x6c, 0x95, 0x63, 0x3d, 0x7e }, { 0xf0, 0xec, 0xbc, 0x77, 0x4e, 0x76, 0x9d, 0x3a, 0x35, 0x02, 0x1a, 0x3b, 0x8b, 0x6f, 0x62, 0x31, 0xa7, 0xc2, 0x13, 0x90, 0xfa, 0x95, 0x3d, 0xc8, 0x20 }, { 0x74, 0x07, 0x35, 0xa8, 0x17, 0x31, 0x6c, 0x7f, 0x02, 0x11, 0xd3, 0x1d, 0xc2, 0xe0, 0x66, 0x8a, 0x4f, 0xa4, 0xe5, 0xca, 0xd1, 0x0d, 0x5a, 0xb0, 0xfc }, { 0x67, 0xd9, 0x83, 0xa4, 0xd6, 0x99, 0xbd, 0x58, 0x2c, 0xe0, 0x60, 0xb9, 0x80, 0x62, 0xd8, 0x6b, 0xc0, 0xf8, 0x66, 0x72, 0x17, 0x55, 0x79, 0x04, 0x8f }, { 0x14, 0x44, 0x53, 0x34, 0x8f, 0xd8, 0x94, 0xd8, 0xd9, 0x19, 0x83, 0x2f, 0xb1, 0x8e, 0x6e, 0xc5, 0xcf, 0xd6, 0x7a, 0xff, 0xfd, 0x24, 0x9c, 0xc2, 0x12 }, { 0x21, 0xd5, 0xab, 0x2f, 0x2b, 0x33, 0x24, 0x2f, 0x25, 0xdd, 0x4f, 0xba, 0x01, 0x67, 0x7f, 0xa1, 0xfd, 0xc0, 0x80, 0x77, 0x3b, 0xcc, 0x17, 0xa5, 0x44 }, { 0x04, 0xef, 0x8b, 0xf5, 0x56, 0xa2, 0xc0, 0x80, 0x3e, 0x2e, 0x35, 0xe3, 0xe8, 0xdb, 0x03, 0x4f, 0x3a, 0xcc, 0xf3, 0xe3, 0x41, 0x2b, 0xbf, 0xdf, 0xa6 }, { 0xdf, 0x0a, 0x8a, 0x6f, 0x98, 0xdd, 0x44, 0xb2, 0x53, 0x49, 0x10, 0x79, 0x7f, 0xeb, 0x97, 0x45, 0xe1, 0xd1, 0xae, 0x7b, 0xc7, 0xe6, 0xcb, 0x1e, 0x72 }, { 0xd1, 0x66, 0x39, 0xeb, 0x84, 0x43, 0x30, 0xa0, 0xa6, 0xed, 0x57, 0x3e, 0xb7, 0xd6, 0x1f, 0x00, 0xdb, 0x66, 0xb1, 0xe1, 0x46, 0x11, 0x73, 0x84, 0xea }, { 0x2a, 0x67, 0x60, 0x85, 0x47, 0xb9, 0xd9, 0xd9, 0x03, 0xb2, 0xd7, 0xcb, 0x2b, 0x6c, 0x65, 0x48, 0x58, 0xe8, 0x1a, 0xab, 0x2b, 0x1d, 0x9a, 0x72, 0xaa }, { 0x13, 0x54, 0x02, 0x85, 0x77, 0x76, 0xb8, 0x1a, 0x0d, 0x1e, 0xff, 0x89, 0x1d, 0x58, 0x3b, 0x92, 0x27, 0x6a, 0x9a, 0xbe, 0x7c, 0x51, 0xfa, 0x3f, 0x0a }, { 0xd6, 0x3c, 0xbd, 0x68, 0x96, 0xae, 0x1a, 0x9d, 0xee, 0x4c, 0x93, 0xa2, 0x83, 0x1b, 0xeb, 0x71, 0xbe, 0xec, 0x5b, 0x37, 0xb0, 0x83, 0xb8, 0x0e, 0x56 }, { 0x91, 0x93, 0xa9, 0x21, 0xae, 0x6e, 0x83, 0x0d, 0x9c, 0xe7, 0x21, 0xe9, 0x1d, 0x20, 0xed, 0x23, 0x6e, 0x78, 0x09, 0xfa, 0x09, 0x64, 0x0c, 0xb0, 0xfb }, { 0x6f, 0xab, 0x95, 0x91, 0xcd, 0x07, 0x47, 0x2b, 0x81, 0xf2, 0xd9, 0x06, 0x06, 0x8d, 0xa0, 0x71, 0x89, 0xc9, 0x77, 0xdb, 0x6e, 0x09, 0x23, 0x1c, 0x0c }, { 0xb5, 0x2b, 0x14, 0x48, 0xbc, 0xf6, 0xd0, 0x13, 0xcc, 0x28, 0xc4, 0x91, 0xe4, 0xd3, 0x78, 0x07, 0xff, 0x8e, 0x88, 0x25, 0xe1, 0xf5, 0xff, 0xde, 0xc6 }, { 0x94, 0x97, 0x15, 0x3d, 0x73, 0x7a, 0xba, 0xf2, 0xaa, 0x1c, 0xe7, 0xbb, 0xf5, 0x91, 0xff, 0x5a, 0x76, 0x4c, 0xdf, 0x95, 0xe6, 0xbe, 0x9f, 0x28, 0x38 }, { 0x6b, 0xb7, 0x4f, 0xaf, 0x0b, 0x17, 0x83, 0x3a, 0x3a, 0x1a, 0x95, 0xf6, 0x73, 0x67, 0x5e, 0x23, 0x0c, 0x51, 0x8d, 0xfa, 0x26, 0xfd, 0x98, 0xa5, 0x2a }, { 0x84, 0xbb, 0x8d, 0x17, 0x72, 0xe9, 0x3f, 0x00, 0xe8, 0x0d, 0xf5, 0xb2, 0x0e, 0x5d, 0x1a, 0x56, 0x02, 0xab, 0x9b, 0x00, 0x1b, 0xad, 0xec, 0x7b, 0x4a }, { 0x9e, 0x12, 0xe6, 0xb7, 0x0d, 0x6a, 0xa1, 0x68, 0x72, 0x88, 0xa6, 0xe4, 0x9c, 0xd8, 0xb6, 0xd8, 0x61, 0xdb, 0xa0, 0x40, 0x0e, 0x05, 0xaa, 0xf7, 0x52 }, { 0x37, 0x5f, 0xbc, 0xb5, 0xa0, 0x46, 0x65, 0x5e, 0x2e, 0xed, 0xfa, 0x4f, 0x17, 0x7a, 0x0c, 0xd8, 0xce, 0x3a, 0x7f, 0x62, 0xc8, 0x1c, 0x08, 0x51, 0x88 }, { 0x6b, 0x4d, 0x11, 0x42, 0x67, 0x9b, 0x32, 0x1c, 0x02, 0x65, 0x21, 0x5b, 0xce, 0xd8, 0x9e, 0x8c, 0xd9, 0xff, 0x1c, 0x73, 0x21, 0x44, 0x75, 0x94, 0xf1 }, { 0xdd, 0x21, 0x21, 0x43, 0x56, 0x9f, 0x1c, 0x9d, 0x80, 0x02, 0x22, 0x4b, 0xf0, 0x14, 0x9f, 0x33, 0x90, 0x8f, 0xd1, 0xf7, 0x11, 0xfa, 0xa7, 0x7d, 0x38 }, { 0x8e, 0x81, 0x21, 0x8f, 0x00, 0x69, 0xe1, 0x00, 0x2e, 0x21, 0x8f, 0xee, 0x9b, 0x95, 0x30, 0xb1, 0xc2, 0x29, 0x23, 0x3d, 0xe6, 0x61, 0xaa, 0xa2, 0x8e }, { 0xa1, 0x1f, 0x8f, 0xd6, 0xa5, 0x71, 0xed, 0x60, 0x1f, 0xbd, 0x52, 0x43, 0x9a, 0x72, 0x7d, 0x47, 0x62, 0x66, 0x77, 0x6b, 0xc8, 0x53, 0xa3, 0xd7, 0xfa }, { 0x52, 0x0f, 0x01, 0xb9, 0xd8, 0x28, 0x5b, 0xe1, 0xf9, 0x56, 0xdf, 0x7b, 0x76, 0x5d, 0x1c, 0x60, 0x1c, 0x2d, 0xfd, 0x0d, 0x7a, 0x19, 0xf5, 0x0f, 0xec }, { 0x50, 0x36, 0x02, 0x49, 0x90, 0xb5, 0x8e, 0x01, 0x7a, 0x25, 0x61, 0xf1, 0x26, 0xc1, 0x43, 0xec, 0xfe, 0xf3, 0x43, 0xeb, 0x6b, 0x1f, 0x3f, 0x33, 0x3d }, { 0x2b, 0xa0, 0x7a, 0xaf, 0x5b, 0xe5, 0x55, 0x0e, 0xd7, 0xb4, 0x4e, 0x28, 0x07, 0x04, 0x14, 0xf1, 0x54, 0xaa, 0xf3, 0x0e, 0xc8, 0x90, 0x4e, 0x82, 0x52 }, { 0x57, 0x09, 0xfb, 0xb5, 0x09, 0xac, 0x67, 0x76, 0x79, 0x74, 0x23, 0xbc, 0x64, 0xf3, 0x01, 0x40, 0xd5, 0x7d, 0xa9, 0xf5, 0xde, 0xca, 0xed, 0xe0, 0x8f }, { 0xdc, 0x79, 0xb0, 0x9e, 0xde, 0xaa, 0x45, 0xff, 0x81, 0x39, 0x53, 0xaf, 0x1b, 0x00, 0x61, 0x51, 0x24, 0xca, 0x66, 0x0a, 0xbf, 0x00, 0xfc, 0x92, 0xdc }, { 0x8d, 0x1a, 0x41, 0x99, 0xa2, 0x97, 0x14, 0x81, 0xed, 0x29, 0x3b, 0x98, 0x43, 0xf0, 0x71, 0x4b, 0x5e, 0x67, 0x01, 0x46, 0x18, 0x8c, 0x1c, 0x65, 0x06 }, { 0x82, 0x33, 0x1c, 0xf0, 0x5a, 0x8e, 0xb9, 0x91, 0x2d, 0x44, 0x72, 0x3c, 0x8d, 0xda, 0x59, 0x5a, 0x2f, 0xa2, 0x70, 0x6c, 0x10, 0xe8, 0x13, 0x79, 0xe4 }, { 0xd4, 0xa6, 0x30, 0x9e, 0x57, 0x49, 0xeb, 0x50, 0x6f, 0x25, 0xb5, 0x7c, 0xc3, 0x13, 0xab, 0x50, 0xdc, 0x37, 0x3f, 0xe7, 0x09, 0xef, 0x44, 0x11, 0x4c }, { 0x7c, 0x92, 0x8f, 0x21, 0x0f, 0x98, 0x31, 0x25, 0xee, 0x6c, 0xb1, 0x21, 0x7b, 0x6e, 0x55, 0x64, 0x3a, 0x32, 0x63, 0x23, 0x4c, 0x21, 0x92, 0xfe, 0x5f }, { 0xc2, 0x01, 0x1f, 0x95, 0x9c, 0x7e, 0x80, 0x9c, 0x89, 0x76, 0xdb, 0x6b, 0xa7, 0x83, 0x03, 0x4b, 0xbb, 0x2a, 0xd1, 0x58, 0x97, 0x30, 0xff, 0x0a, 0x1e }, { 0xa6, 0xb9, 0xbe, 0x98, 0xf5, 0xe1, 0xfe, 0x54, 0x59, 0xe2, 0x39, 0x47, 0x4d, 0xc4, 0x1b, 0x34, 0xa3, 0xdc, 0xcc, 0x38, 0x95, 0xce, 0x11, 0x21, 0xd3 }, { 0x5f, 0x5a, 0x7a, 0x30, 0xcf, 0x1d, 0xa7, 0xe9, 0x79, 0xd0, 0x06, 0xd7, 0x68, 0x90, 0xdd, 0xb9, 0x75, 0xae, 0x17, 0x17, 0x41, 0xb9, 0x03, 0xba, 0x88 }, { 0xd6, 0x5a, 0x3c, 0xbb, 0xbc, 0x2a, 0x42, 0xf1, 0x40, 0xe4, 0x6c, 0xf4, 0x01, 0x1c, 0x4e, 0x68, 0x6b, 0xe6, 0xf4, 0xa9, 0x80, 0x4e, 0x9f, 0x63, 0x1b }, { 0x45, 0xe1, 0xdd, 0xae, 0x35, 0xc6, 0x7c, 0x99, 0xb8, 0x25, 0x18, 0xbc, 0xf7, 0xe6, 0xb3, 0xd1, 0xcf, 0x5f, 0x30, 0xe4, 0x8c, 0x30, 0x91, 0x04, 0xcd }, { 0xb8, 0x2c, 0x5c, 0x5a, 0x21, 0x60, 0xea, 0xec, 0x98, 0x9a, 0xe7, 0x02, 0x66, 0xb9, 0xe3, 0x46, 0xcd, 0x9d, 0xaa, 0x95, 0xde, 0x12, 0x77, 0x88, 0xa1 }, { 0x2b, 0xe8, 0xb0, 0xc0, 0xfa, 0xeb, 0x45, 0xad, 0x38, 0xc9, 0x0b, 0x4b, 0xf7, 0x03, 0x90, 0x3b, 0x01, 0x5a, 0x87, 0xec, 0x65, 0x24, 0x81, 0x9d, 0xeb }, { 0x6b, 0x50, 0xdb, 0x3d, 0x29, 0x4c, 0x3f, 0x4a, 0xba, 0x33, 0x59, 0x42, 0xa0, 0x23, 0x40, 0xc7, 0xf6, 0x1e, 0xa4, 0xfe, 0x67, 0x0e, 0x3f, 0x0b, 0xa2 } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t cipher_texts4_128bit[ 100 ][ 32 ] = { { 0x3c, 0x21, 0x49, 0x04, 0x07, 0x2f, 0xc4, 0xac, 0x45, 0xa2, 0x24, 0x53, 0x41, 0xf7, 0x8b, 0x78, 0x73, 0xf0, 0x5d, 0x32, 0x55, 0xd3, 0x40, 0x11, 0x5a, 0x92, 0x0d, 0x0b, 0xf2, 0xab, 0xf6, 0x71 }, { 0xd9, 0x6b, 0xdb, 0xbf, 0xdc, 0xe8, 0xd8, 0x98, 0xd5, 0x10, 0x81, 0xc4, 0x6d, 0x95, 0x78, 0xe2, 0x9b, 0x3f, 0x59, 0x87, 0x57, 0xe8, 0x3c, 0xec, 0x92, 0xab, 0x92, 0x1a, 0x41, 0xe4, 0x59, 0xef }, { 0xa1, 0xe2, 0xd8, 0xbc, 0x5a, 0x24, 0x73, 0x6f, 0xd7, 0x1b, 0x62, 0x4e, 0x7c, 0xde, 0xb9, 0xaf, 0xa9, 0x2e, 0x60, 0x44, 0x92, 0x35, 0x40, 0xde, 0xeb, 0x17, 0xb6, 0xc6, 0x81, 0x29, 0x9e, 0xfa }, { 0x2b, 0xed, 0x1e, 0xbb, 0x1c, 0x0e, 0x66, 0x5f, 0xcd, 0x05, 0x07, 0x39, 0x39, 0x0c, 0x71, 0xfb, 0x6b, 0x99, 0xc0, 0x00, 0xcc, 0x97, 0x78, 0x0b, 0xda, 0x64, 0xe1, 0x2f, 0x5d, 0xe5, 0xe1, 0xf5 }, { 0x03, 0x05, 0xe8, 0x09, 0xed, 0xba, 0x6c, 0x0e, 0xd9, 0x99, 0x87, 0xc9, 0xb5, 0xf4, 0x6a, 0x96, 0x59, 0xfb, 0x7e, 0xdb, 0x95, 0x8c, 0xa0, 0xec, 0x2b, 0xc9, 0x2f, 0x0b, 0xf4, 0xa5, 0xea, 0x76 }, { 0x46, 0x46, 0xde, 0x2e, 0xc0, 0x5b, 0x00, 0xe5, 0x42, 0xbb, 0x00, 0x49, 0x9e, 0xab, 0x1c, 0x7c, 0x00, 0x2e, 0xaf, 0xe9, 0x9a, 0x18, 0x02, 0xec, 0x89, 0xee, 0xa6, 0x73, 0xbd, 0xe9, 0x7f, 0xd0 }, { 0x8c, 0x79, 0xd7, 0xed, 0xf7, 0x8b, 0xc9, 0x4d, 0x15, 0xfb, 0x51, 0x4e, 0x48, 0xc2, 0x8d, 0x4b, 0xfa, 0xc0, 0xc6, 0x4c, 0xc1, 0xda, 0x7e, 0x09, 0xee, 0x87, 0xb3, 0x4e, 0x83, 0xb3, 0x6d, 0xa5 }, { 0xe1, 0x98, 0x77, 0xfa, 0x2b, 0xfd, 0x08, 0x58, 0x9d, 0x2f, 0x23, 0xf5, 0xd6, 0x5a, 0xf5, 0x67, 0x49, 0x99, 0x0d, 0x5d, 0x90, 0x8e, 0xa0, 0xf9, 0x29, 0x1f, 0x4c, 0x40, 0x62, 0x93, 0x26, 0xed }, { 0xd0, 0x31, 0x15, 0x99, 0x66, 0x17, 0xd3, 0x36, 0xf2, 0x2b, 0xfc, 0xd2, 0xa6, 0xbc, 0x99, 0x6e, 0x17, 0x60, 0x34, 0x90, 0x22, 0xb9, 0x3e, 0x5f, 0x50, 0x3e, 0x21, 0x90, 0x1f, 0x99, 0xe9, 0xf5 }, { 0x6d, 0xc4, 0xf1, 0x43, 0xed, 0x48, 0xd3, 0x97, 0x77, 0xe4, 0x96, 0x01, 0x94, 0xa4, 0x25, 0x1d, 0xc1, 0xf5, 0x00, 0x80, 0xa8, 0x8f, 0x33, 0x9e, 0xda, 0x36, 0xa8, 0x40, 0x26, 0x9a, 0x4d, 0x2a }, { 0x4c, 0x6c, 0x48, 0x42, 0x07, 0x92, 0x2c, 0xdb, 0x46, 0x09, 0x34, 0x77, 0x77, 0x62, 0xad, 0x0a, 0xe9, 0xb1, 0x19, 0xba, 0xba, 0x71, 0x1a, 0x66, 0x87, 0xfc, 0xc8, 0x82, 0x8d, 0x20, 0x32, 0xef }, { 0xfb, 0x0d, 0x27, 0xad, 0xd7, 0x00, 0x9d, 0xb0, 0x6d, 0xb5, 0x57, 0xc8, 0x57, 0x10, 0x09, 0x1e, 0xd8, 0xe3, 0xcf, 0xe5, 0xbe, 0x41, 0x8b, 0xe0, 0x61, 0x36, 0x26, 0xb9, 0x50, 0x11, 0x47, 0x55 }, { 0xba, 0xdf, 0x40, 0x8b, 0xc9, 0xa6, 0xc2, 0xd4, 0x3a, 0x5d, 0xbf, 0xd6, 0x41, 0xc2, 0x24, 0x96, 0x5b, 0xfd, 0x56, 0x0e, 0xac, 0x91, 0x72, 0x91, 0x97, 0xb7, 0x20, 0x54, 0x80, 0x06, 0x74, 0x1c }, { 0x8b, 0x6a, 0x27, 0x67, 0xa2, 0xd4, 0x76, 0x12, 0x2c, 0xac, 0x5b, 0xfd, 0xcf, 0xf0, 0x44, 0xf3, 0x16, 0xeb, 0x2e, 0x1c, 0xcb, 0x02, 0x66, 0xf5, 0x96, 0xb9, 0x94, 0x79, 0x3c, 0x8c, 0x65, 0x32 }, { 0x19, 0x1f, 0xf1, 0x78, 0xe8, 0x21, 0x7e, 0xf1, 0x1d, 0x24, 0x57, 0x95, 0xe4, 0x48, 0xdb, 0x51, 0x68, 0xf2, 0xe9, 0xdb, 0x18, 0x4c, 0xbe, 0x09, 0x83, 0xcf, 0x06, 0x6c, 0x40, 0x8f, 0x2c, 0x8e }, { 0x0c, 0x40, 0xb0, 0xb4, 0xe5, 0x33, 0x7f, 0x8c, 0x6f, 0xed, 0x30, 0x2f, 0x05, 0x18, 0x28, 0xa3, 0x53, 0x11, 0xb6, 0x58, 0x02, 0xbe, 0x92, 0x0e, 0xfa, 0x46, 0x8a, 0x59, 0x8e, 0x18, 0x17, 0x5d }, { 0x30, 0xee, 0x20, 0x84, 0xaa, 0xda, 0xfe, 0xd9, 0x74, 0xda, 0xda, 0x9b, 0x39, 0x57, 0x78, 0xc4, 0x07, 0xef, 0xd9, 0x90, 0x2c, 0x4c, 0x30, 0xbc, 0x95, 0xe2, 0x86, 0xae, 0x30, 0xea, 0x28, 0x66 }, { 0x07, 0x00, 0xf9, 0x06, 0x2e, 0xce, 0x9f, 0xc6, 0xfe, 0x38, 0xe4, 0x46, 0x3f, 0x24, 0x8a, 0x41, 0x30, 0xa1, 0x29, 0x21, 0x94, 0x80, 0xf9, 0xca, 0xaf, 0x4e, 0x5a, 0xc0, 0x8f, 0xd4, 0x7e, 0x8f }, { 0xe5, 0xc8, 0xb5, 0xc9, 0x9a, 0x39, 0x4c, 0x5f, 0xa9, 0x4d, 0x3b, 0xc3, 0xfb, 0x9b, 0x34, 0xe3, 0x3a, 0x95, 0xe1, 0x49, 0x4a, 0x59, 0xf8, 0x2a, 0xf7, 0xf3, 0xdc, 0xaf, 0x8b, 0xe2, 0x69, 0x03 }, { 0x6a, 0xb0, 0x0f, 0x3f, 0x79, 0x57, 0x7c, 0x1d, 0xa7, 0xa7, 0x66, 0xe0, 0xe5, 0x96, 0x52, 0x09, 0x51, 0x8a, 0xde, 0x87, 0x13, 0x0e, 0x28, 0x8c, 0x78, 0x99, 0xf6, 0x00, 0x3c, 0x8e, 0x25, 0xe0 }, { 0x4b, 0xaa, 0xe5, 0xa5, 0x19, 0x4e, 0xa7, 0xb0, 0x00, 0xbe, 0x20, 0x94, 0x3b, 0x08, 0xe8, 0xa4, 0x32, 0x74, 0xc6, 0x47, 0x62, 0xf4, 0x86, 0x05, 0x3b, 0x93, 0xfd, 0x2d, 0x53, 0x59, 0x59, 0x61 }, { 0x56, 0xf7, 0x5a, 0x34, 0x0c, 0xad, 0x8b, 0x53, 0xda, 0xbd, 0xb5, 0xcf, 0xaf, 0x94, 0xd7, 0x83, 0xfa, 0xbc, 0xa1, 0x91, 0x5c, 0x97, 0x20, 0x8c, 0x6a, 0xe0, 0x5c, 0xe5, 0xa1, 0xbe, 0x1c, 0xf9 }, { 0xf1, 0x81, 0x89, 0x75, 0xf8, 0x1e, 0xfc, 0xc3, 0x0a, 0xf5, 0x8f, 0xbe, 0x01, 0xc2, 0x28, 0x3c, 0x2f, 0xb8, 0x36, 0xf4, 0x1e, 0x9d, 0xb5, 0xdc, 0x66, 0x95, 0xc0, 0x9c, 0xbd, 0x43, 0xdc, 0x01 }, { 0x51, 0x0f, 0xc8, 0xbf, 0x09, 0x43, 0xa1, 0xe7, 0x09, 0x69, 0xa0, 0x4e, 0xda, 0x28, 0x8e, 0xf9, 0xfc, 0xdb, 0x2a, 0x4b, 0x86, 0x7e, 0xf4, 0x22, 0x31, 0xe4, 0xf5, 0xda, 0xc2, 0x7a, 0xcb, 0x68 }, { 0x78, 0x65, 0x38, 0xd1, 0x7c, 0x9f, 0x31, 0xc6, 0x54, 0xe2, 0x00, 0x93, 0xa9, 0x44, 0xe2, 0xe7, 0x28, 0x5d, 0x58, 0x3c, 0x56, 0x3c, 0x39, 0x88, 0xe9, 0xa4, 0xcc, 0xe3, 0x9b, 0x18, 0xff, 0x50 }, { 0x8c, 0x37, 0x7b, 0x5c, 0xdb, 0x03, 0xb6, 0xf4, 0x22, 0xfa, 0x76, 0x1d, 0xd2, 0xe2, 0x1c, 0x69, 0x4a, 0xe7, 0x7d, 0x53, 0x6e, 0xd9, 0x5d, 0x35, 0x46, 0xda, 0x9b, 0x13, 0xbf, 0xac, 0xb1, 0x4e }, { 0x9e, 0x55, 0x11, 0x21, 0x99, 0x1f, 0x1c, 0x22, 0xf8, 0x16, 0x89, 0xbf, 0x42, 0x69, 0xfd, 0x97, 0xce, 0x5b, 0xce, 0xe7, 0xbd, 0x45, 0x7b, 0x9a, 0x74, 0x45, 0xae, 0x51, 0x73, 0xa0, 0x78, 0x4c }, { 0x16, 0x64, 0xe8, 0xe2, 0xb9, 0xf1, 0xc2, 0xbf, 0x86, 0x98, 0x7a, 0xae, 0xe4, 0xb3, 0xc3, 0x7a, 0xa4, 0xbb, 0x24, 0x54, 0x24, 0x12, 0x40, 0xa5, 0x80, 0x8d, 0x45, 0x9c, 0x34, 0x2e, 0x5e, 0x67 }, { 0xa0, 0xb3, 0xed, 0xcf, 0xd2, 0xbc, 0x4b, 0x6d, 0xe6, 0x55, 0x32, 0x93, 0x45, 0x29, 0xd8, 0x15, 0xf7, 0xce, 0xad, 0xdc, 0xb4, 0x64, 0x7f, 0x06, 0x69, 0xac, 0x0f, 0x93, 0xea, 0xab, 0xa4, 0xe1 }, { 0xa0, 0xc5, 0x4e, 0xba, 0xd2, 0x78, 0xee, 0x52, 0x29, 0xbc, 0xf9, 0x97, 0x26, 0x15, 0x89, 0xef, 0xd7, 0x72, 0x2b, 0xdf, 0xd8, 0x9d, 0xeb, 0x03, 0x1c, 0x11, 0x54, 0xe6, 0x50, 0xee, 0xd0, 0x6c }, { 0xe6, 0x07, 0xcd, 0x33, 0x36, 0x9b, 0xbf, 0x87, 0x48, 0xa6, 0xa6, 0xfa, 0x93, 0x59, 0xe4, 0x87, 0xe4, 0x16, 0x09, 0x50, 0x45, 0xce, 0x2c, 0xbc, 0xce, 0x46, 0xbb, 0xed, 0xa6, 0x4c, 0xf1, 0xd6 }, { 0x1f, 0x92, 0x49, 0x68, 0xc0, 0x02, 0x07, 0x93, 0xe5, 0x57, 0x8d, 0x71, 0xb0, 0x76, 0x3c, 0x7e, 0x46, 0x93, 0xd5, 0x64, 0x8e, 0x91, 0x92, 0xaa, 0x21, 0x05, 0x12, 0x47, 0xa9, 0xdf, 0x71, 0x3d }, { 0x2d, 0x86, 0x57, 0x2c, 0xfb, 0x63, 0xcb, 0x0c, 0x7e, 0x38, 0xe0, 0x31, 0x5a, 0x71, 0x59, 0xd8, 0x98, 0x54, 0x2b, 0x7c, 0x35, 0xd2, 0x09, 0xc2, 0xb7, 0x63, 0xc0, 0xf4, 0x57, 0x7a, 0x85, 0xa4 }, { 0xa5, 0xcd, 0x1f, 0xbc, 0x64, 0x56, 0x09, 0x54, 0x1c, 0x77, 0x7e, 0xab, 0xdb, 0x14, 0x25, 0xb6, 0x43, 0xe2, 0xac, 0xbe, 0xd1, 0x2f, 0x7e, 0x04, 0xdd, 0x17, 0x87, 0x65, 0xc9, 0x6a, 0x8f, 0xe5 }, { 0x38, 0x64, 0x33, 0x98, 0x09, 0x3d, 0x79, 0x79, 0xb7, 0x20, 0x21, 0x00, 0x4e, 0x94, 0xeb, 0x92, 0x8a, 0xa8, 0x29, 0x15, 0xf0, 0x52, 0xc5, 0xdc, 0x44, 0xd0, 0x22, 0xf4, 0x98, 0x2b, 0xa0, 0x59 }, { 0x91, 0x62, 0xa2, 0x10, 0x9d, 0xe3, 0xb6, 0xcc, 0x07, 0xef, 0x8c, 0xa7, 0x51, 0x29, 0xb4, 0x66, 0x03, 0x1b, 0x45, 0xd4, 0xb6, 0x47, 0x6b, 0x79, 0x45, 0xfa, 0x11, 0x29, 0x33, 0x9e, 0xca, 0xb5 }, { 0xd0, 0x46, 0x6e, 0x1d, 0xa9, 0x46, 0x51, 0x5e, 0x65, 0x72, 0xc3, 0x35, 0x9b, 0x2f, 0x0a, 0xa9, 0x94, 0x21, 0x3d, 0xb1, 0xc8, 0x78, 0xa4, 0x82, 0x8e, 0x08, 0xa8, 0x8f, 0x4b, 0x18, 0xaf, 0xaf }, { 0x3d, 0x05, 0x5f, 0x21, 0xe3, 0xb3, 0x63, 0xf7, 0x70, 0xe9, 0x51, 0x4b, 0x9b, 0xbe, 0x4f, 0xb5, 0x2a, 0x4c, 0x96, 0x32, 0x19, 0xdc, 0x70, 0x33, 0x3b, 0x24, 0x09, 0x6c, 0x6d, 0x46, 0x43, 0x95 }, { 0x11, 0x12, 0xb6, 0x9e, 0x11, 0x86, 0x32, 0xf3, 0x48, 0x70, 0x26, 0x5f, 0xec, 0xef, 0xa0, 0xb7, 0xee, 0x0e, 0xec, 0x2b, 0x65, 0x51, 0xff, 0xd3, 0x6a, 0x8e, 0xde, 0x26, 0x9c, 0x1c, 0x2a, 0xb7 }, { 0xde, 0x0e, 0x7d, 0xf7, 0xee, 0x6a, 0xb1, 0xf1, 0xf4, 0x70, 0x8c, 0x9a, 0x7f, 0x17, 0x95, 0x10, 0x15, 0x7c, 0xa6, 0x20, 0x63, 0x1e, 0x76, 0x2b, 0xa6, 0x9c, 0xbd, 0xfb, 0xf3, 0x50, 0x9a, 0xed }, { 0x65, 0x2c, 0x40, 0x27, 0x3b, 0x2f, 0xb4, 0xf5, 0xeb, 0x86, 0x81, 0xfc, 0xe6, 0xff, 0x79, 0x59, 0x06, 0x7e, 0xb9, 0xd3, 0xbf, 0x7a, 0x16, 0x71, 0x07, 0x2c, 0x21, 0xc9, 0x52, 0x42, 0x43, 0xd9 }, { 0x22, 0x49, 0x0f, 0x0c, 0x1f, 0x57, 0x82, 0x68, 0x1e, 0x20, 0x96, 0x86, 0x08, 0x2a, 0x22, 0xea, 0x76, 0xdd, 0x5e, 0x13, 0x46, 0x28, 0x5b, 0x56, 0x58, 0xbf, 0xd7, 0x88, 0xc7, 0xee, 0x0f, 0x4c }, { 0xe5, 0x7b, 0xad, 0x71, 0x73, 0xc8, 0xe5, 0xcc, 0x7f, 0x43, 0x0a, 0x6b, 0x7e, 0x76, 0x85, 0xb6, 0xa3, 0x62, 0xb8, 0xea, 0x49, 0x79, 0x1d, 0x9d, 0x71, 0x01, 0x78, 0x27, 0x6d, 0x5e, 0x36, 0x95 }, { 0x1d, 0x69, 0x1f, 0x56, 0xd7, 0xa5, 0x42, 0x55, 0x95, 0x0c, 0x4d, 0xf1, 0xcb, 0xd8, 0x61, 0x1d, 0x2a, 0x45, 0xf9, 0x02, 0x54, 0xba, 0x3f, 0x5d, 0xe8, 0xcc, 0xe7, 0x03, 0xf0, 0xeb, 0x9e, 0xdc }, { 0x41, 0xa8, 0xff, 0x28, 0x85, 0x86, 0x38, 0x91, 0xc6, 0x11, 0x28, 0xe1, 0x21, 0x5d, 0x3a, 0x19, 0x43, 0x84, 0x81, 0x52, 0x35, 0x0f, 0x6a, 0x88, 0x18, 0x10, 0x58, 0x34, 0x63, 0x11, 0x0b, 0x9e }, { 0x2c, 0x67, 0x06, 0x35, 0xda, 0x30, 0x41, 0x40, 0xa3, 0xf9, 0xf1, 0xb6, 0x88, 0x40, 0xa4, 0x13, 0xbf, 0xa4, 0xf2, 0xc7, 0x0c, 0x39, 0x26, 0xe7, 0xf3, 0xdc, 0x22, 0x3d, 0x33, 0x41, 0x9a, 0x2d }, { 0x1f, 0xbd, 0x95, 0xf2, 0x61, 0xe4, 0x50, 0x99, 0xf8, 0xef, 0x7d, 0x98, 0xa3, 0x5b, 0xb7, 0xfa, 0x45, 0x0f, 0x01, 0x05, 0x4a, 0x68, 0x1e, 0x07, 0x72, 0xcb, 0x35, 0x71, 0xd5, 0xb1, 0x64, 0x30 }, { 0x5b, 0x2a, 0xe9, 0xd5, 0xa8, 0x82, 0x38, 0xb6, 0x1d, 0x09, 0xe0, 0x9b, 0x40, 0x28, 0x8a, 0xd7, 0xe6, 0xd0, 0x4a, 0xb4, 0x8c, 0xe7, 0x33, 0x57, 0x1e, 0x2e, 0x66, 0xd3, 0xac, 0x8b, 0xea, 0xb4 }, { 0xe1, 0x7e, 0xfd, 0xce, 0xee, 0x7f, 0xee, 0xce, 0x1f, 0x0f, 0x99, 0xc3, 0x6c, 0x2d, 0x40, 0x6d, 0x0f, 0xd3, 0x21, 0x04, 0x25, 0x48, 0xb8, 0xa8, 0xcd, 0x47, 0xc3, 0x08, 0x5e, 0x5e, 0x43, 0x3d }, { 0x1d, 0xe3, 0x47, 0x05, 0x90, 0x62, 0x95, 0xde, 0xcf, 0x89, 0x03, 0x3d, 0x95, 0xef, 0xb5, 0x1b, 0x97, 0xbb, 0x94, 0xe1, 0xcc, 0xf4, 0xbd, 0x71, 0xd0, 0x55, 0x4f, 0x76, 0x95, 0x27, 0x52, 0x46 }, { 0x5d, 0x59, 0x9e, 0x39, 0x57, 0xbf, 0x95, 0xed, 0x6a, 0x10, 0xfe, 0x8a, 0x5a, 0x58, 0x5f, 0xd6, 0xe1, 0xfa, 0x89, 0x27, 0xa3, 0x63, 0x92, 0x27, 0xee, 0x47, 0x24, 0xae, 0x68, 0xca, 0x7b, 0x1e }, { 0x07, 0x63, 0x62, 0xc7, 0xf5, 0x29, 0x3e, 0x9e, 0x8f, 0x42, 0x12, 0xdf, 0xea, 0xdf, 0xdd, 0x5f, 0xd4, 0xb4, 0x34, 0x70, 0xc4, 0x02, 0x91, 0x0a, 0x44, 0x1e, 0x8e, 0x59, 0x68, 0x46, 0x6a, 0x4b }, { 0x73, 0x56, 0x1f, 0x50, 0x17, 0x2c, 0xf7, 0x49, 0x1d, 0xbf, 0x7e, 0x57, 0x99, 0x02, 0x20, 0x78, 0x31, 0xb7, 0xb4, 0xa0, 0x3e, 0xf8, 0x8a, 0x83, 0x59, 0x7c, 0x73, 0xfc, 0x48, 0x68, 0xec, 0xcd }, { 0x0f, 0x1d, 0x8d, 0xe3, 0x32, 0x15, 0x29, 0x26, 0x38, 0x72, 0x83, 0x74, 0xe6, 0x40, 0xf0, 0xa3, 0x9a, 0x17, 0x17, 0x21, 0xd4, 0xf1, 0x80, 0x0b, 0x79, 0xca, 0xaa, 0xe9, 0x23, 0xaf, 0x80, 0xff }, { 0x7e, 0xbf, 0x72, 0x3a, 0x6b, 0xeb, 0xdd, 0xba, 0xbd, 0x9d, 0xe7, 0x15, 0x6f, 0x34, 0x21, 0x25, 0x8e, 0xdb, 0x9c, 0xa5, 0x6e, 0x40, 0x27, 0xb3, 0x7c, 0x95, 0xf5, 0xb9, 0x4a, 0x98, 0x59, 0x3e }, { 0xe9, 0xbe, 0x27, 0xb1, 0x0c, 0x70, 0x7e, 0x79, 0x4e, 0x8f, 0x8d, 0x0b, 0x74, 0xc5, 0xdd, 0xb0, 0x7c, 0x77, 0x57, 0x1b, 0xd3, 0xe1, 0xd9, 0x59, 0x2e, 0x8e, 0xc7, 0xff, 0xbb, 0x18, 0x64, 0x44 }, { 0x99, 0x4a, 0xf7, 0x37, 0xb1, 0xd3, 0x07, 0x6e, 0x6d, 0xfc, 0x4c, 0xee, 0x6f, 0x19, 0x77, 0x9b, 0xaf, 0xc7, 0xd4, 0x9b, 0x54, 0x24, 0x34, 0xa5, 0x42, 0x1c, 0x8e, 0xc9, 0xa8, 0xad, 0x78, 0xf9 }, { 0x77, 0x13, 0xec, 0x1f, 0x80, 0x4d, 0x16, 0x69, 0x03, 0xbd, 0x0b, 0xb7, 0x22, 0xd4, 0x42, 0x14, 0x8d, 0x6f, 0x0d, 0x1e, 0x6a, 0xfd, 0xe7, 0x0c, 0x13, 0x38, 0x9f, 0x14, 0xc6, 0xe6, 0x54, 0x75 }, { 0xf9, 0x7f, 0xb1, 0xc1, 0xdb, 0x5e, 0x6a, 0x75, 0x01, 0x09, 0x71, 0xd0, 0x2c, 0x45, 0x81, 0x75, 0x98, 0x1d, 0xaa, 0xd7, 0x82, 0xd5, 0x15, 0x2f, 0x09, 0x26, 0x5b, 0x69, 0xa2, 0xa9, 0x27, 0xdc }, { 0xcb, 0x07, 0x42, 0xe1, 0x1c, 0xbc, 0x49, 0xa1, 0x43, 0x79, 0xc7, 0xd3, 0x4d, 0x0f, 0x18, 0x1e, 0x52, 0xaa, 0x56, 0xfa, 0x3a, 0xed, 0xe8, 0x70, 0xfb, 0x30, 0x7d, 0xb5, 0x50, 0xcd, 0x28, 0x15 }, { 0x6a, 0x02, 0xdb, 0x70, 0x4d, 0xd9, 0x37, 0x39, 0xc0, 0xa5, 0x36, 0xf1, 0x8f, 0x9a, 0xcc, 0x13, 0x48, 0x15, 0xae, 0xc3, 0x2f, 0x5d, 0x0d, 0x8c, 0x2d, 0xfe, 0xd1, 0x96, 0x8a, 0xfa, 0x1d, 0xd5 }, { 0x14, 0x29, 0x79, 0xca, 0x70, 0xe1, 0x72, 0x53, 0x22, 0xaf, 0x45, 0x22, 0xca, 0x85, 0xa0, 0x15, 0x8a, 0x57, 0x2c, 0xb3, 0x86, 0xd2, 0x5a, 0x80, 0x22, 0x69, 0x2b, 0x7c, 0xe1, 0xb7, 0x4b, 0xac }, { 0x33, 0xf2, 0xf5, 0xc1, 0xce, 0xee, 0xbe, 0x60, 0x3a, 0xae, 0xa4, 0x64, 0x0b, 0xcc, 0x0b, 0x4d, 0x49, 0x9c, 0x46, 0x45, 0x8d, 0x6b, 0xab, 0xf5, 0xd2, 0x17, 0x40, 0x89, 0x0f, 0xd0, 0x89, 0x44 }, { 0xec, 0x7d, 0x3b, 0x09, 0x25, 0x71, 0xc3, 0x05, 0xc6, 0x9c, 0x81, 0xc8, 0x40, 0x40, 0xc5, 0xfc, 0xf3, 0xb0, 0x79, 0xb0, 0x5c, 0x3e, 0xab, 0xde, 0x9d, 0x23, 0x47, 0xc5, 0xb6, 0x92, 0x37, 0x1a }, { 0x11, 0x7e, 0xf2, 0x41, 0xa4, 0x38, 0x42, 0xab, 0x8a, 0xec, 0x22, 0x25, 0xcd, 0xb7, 0x6a, 0xa5, 0x4c, 0xee, 0x1a, 0xe7, 0x93, 0x39, 0x5d, 0x28, 0xfa, 0x56, 0xf5, 0x97, 0x84, 0xba, 0xd4, 0xf1 }, { 0x24, 0x48, 0x13, 0x4e, 0x49, 0xbd, 0xef, 0x62, 0x28, 0x63, 0xb2, 0x76, 0xad, 0x08, 0xd3, 0x6e, 0x15, 0x3b, 0xbc, 0xe1, 0xc5, 0xac, 0x68, 0x6d, 0xe0, 0xf6, 0x3e, 0xf8, 0x4c, 0x01, 0x33, 0xed }, { 0xd4, 0xfc, 0x14, 0xd7, 0x59, 0x60, 0xcf, 0xbd, 0x10, 0xae, 0x1c, 0xb1, 0x73, 0xdd, 0x9f, 0x33, 0x69, 0xc9, 0x60, 0x84, 0x1a, 0x98, 0x8c, 0x9b, 0x2a, 0x5c, 0x07, 0xea, 0x75, 0xb7, 0xc6, 0x1f }, { 0xd0, 0xab, 0x93, 0x4b, 0x52, 0x35, 0x10, 0xd2, 0x6c, 0x11, 0x91, 0xa7, 0x4a, 0x7b, 0xc4, 0xa0, 0xca, 0x4d, 0x02, 0xab, 0xa7, 0xd1, 0x7e, 0xae, 0xfc, 0x07, 0xe4, 0x2a, 0xac, 0xc7, 0x53, 0x20 }, { 0xad, 0xe8, 0x2a, 0xec, 0xcf, 0x5c, 0xff, 0x68, 0x50, 0x0b, 0x20, 0xa0, 0x53, 0x6f, 0xcc, 0x3e, 0x44, 0x7d, 0x4c, 0x84, 0x3a, 0xf1, 0x6a, 0x4e, 0xdd, 0x6e, 0x3d, 0xd4, 0x9b, 0xb8, 0xfc, 0x22 }, { 0x7a, 0xcc, 0xb5, 0xb2, 0x92, 0xa6, 0x1f, 0x15, 0x0e, 0x5c, 0x2e, 0x83, 0x87, 0x88, 0x19, 0xd7, 0xd3, 0xfe, 0xcf, 0x8d, 0xd1, 0xbe, 0x6c, 0x7e, 0xae, 0x42, 0xaa, 0x06, 0x02, 0xbb, 0x1a, 0x34 }, { 0x49, 0xbe, 0xc7, 0xe7, 0x69, 0x20, 0xb8, 0xa2, 0xa2, 0xc0, 0x75, 0xaa, 0xb3, 0x56, 0x98, 0x6c, 0x84, 0x69, 0x4f, 0x69, 0x6d, 0x5a, 0x07, 0xbd, 0x78, 0x1e, 0x60, 0x5f, 0x00, 0x40, 0x5b, 0xd6 }, { 0x10, 0x38, 0x41, 0x2a, 0x0a, 0x44, 0xc3, 0xbe, 0x99, 0xfb, 0x4c, 0x19, 0xc2, 0x57, 0x22, 0x5d, 0x27, 0xf6, 0xf3, 0x32, 0x66, 0xf8, 0x7d, 0xc8, 0x01, 0xa2, 0x4c, 0xa6, 0xb8, 0x72, 0xfe, 0x41 }, { 0x5a, 0xdb, 0x62, 0x28, 0xa0, 0xe5, 0xb1, 0x77, 0xbe, 0x82, 0x8b, 0x4f, 0x9c, 0xc9, 0xca, 0x2e, 0x1b, 0x57, 0x41, 0xe5, 0x32, 0x8b, 0x61, 0x34, 0xda, 0x08, 0x1f, 0xc6, 0xee, 0x0d, 0x3d, 0x4f }, { 0xd4, 0x33, 0x05, 0x25, 0xcc, 0x89, 0x7e, 0xc4, 0xd6, 0xfa, 0x57, 0xc7, 0x3a, 0x02, 0x81, 0xf9, 0xf9, 0x13, 0xb7, 0x95, 0x94, 0x3c, 0xa6, 0x18, 0xd9, 0x32, 0x7a, 0xf4, 0xef, 0x96, 0x63, 0xee }, { 0x1e, 0x43, 0x8f, 0x84, 0xd7, 0x89, 0xe1, 0x4a, 0xcf, 0xee, 0x30, 0x31, 0xc8, 0xf4, 0x2c, 0x03, 0x24, 0x5f, 0x66, 0x15, 0x89, 0x52, 0x36, 0x88, 0xe6, 0x81, 0x6a, 0x21, 0x9a, 0x4a, 0xf3, 0xb4 }, { 0x8c, 0x0d, 0xb6, 0x3b, 0xbd, 0x42, 0x60, 0xb2, 0xba, 0x8b, 0x01, 0x63, 0x42, 0xb3, 0xa3, 0x57, 0x72, 0x97, 0x82, 0x41, 0x02, 0x49, 0xf5, 0xf0, 0x26, 0x5c, 0x60, 0xce, 0xc6, 0x1a, 0xbf, 0xd6 }, { 0x6f, 0xba, 0xba, 0xb7, 0xb6, 0x68, 0xb2, 0x0b, 0x2f, 0xd1, 0xef, 0xe4, 0xa2, 0x67, 0x31, 0xc9, 0x1b, 0xdf, 0xbc, 0x0e, 0x58, 0xb3, 0x8a, 0xd2, 0x96, 0xd6, 0x8e, 0x7a, 0xd9, 0x51, 0xab, 0x9c }, { 0x41, 0x58, 0xb9, 0xb1, 0x22, 0xdb, 0x41, 0xc9, 0x62, 0x0d, 0x5c, 0x8b, 0x50, 0xfe, 0x0f, 0x81, 0x30, 0x79, 0x06, 0x2f, 0x68, 0x53, 0x46, 0x7e, 0x5f, 0x75, 0x5e, 0x6b, 0xa9, 0x29, 0xb6, 0xb8 }, { 0x54, 0x1f, 0x41, 0x34, 0x88, 0x30, 0xe7, 0x53, 0x94, 0x1f, 0xae, 0xed, 0x1e, 0xed, 0x94, 0x21, 0x73, 0xbf, 0xf4, 0xdd, 0x94, 0x15, 0x5e, 0x1c, 0xaf, 0x7a, 0xd8, 0xfc, 0xc2, 0x37, 0x83, 0x38 }, { 0x7e, 0x1d, 0xa4, 0x18, 0xe5, 0xff, 0x44, 0xeb, 0xe1, 0x86, 0x56, 0xfc, 0x57, 0x1b, 0x57, 0x61, 0x7f, 0x69, 0x12, 0x46, 0xb8, 0x67, 0x4d, 0x0b, 0x06, 0xb0, 0xd2, 0x57, 0x57, 0xd8, 0xd7, 0xd1 }, { 0x7d, 0x73, 0x00, 0x7f, 0x33, 0x39, 0x72, 0x0f, 0xe1, 0xe7, 0x2c, 0x4c, 0x2e, 0x59, 0xd8, 0x5a, 0x15, 0x18, 0x35, 0x98, 0xc5, 0x91, 0x7f, 0x2a, 0x44, 0x95, 0xbd, 0x9b, 0x2e, 0xdd, 0x5e, 0x0c }, { 0x61, 0xce, 0xd0, 0x09, 0x8f, 0x96, 0x1b, 0xae, 0x4d, 0x3d, 0xa7, 0x49, 0x24, 0xf2, 0x1c, 0x11, 0x46, 0xd2, 0x74, 0x69, 0x0b, 0x8a, 0x8f, 0xf7, 0xd5, 0xa4, 0xef, 0xc3, 0xeb, 0xd3, 0x66, 0xb0 }, { 0x17, 0x64, 0x9c, 0x6b, 0xef, 0x80, 0xa4, 0x87, 0xfc, 0x36, 0x84, 0x9d, 0x25, 0x1f, 0x4e, 0xb8, 0x8d, 0x83, 0x23, 0x24, 0x18, 0x55, 0x4f, 0x28, 0x2f, 0x28, 0x91, 0xbd, 0x5f, 0xbc, 0x25, 0x4e }, { 0x26, 0xfc, 0x5d, 0x9e, 0xaf, 0x3f, 0xe0, 0x7f, 0xa1, 0x21, 0xb2, 0x1b, 0x81, 0x51, 0xce, 0xfc, 0xf8, 0xb6, 0x51, 0x1c, 0xc5, 0xcd, 0xc2, 0x0a, 0xe6, 0xd2, 0xc1, 0xf7, 0x6f, 0x90, 0x99, 0x0b }, { 0xaa, 0xcf, 0x2b, 0xa4, 0xb0, 0x2d, 0xca, 0xfd, 0xa3, 0x14, 0x35, 0xfc, 0x9a, 0x01, 0xd9, 0x23, 0xd2, 0x29, 0x91, 0x4a, 0xdb, 0x47, 0x92, 0x04, 0x0e, 0xdf, 0xfe, 0x22, 0x37, 0xfa, 0x3e, 0x18 }, { 0x84, 0xdb, 0x05, 0x92, 0xc3, 0xae, 0xf2, 0xfa, 0x25, 0x17, 0xf3, 0xbb, 0xcc, 0x4f, 0x40, 0xe9, 0xf1, 0xf8, 0x04, 0x40, 0x44, 0x0d, 0xec, 0x26, 0x87, 0x03, 0xbd, 0x41, 0x58, 0x1b, 0xdf, 0x1a }, { 0xcd, 0xbe, 0x35, 0xd4, 0xbb, 0xfc, 0xbf, 0x06, 0xcf, 0xef, 0xb1, 0x40, 0xbe, 0x14, 0x9a, 0x8b, 0x48, 0x2f, 0x3e, 0xd5, 0x6c, 0x76, 0xc0, 0x56, 0xa2, 0xf9, 0xe7, 0xc3, 0x37, 0x31, 0xfd, 0x64 }, { 0x2b, 0x08, 0xd7, 0x66, 0x36, 0x53, 0xb0, 0xc8, 0x0a, 0x29, 0xec, 0x44, 0x3a, 0x95, 0x84, 0x1c, 0x93, 0x4f, 0x3d, 0x0f, 0xe6, 0x65, 0xe5, 0x20, 0xee, 0xa2, 0x86, 0xd9, 0xf8, 0x0a, 0x6a, 0xef }, { 0x46, 0xbb, 0xf8, 0xde, 0x6f, 0x76, 0xf7, 0x7e, 0x38, 0x2e, 0xbb, 0x9e, 0xfe, 0x21, 0xf8, 0x1d, 0xa5, 0xd4, 0x13, 0x93, 0xa8, 0xe8, 0xea, 0xa3, 0xf6, 0x88, 0x51, 0x24, 0xa8, 0x61, 0x79, 0x52 }, { 0xf0, 0xb0, 0xcf, 0x67, 0x46, 0x2f, 0xe5, 0x3f, 0xf2, 0xed, 0x31, 0x6d, 0x65, 0x42, 0x36, 0xf1, 0xe9, 0x0f, 0x5c, 0x98, 0x6b, 0x30, 0x2d, 0x4f, 0x96, 0xcb, 0x3e, 0x8b, 0xc5, 0x3b, 0x4c, 0x4d }, { 0xf5, 0x33, 0x26, 0xa1, 0x6c, 0x1c, 0xb4, 0xa0, 0xca, 0x9d, 0x46, 0xa5, 0x07, 0x27, 0xf1, 0xc4, 0x5f, 0x5f, 0xa0, 0xde, 0xe6, 0x1f, 0x2c, 0xd4, 0x90, 0xc1, 0x7d, 0xf9, 0xf9, 0x7c, 0x67, 0x20 }, { 0x94, 0x3b, 0x05, 0xe2, 0x9e, 0x87, 0xab, 0xec, 0x1d, 0x51, 0xe5, 0x5e, 0x5f, 0x53, 0xc5, 0xa1, 0x02, 0x8f, 0x4e, 0x51, 0x35, 0xad, 0x91, 0x8a, 0xce, 0xd4, 0x3e, 0xe6, 0x06, 0x95, 0xef, 0x7c }, { 0x2b, 0xd2, 0xc3, 0x07, 0x62, 0x18, 0xf8, 0x52, 0x65, 0x7c, 0xde, 0xc0, 0x0c, 0x17, 0x17, 0xc5, 0x33, 0x3e, 0x4b, 0x6f, 0xf3, 0x3f, 0x2b, 0xcd, 0x24, 0xff, 0xca, 0x33, 0xad, 0xfe, 0x8c, 0x0d }, { 0x52, 0x78, 0xb5, 0x7d, 0x46, 0xe3, 0x46, 0xed, 0xab, 0xb9, 0x2e, 0x9c, 0x13, 0x62, 0x4b, 0xb9, 0xa6, 0x9f, 0xbd, 0x13, 0x8a, 0x31, 0xb7, 0xb7, 0xc5, 0xd6, 0x7f, 0x91, 0x23, 0x22, 0xeb, 0x39 }, { 0xc9, 0xdd, 0x00, 0xa2, 0xac, 0x68, 0xdc, 0x3e, 0x61, 0xd5, 0xdc, 0x51, 0xde, 0xed, 0xea, 0xbf, 0x56, 0xb5, 0x77, 0xdd, 0x24, 0x58, 0x03, 0xd5, 0x66, 0xc0, 0xc9, 0x66, 0xd5, 0x3b, 0xa9, 0x98 }, { 0x1f, 0x38, 0xdb, 0x44, 0x0c, 0x4b, 0xc5, 0xcd, 0x86, 0x6c, 0x29, 0xf6, 0x8f, 0x5b, 0x93, 0x74, 0xdc, 0xe3, 0xca, 0x32, 0xa5, 0xfd, 0x27, 0x1c, 0xd7, 0xab, 0x41, 0x37, 0x70, 0xc1, 0x81, 0xea }, { 0xc7, 0xc1, 0x54, 0x5a, 0x77, 0x2e, 0x19, 0x6c, 0xd6, 0x95, 0x3c, 0x41, 0x06, 0x56, 0xea, 0x4a, 0x48, 0xbe, 0x54, 0xa4, 0x1b, 0x07, 0x45, 0x6c, 0x1c, 0x89, 0x17, 0xd8, 0x1c, 0xa1, 0xb8, 0x30 }, { 0xbb, 0x9d, 0xdc, 0xf4, 0x17, 0xaf, 0xc2, 0x57, 0x02, 0xcc, 0x53, 0x39, 0x52, 0xc6, 0x5f, 0xd8, 0xfd, 0xb7, 0xec, 0x85, 0xe7, 0xd3, 0xb4, 0x07, 0xf8, 0x51, 0xb5, 0x1e, 0x5d, 0xc9, 0xa4, 0xfb }, { 0xe3, 0x3c, 0x52, 0x51, 0x4c, 0xd3, 0x01, 0x53, 0xce, 0xf8, 0xd9, 0x63, 0x65, 0x19, 0xa9, 0xc3, 0x48, 0x17, 0x01, 0x82, 0xe2, 0xa6, 0x47, 0x8d, 0xd4, 0x88, 0x7a, 0x8d, 0x53, 0x6f, 0x0f, 0x45 }, { 0x63, 0xa9, 0x8f, 0x17, 0x8b, 0xe8, 0x56, 0x88, 0xa8, 0xa5, 0xce, 0x00, 0xb2, 0x5b, 0xf0, 0x8a, 0x97, 0x2d, 0x34, 0xec, 0xe9, 0x5c, 0x69, 0x47, 0x26, 0x0e, 0x6e, 0x44, 0xfd, 0xba, 0xa3, 0x57 } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t plain_texts1_128bit[ 100 ][ 16 ] = { { 0x07, 0xf2, 0xc2, 0xd4, 0xe6, 0xdb, 0x6e, 0x12, 0x00, 0xbc, 0x16, 0x5d, 0x15, 0x4e, 0x06, 0x98 }, { 0x32, 0x14, 0x75, 0xac, 0x6a, 0xa0, 0x57, 0x12, 0x55, 0x4d, 0x35, 0xa0, 0xa9, 0x6a, 0x92, 0x65 }, { 0x6e, 0x0a, 0x78, 0xbc, 0x0d, 0xb2, 0x70, 0x21, 0xf0, 0xf5, 0x97, 0x56, 0xa4, 0x47, 0xe3, 0x13 }, { 0x18, 0x75, 0x7e, 0xfd, 0x08, 0x05, 0x9a, 0xb7, 0x0b, 0xde, 0x2d, 0xf7, 0x8f, 0x3b, 0xd6, 0xba }, { 0x7f, 0xec, 0xfc, 0x12, 0x7a, 0x37, 0x62, 0xe3, 0x0e, 0x14, 0x79, 0x11, 0x41, 0xf6, 0x55, 0x85 }, { 0xc5, 0x80, 0x1e, 0xd8, 0xa3, 0x8a, 0x78, 0x27, 0x7a, 0x45, 0x51, 0x6a, 0x3e, 0x12, 0xb3, 0x10 }, { 0x25, 0x16, 0x2f, 0x75, 0x11, 0xb5, 0xc3, 0xb2, 0x4a, 0xee, 0x33, 0x9f, 0xfe, 0xb7, 0x94, 0x1c }, { 0x09, 0xda, 0x2f, 0xc0, 0xed, 0x60, 0x5b, 0x69, 0xd9, 0x5e, 0x0b, 0x77, 0x60, 0x84, 0x0a, 0x99 }, { 0xd6, 0x67, 0x68, 0x54, 0x2f, 0x49, 0x5d, 0x5c, 0x50, 0xb8, 0x62, 0x3f, 0x31, 0x40, 0x85, 0xf8 }, { 0xf6, 0xc5, 0x3b, 0xcb, 0x07, 0xcb, 0xb4, 0x47, 0x47, 0xfc, 0x19, 0xa6, 0x60, 0x4e, 0x26, 0xd7 }, { 0xd2, 0xf5, 0x8a, 0xe0, 0x38, 0x6e, 0x92, 0x30, 0x74, 0x4a, 0x20, 0x56, 0xb7, 0xfd, 0x13, 0x10 }, { 0xe1, 0xfd, 0x15, 0x56, 0x47, 0xde, 0x15, 0xb9, 0xfe, 0x23, 0x0b, 0xaf, 0x66, 0x8d, 0x23, 0xdb }, { 0x5f, 0xc7, 0x17, 0xd7, 0x63, 0xa5, 0x6d, 0x76, 0x4a, 0x21, 0x00, 0x9b, 0x51, 0x32, 0xda, 0xb4 }, { 0xec, 0x53, 0x64, 0xfa, 0x01, 0x84, 0xd8, 0xb9, 0x8e, 0xc0, 0x2c, 0xf9, 0x96, 0x42, 0x8f, 0x38 }, { 0x95, 0x36, 0x0d, 0x08, 0xaf, 0x99, 0x7e, 0xb3, 0xec, 0x62, 0xe6, 0x41, 0xdd, 0x6b, 0x89, 0x9a }, { 0xfd, 0xe4, 0xae, 0x88, 0x7d, 0x89, 0x0b, 0x88, 0x35, 0xa5, 0xfc, 0x80, 0xbf, 0xcc, 0xa7, 0x08 }, { 0xdb, 0x57, 0xd5, 0xb8, 0x19, 0x12, 0x9d, 0x78, 0x96, 0xe2, 0xdf, 0x09, 0x58, 0xa6, 0xf9, 0xf3 }, { 0xf3, 0x61, 0x43, 0x63, 0x03, 0x77, 0xd4, 0xe4, 0xef, 0xd4, 0x4c, 0x57, 0x16, 0xa8, 0xbd, 0xa1 }, { 0x8a, 0xab, 0x74, 0x42, 0x87, 0xbf, 0xf6, 0x90, 0x14, 0x41, 0x90, 0x8d, 0xa2, 0x3f, 0x0b, 0x11 }, { 0xb9, 0xa3, 0x53, 0x3b, 0x48, 0x26, 0x9b, 0x56, 0xf0, 0xdb, 0xb0, 0x57, 0x24, 0x27, 0x2c, 0xe5 }, { 0xd3, 0x37, 0x77, 0xd7, 0x80, 0xa0, 0x4b, 0xfe, 0x62, 0x5c, 0xae, 0x47, 0x1d, 0x2b, 0x81, 0x69 }, { 0xa7, 0xf7, 0xe8, 0x0a, 0x06, 0x8e, 0x75, 0x91, 0xae, 0x68, 0x1f, 0xe3, 0xe5, 0xe2, 0x77, 0xa6 }, { 0xf3, 0x1a, 0xff, 0x86, 0xe5, 0x75, 0x9a, 0x22, 0x43, 0xbf, 0xe9, 0x6f, 0x1c, 0xda, 0xd7, 0xf6 }, { 0x4f, 0x67, 0x07, 0xb5, 0xe6, 0x5d, 0xa3, 0xee, 0xa9, 0x2b, 0x53, 0x53, 0xc7, 0xbd, 0x95, 0xa2 }, { 0xd3, 0xaa, 0x65, 0xaf, 0x58, 0x82, 0xd4, 0x32, 0xe8, 0xaf, 0xda, 0xa0, 0xb4, 0xf4, 0x26, 0x40 }, { 0x87, 0x89, 0xbb, 0x3e, 0x01, 0xc8, 0xd3, 0xe7, 0x68, 0x03, 0x3f, 0x2c, 0x05, 0xff, 0xee, 0x17 }, { 0x1d, 0x72, 0x76, 0x7f, 0xff, 0xb8, 0xde, 0x3a, 0x2a, 0x42, 0x0c, 0xa4, 0x38, 0x30, 0x87, 0xa6 }, { 0xfb, 0x8d, 0x8d, 0xb9, 0xcb, 0x86, 0x39, 0xde, 0x83, 0x44, 0x23, 0x8d, 0xc2, 0xc1, 0xf2, 0x55 }, { 0x90, 0xc0, 0x8a, 0xc7, 0x85, 0xb3, 0xb5, 0xe7, 0xc1, 0x81, 0x54, 0x97, 0xa4, 0x51, 0xa9, 0x6c }, { 0x03, 0x6c, 0xad, 0x62, 0xc2, 0x42, 0x95, 0xb1, 0x88, 0xc4, 0x7c, 0xdc, 0x24, 0x7e, 0xae, 0x41 }, { 0x85, 0x76, 0x79, 0xe4, 0x9c, 0xd6, 0x8b, 0xc6, 0x48, 0xc4, 0xab, 0x09, 0x86, 0xaa, 0x59, 0xf8 }, { 0x5c, 0x93, 0x1a, 0x13, 0x5b, 0x9d, 0x4a, 0x7d, 0x65, 0xc9, 0xa8, 0xd5, 0x53, 0x5c, 0x12, 0x94 }, { 0xdd, 0x15, 0x57, 0x57, 0xfc, 0xf4, 0x57, 0xd9, 0x0b, 0xb5, 0x71, 0xe8, 0xee, 0xbd, 0x46, 0x30 }, { 0x56, 0xfd, 0xd9, 0x2d, 0x70, 0xc1, 0x07, 0xb7, 0x70, 0x7c, 0x9a, 0xa1, 0xd3, 0x3a, 0xb0, 0xac }, { 0xd4, 0x9c, 0xa2, 0xb1, 0xdf, 0xc2, 0x84, 0x81, 0x20, 0xdf, 0xc2, 0xb7, 0x5e, 0x29, 0x2a, 0x0c }, { 0xda, 0x86, 0x8a, 0xfe, 0xec, 0x48, 0x76, 0x40, 0x91, 0xc5, 0x1f, 0x5e, 0x73, 0x32, 0x33, 0x8d }, { 0xe8, 0xcb, 0x04, 0x2a, 0x3d, 0x23, 0x97, 0x71, 0xef, 0x10, 0x4b, 0x58, 0x92, 0xbd, 0x10, 0x67 }, { 0xdf, 0x68, 0x67, 0x69, 0x3d, 0x88, 0x84, 0xcc, 0xa8, 0x19, 0x82, 0x83, 0xbb, 0x2c, 0x3e, 0x16 }, { 0xf2, 0x24, 0xec, 0x19, 0xa5, 0x8b, 0xbd, 0xe0, 0x3c, 0xb6, 0x92, 0xe0, 0xe4, 0xfc, 0x19, 0xd7 }, { 0xb8, 0xfa, 0x08, 0x9c, 0xca, 0x83, 0xd2, 0xc9, 0x97, 0x9e, 0x64, 0x2b, 0x9a, 0x24, 0x88, 0x82 }, { 0x89, 0x69, 0x1c, 0x5d, 0xbc, 0x84, 0xbf, 0x8e, 0x2e, 0x14, 0x54, 0x14, 0x80, 0x49, 0x64, 0x8f }, { 0xd7, 0xf7, 0xc8, 0xbc, 0xcf, 0x89, 0x68, 0xb9, 0xf1, 0x18, 0xbb, 0xea, 0xd3, 0x53, 0xb6, 0x30 }, { 0x8b, 0x65, 0x72, 0x48, 0x73, 0x18, 0x16, 0x7d, 0x1b, 0xab, 0xed, 0xf6, 0xa8, 0xce, 0xf7, 0xb2 }, { 0x53, 0x1d, 0x33, 0x93, 0x77, 0x2d, 0x49, 0xbb, 0xd0, 0xa1, 0xb6, 0xd8, 0x39, 0xde, 0x01, 0x85 }, { 0x92, 0x6c, 0xfa, 0x1f, 0x56, 0x8b, 0x03, 0xc9, 0x14, 0xb5, 0xa8, 0x28, 0x39, 0x20, 0xbe, 0x26 }, { 0xb7, 0x90, 0x36, 0x8e, 0x2a, 0xb0, 0x22, 0x7e, 0x5c, 0x08, 0xad, 0xc4, 0xe7, 0x05, 0x7b, 0xaa }, { 0xc9, 0x4c, 0x62, 0xfd, 0xac, 0x55, 0x0c, 0xf6, 0x2f, 0x3d, 0xbe, 0xc8, 0x9c, 0xb8, 0x61, 0x4c }, { 0x16, 0x93, 0x8d, 0x35, 0xe7, 0x4a, 0x7a, 0xb0, 0xca, 0xdd, 0xde, 0x53, 0x1c, 0xbb, 0xc3, 0x33 }, { 0x35, 0xd1, 0x6e, 0x1d, 0x15, 0xcd, 0xad, 0x05, 0x02, 0xe7, 0xef, 0x58, 0xe8, 0x6f, 0x4d, 0x4c }, { 0x6a, 0xf3, 0x15, 0x2f, 0x97, 0x63, 0xe3, 0x9a, 0x83, 0xb9, 0x4f, 0xe9, 0x60, 0xe0, 0x44, 0x47 }, { 0xd5, 0xa4, 0xd8, 0xec, 0x68, 0xe5, 0x3c, 0x0a, 0xac, 0x09, 0x4b, 0x95, 0xb8, 0xad, 0xd3, 0xc9 }, { 0x63, 0x87, 0x89, 0xa3, 0x03, 0x15, 0x4f, 0xb3, 0x64, 0xe5, 0x16, 0x8a, 0xa9, 0x34, 0x08, 0x82 }, { 0x5f, 0xf7, 0xc0, 0x24, 0x9b, 0xe2, 0xb6, 0x94, 0xad, 0x82, 0xe6, 0x80, 0x23, 0x97, 0x45, 0x33 }, { 0x44, 0x62, 0xbc, 0x46, 0x9e, 0x79, 0x4f, 0xd7, 0x42, 0x88, 0xf3, 0xf7, 0x75, 0xc0, 0x2c, 0xf9 }, { 0x3f, 0x29, 0xbf, 0xa0, 0x56, 0x16, 0x50, 0x77, 0x92, 0xce, 0xdc, 0x91, 0xe2, 0x7e, 0x4f, 0xbc }, { 0x44, 0x79, 0x88, 0x5b, 0x32, 0xed, 0x93, 0xa0, 0x5b, 0xc9, 0x73, 0xd9, 0x25, 0xb3, 0x0a, 0x71 }, { 0x5f, 0xaa, 0x52, 0x85, 0x56, 0xf7, 0x90, 0x49, 0x11, 0x8c, 0x00, 0x85, 0x2e, 0x02, 0x2d, 0x96 }, { 0xfa, 0x58, 0xed, 0x4b, 0x55, 0x30, 0xec, 0xb8, 0xad, 0xb5, 0xf4, 0xc1, 0x19, 0xa9, 0xed, 0xda }, { 0x83, 0xf4, 0x63, 0x9b, 0x4f, 0xa5, 0x4f, 0x5f, 0x65, 0x7c, 0x03, 0xfe, 0x4c, 0x00, 0x98, 0x3e }, { 0x9c, 0x08, 0x5e, 0xbe, 0x5c, 0xd4, 0x2b, 0x24, 0x88, 0x9b, 0xe0, 0x7f, 0x59, 0xf7, 0x61, 0xb1 }, { 0x0c, 0xca, 0xac, 0x98, 0xe1, 0xc9, 0x60, 0x9f, 0x40, 0x69, 0x30, 0x61, 0x7f, 0x1e, 0x35, 0xec }, { 0x1f, 0xb8, 0xa2, 0xd4, 0x99, 0x6b, 0xac, 0xf3, 0x4f, 0x62, 0xca, 0xf1, 0x40, 0x2c, 0xed, 0x12 }, { 0xab, 0xca, 0xe5, 0x4a, 0xfc, 0xbb, 0x0b, 0x0e, 0xc7, 0x58, 0x84, 0xb1, 0x1a, 0x99, 0x01, 0xff }, { 0xc9, 0xfe, 0xd3, 0xc2, 0x9c, 0xf7, 0xc2, 0xa2, 0x84, 0x63, 0x68, 0x4f, 0x55, 0x1c, 0x11, 0xcd }, { 0x55, 0xdd, 0xb8, 0xbc, 0x2b, 0xa1, 0x56, 0xbc, 0xd6, 0x64, 0x83, 0xab, 0x6a, 0x2c, 0xfe, 0x5c }, { 0x7d, 0x88, 0x58, 0xef, 0xdf, 0x67, 0x84, 0x73, 0xd1, 0x13, 0x89, 0xac, 0xee, 0x8d, 0xed, 0x16 }, { 0xcb, 0x1e, 0x87, 0x32, 0xf3, 0xa2, 0xdc, 0xd4, 0x5f, 0x4d, 0x05, 0x74, 0x09, 0xeb, 0x4d, 0x06 }, { 0x44, 0x72, 0x9a, 0x79, 0x75, 0xc2, 0x2a, 0x89, 0xc6, 0x15, 0xd0, 0xf4, 0x8b, 0xcb, 0xad, 0x63 }, { 0xee, 0xdc, 0x77, 0x72, 0x6b, 0xe4, 0x30, 0x17, 0xfb, 0x49, 0xbc, 0x40, 0x31, 0x42, 0x9e, 0x46 }, { 0x98, 0x90, 0x0b, 0xbe, 0x2e, 0x11, 0x41, 0xb5, 0x94, 0xc0, 0x5c, 0x93, 0xbd, 0xa6, 0x8c, 0x50 }, { 0x8c, 0x9c, 0x92, 0x31, 0x73, 0x2b, 0x49, 0xba, 0xa0, 0x7f, 0x99, 0x4a, 0xc9, 0x0c, 0xbb, 0x74 }, { 0xb4, 0x38, 0xd1, 0x1e, 0x4a, 0xf5, 0x11, 0x07, 0xa4, 0x21, 0x2f, 0x48, 0x44, 0xd8, 0xc6, 0x70 }, { 0x83, 0xee, 0xe4, 0x5a, 0xba, 0x63, 0x8b, 0xcf, 0x71, 0x26, 0x24, 0x21, 0x77, 0x19, 0x35, 0x63 }, { 0xe7, 0xe4, 0xdf, 0xf4, 0xb3, 0x6e, 0xe9, 0x69, 0xfd, 0x6d, 0x80, 0xe8, 0xba, 0xec, 0x55, 0xc1 }, { 0xc3, 0x99, 0x04, 0x09, 0x70, 0x6e, 0xb8, 0xa1, 0xad, 0xcf, 0xe3, 0xba, 0xea, 0x3b, 0x42, 0x1a }, { 0x47, 0xfe, 0x4c, 0x37, 0x59, 0x75, 0x8e, 0xbe, 0xc5, 0x0f, 0x37, 0x0d, 0x48, 0x3e, 0xbb, 0xb8 }, { 0x5c, 0x70, 0x9d, 0x12, 0x02, 0x04, 0xee, 0x3e, 0x32, 0xa5, 0x7b, 0x8e, 0xa2, 0x78, 0xe5, 0x84 }, { 0xfa, 0x81, 0xd0, 0xc1, 0xf6, 0x17, 0x25, 0x7b, 0x43, 0xa7, 0x01, 0x36, 0xae, 0xb5, 0x51, 0x68 }, { 0x2b, 0xec, 0xd5, 0x0a, 0x3b, 0xeb, 0x5b, 0xa4, 0x1a, 0xef, 0xd8, 0x95, 0x88, 0x41, 0x3c, 0x49 }, { 0x7c, 0xf6, 0xc0, 0x26, 0x93, 0xcb, 0xb1, 0xf3, 0xfc, 0x82, 0x5e, 0x4a, 0x5c, 0xdb, 0x7f, 0xaf }, { 0x0d, 0x59, 0xb4, 0x0b, 0xa3, 0xd9, 0x17, 0x4b, 0x58, 0xda, 0x3e, 0xb8, 0x2a, 0xe3, 0x0d, 0xe3 }, { 0x4a, 0x88, 0x02, 0x1a, 0x53, 0xaf, 0x93, 0x89, 0xe3, 0xab, 0xc1, 0x9a, 0xb6, 0xc2, 0x29, 0xa1 }, { 0xa8, 0x4d, 0xfd, 0x53, 0x49, 0x2e, 0xc2, 0xe8, 0x0b, 0xda, 0x18, 0x78, 0x92, 0x9d, 0x29, 0x52 }, { 0xa6, 0x01, 0xc1, 0x69, 0xee, 0x05, 0x9b, 0x8e, 0x1d, 0x0d, 0xce, 0x77, 0xcf, 0x28, 0x62, 0xf3 }, { 0x85, 0xc9, 0x3e, 0xdc, 0x4e, 0xc4, 0xd3, 0x3d, 0x6c, 0x4e, 0xfd, 0x25, 0x58, 0x18, 0x40, 0x25 }, { 0x3f, 0x71, 0x52, 0x73, 0xef, 0xe1, 0x95, 0x45, 0x65, 0x66, 0x9a, 0x20, 0x85, 0x04, 0xa7, 0x63 }, { 0x9d, 0xad, 0x8e, 0x38, 0x5c, 0x80, 0x6d, 0x90, 0xf8, 0x8b, 0xfc, 0xbb, 0x5a, 0x7a, 0x96, 0x86 }, { 0xa5, 0x93, 0xe8, 0x7b, 0xca, 0x06, 0xf1, 0xba, 0x52, 0x93, 0x17, 0xa7, 0x18, 0x88, 0x3a, 0xbc }, { 0x89, 0xc0, 0xbb, 0x8f, 0x0f, 0xc6, 0x39, 0x87, 0xcf, 0xd3, 0x5c, 0x72, 0x92, 0xdd, 0xc5, 0x0e }, { 0xdb, 0x8d, 0x01, 0x9a, 0xb1, 0x2c, 0x98, 0x76, 0x5e, 0xdb, 0x0a, 0x7c, 0xa2, 0x58, 0x92, 0x48 }, { 0xf8, 0x56, 0x0d, 0x79, 0x95, 0xe8, 0x48, 0xfd, 0x0a, 0xfc, 0x51, 0x8b, 0x6c, 0x7b, 0x62, 0x78 }, { 0xbb, 0xfe, 0xeb, 0xa2, 0x07, 0x7e, 0x7d, 0x29, 0xc6, 0x7d, 0xaf, 0x70, 0xa1, 0xef, 0x1c, 0xa3 }, { 0x07, 0x70, 0xf6, 0x40, 0xb1, 0x01, 0x3a, 0x31, 0x48, 0x0c, 0x32, 0x50, 0x88, 0x3b, 0x0b, 0xc7 }, { 0xd1, 0x61, 0xe0, 0x8e, 0xcf, 0x9c, 0xf2, 0x73, 0x24, 0xff, 0xa8, 0x4a, 0xad, 0xf1, 0x69, 0x41 }, { 0xa1, 0x38, 0xf2, 0xa1, 0x60, 0x33, 0xe8, 0xc2, 0x24, 0x52, 0x43, 0xda, 0x3a, 0xdc, 0x14, 0x98 }, { 0x6a, 0xb5, 0xf2, 0xbe, 0x0f, 0xca, 0x76, 0xbc, 0xd8, 0x95, 0xbf, 0x9d, 0x46, 0xde, 0x01, 0xc9 }, { 0x70, 0x33, 0x05, 0x58, 0xf8, 0x28, 0x8b, 0x74, 0xe8, 0x76, 0x8c, 0xde, 0x82, 0x71, 0x37, 0xc8 }, { 0xa2, 0x20, 0xba, 0x8c, 0x18, 0x4a, 0x68, 0x26, 0x2b, 0x45, 0x5e, 0x73, 0xc1, 0x3e, 0x6f, 0xfc }, { 0x66, 0x23, 0x59, 0x74, 0xce, 0x1e, 0x71, 0x8c, 0x12, 0xf7, 0xb8, 0xfd, 0x72, 0x9d, 0xef, 0xe0 }, { 0xc3, 0x33, 0xdc, 0xc0, 0x14, 0x9f, 0xac, 0x9f, 0x23, 0x37, 0x4f, 0x90, 0x23, 0xfe, 0x92, 0xd0 } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t plain_texts2_128bit[ 100 ][ 32 ] = { { 0x19, 0x43, 0x90, 0x1f, 0xff, 0x18, 0x17, 0x0a, 0xc5, 0x9c, 0x0b, 0xbb, 0xd6, 0xb7, 0x23, 0x62, 0xdb, 0xb5, 0xc6, 0x50, 0x57, 0xbf, 0x05, 0x53, 0x89, 0xf5, 0x20, 0x75, 0x7a, 0xc2, 0x9d, 0xaf }, { 0xec, 0xc4, 0x11, 0xf4, 0xac, 0x85, 0x29, 0x2d, 0x40, 0xf4, 0xcf, 0x8b, 0xe6, 0x25, 0x64, 0x57, 0xed, 0xa2, 0xab, 0x5a, 0xa6, 0xd6, 0xef, 0xf1, 0x5b, 0xc4, 0x6d, 0xa8, 0xa5, 0xa8, 0x7c, 0x56 }, { 0x73, 0x50, 0x53, 0xbd, 0x54, 0x47, 0x06, 0x47, 0xb5, 0x67, 0x4a, 0x12, 0xc5, 0x7a, 0x51, 0xb6, 0xe7, 0xce, 0x80, 0x45, 0x47, 0x0a, 0xfe, 0xf1, 0xc1, 0x2b, 0x69, 0x18, 0xa3, 0xa9, 0x16, 0x11 }, { 0x29, 0xf7, 0xc9, 0x3b, 0xd3, 0x21, 0xb1, 0x07, 0x68, 0x05, 0xc7, 0xda, 0xfb, 0xcc, 0x35, 0x39, 0x0a, 0xa9, 0x01, 0x4b, 0x60, 0x54, 0x3f, 0x81, 0x6e, 0x08, 0x01, 0x07, 0xc6, 0xc1, 0x4b, 0x9c }, { 0x3e, 0x02, 0x1d, 0x77, 0xd9, 0x11, 0x26, 0x9e, 0xbf, 0x24, 0xd2, 0xd7, 0xb7, 0xe9, 0xa5, 0x79, 0xd4, 0xee, 0x38, 0xf8, 0x73, 0xb6, 0x7b, 0xff, 0xe3, 0xfa, 0x55, 0xc7, 0x86, 0x04, 0x7f, 0x19 }, { 0x14, 0xa7, 0xb3, 0x0c, 0x80, 0xd3, 0x41, 0x60, 0x9c, 0x29, 0x16, 0x80, 0xf8, 0xcb, 0xdd, 0x66, 0x28, 0xcf, 0x6d, 0xbb, 0x46, 0x00, 0x4e, 0x52, 0x65, 0x3b, 0x91, 0xcd, 0x9c, 0x18, 0x9d, 0x48 }, { 0xde, 0xac, 0x6e, 0x7b, 0x9e, 0x06, 0x34, 0xc3, 0x1d, 0xa6, 0xa5, 0xff, 0x71, 0x98, 0x1f, 0x04, 0xc0, 0x86, 0xf4, 0x87, 0x96, 0x32, 0xb3, 0xcd, 0x5a, 0xff, 0x69, 0x6f, 0x94, 0xba, 0x13, 0xe0 }, { 0xb8, 0x2a, 0x58, 0xa6, 0x4d, 0x81, 0x1c, 0x34, 0x2b, 0x04, 0x20, 0xef, 0xb3, 0x88, 0x6f, 0xd9, 0x9f, 0xd8, 0x5f, 0x59, 0xc5, 0x2d, 0x40, 0xd1, 0x99, 0xfa, 0xa2, 0xd3, 0x60, 0x86, 0x79, 0xe4 }, { 0x02, 0xf3, 0xaf, 0xf6, 0x9a, 0x08, 0xb6, 0x51, 0x79, 0x30, 0xea, 0xd6, 0x66, 0xaf, 0xda, 0xa2, 0xaf, 0x68, 0x89, 0x88, 0x06, 0xcd, 0x72, 0x3a, 0x50, 0xfb, 0x9b, 0xc0, 0x48, 0x8d, 0x7a, 0x0c }, { 0x57, 0xc5, 0xef, 0x3e, 0x9f, 0x7e, 0xab, 0x67, 0x6d, 0xe9, 0x59, 0xee, 0xb3, 0x25, 0xf9, 0x54, 0x66, 0xf6, 0xa9, 0xdd, 0xab, 0xd8, 0x4d, 0x7b, 0xd7, 0x5d, 0x26, 0xc4, 0x4f, 0x50, 0x8f, 0x49 }, { 0x97, 0xaa, 0xb7, 0x62, 0xae, 0x88, 0x3f, 0xf6, 0xa1, 0x08, 0x16, 0xa1, 0x2e, 0xc0, 0x72, 0x35, 0x62, 0xc9, 0x41, 0xfd, 0x09, 0x49, 0x72, 0xb1, 0xb8, 0x5b, 0xf9, 0x14, 0x06, 0xc4, 0xd6, 0xc8 }, { 0x1c, 0x8d, 0xdd, 0x3f, 0x0c, 0xe1, 0xf8, 0x24, 0xea, 0x03, 0xa9, 0x40, 0x1c, 0x53, 0x89, 0xb0, 0x7e, 0x82, 0xf6, 0x81, 0xf5, 0x76, 0x7f, 0x17, 0xdb, 0xb0, 0x91, 0x03, 0x50, 0x6e, 0xbb, 0x98 }, { 0x40, 0x51, 0x97, 0x6a, 0x40, 0x3c, 0x91, 0xb1, 0x63, 0x07, 0xda, 0x58, 0x67, 0xf7, 0x3f, 0x40, 0x9f, 0x35, 0xd5, 0x30, 0x4d, 0x88, 0x70, 0x05, 0x18, 0x09, 0x44, 0x54, 0x11, 0x7d, 0x84, 0xc1 }, { 0x30, 0x81, 0x63, 0x67, 0xfe, 0xff, 0xff, 0x5f, 0xcf, 0x4d, 0x13, 0x08, 0xd8, 0x3c, 0xf6, 0xc1, 0x84, 0x4d, 0x8b, 0xfa, 0xa8, 0x42, 0xb3, 0x1a, 0xe4, 0x44, 0x60, 0xf6, 0x11, 0x47, 0x9f, 0x45 }, { 0xe5, 0xe8, 0x1f, 0x1c, 0x11, 0x93, 0xad, 0x8d, 0x1e, 0x2e, 0xc1, 0x1a, 0x3c, 0x82, 0xd9, 0x36, 0x1a, 0x80, 0x36, 0x85, 0x2e, 0xf7, 0x78, 0x3e, 0xd0, 0x98, 0xe1, 0xb6, 0x23, 0x45, 0x99, 0xe7 }, { 0xbb, 0xe7, 0x41, 0x2a, 0x55, 0xba, 0x62, 0x4e, 0xf8, 0x18, 0x55, 0xd6, 0x01, 0x80, 0xee, 0x0a, 0x49, 0x40, 0x94, 0x47, 0xb4, 0x12, 0xb7, 0x63, 0x9d, 0x05, 0x4b, 0x18, 0xfb, 0xa6, 0x6e, 0xc4 }, { 0x4b, 0x0c, 0x63, 0x08, 0x78, 0x38, 0xff, 0xc7, 0x52, 0x1a, 0xfc, 0xcc, 0x0f, 0x03, 0x1c, 0xc7, 0x7e, 0x3c, 0x6e, 0x8d, 0xcf, 0x8d, 0x63, 0xc4, 0x8b, 0x47, 0x16, 0x5d, 0x65, 0x41, 0x45, 0x90 }, { 0xae, 0x9b, 0x10, 0xbd, 0xe3, 0x6f, 0x92, 0x5e, 0x82, 0xeb, 0x25, 0x06, 0xd2, 0xf5, 0xfb, 0xfe, 0x07, 0x42, 0x05, 0x3b, 0xbe, 0x82, 0x2f, 0x83, 0x4e, 0xe0, 0x03, 0x9f, 0xa7, 0x1b, 0x1c, 0xb0 }, { 0x8b, 0x36, 0xcd, 0x24, 0xbe, 0xbf, 0x36, 0x18, 0x83, 0x99, 0x79, 0xf4, 0x0a, 0xb0, 0x1d, 0xd8, 0x3c, 0xe9, 0x56, 0x7d, 0xf7, 0xf4, 0x44, 0xd2, 0xf9, 0x98, 0xd3, 0xb0, 0x76, 0x99, 0xab, 0xb9 }, { 0xba, 0x5e, 0xf8, 0xbf, 0xe3, 0xc9, 0x56, 0x2c, 0xfe, 0xce, 0x16, 0x8b, 0xd4, 0xe1, 0xad, 0x3b, 0x5f, 0xa5, 0x18, 0xb9, 0x87, 0x91, 0x17, 0x5a, 0xb3, 0x16, 0xed, 0x75, 0x12, 0x95, 0x2e, 0x44 }, { 0x23, 0xaf, 0x1a, 0x58, 0x91, 0xbc, 0x51, 0xe5, 0x78, 0x89, 0x67, 0xa9, 0xf8, 0x41, 0x9a, 0xeb, 0x71, 0x27, 0x74, 0x4c, 0x2a, 0xc8, 0x62, 0x25, 0xd8, 0x3b, 0x18, 0x01, 0x35, 0xac, 0xdc, 0xda }, { 0x71, 0x34, 0xee, 0xa5, 0x21, 0x79, 0xc4, 0x7b, 0xa7, 0xcc, 0x1a, 0x7f, 0x0e, 0x15, 0xac, 0x2a, 0x5b, 0x19, 0x93, 0xa6, 0x05, 0x12, 0x77, 0x5f, 0x35, 0x3a, 0x12, 0x88, 0xa7, 0x92, 0x6e, 0x7a }, { 0x0d, 0x31, 0x11, 0xcf, 0x9e, 0x10, 0x52, 0x17, 0xbf, 0xd2, 0x55, 0x15, 0x2c, 0x28, 0x00, 0x4f, 0x37, 0x28, 0x20, 0x7a, 0x43, 0xc0, 0x6a, 0xab, 0xff, 0x00, 0xb3, 0x8f, 0x3b, 0x2f, 0xb3, 0x89 }, { 0x4f, 0x61, 0xf2, 0xea, 0x0f, 0x7a, 0xe3, 0xe6, 0x73, 0xa7, 0x09, 0x8e, 0x0a, 0x17, 0x91, 0x91, 0x13, 0x09, 0x43, 0xbc, 0x78, 0xcf, 0x4f, 0x36, 0x1e, 0xbc, 0xe0, 0xb8, 0x48, 0x77, 0xe4, 0xe6 }, { 0xf2, 0xe0, 0x1a, 0x94, 0xb2, 0x10, 0x13, 0x72, 0xed, 0x33, 0xf6, 0x7e, 0x51, 0xdd, 0xfa, 0x2c, 0x50, 0xdc, 0x2d, 0xfe, 0x7b, 0xd8, 0x81, 0x27, 0x3a, 0x09, 0xae, 0x24, 0x7c, 0xec, 0x9b, 0x63 }, { 0xbd, 0xc5, 0x46, 0x8f, 0xbc, 0x8d, 0x50, 0xa1, 0x0d, 0x1c, 0x85, 0x7f, 0x79, 0x1c, 0x5c, 0xba, 0xb3, 0x81, 0x0d, 0x0d, 0x73, 0xcf, 0x8f, 0x20, 0x46, 0xb1, 0xd1, 0x9e, 0x7d, 0x5d, 0x8a, 0x56 }, { 0x10, 0xfe, 0x87, 0xe6, 0xc7, 0x15, 0x57, 0x5e, 0x7e, 0x23, 0x22, 0x0f, 0x38, 0xe9, 0xc5, 0xb9, 0xd4, 0xee, 0x25, 0xb8, 0xcf, 0x74, 0x4e, 0x44, 0x7f, 0x2d, 0x40, 0x56, 0xc9, 0xef, 0xab, 0xc0 }, { 0xa2, 0xb4, 0x5e, 0xd5, 0xe5, 0x93, 0xa1, 0xfc, 0xbf, 0x9b, 0xcf, 0x3f, 0x40, 0x6b, 0xb7, 0xaf, 0xc5, 0x41, 0x99, 0x7d, 0x45, 0x4c, 0x25, 0x1e, 0xa9, 0x24, 0x80, 0x4c, 0x44, 0xa0, 0x37, 0xbc }, { 0xe4, 0xa1, 0x9c, 0xdc, 0x4e, 0xab, 0x9f, 0x3a, 0x91, 0xbf, 0x42, 0xa8, 0xb0, 0x84, 0xa2, 0xd7, 0x12, 0x09, 0x5a, 0x64, 0x6a, 0xa0, 0x3a, 0x3c, 0x0b, 0xc9, 0xbf, 0x69, 0x5b, 0x19, 0xc4, 0xbc }, { 0x91, 0x53, 0x58, 0x47, 0x0c, 0xb9, 0xfa, 0xec, 0x9f, 0x4b, 0xd5, 0x2b, 0x91, 0x5c, 0x9f, 0x1b, 0x30, 0xac, 0x83, 0x77, 0xd3, 0x16, 0xe5, 0xa9, 0x2d, 0x3e, 0xea, 0x87, 0x65, 0x39, 0x46, 0xae }, { 0x47, 0xa8, 0x33, 0xc7, 0xbd, 0xc5, 0x6e, 0x7e, 0xa9, 0x5f, 0x2d, 0xac, 0xf4, 0x41, 0x58, 0x72, 0x13, 0x1d, 0xd2, 0xc7, 0x6d, 0x6c, 0x2c, 0x9b, 0xe4, 0x9a, 0xd3, 0x07, 0x9c, 0x90, 0xd4, 0x93 }, { 0x1c, 0xf2, 0x8a, 0x0f, 0x09, 0xa3, 0x1a, 0x0e, 0x84, 0xe0, 0x7b, 0x5f, 0xd6, 0x59, 0xf6, 0x5b, 0x03, 0x3a, 0x6d, 0x51, 0xad, 0x7c, 0x92, 0x90, 0x2e, 0xc6, 0xa4, 0x4c, 0xe9, 0xb3, 0xc3, 0x9e }, { 0xb7, 0xa0, 0x29, 0x4e, 0x79, 0x8c, 0x9b, 0xa0, 0x85, 0xa3, 0x96, 0x93, 0x81, 0x02, 0x78, 0x39, 0x1e, 0x51, 0x38, 0x1f, 0xfb, 0xfd, 0x9b, 0x49, 0xb8, 0x9e, 0x2e, 0x7f, 0xaa, 0xa9, 0x3a, 0xa0 }, { 0xc9, 0x45, 0x43, 0xb7, 0x13, 0x10, 0x88, 0x15, 0x74, 0x6c, 0x14, 0xc9, 0x2b, 0x35, 0x16, 0x5f, 0x6c, 0x1d, 0x7a, 0xeb, 0x34, 0xd0, 0x3b, 0xe8, 0x22, 0x31, 0xb1, 0xbf, 0xc2, 0xd9, 0xcc, 0x39 }, { 0x4e, 0x11, 0x46, 0x66, 0xf7, 0xb6, 0x43, 0xbd, 0x10, 0x30, 0x91, 0xcc, 0xc0, 0x66, 0x05, 0x3d, 0x14, 0x48, 0xc6, 0x0f, 0x4a, 0xde, 0xe1, 0x19, 0x30, 0xdf, 0xd9, 0x89, 0xa8, 0xb8, 0x64, 0x17 }, { 0x69, 0xa6, 0xea, 0x57, 0x3c, 0xf4, 0xb6, 0xfa, 0xb1, 0xd0, 0x75, 0xbf, 0x18, 0xeb, 0x00, 0x4c, 0xb2, 0xbf, 0x42, 0xdd, 0x7d, 0x8f, 0xbc, 0xd5, 0x73, 0xf7, 0x3a, 0x6c, 0xfb, 0x7d, 0x38, 0xb8 }, { 0x75, 0x07, 0xfe, 0x91, 0x23, 0xcd, 0x07, 0xef, 0x45, 0xb7, 0x67, 0xa1, 0x9f, 0xa8, 0xc8, 0x52, 0xe6, 0x68, 0x12, 0x44, 0xdf, 0x9e, 0x99, 0xf3, 0x87, 0xce, 0xae, 0x37, 0x3c, 0x64, 0x06, 0xf2 }, { 0xf8, 0xd1, 0xba, 0xc5, 0x2d, 0x1e, 0x3e, 0xd9, 0x81, 0xe9, 0xad, 0xcc, 0x51, 0x0c, 0x26, 0xda, 0xcc, 0x00, 0xf4, 0x77, 0x8f, 0xb2, 0xb9, 0x2c, 0xec, 0x8a, 0x62, 0xd0, 0xb8, 0x14, 0xe0, 0xdf }, { 0x2b, 0xa7, 0xa7, 0xc3, 0x94, 0x84, 0x0f, 0xe2, 0xa0, 0x40, 0x18, 0x60, 0x81, 0x5b, 0xe1, 0x1c, 0x40, 0x4d, 0x09, 0xe7, 0x6c, 0xb9, 0x02, 0xa8, 0xc4, 0xed, 0x37, 0x2f, 0xe3, 0x23, 0x13, 0x19 }, { 0x0a, 0x69, 0xec, 0xda, 0xb9, 0xec, 0xc6, 0x5c, 0x04, 0xb6, 0x7f, 0x77, 0x78, 0x3b, 0xb7, 0x33, 0xc8, 0x69, 0x1b, 0x71, 0xe0, 0x79, 0xdc, 0xa5, 0xa6, 0x29, 0x45, 0xe6, 0x22, 0x49, 0x3e, 0xff }, { 0x69, 0xb2, 0x79, 0x9e, 0x4a, 0xaf, 0x63, 0x11, 0x14, 0xd1, 0x55, 0x8b, 0x6e, 0xe7, 0x8c, 0x7e, 0xa0, 0x5a, 0x9d, 0xbf, 0x5c, 0xd3, 0x6f, 0x7e, 0xd7, 0xd4, 0xf7, 0x78, 0xdf, 0x77, 0xd9, 0xfe }, { 0x53, 0x2d, 0x3e, 0x0c, 0xfe, 0x56, 0xe1, 0xb1, 0xe6, 0xbf, 0xf4, 0x3c, 0x48, 0xb6, 0x26, 0x80, 0xaa, 0x79, 0x9f, 0xa5, 0x0b, 0x46, 0x1a, 0x2d, 0x01, 0x8b, 0x89, 0x2d, 0xae, 0x24, 0x00, 0xa9 }, { 0x93, 0x48, 0xdc, 0x37, 0x1e, 0x73, 0xa0, 0x5c, 0xa8, 0x61, 0x6b, 0xd2, 0xb1, 0x35, 0xfa, 0x30, 0x12, 0x60, 0xa5, 0x4b, 0xd3, 0x96, 0xc4, 0xb0, 0xdb, 0xf1, 0x75, 0x03, 0x7b, 0x08, 0xe8, 0xba }, { 0x74, 0x62, 0x71, 0x28, 0xb5, 0x29, 0xc5, 0x71, 0xad, 0x25, 0x56, 0x62, 0x37, 0xc1, 0x4f, 0x2f, 0x42, 0x81, 0xbf, 0x36, 0x5a, 0xbd, 0x40, 0xcd, 0x04, 0x8a, 0x3d, 0x5e, 0x42, 0x55, 0x8d, 0x7e }, { 0x48, 0x0f, 0x82, 0x02, 0x56, 0x61, 0x0b, 0x56, 0x15, 0xd5, 0xad, 0xab, 0x88, 0x8c, 0x71, 0x57, 0xdb, 0x22, 0xd7, 0x60, 0x64, 0xbe, 0x1a, 0xf6, 0xc6, 0x57, 0x9b, 0x52, 0x4a, 0x80, 0xe4, 0x9e }, { 0xe7, 0xbe, 0x50, 0xcb, 0x36, 0x23, 0x89, 0x51, 0x0a, 0xb1, 0x62, 0x0c, 0xf2, 0x4c, 0xf4, 0x27, 0x69, 0x71, 0xf5, 0xb0, 0x3e, 0xf9, 0x04, 0xa3, 0x54, 0xe1, 0x17, 0xe7, 0xd5, 0xa8, 0xf3, 0x8b }, { 0xba, 0x11, 0xde, 0x1d, 0xd9, 0x90, 0xdc, 0x60, 0x61, 0x59, 0xd0, 0x5c, 0x99, 0x48, 0xf9, 0x31, 0x85, 0x64, 0x66, 0x0b, 0x68, 0x72, 0x4e, 0x3d, 0x9f, 0xd7, 0x8e, 0x3b, 0xfd, 0xe5, 0x50, 0xc0 }, { 0xec, 0x08, 0xa6, 0xb0, 0x4e, 0x3a, 0x1c, 0x7d, 0xf5, 0x5e, 0xc7, 0x63, 0x40, 0x19, 0xda, 0x8a, 0x5f, 0xd1, 0xde, 0x89, 0x57, 0xdd, 0xf4, 0x61, 0x06, 0xe3, 0xe2, 0x60, 0x73, 0x96, 0xd1, 0x8b }, { 0x75, 0x39, 0x70, 0x7e, 0x7f, 0xf1, 0xf4, 0x7c, 0xf6, 0x87, 0x8b, 0x08, 0x9d, 0xff, 0x00, 0xbd, 0x8c, 0x21, 0x2a, 0x89, 0x39, 0xff, 0xcf, 0x9e, 0x2c, 0x22, 0x3e, 0x24, 0x52, 0xdc, 0x1a, 0x12 }, { 0x99, 0x71, 0xca, 0xa7, 0xb0, 0x1a, 0x25, 0x26, 0xdf, 0xa5, 0xde, 0x8f, 0x71, 0xb0, 0xa6, 0x08, 0x60, 0x13, 0x18, 0x4e, 0xde, 0x8f, 0xa4, 0x6c, 0xbf, 0x9e, 0x9b, 0x2b, 0x4e, 0x57, 0x3a, 0x0c }, { 0x65, 0x67, 0xad, 0xf8, 0x5f, 0xf4, 0xf8, 0x2c, 0xd1, 0x60, 0x62, 0xf1, 0xaa, 0x78, 0x0d, 0x33, 0xe1, 0x58, 0x26, 0xa8, 0x9b, 0xd3, 0x83, 0x53, 0x5a, 0xa4, 0x2b, 0x7e, 0xf0, 0x03, 0xbc, 0x2e }, { 0xa3, 0xb0, 0xe1, 0x6f, 0x94, 0xc3, 0xa7, 0x77, 0x96, 0xb4, 0xa3, 0x4b, 0xd5, 0x46, 0xef, 0x54, 0xcf, 0x57, 0x06, 0x2d, 0x0d, 0x80, 0x5a, 0x4c, 0x8c, 0x1b, 0x2b, 0xdf, 0x5c, 0xf7, 0x61, 0xf6 }, { 0x42, 0xbb, 0x68, 0x95, 0xee, 0x03, 0xcb, 0xe9, 0x59, 0x19, 0x04, 0xf0, 0xe7, 0xc3, 0x06, 0x47, 0x6d, 0xe7, 0x47, 0x08, 0x43, 0x97, 0xc6, 0xa7, 0xfd, 0x6e, 0xb0, 0x3b, 0x10, 0xcb, 0xd5, 0xf7 }, { 0x2d, 0x86, 0xb8, 0x99, 0xa4, 0x57, 0xc3, 0xcc, 0x2e, 0x77, 0xce, 0xf0, 0x17, 0x60, 0xff, 0x01, 0x18, 0x83, 0x35, 0xbd, 0xe9, 0x3a, 0x7b, 0x23, 0xd8, 0xd6, 0xff, 0x9a, 0xd2, 0xa1, 0x3f, 0xdd }, { 0x24, 0xda, 0xf4, 0x5f, 0x97, 0xf8, 0x9c, 0x97, 0x1c, 0xab, 0x4e, 0x95, 0xe5, 0x1d, 0x25, 0x7a, 0x12, 0xa3, 0x8f, 0x08, 0xa5, 0xb5, 0x54, 0x24, 0x06, 0x3f, 0x6b, 0x31, 0x7b, 0x5a, 0x12, 0x74 }, { 0xc3, 0xce, 0x2a, 0x1e, 0x7f, 0xc5, 0xb6, 0xf3, 0xc2, 0xfb, 0x37, 0x62, 0xab, 0x8f, 0x17, 0xdd, 0x14, 0x98, 0xe5, 0x0b, 0xeb, 0x2e, 0xb6, 0x37, 0x2d, 0x81, 0x12, 0xec, 0x42, 0x0a, 0x12, 0xb8 }, { 0xc7, 0x8c, 0x16, 0x7f, 0xc2, 0x2c, 0xd7, 0xea, 0x26, 0xc7, 0x6b, 0xd3, 0xc3, 0x13, 0x8f, 0xf3, 0xad, 0xee, 0x6d, 0x70, 0xfb, 0x13, 0x4f, 0xeb, 0xe0, 0xb0, 0x51, 0xcd, 0xd2, 0x58, 0x3f, 0x96 }, { 0x9f, 0x84, 0xdc, 0xa7, 0x8c, 0x13, 0x05, 0x3e, 0x73, 0xb7, 0x91, 0x37, 0xd8, 0xd9, 0xe4, 0x05, 0x77, 0x9c, 0xfc, 0x8e, 0xf3, 0xd4, 0x82, 0x49, 0x97, 0xfb, 0xbc, 0xe1, 0xe9, 0x68, 0x2d, 0xbd }, { 0x6d, 0x52, 0x5c, 0x54, 0x60, 0x94, 0xc5, 0xdb, 0x76, 0x00, 0x67, 0x8e, 0x84, 0xa0, 0x7d, 0x15, 0x95, 0x46, 0x85, 0x26, 0xc0, 0x2f, 0x90, 0x7b, 0x34, 0xfe, 0x43, 0xef, 0x32, 0x7f, 0x21, 0x24 }, { 0x8e, 0x9b, 0x5e, 0x02, 0xb0, 0x71, 0xa0, 0xb6, 0x02, 0x31, 0x9e, 0xf3, 0x8a, 0x07, 0x0d, 0x1f, 0xd0, 0x59, 0x06, 0xb8, 0xc3, 0x93, 0x97, 0xb0, 0x0e, 0xb9, 0xbd, 0x0f, 0xd5, 0xc5, 0x28, 0xa2 }, { 0x57, 0x04, 0x19, 0x0a, 0x0c, 0xbc, 0x48, 0x74, 0x63, 0x76, 0x59, 0xed, 0xb3, 0x44, 0x7e, 0x02, 0xa0, 0x94, 0x16, 0xdd, 0xc5, 0x47, 0x74, 0x01, 0x1e, 0xa1, 0x26, 0x1a, 0x86, 0xff, 0x43, 0x8d }, { 0xb3, 0xc5, 0xa7, 0xd0, 0x96, 0x05, 0x9d, 0x81, 0x80, 0xd1, 0x48, 0x58, 0xe4, 0xde, 0xfb, 0x54, 0x4f, 0xab, 0x31, 0xe7, 0x6a, 0x62, 0x89, 0xd4, 0x64, 0x92, 0xd3, 0xdb, 0x5b, 0xab, 0xcf, 0xc7 }, { 0x2d, 0x0b, 0x96, 0xe4, 0x92, 0x10, 0x36, 0x29, 0x54, 0xb0, 0x79, 0x32, 0x00, 0xed, 0x25, 0x2f, 0x7c, 0x4a, 0xb2, 0xc2, 0xa0, 0x39, 0xc7, 0x3b, 0x41, 0x8e, 0x43, 0xa7, 0x81, 0x16, 0xcb, 0xf4 }, { 0xdc, 0xaa, 0x48, 0x3d, 0x90, 0xa1, 0xb6, 0xf5, 0xcc, 0x0f, 0x7a, 0xba, 0xcc, 0xf2, 0x0b, 0xc9, 0x15, 0x53, 0xe1, 0xd9, 0x88, 0xe0, 0x8e, 0x82, 0xf7, 0x98, 0x27, 0x47, 0x6d, 0x15, 0x7c, 0x7c }, { 0x31, 0x51, 0xca, 0x41, 0xcb, 0x6c, 0x80, 0x56, 0x56, 0x58, 0x2d, 0x17, 0x24, 0x10, 0x6c, 0x2a, 0x88, 0xe0, 0x9e, 0x62, 0xb6, 0xa4, 0xac, 0xb0, 0x57, 0x32, 0x05, 0x23, 0x4a, 0xaf, 0x0e, 0x5e }, { 0x16, 0x4e, 0x58, 0x28, 0x28, 0x45, 0xba, 0x15, 0x95, 0xc3, 0xe9, 0x64, 0x62, 0x9f, 0xef, 0x1d, 0x94, 0x3e, 0xb1, 0x34, 0x9a, 0xe9, 0x80, 0x26, 0x2b, 0xb0, 0xef, 0xce, 0xbf, 0x72, 0xcd, 0x8f }, { 0xe0, 0x16, 0xfe, 0x07, 0x4a, 0x6d, 0xa7, 0x31, 0x97, 0x5b, 0x3d, 0x62, 0xd5, 0xd0, 0x4b, 0x0e, 0xe1, 0x6e, 0x5e, 0xd6, 0xbb, 0xd8, 0xb0, 0xfb, 0xab, 0xb4, 0xc8, 0xd4, 0xb5, 0x18, 0xaf, 0x9e }, { 0x86, 0x7b, 0x18, 0x5f, 0xd0, 0xb0, 0x9a, 0x09, 0x3b, 0x0f, 0xd6, 0x1a, 0x20, 0x22, 0xfe, 0x82, 0x55, 0x70, 0xfb, 0x31, 0x1c, 0x8c, 0xb7, 0xf0, 0x4e, 0xf3, 0x56, 0x1e, 0x08, 0xc9, 0x92, 0x89 }, { 0xe7, 0x55, 0x6e, 0x5c, 0xc9, 0x57, 0xab, 0xdb, 0x15, 0x15, 0x88, 0x4c, 0xb3, 0x94, 0x29, 0x52, 0xdc, 0x52, 0x70, 0xe4, 0x31, 0x98, 0xc7, 0x96, 0x13, 0x7e, 0x1d, 0x67, 0x0a, 0xc5, 0x56, 0x17 }, { 0x61, 0x1b, 0xbf, 0xec, 0x47, 0x9a, 0x56, 0x8e, 0xe4, 0x37, 0x06, 0x25, 0x91, 0xb9, 0xd5, 0x0d, 0x4f, 0x87, 0xcc, 0x84, 0x5c, 0x25, 0xe5, 0xa0, 0x84, 0x5c, 0x38, 0xfe, 0x02, 0xc0, 0x7b, 0x74 }, { 0xde, 0x4b, 0xb0, 0xa8, 0x9d, 0x35, 0xa0, 0xa5, 0xa3, 0x3a, 0x03, 0x64, 0xda, 0x56, 0xd9, 0xea, 0x1b, 0x54, 0x1f, 0x0a, 0xcb, 0x36, 0x8e, 0x70, 0x6c, 0x9f, 0x76, 0xfa, 0xb4, 0xed, 0xac, 0xa0 }, { 0x82, 0x28, 0xe1, 0x27, 0x6c, 0x55, 0xe2, 0xc5, 0x15, 0x14, 0xec, 0x67, 0x0a, 0xb8, 0xe9, 0x8d, 0xb0, 0x9b, 0xf1, 0xfa, 0xa5, 0x15, 0x12, 0x00, 0x75, 0xb8, 0xb2, 0x28, 0xbd, 0x32, 0xdc, 0x8e }, { 0x16, 0x50, 0x35, 0x52, 0x1d, 0x63, 0xa1, 0x51, 0x7d, 0xe3, 0xfc, 0x77, 0xc7, 0x2d, 0x82, 0x1f, 0xe6, 0xa8, 0xa6, 0x24, 0xb2, 0xe1, 0x53, 0x7f, 0xd9, 0xf1, 0x80, 0x62, 0x53, 0x22, 0x7f, 0x6a }, { 0x0a, 0xf2, 0xbc, 0x0b, 0x0d, 0x3a, 0x64, 0x8e, 0x39, 0x8b, 0x9e, 0x77, 0xc0, 0x51, 0xf8, 0x68, 0xd4, 0xd3, 0x57, 0xf9, 0x63, 0x47, 0x31, 0x57, 0x42, 0xf5, 0x64, 0x8d, 0xaf, 0x48, 0x8a, 0x1a }, { 0x43, 0xaf, 0xf0, 0x3b, 0x7e, 0x68, 0x76, 0x4f, 0xb5, 0x7b, 0x1e, 0xa8, 0xeb, 0x45, 0x92, 0x8d, 0x75, 0x51, 0x81, 0x9f, 0x7d, 0x3f, 0x07, 0xd8, 0xa3, 0x1c, 0xd4, 0xbb, 0xa8, 0xfc, 0x6a, 0x80 }, { 0x46, 0xfb, 0x35, 0xfe, 0xc3, 0xb3, 0xdc, 0x30, 0x6b, 0x7e, 0x9e, 0xcf, 0x22, 0x1c, 0x48, 0x59, 0x57, 0x34, 0xde, 0x23, 0x45, 0x06, 0xe9, 0xff, 0x36, 0x62, 0x01, 0x15, 0x8c, 0x19, 0xd6, 0xee }, { 0xae, 0xe6, 0x24, 0x92, 0xe9, 0x9c, 0x66, 0x0e, 0xda, 0xd4, 0xb9, 0x30, 0xfd, 0xc7, 0xec, 0x63, 0xfe, 0x8a, 0x1f, 0x0f, 0xa1, 0xdf, 0xca, 0xa9, 0x90, 0xea, 0xbb, 0xa7, 0x65, 0xcb, 0xc9, 0x41 }, { 0xed, 0x49, 0x2a, 0x48, 0x8e, 0x3b, 0x1e, 0x7b, 0x6d, 0x67, 0x2f, 0xdf, 0xf4, 0x89, 0xf6, 0x7d, 0xf0, 0x68, 0x65, 0x2f, 0xd4, 0xe3, 0x53, 0x01, 0x82, 0x83, 0x5d, 0xc7, 0x3d, 0x3c, 0x06, 0xa7 }, { 0x5c, 0x20, 0xb2, 0xe1, 0xc2, 0xe8, 0x37, 0x56, 0x37, 0x78, 0x7d, 0xe9, 0x5d, 0x4e, 0x20, 0x77, 0x67, 0x54, 0x37, 0x5e, 0x53, 0xf5, 0x05, 0xa9, 0x5a, 0x4f, 0x5e, 0xcc, 0xb6, 0xdf, 0x5e, 0x97 }, { 0xd6, 0x50, 0xc5, 0x35, 0xbe, 0xa5, 0x9e, 0xe8, 0x15, 0xe6, 0x45, 0xa1, 0xdd, 0x67, 0xc9, 0xdd, 0x99, 0x57, 0xfd, 0x18, 0xa5, 0x63, 0x4f, 0x28, 0xc0, 0xd5, 0xd7, 0xa2, 0xfb, 0x84, 0xcb, 0xbd }, { 0xba, 0x81, 0x78, 0x77, 0xad, 0x41, 0xb8, 0xc7, 0x70, 0x67, 0x04, 0x26, 0x45, 0x7f, 0xa4, 0x24, 0x1e, 0x90, 0x68, 0x32, 0x9b, 0x39, 0x5c, 0xc0, 0x77, 0xaa, 0x0f, 0x2c, 0x33, 0xb6, 0x4b, 0x78 }, { 0x4b, 0xe5, 0x2b, 0xf0, 0xae, 0xdf, 0x63, 0x96, 0x4f, 0x60, 0x2a, 0x71, 0x73, 0xf6, 0xb7, 0x32, 0x43, 0x27, 0x70, 0x95, 0x0e, 0xe3, 0x5d, 0x3a, 0xd6, 0xad, 0xf5, 0x9b, 0x51, 0x8e, 0x1c, 0xea }, { 0xd2, 0x70, 0xc5, 0x46, 0xf2, 0x5b, 0x75, 0x09, 0x97, 0x58, 0x1b, 0x61, 0xa5, 0x8a, 0x25, 0x2a, 0x0a, 0x4b, 0xb2, 0x19, 0x06, 0x0c, 0x0b, 0x60, 0x80, 0x94, 0x44, 0x11, 0xa8, 0x24, 0x80, 0x6d }, { 0x28, 0x04, 0x94, 0x35, 0xea, 0x0c, 0x68, 0x55, 0x97, 0xce, 0xef, 0x22, 0x18, 0x93, 0x28, 0x19, 0x25, 0xd6, 0x3d, 0xfa, 0x7b, 0x1b, 0x67, 0x12, 0x4c, 0xd8, 0x82, 0x8b, 0x77, 0x5c, 0x95, 0xfd }, { 0x64, 0x59, 0x78, 0xc3, 0x82, 0x06, 0x56, 0x64, 0x86, 0x0f, 0xcf, 0x60, 0xdc, 0xe8, 0xf9, 0x14, 0x42, 0x53, 0xad, 0x4c, 0xc5, 0x8f, 0x93, 0x1e, 0x94, 0x34, 0x4a, 0xa6, 0x46, 0x8d, 0x2a, 0xe0 }, { 0x3c, 0x2a, 0xd1, 0xbd, 0x81, 0x60, 0x94, 0xdc, 0x99, 0x79, 0x0a, 0xb0, 0x8a, 0xd9, 0xdc, 0x3f, 0x44, 0xfc, 0xa7, 0x1a, 0x84, 0xaf, 0x5c, 0xa1, 0x94, 0xa8, 0x49, 0x60, 0xdc, 0x96, 0x9c, 0x85 }, { 0xe1, 0x20, 0x35, 0xd6, 0xfe, 0x97, 0x17, 0x21, 0xde, 0x96, 0xa5, 0xfe, 0x09, 0xf1, 0xac, 0x11, 0x8d, 0x12, 0x66, 0x14, 0x9e, 0xd5, 0xa0, 0xb3, 0x0a, 0x74, 0x00, 0x45, 0x88, 0xed, 0x9b, 0x07 }, { 0x5d, 0x1d, 0x68, 0xff, 0xa0, 0x2c, 0x69, 0x21, 0xec, 0x15, 0xdd, 0x04, 0x40, 0x64, 0xbf, 0x9e, 0x1a, 0x4d, 0xd3, 0xb6, 0xf7, 0x4e, 0xfc, 0x7d, 0x81, 0xcb, 0x6d, 0xd0, 0xd9, 0xe7, 0xe7, 0x14 }, { 0x73, 0xbd, 0xa7, 0x30, 0xdd, 0xde, 0x9e, 0xfc, 0x10, 0xf2, 0x85, 0x17, 0x5d, 0x2d, 0x10, 0xd2, 0x93, 0x8e, 0xdc, 0xf9, 0x81, 0x81, 0x3c, 0xe2, 0x92, 0x80, 0x8a, 0xa6, 0xa9, 0xe0, 0x65, 0xc4 }, { 0x17, 0x27, 0x05, 0x71, 0x4d, 0xe1, 0xea, 0xb0, 0xf9, 0xa8, 0xab, 0xb2, 0xfe, 0x6d, 0xdd, 0x11, 0x1d, 0x8f, 0x24, 0x9f, 0x2d, 0x1f, 0x98, 0x5a, 0x62, 0x23, 0xa1, 0xb2, 0x75, 0xdf, 0x2f, 0xaf }, { 0xc4, 0x69, 0x99, 0x32, 0x99, 0x49, 0x54, 0xae, 0xd4, 0x38, 0x06, 0xa1, 0x57, 0xcf, 0x99, 0x1b, 0xb8, 0xc8, 0x94, 0x7c, 0x5e, 0x80, 0x0e, 0x5b, 0x0e, 0xd2, 0x64, 0xb1, 0xaa, 0x1e, 0x2e, 0x5a }, { 0x9e, 0x0c, 0xfe, 0x3e, 0xec, 0x6e, 0xb1, 0xd4, 0xe6, 0xff, 0x6d, 0xdb, 0xbf, 0xb4, 0x42, 0x58, 0x75, 0xd3, 0x5c, 0x4d, 0xf2, 0xd1, 0x24, 0x75, 0x8f, 0xab, 0xc3, 0x8b, 0x49, 0xf8, 0x5a, 0xff }, { 0x85, 0x12, 0x1f, 0x24, 0x1c, 0xf4, 0x9c, 0xd4, 0x13, 0x57, 0x03, 0xba, 0x2e, 0x58, 0x3e, 0x40, 0xac, 0x62, 0x73, 0xfd, 0x3b, 0x33, 0xfd, 0x3e, 0xe4, 0xbb, 0xa6, 0x61, 0xae, 0xaf, 0x54, 0x55 }, { 0xfb, 0x9b, 0xf7, 0xcc, 0x73, 0xb3, 0x07, 0x13, 0x8b, 0x99, 0x9c, 0x3f, 0xf1, 0xa3, 0x17, 0x62, 0x69, 0x4d, 0x10, 0x6d, 0x45, 0xb3, 0x58, 0x54, 0x51, 0x3c, 0x15, 0x44, 0x59, 0x6a, 0x11, 0xf3 }, { 0x23, 0x2d, 0x6a, 0x3a, 0xe6, 0x85, 0x31, 0xbf, 0xcb, 0x94, 0x91, 0xf1, 0x33, 0x94, 0xea, 0x29, 0x7d, 0x92, 0x5c, 0x79, 0x00, 0x3e, 0xc4, 0xee, 0xaf, 0xce, 0xff, 0x81, 0x41, 0xfa, 0xc8, 0x15 }, { 0xab, 0xd2, 0xb5, 0x2e, 0x27, 0x02, 0xf9, 0xfe, 0xe8, 0x09, 0xfa, 0x08, 0x09, 0x8b, 0x8c, 0x4a, 0x0f, 0x43, 0xa5, 0xcc, 0xbc, 0xcf, 0x21, 0x0f, 0x13, 0xdd, 0xce, 0xab, 0xb7, 0xd4, 0x4c, 0x2a }, { 0x9b, 0x28, 0x4a, 0x37, 0xc4, 0x78, 0xa1, 0x57, 0xc9, 0x29, 0xe7, 0xa7, 0xdd, 0x16, 0xd8, 0x09, 0xf9, 0x04, 0xd5, 0x7c, 0x37, 0xa3, 0x0c, 0xf3, 0xa7, 0x27, 0xc9, 0x77, 0x17, 0xd8, 0x98, 0x0c }, { 0xcd, 0xbe, 0xe0, 0xaf, 0x61, 0x92, 0xa0, 0x26, 0x95, 0x87, 0x92, 0x14, 0xb6, 0x0d, 0x57, 0x8f, 0x97, 0x2a, 0x37, 0xf5, 0xd7, 0x2e, 0xc8, 0xd0, 0xb5, 0xb6, 0x27, 0xd5, 0x42, 0xc7, 0x0c, 0xd3 }, { 0x40, 0xff, 0x1b, 0xb2, 0x16, 0x13, 0x37, 0x99, 0xf3, 0xef, 0x4f, 0xaa, 0xba, 0xe5, 0xfa, 0x24, 0x09, 0xa5, 0xc9, 0x5a, 0xff, 0xc9, 0xb5, 0x42, 0xff, 0xe7, 0xad, 0xbf, 0xb6, 0x42, 0xa6, 0xc1 }, { 0xcf, 0xaa, 0x36, 0xb3, 0xa0, 0xda, 0xcf, 0x1f, 0x43, 0xcb, 0x90, 0x7d, 0xf5, 0x3d, 0x0a, 0xc0, 0x68, 0x8d, 0x36, 0xfe, 0xb3, 0x0d, 0xf1, 0x16, 0x0d, 0xe1, 0x24, 0x43, 0xb0, 0x41, 0x5f, 0xbb }, }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t plain_texts3_128bit[ 100 ][ 25 ] = { { 0x94, 0x75, 0xdd, 0x02, 0x15, 0x37, 0x32, 0xbb, 0x6b, 0x31, 0xe2, 0x9f, 0x8d, 0xa5, 0xc3, 0x57, 0x65, 0x8c, 0x2d, 0xad, 0x55, 0xbf, 0xe9, 0x60, 0xdf }, { 0xed, 0x35, 0x0c, 0xb0, 0x5b, 0xa6, 0x5b, 0x5e, 0x5b, 0x1f, 0xe4, 0x37, 0xa1, 0x5d, 0xb5, 0x7c, 0x66, 0xb4, 0xc2, 0xb7, 0x48, 0x1a, 0x41, 0x5e, 0x6f }, { 0x86, 0x12, 0x0e, 0x30, 0x8d, 0x7e, 0x38, 0xe7, 0xbd, 0x9b, 0x43, 0x77, 0x15, 0xe1, 0x9e, 0x43, 0xb2, 0x43, 0xfc, 0xa9, 0xe4, 0xcd, 0x05, 0xc0, 0xf5 }, { 0x92, 0xde, 0xa2, 0xec, 0x45, 0x9a, 0x91, 0xdf, 0xe8, 0x4b, 0xdf, 0xcc, 0x5c, 0x08, 0xeb, 0x6a, 0x3c, 0x86, 0x12, 0x41, 0xc0, 0x52, 0x41, 0xc7, 0xfa }, { 0xec, 0xbf, 0xfc, 0xcc, 0xdc, 0x9e, 0x1b, 0xbe, 0x60, 0x2f, 0x1a, 0xa1, 0xe5, 0x1b, 0xb3, 0xad, 0x0d, 0x70, 0xc5, 0x6d, 0x34, 0x40, 0x5b, 0xce, 0xdd }, { 0x49, 0x0c, 0x6b, 0x50, 0x8d, 0x5d, 0x58, 0xfe, 0x24, 0xc5, 0xd3, 0xdf, 0x81, 0xdd, 0x90, 0x8c, 0xb0, 0x47, 0x47, 0x37, 0x57, 0xac, 0xb4, 0x61, 0x13 }, { 0xdd, 0x74, 0x3f, 0x4d, 0xe3, 0xcb, 0xb9, 0x91, 0x1f, 0xc6, 0xb8, 0xa0, 0x49, 0x32, 0x1c, 0xd1, 0xfb, 0x81, 0x3a, 0x7e, 0x91, 0x52, 0xfe, 0xe4, 0x84 }, { 0xf8, 0x26, 0x70, 0x8d, 0xf3, 0x91, 0xb4, 0x65, 0xc3, 0x95, 0x71, 0xcf, 0x69, 0x08, 0xa5, 0xf7, 0x30, 0xea, 0x60, 0x38, 0x03, 0x4f, 0x25, 0xa1, 0x50 }, { 0x92, 0x43, 0x75, 0x49, 0x96, 0xb0, 0x06, 0x61, 0x08, 0x9e, 0x35, 0xac, 0x65, 0x42, 0x3d, 0x63, 0x17, 0x7d, 0xa0, 0x76, 0x46, 0x2c, 0x71, 0x85, 0xc6 }, { 0x9a, 0xd2, 0x3c, 0xb9, 0xbd, 0x37, 0x7a, 0x05, 0x02, 0xe4, 0xcc, 0x9f, 0x9d, 0xf4, 0x3b, 0x8b, 0x83, 0x05, 0x49, 0x77, 0x9e, 0x92, 0x23, 0xfe, 0xf8 }, { 0x54, 0x32, 0x4f, 0x39, 0xcf, 0xe3, 0x46, 0x31, 0x26, 0x92, 0x5e, 0xf4, 0x44, 0xca, 0xf1, 0x8b, 0x3b, 0xeb, 0xd2, 0x95, 0x66, 0x51, 0xf0, 0xe6, 0xfd }, { 0xd3, 0xd4, 0x36, 0x53, 0x39, 0x38, 0x03, 0xfd, 0x1b, 0xc2, 0xbd, 0xb4, 0xa2, 0x7c, 0xad, 0x10, 0x85, 0xd8, 0x23, 0x5c, 0xf8, 0x75, 0x42, 0x6a, 0xf3 }, { 0x2e, 0x6d, 0xa9, 0xda, 0xc3, 0xd1, 0x67, 0x20, 0xd0, 0xb4, 0x02, 0xea, 0xa4, 0x8d, 0x58, 0x5f, 0x76, 0xa3, 0xc6, 0xda, 0x6a, 0x87, 0x2e, 0x94, 0xdb }, { 0x6e, 0x3a, 0x04, 0x42, 0x95, 0x8f, 0x64, 0x21, 0xa1, 0x47, 0xb2, 0xb4, 0xef, 0x7a, 0x8d, 0xe8, 0xcf, 0x3e, 0x37, 0x5a, 0xf8, 0xd0, 0x7d, 0x73, 0xbd }, { 0x85, 0x86, 0x8e, 0xc4, 0xaf, 0x1d, 0xf8, 0x7f, 0xbc, 0x3a, 0x3c, 0xb8, 0x40, 0xea, 0x93, 0xbe, 0x60, 0x98, 0xc0, 0xdc, 0xf3, 0x5f, 0x18, 0x90, 0x1b }, { 0xe5, 0xa0, 0xe9, 0x87, 0x44, 0x8f, 0xb9, 0x09, 0xb5, 0x80, 0x33, 0xf8, 0x67, 0x0a, 0xaa, 0x88, 0x23, 0x17, 0x37, 0x0f, 0x0a, 0x44, 0x27, 0xfb, 0xc3 }, { 0xaf, 0x0d, 0xb7, 0x96, 0x8c, 0x67, 0xf6, 0x8f, 0x31, 0x37, 0x08, 0xa5, 0x5d, 0x1d, 0xe9, 0xde, 0x87, 0x49, 0x1c, 0x2c, 0x07, 0xf7, 0x4c, 0xdf, 0x85 }, { 0xd6, 0x06, 0xec, 0x41, 0x46, 0x42, 0x81, 0x45, 0xdb, 0x4c, 0xac, 0xcb, 0x7b, 0x5b, 0x87, 0xfd, 0xc2, 0xd4, 0xd2, 0x5b, 0x7a, 0x44, 0xec, 0x99, 0x3a }, { 0x63, 0xdb, 0x50, 0x6c, 0x7e, 0xa1, 0x7e, 0x5c, 0xd7, 0x5d, 0xcc, 0x12, 0xf6, 0xc4, 0xa4, 0x27, 0x30, 0x5b, 0xb9, 0x8e, 0xa6, 0x24, 0x7b, 0x47, 0xb2 }, { 0xbd, 0x22, 0x51, 0x16, 0x0c, 0x6b, 0x3e, 0xa8, 0x0c, 0xcc, 0x35, 0x47, 0x58, 0xee, 0x29, 0x71, 0xbd, 0xc8, 0xde, 0x9e, 0xf7, 0xe9, 0x40, 0x56, 0xc4 }, { 0xc6, 0x69, 0xd4, 0x46, 0x47, 0x84, 0xeb, 0x9b, 0xcd, 0xd0, 0x9f, 0x8e, 0x3a, 0xa3, 0x8a, 0x3c, 0x83, 0x8d, 0x1d, 0x34, 0xf8, 0xd3, 0xf5, 0x50, 0x52 }, { 0xc3, 0xf4, 0x59, 0x37, 0x0e, 0xa0, 0x4d, 0x69, 0x97, 0xb4, 0x6a, 0x7c, 0xe5, 0x23, 0xf6, 0x3e, 0x26, 0x0a, 0x24, 0x95, 0xdc, 0xb6, 0x48, 0xae, 0xc7 }, { 0xe9, 0x53, 0x2d, 0xa7, 0x5d, 0xa1, 0xa5, 0xc1, 0x3b, 0x74, 0x66, 0x67, 0xfb, 0x07, 0x26, 0x01, 0xdd, 0x70, 0x15, 0x67, 0x71, 0x4a, 0xdc, 0xe4, 0x2d }, { 0x5a, 0xa1, 0x1c, 0x28, 0x74, 0x5d, 0x15, 0x56, 0x7c, 0x77, 0x4a, 0xd6, 0x18, 0x58, 0x13, 0xc2, 0x28, 0x06, 0x73, 0xc8, 0xf0, 0x32, 0xa6, 0x1c, 0x6c }, { 0x04, 0x9e, 0xe2, 0xf3, 0xb0, 0x49, 0xe9, 0x30, 0x3a, 0x0d, 0x4b, 0xf4, 0x7f, 0x0c, 0x5b, 0x76, 0xe6, 0xf6, 0xd1, 0x43, 0x11, 0x58, 0xb2, 0xd2, 0x3a }, { 0x81, 0xab, 0x55, 0x15, 0x1b, 0x51, 0xb4, 0x18, 0x81, 0xe6, 0x75, 0xc4, 0xd8, 0xbf, 0xb3, 0x76, 0xd7, 0x9c, 0x26, 0x42, 0x5b, 0xe1, 0xbd, 0x6a, 0x5e }, { 0xc5, 0x98, 0x1c, 0x2f, 0x99, 0xd8, 0xba, 0xf6, 0xcf, 0x78, 0x50, 0xd9, 0xf3, 0x62, 0x9b, 0xe0, 0x55, 0x8d, 0x41, 0x1b, 0xaf, 0xa3, 0x06, 0x57, 0xe3 }, { 0x33, 0xd4, 0xc7, 0x1a, 0x8c, 0x59, 0x39, 0x4c, 0x82, 0x62, 0xa9, 0x20, 0x9b, 0xec, 0x31, 0x48, 0x4c, 0xfe, 0xc2, 0x7f, 0x44, 0x9e, 0x22, 0x3b, 0x3b }, { 0x95, 0xed, 0xed, 0xf9, 0xfa, 0x5c, 0xa3, 0x94, 0x8a, 0x84, 0x9e, 0x5e, 0x3e, 0xea, 0x11, 0x64, 0x2f, 0xae, 0xfd, 0xa4, 0xdb, 0x41, 0x5f, 0xab, 0x5b }, { 0x35, 0x8e, 0x7b, 0xe7, 0x5e, 0x5a, 0x18, 0xa8, 0x23, 0x4e, 0x53, 0x6e, 0x37, 0x40, 0x24, 0xc4, 0x73, 0x68, 0x01, 0x86, 0xd3, 0xa8, 0x5f, 0x5d, 0x20 }, { 0x82, 0xa0, 0x50, 0x58, 0x46, 0x4d, 0x90, 0xec, 0xc6, 0x7b, 0x5a, 0xd3, 0x14, 0xe5, 0x79, 0x5a, 0xb0, 0xa4, 0x56, 0x27, 0x41, 0x66, 0x32, 0x87, 0x3f }, { 0xd8, 0x12, 0xb7, 0x64, 0x44, 0x9a, 0xc9, 0x57, 0xf8, 0x8b, 0x3c, 0xc6, 0x34, 0x9c, 0x0a, 0x74, 0x33, 0x8a, 0x52, 0x9d, 0xd7, 0x9d, 0x6b, 0xca, 0xab }, { 0x4d, 0xb3, 0x87, 0x63, 0xd9, 0x3f, 0x33, 0x45, 0x47, 0xcc, 0x76, 0x0d, 0xfb, 0x6b, 0x18, 0x7a, 0xbe, 0x5b, 0x5a, 0x02, 0x46, 0xc5, 0x8e, 0xb0, 0x66 }, { 0xd3, 0xfe, 0xf0, 0x15, 0x61, 0x3f, 0x51, 0xd2, 0xe3, 0x58, 0x83, 0x7f, 0x4e, 0x0e, 0x23, 0xa1, 0x05, 0xba, 0xa8, 0x74, 0xc6, 0x4d, 0xb2, 0x53, 0x1d }, { 0x41, 0x26, 0x39, 0xe3, 0x06, 0xc3, 0x06, 0x13, 0x47, 0x6f, 0x95, 0x1e, 0xc6, 0x1a, 0x20, 0x32, 0x1a, 0x00, 0x83, 0x88, 0x6f, 0xc3, 0xc0, 0xe3, 0xa7 }, { 0x9d, 0x24, 0x7e, 0xef, 0x8e, 0x3e, 0x00, 0xfc, 0xcf, 0x51, 0x9a, 0x7e, 0x0b, 0x61, 0x00, 0x8f, 0xd7, 0x3d, 0x2a, 0x5a, 0x17, 0x67, 0x72, 0x10, 0x96 }, { 0xaa, 0x7a, 0x0f, 0xb2, 0x19, 0x3c, 0x6c, 0x57, 0xb8, 0x2d, 0x3f, 0x37, 0x56, 0x2f, 0x3f, 0xf8, 0xc9, 0xd8, 0xec, 0x0e, 0x5f, 0xe7, 0xea, 0xd0, 0xd6 }, { 0x22, 0x90, 0x1e, 0xf0, 0xf8, 0x65, 0xe9, 0x2d, 0x2b, 0xea, 0x19, 0x23, 0x8c, 0xf5, 0xd7, 0x6a, 0x80, 0x2b, 0x7a, 0xf4, 0x76, 0x42, 0xeb, 0xd7, 0x42 }, { 0x88, 0x1e, 0x90, 0xb4, 0xc7, 0x0d, 0xdb, 0xda, 0x40, 0xb7, 0xe4, 0xc4, 0x65, 0x48, 0x2e, 0x98, 0x54, 0xe1, 0x94, 0xba, 0x96, 0x4d, 0x1f, 0x80, 0xa2 }, { 0x25, 0xb2, 0xed, 0x35, 0x46, 0xe7, 0xf1, 0x74, 0xa2, 0x9b, 0xf8, 0x43, 0x37, 0x7e, 0x91, 0x39, 0xae, 0x42, 0x8a, 0x24, 0xd4, 0xc9, 0xe6, 0x28, 0x52 }, { 0x67, 0xa3, 0x7d, 0x74, 0xef, 0x2e, 0xde, 0x7c, 0xee, 0x56, 0xfd, 0x5e, 0xa3, 0xad, 0x41, 0x8d, 0x08, 0xcf, 0x9a, 0x1d, 0xbb, 0xf1, 0x1a, 0xf9, 0xc3 }, { 0xc4, 0x48, 0x0c, 0x6e, 0x7c, 0xb1, 0x94, 0xe0, 0x86, 0xb9, 0x8f, 0xa2, 0xae, 0x41, 0xf6, 0x62, 0xc8, 0xb6, 0xbd, 0xad, 0xa2, 0x9e, 0x3d, 0x39, 0x4c }, { 0x95, 0xa6, 0x5a, 0x9e, 0x57, 0xc8, 0x1a, 0xd3, 0xa3, 0x81, 0xb0, 0x99, 0x4c, 0xb7, 0x19, 0x71, 0x4a, 0xd6, 0x83, 0x82, 0x55, 0x53, 0x4d, 0x3d, 0x1b }, { 0x29, 0xc3, 0x50, 0x8f, 0xba, 0x48, 0x28, 0x5f, 0x2c, 0x02, 0xea, 0xab, 0xf7, 0x5e, 0x79, 0x02, 0x68, 0xa6, 0xd5, 0x9e, 0x52, 0xfc, 0x2d, 0xcc, 0xab }, { 0xa3, 0x2d, 0x4b, 0x93, 0x55, 0xaf, 0xa6, 0x90, 0x52, 0x52, 0x11, 0x18, 0x5e, 0x19, 0x58, 0x68, 0x60, 0xea, 0xb6, 0x7d, 0x34, 0x30, 0x8e, 0xc4, 0xa6 }, { 0x59, 0x63, 0x16, 0x52, 0xdd, 0xbc, 0x62, 0x39, 0x57, 0x84, 0xbf, 0x18, 0xcb, 0xc9, 0x67, 0xce, 0xf6, 0x6e, 0xa5, 0x18, 0x0f, 0x3f, 0x6d, 0xf5, 0xaa }, { 0xd4, 0x2a, 0xd0, 0x36, 0x52, 0x1b, 0x1d, 0x84, 0x20, 0x0f, 0xaf, 0x86, 0xd9, 0x78, 0x86, 0x79, 0xe8, 0x93, 0x77, 0x28, 0x0b, 0x78, 0x33, 0xe4, 0x34 }, { 0x66, 0x31, 0x73, 0x22, 0xce, 0xf8, 0x42, 0x5d, 0x53, 0x5e, 0xb6, 0xb2, 0x95, 0x10, 0xac, 0x97, 0x62, 0xed, 0x07, 0x7c, 0x66, 0x24, 0xc5, 0x00, 0xe9 }, { 0x86, 0x10, 0x52, 0xfe, 0xe0, 0xe7, 0x44, 0xf3, 0x46, 0xf1, 0x13, 0xaf, 0x0e, 0x81, 0x10, 0x03, 0x60, 0x08, 0x8f, 0xaf, 0x18, 0x34, 0xbc, 0x6c, 0xc5 }, { 0x48, 0x0b, 0xfe, 0x39, 0x8c, 0x1a, 0x62, 0x71, 0x29, 0xd1, 0x1a, 0x51, 0xc9, 0xde, 0x9b, 0x4e, 0x0a, 0xbd, 0xa9, 0x40, 0x20, 0xdb, 0xc5, 0xd1, 0x49 }, { 0x30, 0xa7, 0xe3, 0x38, 0x2b, 0x77, 0x78, 0xbb, 0x6f, 0xd2, 0xee, 0xc2, 0xb6, 0x1e, 0x29, 0x70, 0xdc, 0xc3, 0x4f, 0xe8, 0xe9, 0xb7, 0xb8, 0xbf, 0x4e }, { 0x3d, 0x90, 0xee, 0xed, 0x5a, 0x13, 0x68, 0x06, 0x53, 0xb2, 0x1e, 0x6d, 0x8e, 0x76, 0x66, 0x24, 0x62, 0x1e, 0x00, 0x27, 0xf8, 0xc6, 0x0c, 0xd1, 0x05 }, { 0xe1, 0x71, 0xb4, 0x93, 0x71, 0xf0, 0x13, 0x55, 0xb8, 0x6c, 0xa8, 0xf7, 0xe4, 0x5a, 0x9b, 0xf5, 0x35, 0x71, 0x3b, 0x05, 0xea, 0x0e, 0x14, 0x54, 0xe5 }, { 0x54, 0xb3, 0xbf, 0xb4, 0x07, 0x6e, 0x61, 0xaa, 0x95, 0x23, 0x54, 0xf3, 0xc2, 0xe1, 0x5b, 0xab, 0xc3, 0x81, 0x7f, 0xc8, 0x64, 0xc2, 0xba, 0xd3, 0x29 }, { 0x6e, 0x17, 0x2a, 0xa1, 0x52, 0x3c, 0x95, 0x1b, 0xe8, 0xe7, 0x60, 0xf5, 0x07, 0x84, 0xe7, 0x2b, 0x14, 0xe0, 0xb3, 0x51, 0x68, 0xa3, 0xc5, 0x41, 0xa3 }, { 0xb1, 0x36, 0xf6, 0x20, 0x3b, 0x48, 0xcf, 0x1d, 0xef, 0x82, 0x61, 0xfc, 0x40, 0xab, 0x6e, 0xb8, 0x27, 0xc3, 0x3b, 0x7e, 0x53, 0xcc, 0xc4, 0xde, 0x95 }, { 0xe1, 0x43, 0x71, 0xfe, 0xa2, 0x6a, 0xc4, 0x67, 0xe1, 0x4c, 0x13, 0x84, 0xb7, 0xe0, 0x50, 0xa3, 0xb5, 0x1d, 0x63, 0xbf, 0x9d, 0xd0, 0xd5, 0x77, 0x41 }, { 0xad, 0x2a, 0xaa, 0xa8, 0x3e, 0x52, 0x61, 0x30, 0x34, 0xe0, 0x71, 0xc2, 0x2e, 0xd9, 0xa1, 0xac, 0xf5, 0x71, 0xfc, 0x56, 0x39, 0xd9, 0x6b, 0x94, 0x77 }, { 0x15, 0xa9, 0xe6, 0x88, 0xa0, 0x1f, 0x8a, 0x20, 0x1d, 0xc7, 0xb8, 0x08, 0x47, 0xeb, 0xb5, 0x98, 0xa8, 0xd4, 0xd3, 0x9b, 0xa0, 0xde, 0x21, 0xdf, 0xc6 }, { 0xa8, 0x7f, 0x0f, 0xef, 0xde, 0x2e, 0xfa, 0x27, 0x20, 0xf0, 0xdf, 0xff, 0x0c, 0xf1, 0x06, 0xbf, 0xe3, 0x52, 0x95, 0xdc, 0x29, 0xce, 0xf8, 0x63, 0x4b }, { 0x65, 0xc5, 0xd0, 0xb8, 0xa6, 0xb2, 0xaf, 0x57, 0x16, 0xbf, 0xfd, 0xd8, 0xf6, 0xae, 0xa7, 0xb3, 0x9e, 0x5e, 0xe2, 0x02, 0x32, 0x47, 0x21, 0x99, 0x3e }, { 0xd3, 0x59, 0x16, 0xfd, 0xe4, 0xf2, 0xe0, 0x86, 0xcc, 0x31, 0x0a, 0x17, 0xa5, 0x54, 0xa6, 0x0c, 0x9f, 0xc5, 0xa2, 0x27, 0x20, 0x78, 0xe0, 0x67, 0x42 }, { 0x99, 0x5d, 0x9c, 0x98, 0x3d, 0xd7, 0x7b, 0xd6, 0x82, 0x83, 0x0f, 0x03, 0xc0, 0x43, 0xe7, 0xc4, 0xa1, 0x06, 0xb8, 0x97, 0x3e, 0x02, 0xe8, 0xb2, 0xa9 }, { 0xe3, 0x5c, 0xb6, 0x77, 0x1a, 0x79, 0x83, 0xbd, 0x99, 0x0d, 0xec, 0x0d, 0xcb, 0x28, 0xef, 0x5d, 0x5b, 0xff, 0x22, 0x25, 0x3b, 0xf7, 0x41, 0xac, 0x87 }, { 0xb2, 0x39, 0x68, 0x07, 0x4f, 0x63, 0x9f, 0xf6, 0x5c, 0xe5, 0x5f, 0x9f, 0x0f, 0xbe, 0xb5, 0x7a, 0x10, 0x95, 0x46, 0x8a, 0x98, 0x64, 0xf1, 0xd6, 0x16 }, { 0x21, 0xe9, 0xa2, 0x41, 0xc5, 0x81, 0x40, 0xe0, 0x36, 0x9b, 0x36, 0x77, 0x04, 0x5a, 0xa4, 0xf2, 0x25, 0xca, 0x73, 0x5e, 0xf9, 0xac, 0x5e, 0x87, 0xd1 }, { 0x4c, 0x5c, 0x75, 0xf0, 0xfe, 0xdc, 0x86, 0xb7, 0x66, 0xeb, 0x4d, 0xf5, 0x94, 0x65, 0x43, 0x1e, 0xb3, 0xe7, 0x16, 0x00, 0x7b, 0xba, 0x8d, 0xc9, 0xec }, { 0x9b, 0x7d, 0x57, 0xf9, 0xd4, 0x58, 0x54, 0xa0, 0x11, 0x51, 0x6d, 0x93, 0xdc, 0x56, 0xff, 0x73, 0xda, 0x2c, 0xb3, 0x74, 0x56, 0x2a, 0x67, 0x1b, 0xef }, { 0x72, 0x29, 0x1a, 0xea, 0x23, 0x0d, 0x2b, 0x52, 0xb9, 0x27, 0xd6, 0xaa, 0xe5, 0x95, 0x7c, 0x08, 0xa3, 0x8f, 0x21, 0xb2, 0x6a, 0x37, 0x99, 0x08, 0xec }, { 0xc1, 0x10, 0x19, 0x1e, 0x9e, 0x93, 0x2d, 0xcb, 0x81, 0xfa, 0x86, 0xf9, 0x4f, 0xf5, 0x03, 0x88, 0x10, 0x44, 0xdd, 0x1e, 0x12, 0x9e, 0xdf, 0x16, 0xe5 }, { 0xb2, 0x10, 0x74, 0xd1, 0x12, 0x57, 0xea, 0xdf, 0xd8, 0x28, 0x29, 0x1a, 0xd5, 0x7e, 0x1f, 0x29, 0x4f, 0xf7, 0x07, 0x94, 0xd3, 0x33, 0x82, 0x17, 0x26 }, { 0xa7, 0xc8, 0xd6, 0x67, 0x21, 0xa4, 0xc7, 0x6d, 0x1c, 0xa9, 0xf5, 0x20, 0x5d, 0x53, 0x27, 0xb5, 0x20, 0x67, 0xcb, 0x6f, 0x51, 0x20, 0x95, 0xb8, 0x63 }, { 0x85, 0x0d, 0xe3, 0x08, 0x2a, 0x0c, 0x7d, 0xe1, 0xee, 0xda, 0x92, 0x34, 0xb6, 0xeb, 0x6d, 0x76, 0x74, 0x7d, 0xe1, 0x26, 0x7a, 0x2e, 0xe3, 0xe5, 0xfe }, { 0x8a, 0x95, 0x26, 0xbf, 0xd3, 0x45, 0x78, 0x40, 0x8b, 0xb7, 0xe8, 0x98, 0x45, 0xc6, 0xe5, 0xa7, 0x9c, 0x34, 0x8c, 0xd1, 0xc6, 0xa9, 0x5d, 0xab, 0x09 }, { 0x7b, 0x3c, 0x94, 0x2a, 0x7b, 0x29, 0xc0, 0xf3, 0xa3, 0x12, 0x5f, 0x14, 0x73, 0xac, 0x20, 0x9f, 0xf5, 0x73, 0x12, 0x65, 0x82, 0x4f, 0xf2, 0xdf, 0x31 }, { 0x98, 0xd6, 0xda, 0xdb, 0xad, 0xb6, 0x7b, 0x5b, 0x1d, 0xf7, 0x27, 0x94, 0xdb, 0xcc, 0xec, 0xb3, 0xc1, 0xbc, 0x1d, 0xe3, 0xef, 0xdb, 0x29, 0x83, 0xc3 }, { 0x8a, 0x52, 0x24, 0xeb, 0xb2, 0x72, 0x92, 0xc6, 0x99, 0x63, 0x50, 0xb3, 0x2c, 0x3b, 0x1f, 0x2f, 0xf1, 0x88, 0x4c, 0x17, 0x9d, 0x3b, 0x5b, 0x4a, 0xbf }, { 0xf4, 0x7d, 0xb3, 0x36, 0xf1, 0x94, 0xe8, 0x9a, 0x9e, 0x3f, 0x2a, 0xfa, 0xee, 0x51, 0xb5, 0x07, 0x55, 0x83, 0xa5, 0x33, 0x32, 0x0f, 0x92, 0x30, 0xb6 }, { 0xdc, 0xdf, 0x42, 0x7f, 0x9c, 0x2b, 0xe9, 0x6f, 0xea, 0xaa, 0x58, 0x74, 0x09, 0x92, 0x4c, 0xe0, 0x0b, 0xd2, 0x7d, 0x4d, 0xc3, 0xd3, 0x98, 0x0c, 0x61 }, { 0x1e, 0xd7, 0x4f, 0xf9, 0xe6, 0x35, 0x51, 0xd4, 0x74, 0xf5, 0x33, 0x1f, 0x63, 0xb3, 0xa2, 0x2d, 0x64, 0x40, 0xbe, 0x19, 0x33, 0x57, 0x32, 0x98, 0xfa }, { 0x58, 0x58, 0xc5, 0xe8, 0x9f, 0x58, 0xdd, 0xe6, 0x00, 0xd3, 0x0a, 0xda, 0x52, 0x0c, 0x35, 0xef, 0x68, 0xa9, 0x18, 0x25, 0x07, 0x27, 0x17, 0x96, 0x42 }, { 0x56, 0x79, 0x52, 0x1a, 0x1b, 0xa1, 0xda, 0xc5, 0xb6, 0xe3, 0xa6, 0x15, 0xe1, 0x2e, 0xa8, 0xa0, 0x5c, 0xe6, 0xc3, 0x5a, 0xc3, 0x6c, 0x80, 0x11, 0x8e }, { 0x5f, 0xec, 0x25, 0xa3, 0x95, 0x6f, 0x46, 0xb4, 0x7e, 0x66, 0x07, 0x27, 0x9c, 0x50, 0xeb, 0xc3, 0x04, 0x36, 0xa4, 0xe6, 0xeb, 0xbf, 0xad, 0xed, 0xe4 }, { 0x4e, 0xad, 0xbe, 0xb0, 0xba, 0xce, 0xeb, 0x9c, 0x50, 0x9c, 0xb9, 0x1b, 0x84, 0x24, 0x19, 0xb4, 0x58, 0x0c, 0x45, 0x48, 0x6b, 0xaf, 0xe7, 0xb2, 0xb1 }, { 0xec, 0x7b, 0xd1, 0x11, 0x2c, 0x86, 0x90, 0xcf, 0x0e, 0xc3, 0x20, 0xa7, 0xe6, 0xde, 0x7b, 0x89, 0x8d, 0xca, 0xcf, 0x76, 0x87, 0xfa, 0xf4, 0x9a, 0xf9 }, { 0x62, 0xdb, 0x2c, 0x1e, 0x58, 0x79, 0xd0, 0xc9, 0xb1, 0x6e, 0xfe, 0x58, 0xc2, 0x45, 0xc3, 0xe0, 0x11, 0xb3, 0x65, 0x74, 0x57, 0x04, 0x46, 0x47, 0x6a }, { 0x0d, 0xad, 0x6e, 0x21, 0xac, 0x44, 0x0d, 0xe5, 0x42, 0x84, 0xe3, 0x87, 0x85, 0xdb, 0x84, 0x64, 0x86, 0x19, 0x01, 0x7a, 0xac, 0x90, 0xf2, 0xdc, 0x37 }, { 0xfe, 0xa7, 0x11, 0x05, 0xd2, 0xd8, 0x6b, 0x1b, 0xcd, 0x1f, 0xfe, 0xb0, 0xf9, 0xd0, 0xfa, 0xf6, 0x1b, 0x6b, 0x99, 0xf2, 0x14, 0xb4, 0x6f, 0xf2, 0xce }, { 0xe8, 0xe7, 0x5f, 0x23, 0xf2, 0xdd, 0x38, 0x4a, 0xdc, 0x24, 0x50, 0x53, 0x16, 0x9f, 0x25, 0xc4, 0x6a, 0xd0, 0x37, 0x4c, 0x41, 0xce, 0x40, 0x0f, 0x7f }, { 0x30, 0x9f, 0x2c, 0x68, 0xbd, 0x7d, 0x10, 0x78, 0x5f, 0xac, 0x15, 0x4e, 0xf7, 0x47, 0xe0, 0x71, 0xf0, 0x08, 0x00, 0xfd, 0x3e, 0x23, 0x3a, 0x58, 0x51 }, { 0x6f, 0x9a, 0x99, 0x54, 0x0b, 0x46, 0x70, 0xa0, 0x90, 0x81, 0xe7, 0x25, 0x08, 0x00, 0x7d, 0x5e, 0x98, 0x13, 0xed, 0xd9, 0x80, 0x9a, 0xd4, 0x79, 0x5e }, { 0x1b, 0x7b, 0xd0, 0x9b, 0x86, 0x07, 0xa1, 0x76, 0xaf, 0xaf, 0xae, 0xdd, 0x46, 0xc7, 0x66, 0x71, 0xa4, 0x60, 0x8f, 0x3d, 0x0d, 0xe0, 0x99, 0x3d, 0x27 }, { 0xf7, 0xfc, 0x57, 0x05, 0x48, 0xb2, 0x43, 0xa5, 0xf9, 0x83, 0xe9, 0x73, 0xf3, 0x4d, 0xf1, 0x7e, 0x65, 0x4f, 0x76, 0x1c, 0x47, 0xad, 0x95, 0x17, 0x38 }, { 0x4d, 0xf1, 0x22, 0x79, 0xfa, 0x56, 0xbb, 0xce, 0x90, 0x47, 0x4c, 0xa3, 0x3d, 0x87, 0x98, 0x67, 0xab, 0x08, 0x79, 0x38, 0x31, 0x7c, 0x53, 0x20, 0x7e }, { 0x38, 0xe0, 0x4d, 0xd8, 0x50, 0x78, 0x08, 0xd0, 0x74, 0x03, 0x21, 0xd8, 0xbe, 0x4a, 0x9f, 0xdd, 0x19, 0x61, 0xaa, 0x27, 0xf8, 0x7f, 0x33, 0x66, 0xcf }, { 0x83, 0x78, 0xed, 0x13, 0x41, 0xe3, 0x87, 0xef, 0x4f, 0x27, 0xbe, 0xc0, 0x3a, 0x88, 0x65, 0x8d, 0x11, 0x29, 0x84, 0xef, 0x88, 0x89, 0x55, 0xc6, 0xd6 }, { 0x65, 0x6b, 0x11, 0x42, 0xf3, 0x98, 0x26, 0x03, 0xc5, 0x49, 0xb1, 0xaa, 0x61, 0xe9, 0x76, 0x9a, 0xd7, 0x46, 0x70, 0x12, 0xc0, 0x3c, 0x41, 0x3d, 0xb8 }, { 0x95, 0xf4, 0x13, 0x24, 0x08, 0xc7, 0xca, 0x95, 0x6c, 0x4f, 0xdc, 0x71, 0x2c, 0xc9, 0x93, 0xaf, 0x4a, 0x8c, 0x38, 0x77, 0x96, 0xa3, 0x17, 0x75, 0x5b }, { 0x59, 0x9f, 0x54, 0x97, 0x75, 0xaa, 0x84, 0xbf, 0xe3, 0x98, 0xed, 0xf8, 0x91, 0x98, 0xed, 0x26, 0xc6, 0x12, 0x82, 0x8e, 0x69, 0x43, 0xce, 0x2e, 0x3f }, { 0xf0, 0x8e, 0x49, 0x31, 0x75, 0xaa, 0xc4, 0x5d, 0x9b, 0x51, 0x78, 0xf5, 0x65, 0xf5, 0x0c, 0x2b, 0xbd, 0x3d, 0x58, 0x75, 0x65, 0xca, 0x67, 0x7c, 0x78 } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES128.rsp" */ uint8_t plain_texts4_128bit[ 100 ][ 32 ] = { { 0xa8, 0xac, 0x2b, 0xba, 0x1d, 0x5d, 0xe9, 0x39, 0x67, 0x9f, 0xbe, 0x3b, 0x97, 0x59, 0x09, 0x49, 0x01, 0x72, 0xfe, 0x86, 0x0e, 0x6c, 0x24, 0xc7, 0x07, 0x63, 0x74, 0xdc, 0x0c, 0xaf, 0x55, 0x35 }, { 0xe4, 0x8c, 0x20, 0x8d, 0x26, 0x76, 0xad, 0xb2, 0xa5, 0xa6, 0x1d, 0x07, 0x67, 0x7d, 0x4a, 0xfc, 0x1e, 0xec, 0x52, 0x10, 0xc4, 0x17, 0xa9, 0x81, 0x3f, 0x57, 0x9c, 0xa6, 0x26, 0x2a, 0x70, 0xa8 }, { 0xdb, 0x1d, 0x67, 0x61, 0x19, 0x74, 0xde, 0xf4, 0x90, 0x13, 0xf2, 0xa2, 0xdf, 0x32, 0x28, 0x29, 0xfb, 0xc9, 0x53, 0x62, 0xd1, 0xe0, 0x73, 0x70, 0x0d, 0x65, 0x60, 0xc7, 0x99, 0xa7, 0x5f, 0x09 }, { 0x0b, 0xc2, 0x08, 0x38, 0x6e, 0xaa, 0xba, 0xe4, 0xc9, 0x86, 0x4e, 0x9f, 0x20, 0x1e, 0x7b, 0xe3, 0x76, 0x45, 0x68, 0xa3, 0x3d, 0x29, 0x29, 0x61, 0x64, 0x27, 0x21, 0x4e, 0xb4, 0x54, 0xae, 0xb6 }, { 0x8a, 0x43, 0x6c, 0x6d, 0x15, 0xaf, 0xc0, 0xd6, 0x53, 0x54, 0xe8, 0xdd, 0xa2, 0x2d, 0x86, 0x29, 0x65, 0x37, 0xf7, 0x74, 0x68, 0xdf, 0xbf, 0x79, 0x9d, 0xd7, 0xa5, 0x51, 0x7e, 0xe3, 0x9b, 0x46 }, { 0x8e, 0x1a, 0xc1, 0x76, 0xac, 0x7a, 0xce, 0x30, 0x7f, 0x54, 0xcb, 0xef, 0xdc, 0xfd, 0xd9, 0x62, 0x7d, 0x73, 0x6c, 0xb7, 0xcd, 0x8b, 0xdf, 0x1f, 0xab, 0xa3, 0x38, 0xc3, 0x65, 0x14, 0x61, 0x6f }, { 0x42, 0x8d, 0x27, 0xa5, 0x57, 0xc5, 0xd6, 0x4f, 0xa7, 0xc3, 0xf3, 0x08, 0x82, 0x61, 0x20, 0x6e, 0x82, 0xdb, 0xa0, 0x3e, 0x31, 0x9a, 0x77, 0x60, 0x97, 0xab, 0x1a, 0x87, 0xb5, 0x4c, 0x4b, 0x19 }, { 0xb8, 0xfe, 0x1b, 0x89, 0x72, 0xf1, 0xa5, 0xac, 0x81, 0x48, 0xef, 0x18, 0xdb, 0x69, 0x11, 0x86, 0x40, 0xed, 0x36, 0x88, 0x12, 0xa3, 0xa2, 0xd6, 0xbd, 0xc7, 0x1b, 0x09, 0x80, 0x3d, 0x4c, 0x37 }, { 0xd3, 0x1a, 0xd7, 0xc6, 0xfb, 0x07, 0x8c, 0x5b, 0xef, 0xa0, 0x7c, 0xe9, 0x25, 0x65, 0xbd, 0xe2, 0xc6, 0xcb, 0x6d, 0x72, 0x1d, 0x6c, 0x29, 0x49, 0x91, 0x63, 0x80, 0x17, 0xfa, 0x94, 0x07, 0xfc }, { 0xdf, 0x07, 0x27, 0xcf, 0x34, 0x56, 0xbf, 0x55, 0x1b, 0x80, 0x5e, 0x8c, 0x6a, 0xfd, 0xe6, 0x6b, 0x58, 0x68, 0x2e, 0xd0, 0x32, 0xba, 0x1f, 0x48, 0xa8, 0x2b, 0xe5, 0x78, 0xe3, 0x29, 0x3a, 0x7e }, { 0x6b, 0x48, 0x8f, 0xb6, 0xb8, 0x67, 0xe0, 0xac, 0x60, 0xbd, 0x5d, 0x8f, 0xea, 0x9d, 0x5a, 0x89, 0xae, 0x49, 0xa4, 0x45, 0x87, 0x58, 0x33, 0x2d, 0xc5, 0x68, 0x17, 0xd6, 0x1e, 0x0d, 0x45, 0x5e }, { 0xb6, 0x03, 0x65, 0xad, 0x30, 0xae, 0xa1, 0xf4, 0xdf, 0x65, 0x8b, 0x2c, 0x8d, 0xfd, 0x7e, 0x61, 0xf3, 0xdb, 0xae, 0x26, 0x22, 0xd5, 0x12, 0x12, 0x9c, 0xd9, 0x41, 0x8f, 0x68, 0x3b, 0x9f, 0x4f }, { 0x2f, 0xf1, 0x89, 0xdf, 0x5c, 0x34, 0x43, 0x6c, 0x98, 0xed, 0xff, 0x0f, 0xa4, 0x75, 0xfa, 0x81, 0x7a, 0xc7, 0x6b, 0x9b, 0x6b, 0x3a, 0x1a, 0xcc, 0x20, 0x4b, 0xde, 0x61, 0xfe, 0xdd, 0xcf, 0xe8 }, { 0x7a, 0x08, 0xa0, 0xd0, 0x4f, 0x29, 0x5c, 0x5e, 0x95, 0x0c, 0xe2, 0xcc, 0x23, 0x56, 0xc0, 0x59, 0x97, 0x09, 0xa5, 0xa0, 0xce, 0x6c, 0x8a, 0x72, 0xb5, 0xdc, 0xc3, 0x8f, 0x28, 0xdd, 0x08, 0x93 }, { 0xb2, 0x83, 0x08, 0x6e, 0x62, 0x10, 0x4f, 0x78, 0x45, 0xa9, 0xbf, 0xdc, 0x68, 0xc6, 0xd9, 0x16, 0x65, 0xb5, 0x81, 0xb8, 0x11, 0x21, 0xf9, 0xfa, 0x9a, 0x9e, 0xa7, 0xea, 0x28, 0x87, 0xf1, 0x66 }, { 0x96, 0x96, 0xc5, 0x5a, 0xc6, 0x63, 0xe9, 0x50, 0x6d, 0x41, 0x39, 0x30, 0x64, 0x1d, 0x6a, 0x25, 0xfd, 0x50, 0xa4, 0xab, 0xbb, 0x4b, 0xe6, 0x9b, 0xf0, 0xcd, 0xf0, 0xd4, 0x76, 0x73, 0xc0, 0x27 }, { 0x43, 0xe7, 0x2a, 0x74, 0x12, 0x7c, 0x90, 0xb7, 0x2a, 0x94, 0xe2, 0xf0, 0xa5, 0x4c, 0x99, 0xb2, 0x0c, 0x2a, 0xb6, 0x31, 0x6f, 0x1d, 0x44, 0x6e, 0xe7, 0x4e, 0x47, 0x14, 0x5d, 0x99, 0x9e, 0x5b }, { 0x9b, 0xaa, 0x10, 0x04, 0xf2, 0x9b, 0xf2, 0x1d, 0xe2, 0x37, 0xe3, 0x49, 0x1e, 0x41, 0x3b, 0xf2, 0x33, 0xb2, 0xfc, 0x68, 0x6d, 0x86, 0x59, 0x7b, 0xf9, 0x8f, 0x44, 0x4e, 0x1c, 0x4a, 0x5f, 0xcb }, { 0x9b, 0x2e, 0x6d, 0x09, 0xd6, 0x33, 0xaa, 0xe3, 0xbb, 0x00, 0x23, 0x90, 0xc6, 0x30, 0x15, 0x05, 0xae, 0x97, 0x9c, 0x12, 0x19, 0x40, 0x0f, 0x47, 0x1a, 0x67, 0x15, 0x76, 0xd8, 0x8e, 0x00, 0x6d }, { 0x89, 0xa4, 0x2f, 0xfe, 0xf6, 0x6f, 0x2a, 0xd4, 0x41, 0xb4, 0x40, 0x65, 0xda, 0xdc, 0xb7, 0x37, 0xaa, 0x42, 0x82, 0x06, 0xce, 0xaf, 0xe9, 0x13, 0xd0, 0xb5, 0x3d, 0x3d, 0xfb, 0x88, 0xef, 0xcb }, { 0x22, 0x0f, 0x0b, 0x29, 0xa4, 0x18, 0x28, 0xde, 0x27, 0x1f, 0xbc, 0xd2, 0xc4, 0x61, 0x1a, 0xc6, 0xd2, 0x4f, 0x2d, 0x48, 0xa7, 0x88, 0x1e, 0x6d, 0xe9, 0x02, 0x2f, 0xe6, 0x26, 0x83, 0x8a, 0xeb }, { 0x87, 0x54, 0xe4, 0xc8, 0xa7, 0xe8, 0xe3, 0xba, 0xb9, 0xa6, 0x15, 0x90, 0xdf, 0x5a, 0xea, 0x1b, 0xc5, 0x16, 0x51, 0xda, 0x24, 0xe3, 0x19, 0x1c, 0x3d, 0xbf, 0x0e, 0xc0, 0xc1, 0xec, 0x69, 0x67 }, { 0x86, 0x7d, 0x72, 0x18, 0x70, 0x8f, 0x80, 0x95, 0xa5, 0x0a, 0x58, 0x31, 0xd9, 0x5f, 0xe6, 0xf0, 0x8f, 0x84, 0x2e, 0x43, 0x06, 0xe1, 0xc1, 0x55, 0x33, 0xb8, 0x07, 0x5b, 0xd0, 0x5d, 0x08, 0x05 }, { 0x7b, 0x68, 0xea, 0x6b, 0xe1, 0x85, 0x52, 0xfa, 0x49, 0xa1, 0x4c, 0x0c, 0xc7, 0xc1, 0x07, 0x78, 0xbb, 0x43, 0xe4, 0x8d, 0xd4, 0xa7, 0x78, 0x21, 0xcb, 0x58, 0x97, 0x87, 0xbc, 0x2c, 0xa2, 0x27 }, { 0x96, 0x2b, 0x33, 0xdf, 0x39, 0xd5, 0x31, 0x0b, 0x34, 0xb0, 0x26, 0xbc, 0x7d, 0x14, 0x7c, 0x9f, 0x13, 0xbe, 0xa7, 0x6d, 0x19, 0xd1, 0x1b, 0x66, 0xd3, 0x35, 0xe3, 0xf5, 0xb8, 0x25, 0x89, 0x3c }, { 0x43, 0x37, 0x57, 0x26, 0x09, 0x2d, 0xed, 0xb5, 0x30, 0xb2, 0x2a, 0xb3, 0x7f, 0xa5, 0x73, 0x3a, 0x7b, 0xef, 0xb1, 0xc1, 0xc1, 0x14, 0x79, 0x1d, 0x97, 0x22, 0xee, 0x90, 0x5f, 0x96, 0xac, 0xbe }, { 0xfa, 0x37, 0x0c, 0x44, 0xaa, 0xac, 0x8b, 0xa4, 0xfc, 0xd0, 0x7a, 0x81, 0x50, 0x79, 0xcf, 0x99, 0x1c, 0xed, 0x83, 0xe4, 0x35, 0xa9, 0x46, 0xf7, 0xcf, 0x52, 0xdf, 0xe3, 0xe3, 0x45, 0xa1, 0x0c }, { 0xa4, 0x2f, 0xfa, 0x84, 0xb5, 0x7e, 0x27, 0xb0, 0x89, 0xaf, 0xd3, 0xf7, 0xae, 0xc4, 0x0e, 0xf7, 0xf5, 0xd5, 0x6e, 0xe3, 0xf4, 0xc8, 0x29, 0xfe, 0x93, 0x16, 0xf3, 0xef, 0xb5, 0xb7, 0x59, 0x0f }, { 0x44, 0x3a, 0x21, 0x0f, 0x6a, 0xd8, 0xec, 0x3b, 0xf4, 0x55, 0x41, 0x13, 0xfe, 0x34, 0x64, 0x81, 0x4c, 0xa4, 0xdd, 0xe4, 0x02, 0xe7, 0x61, 0xd3, 0x9b, 0xe6, 0x74, 0x87, 0xfb, 0x57, 0xf6, 0x51 }, { 0x6a, 0x6f, 0xc6, 0x5a, 0x0d, 0xf7, 0xac, 0x6d, 0x01, 0xd3, 0xb8, 0x94, 0x52, 0xd1, 0x2a, 0x91, 0x7a, 0x71, 0x8d, 0x97, 0xc8, 0xb7, 0x57, 0xe4, 0x9f, 0x08, 0x9a, 0x5d, 0x6f, 0x05, 0x1a, 0x13 }, { 0xe6, 0xd0, 0xdd, 0xdf, 0x71, 0x11, 0xce, 0x86, 0xb6, 0x9d, 0x00, 0x88, 0xc3, 0x51, 0xc1, 0x94, 0xe7, 0x5f, 0xe0, 0x00, 0x27, 0x05, 0x8a, 0x33, 0xca, 0x84, 0x67, 0xd3, 0x23, 0x07, 0xdb, 0x49 }, { 0x8b, 0x42, 0xa0, 0xa8, 0x76, 0x30, 0x20, 0x1a, 0x21, 0x2c, 0xc4, 0x81, 0x54, 0x55, 0xdb, 0x5c, 0x22, 0x99, 0x15, 0x28, 0x61, 0x6a, 0x7f, 0xd0, 0x66, 0xa7, 0x14, 0x6e, 0xe8, 0x62, 0x3e, 0x1f }, { 0x22, 0x09, 0x9b, 0xe8, 0xcd, 0x7b, 0x4f, 0xf0, 0xd5, 0x0f, 0xe6, 0x8e, 0x8d, 0x8f, 0xcb, 0xeb, 0xdf, 0xd3, 0x53, 0x2d, 0x0b, 0x95, 0x18, 0x9d, 0x72, 0xd8, 0x33, 0x77, 0xb1, 0x17, 0xca, 0x83 }, { 0x32, 0xe7, 0x21, 0x1a, 0x70, 0x91, 0x5a, 0xa7, 0x4c, 0xe0, 0x59, 0xfb, 0x05, 0xea, 0x54, 0x3d, 0x71, 0x73, 0x46, 0x94, 0x07, 0x89, 0xbf, 0x16, 0x37, 0x51, 0xa7, 0x44, 0x7d, 0x32, 0xe8, 0x4c }, { 0xbc, 0xd2, 0xf0, 0xaf, 0xd0, 0x07, 0x8a, 0x93, 0x13, 0xa6, 0xf0, 0xf7, 0xe6, 0x83, 0xdc, 0xc8, 0x3b, 0x8a, 0x92, 0x80, 0x55, 0x51, 0xb0, 0xf1, 0x57, 0x55, 0x1c, 0xf6, 0x19, 0xa8, 0x02, 0x08 }, { 0x5b, 0x22, 0x29, 0xea, 0x87, 0x09, 0x30, 0x99, 0x94, 0xef, 0xdc, 0x7d, 0xdf, 0x0e, 0xc9, 0x2b, 0xc5, 0x1f, 0x06, 0xa9, 0xfc, 0xb5, 0x9e, 0x5d, 0x2f, 0xa4, 0xc9, 0xef, 0x4b, 0xed, 0xaf, 0xb5 }, { 0xf7, 0x1f, 0x0f, 0x2e, 0x51, 0x4b, 0x22, 0xb4, 0x13, 0x96, 0x29, 0xae, 0x6e, 0x45, 0xd5, 0xc5, 0xf3, 0x8c, 0xf4, 0xf0, 0xa3, 0x03, 0xa7, 0x8a, 0x08, 0x60, 0x3c, 0x2e, 0x6a, 0x11, 0xd7, 0xb1 }, { 0x91, 0x35, 0x77, 0xa2, 0xd4, 0xa9, 0x8b, 0xca, 0x80, 0x1c, 0x85, 0x7d, 0xec, 0x36, 0x86, 0x74, 0xeb, 0x20, 0xbe, 0x04, 0xf5, 0xac, 0x8b, 0xea, 0x04, 0x7f, 0xe3, 0xa9, 0x37, 0x3d, 0xca, 0x62 }, { 0x17, 0x49, 0x91, 0x83, 0x95, 0x07, 0x57, 0xc2, 0xf4, 0xcd, 0xfc, 0x37, 0xd0, 0xe5, 0x05, 0xa2, 0x77, 0xcf, 0x27, 0xe0, 0x09, 0x48, 0xb1, 0x1b, 0x4d, 0x35, 0x37, 0xcb, 0x36, 0x2a, 0xd7, 0x69 }, { 0x74, 0x86, 0xcd, 0x75, 0x1a, 0x51, 0xd9, 0x19, 0x57, 0x20, 0x8b, 0x73, 0x89, 0x6f, 0x01, 0x42, 0x06, 0x2f, 0x87, 0x88, 0xb5, 0xf6, 0x78, 0x70, 0x11, 0x02, 0x0c, 0x9f, 0x18, 0xb2, 0x19, 0x69 }, { 0x44, 0xef, 0xa5, 0x75, 0xe7, 0xbb, 0x73, 0xcd, 0xd6, 0x90, 0x57, 0x86, 0x50, 0x7d, 0xbd, 0x43, 0x71, 0xc9, 0x8a, 0xbc, 0x8f, 0xb2, 0xef, 0x1b, 0xdd, 0x58, 0xab, 0x1b, 0x6c, 0xb7, 0x0a, 0x49 }, { 0xe8, 0x11, 0xe5, 0x45, 0xf4, 0xa9, 0x9e, 0x87, 0x53, 0x92, 0xb6, 0x2f, 0x0e, 0xab, 0x77, 0xfd, 0x7d, 0x77, 0x8a, 0x41, 0xf3, 0x6c, 0x0f, 0xed, 0x62, 0x25, 0xed, 0x57, 0xef, 0x40, 0xdb, 0xf9 }, { 0x48, 0xea, 0x1e, 0x9c, 0x16, 0x07, 0x40, 0x30, 0x1b, 0x2f, 0x7e, 0x0e, 0xc0, 0x03, 0x51, 0xa2, 0x05, 0xba, 0x38, 0x05, 0x9d, 0x13, 0x4c, 0x69, 0x03, 0x61, 0x8f, 0x3a, 0x26, 0x9c, 0x87, 0xe3 }, { 0xca, 0x91, 0x89, 0x59, 0x6b, 0x2a, 0x42, 0xf3, 0x78, 0x0e, 0x2b, 0x50, 0x92, 0x11, 0xa9, 0xbc, 0x81, 0xff, 0xa6, 0xc0, 0x0e, 0xae, 0x1f, 0x65, 0xe4, 0x49, 0x0d, 0xff, 0x66, 0x4c, 0xdb, 0xbd }, { 0x96, 0x2d, 0xff, 0xd1, 0x2f, 0x95, 0xe0, 0xd6, 0xdc, 0x8f, 0x67, 0xba, 0x38, 0x77, 0x4f, 0x63, 0x51, 0xdd, 0x4a, 0x89, 0x69, 0x9d, 0xd9, 0xa8, 0xa9, 0xce, 0x3d, 0x7c, 0x69, 0x9b, 0x1f, 0x22 }, { 0x65, 0x6d, 0x34, 0x1a, 0x14, 0xd0, 0x46, 0x56, 0xa6, 0x7b, 0x7a, 0xeb, 0x4b, 0xd7, 0x3b, 0x66, 0xd4, 0x7c, 0x34, 0xf9, 0x7f, 0xd2, 0xff, 0x45, 0x76, 0x6a, 0x22, 0x62, 0xda, 0x76, 0x7f, 0xc8 }, { 0x6f, 0x32, 0x2b, 0xf7, 0x2d, 0x74, 0x4d, 0x51, 0x29, 0xe4, 0x9f, 0xb3, 0x73, 0x0f, 0x87, 0x2b, 0xa0, 0x39, 0xd8, 0x6a, 0x6c, 0x4e, 0xdd, 0x3f, 0xd9, 0x86, 0x4f, 0xb7, 0x96, 0x39, 0x3f, 0x04 }, { 0xb0, 0x2c, 0x69, 0xe0, 0x84, 0xe3, 0xbe, 0x5c, 0x79, 0x48, 0xf8, 0x2c, 0x20, 0x10, 0x59, 0x3f, 0x4c, 0x4a, 0x0d, 0xbd, 0x7c, 0x4e, 0xbf, 0x28, 0x41, 0x9e, 0x65, 0xf3, 0x34, 0x73, 0xc5, 0x08 }, { 0x33, 0x46, 0x6c, 0xae, 0xd9, 0xda, 0x1f, 0x28, 0x05, 0x6d, 0x2c, 0x81, 0xb5, 0x75, 0x7b, 0xfe, 0x54, 0xd2, 0xda, 0x18, 0x8e, 0x5c, 0x88, 0xc1, 0x73, 0x54, 0x1e, 0xd1, 0xfc, 0x4b, 0xc3, 0x77 }, { 0x78, 0x1f, 0xe9, 0xd6, 0x55, 0x42, 0x04, 0xb6, 0xd3, 0x8f, 0xae, 0x0b, 0x53, 0x0d, 0xbc, 0x7e, 0xde, 0x39, 0x26, 0x9a, 0x52, 0x27, 0x61, 0xc1, 0x71, 0x65, 0x86, 0xb3, 0x51, 0xaa, 0xef, 0x17 }, { 0x2c, 0x1c, 0x50, 0xc8, 0x72, 0xa1, 0x6f, 0x3b, 0x51, 0x55, 0x0e, 0x87, 0x36, 0x77, 0xba, 0xaa, 0x08, 0xe9, 0x04, 0x31, 0xf4, 0xf3, 0xe6, 0xd0, 0xcc, 0x88, 0x0d, 0xa0, 0xf8, 0x24, 0x40, 0x23 }, { 0xe2, 0xdd, 0xec, 0xc1, 0xf7, 0x01, 0x7b, 0x21, 0x19, 0xcf, 0xc2, 0x6b, 0xa2, 0x0f, 0xb4, 0xab, 0x0d, 0x31, 0xe1, 0x58, 0x75, 0xee, 0x2b, 0xb9, 0xb0, 0xb3, 0xe6, 0x27, 0xd8, 0xa5, 0xa3, 0xfc }, { 0x87, 0x3c, 0xbc, 0x71, 0xd5, 0x07, 0x03, 0x07, 0xa5, 0xf9, 0x36, 0x47, 0xac, 0xe4, 0xea, 0xf1, 0x1f, 0xdf, 0x82, 0x7a, 0x35, 0x6e, 0xac, 0xf9, 0x7a, 0x45, 0x7f, 0x5e, 0x53, 0x39, 0x27, 0x5f }, { 0xfa, 0xde, 0xd1, 0xd0, 0x57, 0xe3, 0xad, 0xfb, 0xe6, 0x86, 0x12, 0x03, 0xf7, 0x62, 0x44, 0xc7, 0x3d, 0xde, 0x51, 0x96, 0x65, 0x20, 0xa9, 0x07, 0x16, 0x15, 0xff, 0x63, 0x39, 0x84, 0x04, 0xf1 }, { 0x06, 0x52, 0x95, 0x77, 0xd8, 0x12, 0x4b, 0x46, 0x26, 0x4c, 0xcc, 0x8c, 0xdf, 0x57, 0xab, 0xb8, 0xcb, 0x97, 0x35, 0x32, 0x5a, 0xdd, 0xfb, 0x64, 0x33, 0xbc, 0x68, 0x46, 0x23, 0xf3, 0x7c, 0x51 }, { 0xb4, 0x6d, 0xf5, 0xbf, 0x50, 0xa4, 0x8f, 0x51, 0x69, 0x51, 0x47, 0x8a, 0x96, 0x11, 0xdc, 0x69, 0x56, 0x96, 0xc8, 0x2d, 0xf8, 0xba, 0x7c, 0x57, 0x81, 0x61, 0x0f, 0x70, 0xc2, 0x71, 0x86, 0x5e }, { 0x0e, 0x67, 0xb5, 0xa5, 0x27, 0x83, 0x33, 0xb2, 0x2b, 0x83, 0x90, 0xbb, 0xea, 0xfb, 0x90, 0xb4, 0xfb, 0x49, 0x83, 0xea, 0x4f, 0x70, 0x90, 0xeb, 0x2e, 0x8e, 0xca, 0x46, 0xd4, 0xcc, 0xf6, 0x0d }, { 0xa4, 0x08, 0xfa, 0x05, 0xf3, 0xfa, 0x23, 0x93, 0x12, 0x3c, 0x3f, 0xab, 0xf7, 0x97, 0x29, 0x3f, 0x80, 0x6c, 0xc1, 0xfb, 0x83, 0xe0, 0xdb, 0xa2, 0x27, 0x20, 0x57, 0x33, 0x68, 0x76, 0x6b, 0xbe }, { 0xb4, 0x1d, 0x7c, 0xd7, 0xb6, 0xb9, 0xbb, 0x8d, 0xef, 0x7f, 0x88, 0xad, 0xaa, 0x69, 0x5f, 0xe1, 0x5e, 0x9c, 0x19, 0x5d, 0x60, 0xd4, 0xc7, 0x31, 0xb5, 0xaf, 0x57, 0xe4, 0x33, 0x0a, 0x71, 0x68 }, { 0x74, 0xc3, 0x6e, 0x7d, 0xef, 0xa0, 0x7e, 0x87, 0xb1, 0x97, 0x48, 0x82, 0xb6, 0xb0, 0xf0, 0xd7, 0x0c, 0x00, 0x81, 0x91, 0x29, 0x89, 0xdd, 0x70, 0xde, 0x74, 0xad, 0xf0, 0x61, 0xf5, 0xe7, 0x64 }, { 0xf2, 0x9e, 0x94, 0xe3, 0x42, 0x40, 0x9f, 0x19, 0x83, 0xf4, 0xe6, 0x4c, 0x8f, 0x7d, 0xf5, 0x86, 0x5d, 0x1c, 0xe9, 0xe2, 0x8f, 0x11, 0x74, 0x16, 0x70, 0x79, 0x1d, 0xaa, 0xc0, 0x91, 0xc5, 0x1d }, { 0xcd, 0x53, 0x6b, 0xf7, 0x8f, 0xd3, 0x4c, 0x81, 0x2a, 0x24, 0x3f, 0x14, 0xe7, 0x75, 0x7a, 0xc2, 0xa9, 0x6b, 0xe4, 0xc5, 0x26, 0xf1, 0xf8, 0x4d, 0xd3, 0x06, 0xae, 0x43, 0x97, 0xe6, 0xee, 0x0d }, { 0x08, 0xbf, 0x47, 0x2a, 0x32, 0x11, 0xf7, 0xd8, 0xc4, 0x61, 0x33, 0xeb, 0x9c, 0x08, 0x7f, 0x17, 0xcd, 0xe9, 0x34, 0x83, 0x60, 0xd6, 0x3e, 0x2a, 0x8e, 0xc9, 0x50, 0x19, 0x36, 0x91, 0xba, 0x67 }, { 0x16, 0xca, 0x76, 0x6a, 0x9b, 0x91, 0x3f, 0x56, 0x9e, 0x47, 0xde, 0x8c, 0x03, 0x60, 0xc2, 0x22, 0x89, 0x99, 0x7c, 0x4a, 0xb7, 0x9a, 0xdb, 0x26, 0x3d, 0x54, 0x6c, 0x2f, 0x2d, 0xf0, 0xae, 0x75 }, { 0xc3, 0x16, 0x49, 0xe0, 0x9f, 0x35, 0x01, 0xcc, 0xf9, 0xea, 0x6d, 0x9e, 0x48, 0x98, 0xff, 0x4c, 0x1d, 0x54, 0x11, 0xa6, 0xa0, 0x91, 0xca, 0xdc, 0x96, 0xa0, 0x83, 0x81, 0x58, 0x3e, 0xc0, 0xa3 }, { 0xa5, 0x66, 0x94, 0xcb, 0x3b, 0x80, 0x23, 0x8f, 0xa8, 0x28, 0x45, 0x48, 0xaf, 0x91, 0x08, 0xd7, 0x69, 0xe7, 0xa3, 0xf3, 0xdb, 0xaa, 0xb0, 0x04, 0x74, 0x98, 0xc9, 0xe8, 0xc0, 0x56, 0xf6, 0x0c }, { 0xbf, 0x26, 0x73, 0xc9, 0xd6, 0x53, 0xdc, 0xbd, 0x55, 0xf6, 0x7e, 0xc2, 0xd3, 0xc4, 0x08, 0x8a, 0x44, 0x2f, 0xf5, 0xd5, 0x07, 0x65, 0x80, 0x9a, 0x20, 0x40, 0x39, 0xf3, 0xee, 0xd8, 0xba, 0xd7 }, { 0xf5, 0xdc, 0x9a, 0xfc, 0xae, 0xfe, 0x38, 0x7c, 0x3d, 0x16, 0x2d, 0x02, 0xba, 0xac, 0x1e, 0x8d, 0xa6, 0x9f, 0xe2, 0x16, 0xa7, 0x2c, 0x16, 0xb7, 0xb1, 0x74, 0x82, 0x3a, 0x32, 0xbf, 0x91, 0x61 }, { 0x11, 0x28, 0x3c, 0x92, 0x62, 0xd5, 0xe2, 0x14, 0xdb, 0x2f, 0x29, 0xc1, 0x6b, 0x5c, 0xd0, 0x25, 0x68, 0x22, 0xca, 0x94, 0xc8, 0x1d, 0x9b, 0xe5, 0xc0, 0x33, 0xc6, 0xd2, 0xaf, 0x2a, 0xad, 0x84 }, { 0xe4, 0xa1, 0xae, 0xeb, 0x8f, 0x2e, 0x85, 0x8b, 0x03, 0x0d, 0x24, 0x97, 0xe0, 0x88, 0xf9, 0x0c, 0x02, 0x4c, 0x9d, 0x82, 0x0c, 0x32, 0x86, 0x57, 0x67, 0xe4, 0x95, 0x0c, 0x20, 0xd9, 0x06, 0xe4 }, { 0xc9, 0x22, 0xea, 0xde, 0xc1, 0x65, 0x21, 0x67, 0x8d, 0xc5, 0x12, 0xf8, 0x99, 0xb9, 0x2a, 0x16, 0x9d, 0xb8, 0xb5, 0x14, 0xfb, 0xd3, 0xcf, 0x01, 0x42, 0x97, 0x86, 0xf5, 0x4a, 0xfa, 0xaf, 0x5d }, { 0xdd, 0xb6, 0xd4, 0xc3, 0xb6, 0x20, 0xbd, 0x22, 0xe0, 0xb7, 0xb5, 0x2d, 0xf4, 0x7c, 0xde, 0xcb, 0x18, 0x18, 0x02, 0x8c, 0xd4, 0x6e, 0x02, 0x83, 0xfb, 0x82, 0x54, 0x6a, 0x09, 0x5c, 0x42, 0x77 }, { 0xa3, 0x60, 0x27, 0x59, 0x5a, 0xc1, 0x00, 0x7c, 0x48, 0x6f, 0xa7, 0x35, 0x3d, 0x7f, 0x6a, 0xa2, 0xda, 0xc3, 0x6f, 0xcd, 0x3c, 0x08, 0xfb, 0x32, 0xbd, 0x5e, 0x72, 0x86, 0x62, 0xec, 0x2b, 0xd9 }, { 0x1b, 0x0f, 0xe2, 0xa5, 0x67, 0xf5, 0x62, 0x28, 0x97, 0x39, 0xe2, 0x98, 0xa9, 0x12, 0x41, 0x5a, 0x10, 0x21, 0xdd, 0xf3, 0x23, 0x27, 0x84, 0x59, 0x68, 0xf5, 0x36, 0x3f, 0x7f, 0xe7, 0x41, 0x35 }, { 0x86, 0x7d, 0x46, 0xa7, 0x39, 0x70, 0xc7, 0xc9, 0xca, 0xcc, 0xa6, 0x35, 0x54, 0xc8, 0x59, 0xb6, 0x43, 0xd6, 0x26, 0x6a, 0xeb, 0xc1, 0xf9, 0x1d, 0x67, 0x4e, 0xd7, 0x39, 0xfd, 0x2d, 0x4c, 0xf5 }, { 0x28, 0xb4, 0x0e, 0x90, 0xb5, 0x4c, 0x8f, 0xab, 0xad, 0xa1, 0xd0, 0xad, 0x5d, 0x08, 0x04, 0x03, 0x89, 0x3f, 0x41, 0xa1, 0x75, 0x3b, 0xe6, 0x15, 0x7c, 0x15, 0x4b, 0xce, 0x7c, 0x18, 0x94, 0xd1 }, { 0x66, 0x3d, 0x63, 0x38, 0x24, 0xe9, 0xde, 0x45, 0x58, 0xa3, 0xf2, 0x64, 0xc7, 0x60, 0xa9, 0xee, 0xe6, 0x04, 0x1e, 0x19, 0xc1, 0x94, 0xff, 0x8d, 0xf3, 0xfe, 0xe4, 0xd4, 0xf8, 0x00, 0xad, 0xd7 }, { 0xc9, 0x0c, 0x05, 0x13, 0x3a, 0x3c, 0x98, 0x90, 0xc3, 0x32, 0xfb, 0x2a, 0xf5, 0xe9, 0xe2, 0x3b, 0x2a, 0xf6, 0x62, 0xcd, 0x6c, 0x17, 0xf4, 0x2e, 0xa6, 0xfc, 0xf9, 0x14, 0x62, 0x72, 0xee, 0x03 }, { 0xeb, 0x3d, 0x61, 0xb6, 0xfe, 0x42, 0x41, 0xd4, 0x26, 0xfd, 0xaa, 0xe3, 0x84, 0xcc, 0xd0, 0x51, 0xac, 0xf3, 0x74, 0x82, 0xe2, 0x51, 0x27, 0x64, 0x8f, 0xdb, 0x5e, 0x27, 0xfe, 0x9a, 0x8c, 0xdc }, { 0xa6, 0xca, 0x82, 0x3c, 0xb5, 0xcd, 0xd2, 0x48, 0x99, 0x99, 0x03, 0x45, 0xcb, 0x57, 0x62, 0x08, 0x39, 0xae, 0x99, 0xc9, 0xbc, 0xa2, 0xeb, 0x83, 0x7b, 0x3f, 0x8d, 0x5c, 0xea, 0xc9, 0xd6, 0xd7 }, { 0x10, 0x76, 0x76, 0x29, 0x1b, 0x7f, 0x53, 0x19, 0xfd, 0xd8, 0x96, 0xfd, 0x2d, 0xb6, 0x0a, 0x1f, 0x8e, 0x2b, 0xf7, 0xda, 0x12, 0x53, 0x77, 0x2d, 0x4c, 0x8b, 0x46, 0xe3, 0x02, 0x35, 0xb7, 0xde }, { 0xb0, 0xb1, 0x26, 0xea, 0x7f, 0x1d, 0xba, 0xc0, 0x6c, 0x95, 0x8d, 0xaf, 0xd4, 0x6c, 0xeb, 0xfc, 0x7c, 0x61, 0x12, 0xde, 0x15, 0x40, 0x83, 0x43, 0xac, 0xee, 0x91, 0x87, 0x94, 0x6b, 0xc9, 0xa7 }, { 0xd3, 0xc6, 0x41, 0x13, 0x20, 0x78, 0x8f, 0xd6, 0x46, 0x9e, 0x79, 0x7a, 0x53, 0x6b, 0x3f, 0x2c, 0x20, 0x2e, 0x27, 0xb8, 0x2b, 0x21, 0x23, 0x35, 0x48, 0xa9, 0x4b, 0xd0, 0x6c, 0xe7, 0x0a, 0xff }, { 0x40, 0x29, 0xde, 0xb5, 0x20, 0xea, 0xb1, 0x5d, 0xea, 0x3a, 0x3f, 0x78, 0x0d, 0xa9, 0x43, 0x70, 0x98, 0x5a, 0xb9, 0x09, 0xe2, 0xf4, 0x49, 0x45, 0xc5, 0xbd, 0xe0, 0x12, 0x31, 0x6e, 0x1c, 0xdc }, { 0x1b, 0xc4, 0x1d, 0x7f, 0x8e, 0x50, 0x06, 0xf0, 0x43, 0x67, 0xfe, 0xe1, 0x64, 0xd9, 0x75, 0xa7, 0xac, 0xe7, 0x7b, 0x78, 0x4e, 0xf5, 0xa0, 0xdb, 0x8a, 0x31, 0xbc, 0xa0, 0x5b, 0xf6, 0xcc, 0x88 }, { 0x43, 0xe0, 0x7f, 0xf6, 0xfe, 0x1b, 0x25, 0xdc, 0xac, 0x7d, 0x0c, 0x25, 0xdb, 0x07, 0x06, 0x97, 0x27, 0xec, 0xf4, 0x12, 0x09, 0x0a, 0x6a, 0x68, 0x7b, 0x09, 0x75, 0x91, 0x16, 0x17, 0x84, 0xab }, { 0xef, 0xca, 0x2d, 0x3e, 0x28, 0x97, 0x65, 0xa8, 0xa5, 0xba, 0x7a, 0x86, 0x16, 0xf0, 0xfc, 0x12, 0x4d, 0xc3, 0xe0, 0x24, 0xc2, 0x03, 0xc8, 0xd2, 0xc8, 0xd8, 0xe7, 0x7b, 0x50, 0x73, 0xd0, 0xbf }, { 0x73, 0xf7, 0x1c, 0x5b, 0x72, 0xdd, 0xa8, 0xaf, 0xb9, 0x14, 0x07, 0x9e, 0xbe, 0xa2, 0x74, 0x86, 0x12, 0xf1, 0x3e, 0xba, 0x8f, 0xf3, 0xc1, 0xa1, 0x0a, 0xe9, 0x61, 0x7e, 0xa1, 0xfc, 0x04, 0x38 }, { 0x9b, 0x86, 0x41, 0x18, 0xd8, 0xcb, 0xb9, 0x5c, 0x2b, 0xe7, 0x22, 0xd8, 0x86, 0xe0, 0xce, 0xee, 0x81, 0x0e, 0x1b, 0x50, 0x60, 0x0d, 0xff, 0x1f, 0x95, 0x02, 0x83, 0x62, 0x31, 0xf9, 0xf8, 0x5d }, { 0xcc, 0xbf, 0xf8, 0x3f, 0xe4, 0x41, 0xe5, 0x2d, 0xcc, 0x54, 0x79, 0x5a, 0xa4, 0xf7, 0x8a, 0xb8, 0x71, 0x78, 0x4b, 0x9a, 0x7b, 0x84, 0x82, 0x63, 0x5d, 0x45, 0x49, 0x82, 0x31, 0xbf, 0x60, 0x52 }, { 0x6d, 0x40, 0x0c, 0x0b, 0x88, 0x0c, 0x35, 0xac, 0x29, 0xe5, 0x12, 0xda, 0x89, 0x92, 0x0c, 0xbe, 0x83, 0xbb, 0xbd, 0x75, 0xa6, 0x62, 0x86, 0xf5, 0x8a, 0xe2, 0x4b, 0x37, 0x58, 0x67, 0xc8, 0x3d }, { 0x58, 0x6d, 0x9a, 0x10, 0x78, 0xf0, 0xac, 0xf4, 0xaf, 0x36, 0x13, 0xc5, 0x10, 0xc8, 0x6b, 0x02, 0x23, 0x6e, 0xc8, 0x6d, 0x39, 0x62, 0x1b, 0x6f, 0x7d, 0x60, 0x5f, 0xac, 0x8f, 0xdc, 0x35, 0xd2 }, { 0xb9, 0x8b, 0x68, 0xf3, 0x96, 0xd3, 0x53, 0xd1, 0x01, 0x17, 0x95, 0x29, 0x21, 0x53, 0xd5, 0x3a, 0xd0, 0x3d, 0x34, 0xb4, 0xb2, 0x35, 0x95, 0xe1, 0x1b, 0xb4, 0x6c, 0xab, 0x7f, 0x40, 0xfc, 0xe1 }, { 0x7d, 0x14, 0x51, 0x49, 0xf8, 0x84, 0x96, 0xcc, 0x0b, 0x1c, 0x19, 0x70, 0xfd, 0x3b, 0x9c, 0x6a, 0x4d, 0x2c, 0x3d, 0x50, 0xdc, 0x9b, 0x6b, 0x52, 0x11, 0x68, 0x44, 0x80, 0x43, 0xfb, 0x00, 0x85 }, { 0x28, 0xec, 0xab, 0x53, 0xa5, 0xd8, 0xe7, 0x44, 0x79, 0x12, 0xaf, 0xb5, 0xf9, 0x9d, 0x02, 0x6c, 0xc5, 0xf3, 0xa1, 0xb9, 0xe8, 0x41, 0x23, 0xeb, 0xd7, 0x79, 0x6f, 0x7b, 0xcc, 0xf8, 0x4d, 0x81 }, { 0xc3, 0x79, 0x3e, 0x73, 0x74, 0xab, 0x0f, 0x7b, 0x16, 0xfe, 0x33, 0x4b, 0xe0, 0x5c, 0x64, 0xc7, 0xa9, 0x21, 0x7d, 0xc7, 0xeb, 0x24, 0xf5, 0x70, 0x05, 0x67, 0xe3, 0x20, 0x7f, 0x2c, 0x5b, 0x54 }, { 0x77, 0xbd, 0x79, 0x42, 0x69, 0x80, 0x8f, 0x22, 0xa1, 0x50, 0xd7, 0x5f, 0xa0, 0xc4, 0x2a, 0x9a, 0x28, 0x87, 0xae, 0xfd, 0x88, 0xcc, 0xad, 0xec, 0x38, 0x75, 0x7f, 0x71, 0xb9, 0xc3, 0x34, 0xb7 }, { 0xc6, 0xdc, 0xaf, 0xbd, 0xbf, 0xd7, 0xf7, 0x1b, 0x02, 0x9b, 0x92, 0x40, 0xce, 0x57, 0xd6, 0x34, 0x95, 0xba, 0x68, 0xc1, 0xc3, 0x13, 0x1e, 0x6e, 0xb1, 0x0d, 0x09, 0xcb, 0x5a, 0x1f, 0xcb, 0x5e }, { 0x2d, 0x93, 0xfe, 0x17, 0xfc, 0xd5, 0x1e, 0xf1, 0x9c, 0x4a, 0x04, 0x89, 0xf7, 0x72, 0xf1, 0xab, 0x91, 0x92, 0x1b, 0x26, 0x1a, 0x30, 0x17, 0x51, 0xf1, 0x0d, 0xf8, 0x19, 0xf6, 0x5d, 0xf8, 0xe8 }, { 0x40, 0x1e, 0xfe, 0x5c, 0x41, 0xce, 0xa2, 0x3d, 0xa0, 0xd3, 0x3c, 0xaa, 0x94, 0x6b, 0x91, 0x6c, 0x88, 0xad, 0x99, 0xd6, 0x5f, 0xb8, 0x23, 0x80, 0x47, 0x59, 0x7b, 0x94, 0xbc, 0xdb, 0x88, 0xb7 } }; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES256.rsp" */ uint8_t keys_256bit[ 500 ][ 32 ]; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES256.rsp" */ uint8_t cipher_texts1_256bit[ 100 ][ 16 ]; /* Values from NIST XTSTest "format tweak value input - 128 hex str/XTSGenAES256.rsp" */ uint8_t plain_texts1_256bit[ 100 ][ 16 ]; int result = 0; int test_index = 0; CAES_TEST_UNREFERENCED_PARAMETER( argv ) if( argc != 1 ) { fprintf( stderr, "Unsupported number of arguments.\n" ); return( EXIT_FAILURE ); } /* Decryption tests */ fprintf( stdout, "Testing AES-XTS 128-bit decryption\t" ); for( test_index = 0; test_index < 100; test_index++ ) { result = caes_test_crypt_xts( LIBCAES_CRYPT_MODE_DECRYPT, keys1_128bit[ test_index ], 128, &( keys1_128bit[ test_index ][ 16 ] ), 128, tweak_value1_128bit[ test_index ], 16, cipher_texts1_128bit[ test_index ], 16, plain_texts1_128bit[ test_index ], 16 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-XTS 128-bit decryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-XTS 128-bit decryption\t" ); for( test_index = 0; test_index < 100; test_index++ ) { result = caes_test_crypt_xts( LIBCAES_CRYPT_MODE_DECRYPT, keys2_128bit[ test_index ], 128, &( keys2_128bit[ test_index ][ 16 ] ), 128, tweak_value2_128bit[ test_index ], 16, cipher_texts2_128bit[ test_index ], 32, plain_texts2_128bit[ test_index ], 32 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-XTS 128-bit decryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-XTS 128-bit decryption\t" ); for( test_index = 0; test_index < 100; test_index++ ) { result = caes_test_crypt_xts( LIBCAES_CRYPT_MODE_DECRYPT, keys3_128bit[ test_index ], 128, &( keys3_128bit[ test_index ][ 16 ] ), 128, tweak_value3_128bit[ test_index ], 16, cipher_texts3_128bit[ test_index ], 25, plain_texts3_128bit[ test_index ], 25 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-XTS 128-bit decryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-XTS 128-bit decryption\t" ); for( test_index = 0; test_index < 100; test_index++ ) { result = caes_test_crypt_xts( LIBCAES_CRYPT_MODE_DECRYPT, keys4_128bit[ test_index ], 128, &( keys4_128bit[ test_index ][ 16 ] ), 128, tweak_value4_128bit[ test_index ], 16, cipher_texts4_128bit[ test_index ], 32, plain_texts4_128bit[ test_index ], 32 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-XTS 128-bit decryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } /* Encryption tests */ fprintf( stdout, "Testing AES-XTS 128-bit encryption\t" ); for( test_index = 0; test_index < 100; test_index++ ) { result = caes_test_crypt_xts( LIBCAES_CRYPT_MODE_ENCRYPT, keys1_128bit[ test_index ], 128, &( keys1_128bit[ test_index ][ 16 ] ), 128, tweak_value1_128bit[ test_index ], 16, plain_texts1_128bit[ test_index ], 16, cipher_texts1_128bit[ test_index ], 16 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-XTS 128-bit encryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-XTS 128-bit encryption\t" ); for( test_index = 0; test_index < 100; test_index++ ) { result = caes_test_crypt_xts( LIBCAES_CRYPT_MODE_ENCRYPT, keys2_128bit[ test_index ], 128, &( keys2_128bit[ test_index ][ 16 ] ), 128, tweak_value2_128bit[ test_index ], 16, plain_texts2_128bit[ test_index ], 32, cipher_texts2_128bit[ test_index ], 32 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-XTS 128-bit encryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-XTS 128-bit encryption\t" ); for( test_index = 0; test_index < 100; test_index++ ) { result = caes_test_crypt_xts( LIBCAES_CRYPT_MODE_ENCRYPT, keys3_128bit[ test_index ], 128, &( keys3_128bit[ test_index ][ 16 ] ), 128, tweak_value3_128bit[ test_index ], 16, plain_texts3_128bit[ test_index ], 25, cipher_texts3_128bit[ test_index ], 25 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-XTS 128-bit encryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } fprintf( stdout, "Testing AES-XTS 128-bit encryption\t" ); for( test_index = 0; test_index < 100; test_index++ ) { result = caes_test_crypt_xts( LIBCAES_CRYPT_MODE_ENCRYPT, keys4_128bit[ test_index ], 128, &( keys4_128bit[ test_index ][ 16 ] ), 128, tweak_value4_128bit[ test_index ], 16, plain_texts4_128bit[ test_index ], 32, cipher_texts4_128bit[ test_index ], 32 ); if( result == -1 ) { fprintf( stderr, "Unable to test AES-XTS 128-bit encryption.\n" ); return( EXIT_FAILURE ); } else if( result != 1 ) { break; } } if( result != 1 ) { fprintf( stdout, "(FAIL)" ); } else { fprintf( stdout, "(PASS)" ); } fprintf( stdout, "\n" ); if( result != 1 ) { return( EXIT_FAILURE ); } return( EXIT_SUCCESS ); } libcaes-20240413/tests/pycaes_test_crypt_ecb.py0000644000175000017500000052474514606473413022335 0ustar00lordyestalordyesta#!/usr/bin/env python # # Python-bindings AES-ECB de/encryption testing program # # Copyright (C) 2011-2024, Joachim Metz # # Refer to AUTHORS for acknowledgements. # # This software is free software: you can redistribute it and/or modify # it under the terms of the GNU Lesser General Public License as published by # the Free Software Foundation, either version 3 of the License, or # (at your option) any later version. # # This software 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 Lesser General Public License # along with this software. If not, see . # import sys import pycaes def pycaes_test_crypt_ecb(mode, key, input_data, expected_output_data): caes_context = pycaes.context() caes_context.set_key(mode, key) output_data = pycaes.crypt_ecb(caes_context, mode, input_data) return output_data == expected_output_data def main(): # Values from NIST KAT-AES ECBVarKey128.rsp, ECBVarKey192.rsp and ECBVarKey256.rsp keys = [ [ 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff ] ]; # Values from NIST KAT-AES ECBVarTxt128.rsp cipher_texts1_128bit = [ [ 0x3a, 0xd7, 0x8e, 0x72, 0x6c, 0x1e, 0xc0, 0x2b, 0x7e, 0xbf, 0xe9, 0x2b, 0x23, 0xd9, 0xec, 0x34 ], [ 0xaa, 0xe5, 0x93, 0x9c, 0x8e, 0xfd, 0xf2, 0xf0, 0x4e, 0x60, 0xb9, 0xfe, 0x71, 0x17, 0xb2, 0xc2 ], [ 0xf0, 0x31, 0xd4, 0xd7, 0x4f, 0x5d, 0xcb, 0xf3, 0x9d, 0xaa, 0xf8, 0xca, 0x3a, 0xf6, 0xe5, 0x27 ], [ 0x96, 0xd9, 0xfd, 0x5c, 0xc4, 0xf0, 0x74, 0x41, 0x72, 0x7d, 0xf0, 0xf3, 0x3e, 0x40, 0x1a, 0x36 ], [ 0x30, 0xcc, 0xdb, 0x04, 0x46, 0x46, 0xd7, 0xe1, 0xf3, 0xcc, 0xea, 0x3d, 0xca, 0x08, 0xb8, 0xc0 ], [ 0x16, 0xae, 0x4c, 0xe5, 0x04, 0x2a, 0x67, 0xee, 0x8e, 0x17, 0x7b, 0x7c, 0x58, 0x7e, 0xcc, 0x82 ], [ 0xb6, 0xda, 0x0b, 0xb1, 0x1a, 0x23, 0x85, 0x5d, 0x9c, 0x5c, 0xb1, 0xb4, 0xc6, 0x41, 0x2e, 0x0a ], [ 0xdb, 0x4f, 0x1a, 0xa5, 0x30, 0x96, 0x7d, 0x67, 0x32, 0xce, 0x47, 0x15, 0xeb, 0x0e, 0xe2, 0x4b ], [ 0xa8, 0x17, 0x38, 0x25, 0x26, 0x21, 0xdd, 0x18, 0x0a, 0x34, 0xf3, 0x45, 0x5b, 0x4b, 0xaa, 0x2f ], [ 0x77, 0xe2, 0xb5, 0x08, 0xdb, 0x7f, 0xd8, 0x92, 0x34, 0xca, 0xf7, 0x93, 0x9e, 0xe5, 0x62, 0x1a ], [ 0xb8, 0x49, 0x9c, 0x25, 0x1f, 0x84, 0x42, 0xee, 0x13, 0xf0, 0x93, 0x3b, 0x68, 0x8f, 0xcd, 0x19 ], [ 0x96, 0x51, 0x35, 0xf8, 0xa8, 0x1f, 0x25, 0xc9, 0xd6, 0x30, 0xb1, 0x75, 0x02, 0xf6, 0x8e, 0x53 ], [ 0x8b, 0x87, 0x14, 0x5a, 0x01, 0xad, 0x1c, 0x6c, 0xed, 0xe9, 0x95, 0xea, 0x36, 0x70, 0x45, 0x4f ], [ 0x8e, 0xae, 0x3b, 0x10, 0xa0, 0xc8, 0xca, 0x6d, 0x1d, 0x3b, 0x0f, 0xa6, 0x1e, 0x56, 0xb0, 0xb2 ], [ 0x64, 0xb4, 0xd6, 0x29, 0x81, 0x0f, 0xda, 0x6b, 0xaf, 0xdf, 0x08, 0xf3, 0xb0, 0xd8, 0xd2, 0xc5 ], [ 0xd7, 0xe5, 0xdb, 0xd3, 0x32, 0x45, 0x95, 0xf8, 0xfd, 0xc7, 0xd7, 0xc5, 0x71, 0xda, 0x6c, 0x2a ], [ 0xf3, 0xf7, 0x23, 0x75, 0x26, 0x4e, 0x16, 0x7f, 0xca, 0x9d, 0xe2, 0xc1, 0x52, 0x7d, 0x96, 0x06 ], [ 0x8e, 0xe7, 0x9d, 0xd4, 0xf4, 0x01, 0xff, 0x9b, 0x7e, 0xa9, 0x45, 0xd8, 0x66, 0x66, 0xc1, 0x3b ], [ 0xdd, 0x35, 0xce, 0xa2, 0x79, 0x99, 0x40, 0xb4, 0x0d, 0xb3, 0xf8, 0x19, 0xcb, 0x94, 0xc0, 0x8b ], [ 0x69, 0x41, 0xcb, 0x6b, 0x3e, 0x08, 0xc2, 0xb7, 0xaf, 0xa5, 0x81, 0xeb, 0xdd, 0x60, 0x7b, 0x87 ], [ 0x2c, 0x20, 0xf4, 0x39, 0xf6, 0xbb, 0x09, 0x7b, 0x29, 0xb8, 0xbd, 0x6d, 0x99, 0xaa, 0xd7, 0x99 ], [ 0x62, 0x5d, 0x01, 0xf0, 0x58, 0xe5, 0x65, 0xf7, 0x7a, 0xe8, 0x63, 0x78, 0xbd, 0x2c, 0x49, 0xb3 ], [ 0xc0, 0xb5, 0xfd, 0x98, 0x19, 0x0e, 0xf4, 0x5f, 0xbb, 0x43, 0x01, 0x43, 0x8d, 0x09, 0x59, 0x50 ], [ 0x13, 0x00, 0x1f, 0xf5, 0xd9, 0x98, 0x06, 0xef, 0xd2, 0x5d, 0xa3, 0x4f, 0x56, 0xbe, 0x85, 0x4b ], [ 0x3b, 0x59, 0x4c, 0x60, 0xf5, 0xc8, 0x27, 0x7a, 0x51, 0x13, 0x67, 0x7f, 0x94, 0x20, 0x8d, 0x82 ], [ 0xe9, 0xc0, 0xfc, 0x18, 0x18, 0xe4, 0xaa, 0x46, 0xbd, 0x2e, 0x39, 0xd6, 0x38, 0xf8, 0x9e, 0x05 ], [ 0xf8, 0x02, 0x3e, 0xe9, 0xc3, 0xfd, 0xc4, 0x5a, 0x01, 0x9b, 0x4e, 0x98, 0x5c, 0x7e, 0x1a, 0x54 ], [ 0x35, 0xf4, 0x01, 0x82, 0xab, 0x46, 0x62, 0xf3, 0x02, 0x3b, 0xae, 0xc1, 0xee, 0x79, 0x6b, 0x57 ], [ 0x3a, 0xeb, 0xba, 0xd7, 0x30, 0x36, 0x49, 0xb4, 0x19, 0x4a, 0x69, 0x45, 0xc6, 0xcc, 0x36, 0x94 ], [ 0xa2, 0x12, 0x4b, 0xea, 0x53, 0xec, 0x28, 0x34, 0x27, 0x9b, 0xed, 0x7f, 0x7e, 0xb0, 0xf9, 0x38 ], [ 0xb9, 0xfb, 0x43, 0x99, 0xfa, 0x4f, 0xac, 0xc7, 0x30, 0x9e, 0x14, 0xec, 0x98, 0x36, 0x0b, 0x0a ], [ 0xc2, 0x62, 0x77, 0x43, 0x74, 0x20, 0xc5, 0xd6, 0x34, 0xf7, 0x15, 0xae, 0xa8, 0x1a, 0x91, 0x32 ], [ 0x17, 0x1a, 0x0e, 0x1b, 0x2d, 0xd4, 0x24, 0xf0, 0xe0, 0x89, 0xaf, 0x2c, 0x4c, 0x10, 0xf3, 0x2f ], [ 0x7c, 0xad, 0xbe, 0x40, 0x2d, 0x1b, 0x20, 0x8f, 0xe7, 0x35, 0xed, 0xce, 0x00, 0xae, 0xe7, 0xce ], [ 0x43, 0xb0, 0x2f, 0xf9, 0x29, 0xa1, 0x48, 0x5a, 0xf6, 0xf5, 0xc6, 0xd6, 0x55, 0x8b, 0xaa, 0x0f ], [ 0x09, 0x2f, 0xaa, 0xcc, 0x9b, 0xf4, 0x35, 0x08, 0xbf, 0x8f, 0xa8, 0x61, 0x3c, 0xa7, 0x5d, 0xea ], [ 0xcb, 0x2b, 0xf8, 0x28, 0x0f, 0x3f, 0x97, 0x42, 0xc7, 0xed, 0x51, 0x3f, 0xe8, 0x02, 0x62, 0x9c ], [ 0x21, 0x5a, 0x41, 0xee, 0x44, 0x2f, 0xa9, 0x92, 0xa6, 0xe3, 0x23, 0x98, 0x6d, 0xed, 0x3f, 0x68 ], [ 0xf2, 0x1e, 0x99, 0xcf, 0x4f, 0x0f, 0x77, 0xce, 0xa8, 0x36, 0xe1, 0x1a, 0x2f, 0xe7, 0x5f, 0xb1 ], [ 0x95, 0xe3, 0xa0, 0xca, 0x90, 0x79, 0xe6, 0x46, 0x33, 0x1d, 0xf8, 0xb4, 0xe7, 0x0d, 0x2c, 0xd6 ], [ 0x4a, 0xfe, 0x7f, 0x12, 0x0c, 0xe7, 0x61, 0x3f, 0x74, 0xfc, 0x12, 0xa0, 0x1a, 0x82, 0x80, 0x73 ], [ 0x82, 0x7f, 0x00, 0x0e, 0x75, 0xe2, 0xc8, 0xb9, 0xd4, 0x79, 0xbe, 0xed, 0x91, 0x3f, 0xe6, 0x78 ], [ 0x35, 0x83, 0x0c, 0x8e, 0x7a, 0xae, 0xfe, 0x2d, 0x30, 0x31, 0x0e, 0xf3, 0x81, 0xcb, 0xf6, 0x91 ], [ 0x19, 0x1a, 0xa0, 0xf2, 0xc8, 0x57, 0x01, 0x44, 0xf3, 0x86, 0x57, 0xea, 0x40, 0x85, 0xeb, 0xe5 ], [ 0x85, 0x06, 0x2c, 0x2c, 0x90, 0x9f, 0x15, 0xd9, 0x26, 0x9b, 0x6c, 0x18, 0xce, 0x99, 0xc4, 0xf0 ], [ 0x67, 0x80, 0x34, 0xdc, 0x9e, 0x41, 0xb5, 0xa5, 0x60, 0xed, 0x23, 0x9e, 0xea, 0xb1, 0xbc, 0x78 ], [ 0xc2, 0xf9, 0x3a, 0x4c, 0xe5, 0xab, 0x6d, 0x5d, 0x56, 0xf1, 0xb9, 0x3c, 0xf1, 0x99, 0x11, 0xc1 ], [ 0x1c, 0x31, 0x12, 0xbc, 0xb0, 0xc1, 0xdc, 0xc7, 0x49, 0xd7, 0x99, 0x74, 0x36, 0x91, 0xbf, 0x82 ], [ 0x00, 0xc5, 0x5b, 0xd7, 0x5c, 0x7f, 0x9c, 0x88, 0x19, 0x89, 0xd3, 0xec, 0x19, 0x11, 0xc0, 0xd4 ], [ 0xea, 0x2e, 0x6b, 0x5e, 0xf1, 0x82, 0xb7, 0xdf, 0xf3, 0x62, 0x9a, 0xbd, 0x6a, 0x12, 0x04, 0x5f ], [ 0x22, 0x32, 0x23, 0x27, 0xe0, 0x17, 0x80, 0xb1, 0x73, 0x97, 0xf2, 0x40, 0x87, 0xf8, 0xcc, 0x6f ], [ 0xc9, 0xca, 0xcb, 0x5c, 0xd1, 0x16, 0x92, 0xc3, 0x73, 0xb2, 0x41, 0x17, 0x68, 0x14, 0x9e, 0xe7 ], [ 0xa1, 0x8e, 0x3d, 0xbb, 0xca, 0x57, 0x78, 0x60, 0xda, 0xb6, 0xb8, 0x0d, 0xa3, 0x13, 0x92, 0x56 ], [ 0x79, 0xb6, 0x1c, 0x37, 0xbf, 0x32, 0x8e, 0xcc, 0xa8, 0xd7, 0x43, 0x26, 0x5a, 0x3d, 0x42, 0x5c ], [ 0xd2, 0xd9, 0x9c, 0x6b, 0xcc, 0x1f, 0x06, 0xfd, 0xa8, 0xe2, 0x7e, 0x8a, 0xe3, 0xf1, 0xcc, 0xc7 ], [ 0x1b, 0xfd, 0x4b, 0x91, 0xc7, 0x01, 0xfd, 0x6b, 0x61, 0xb7, 0xf9, 0x97, 0x82, 0x9d, 0x66, 0x3b ], [ 0x11, 0x00, 0x5d, 0x52, 0xf2, 0x5f, 0x16, 0xbd, 0xc9, 0x54, 0x5a, 0x87, 0x6a, 0x63, 0x49, 0x0a ], [ 0x3a, 0x4d, 0x35, 0x4f, 0x02, 0xbb, 0x5a, 0x5e, 0x47, 0xd3, 0x96, 0x66, 0x86, 0x7f, 0x24, 0x6a ], [ 0xd4, 0x51, 0xb8, 0xd6, 0xe1, 0xe1, 0xa0, 0xeb, 0xb1, 0x55, 0xfb, 0xbf, 0x6e, 0x7b, 0x7d, 0xc3 ], [ 0x68, 0x98, 0xd4, 0xf4, 0x2f, 0xa7, 0xba, 0x6a, 0x10, 0xac, 0x05, 0xe8, 0x7b, 0x9f, 0x20, 0x80 ], [ 0xb6, 0x11, 0x29, 0x5e, 0x73, 0x9c, 0xa7, 0xd9, 0xb5, 0x0f, 0x8e, 0x4c, 0x0e, 0x75, 0x4a, 0x3f ], [ 0x7d, 0x33, 0xfc, 0x7d, 0x8a, 0xbe, 0x3c, 0xa1, 0x93, 0x67, 0x59, 0xf8, 0xf5, 0xde, 0xaf, 0x20 ], [ 0x3b, 0x5e, 0x0f, 0x56, 0x6d, 0xc9, 0x6c, 0x29, 0x8f, 0x0c, 0x12, 0x63, 0x75, 0x39, 0xb2, 0x5c ], [ 0xf8, 0x07, 0xc3, 0xe7, 0x98, 0x5f, 0xe0, 0xf5, 0xa5, 0x0e, 0x2c, 0xdb, 0x25, 0xc5, 0x10, 0x9e ], [ 0x41, 0xf9, 0x92, 0xa8, 0x56, 0xfb, 0x27, 0x8b, 0x38, 0x9a, 0x62, 0xf5, 0xd2, 0x74, 0xd7, 0xe9 ], [ 0x10, 0xd3, 0xed, 0x7a, 0x6f, 0xe1, 0x5a, 0xb4, 0xd9, 0x1a, 0xcb, 0xc7, 0xd0, 0x76, 0x7a, 0xb1 ], [ 0x21, 0xfe, 0xec, 0xd4, 0x5b, 0x2e, 0x67, 0x59, 0x73, 0xac, 0x33, 0xbf, 0x0c, 0x54, 0x24, 0xfc ], [ 0x14, 0x80, 0xcb, 0x39, 0x55, 0xba, 0x62, 0xd0, 0x9e, 0xea, 0x66, 0x8f, 0x7c, 0x70, 0x88, 0x17 ], [ 0x66, 0x40, 0x40, 0x33, 0xd6, 0xb7, 0x2b, 0x60, 0x93, 0x54, 0xd5, 0x49, 0x6e, 0x7e, 0xb5, 0x11 ], [ 0x1c, 0x31, 0x7a, 0x22, 0x0a, 0x7d, 0x70, 0x0d, 0xa2, 0xb1, 0xe0, 0x75, 0xb0, 0x02, 0x66, 0xe1 ], [ 0xab, 0x3b, 0x89, 0x54, 0x22, 0x33, 0xf1, 0x27, 0x1b, 0xf8, 0xfd, 0x0c, 0x0f, 0x40, 0x35, 0x45 ], [ 0xd9, 0x3e, 0xae, 0x96, 0x6f, 0xac, 0x46, 0xdc, 0xa9, 0x27, 0xd6, 0xb1, 0x14, 0xfa, 0x3f, 0x9e ], [ 0x1b, 0xde, 0xc5, 0x21, 0x31, 0x65, 0x03, 0xd9, 0xd5, 0xee, 0x65, 0xdf, 0x3e, 0xa9, 0x4d, 0xdf ], [ 0xee, 0xf4, 0x56, 0x43, 0x1d, 0xea, 0x8b, 0x4a, 0xcf, 0x83, 0xbd, 0xae, 0x37, 0x17, 0xf7, 0x5f ], [ 0x06, 0xf2, 0x51, 0x9a, 0x2f, 0xaf, 0xaa, 0x59, 0x6b, 0xfe, 0xf5, 0xcf, 0xa1, 0x5c, 0x21, 0xb9 ], [ 0x25, 0x1a, 0x7e, 0xac, 0x7e, 0x2f, 0xe8, 0x09, 0xe4, 0xaa, 0x8d, 0x0d, 0x70, 0x12, 0x53, 0x1a ], [ 0x3b, 0xff, 0xc1, 0x6e, 0x4c, 0x49, 0xb2, 0x68, 0xa2, 0x0f, 0x8d, 0x96, 0xa6, 0x0b, 0x40, 0x58 ], [ 0xe8, 0x86, 0xf9, 0x28, 0x19, 0x99, 0xc5, 0xbb, 0x3b, 0x3e, 0x88, 0x62, 0xe2, 0xf7, 0xc9, 0x88 ], [ 0x56, 0x3b, 0xf9, 0x0d, 0x61, 0xbe, 0xef, 0x39, 0xf4, 0x8d, 0xd6, 0x25, 0xfc, 0xef, 0x13, 0x61 ], [ 0x4d, 0x37, 0xc8, 0x50, 0x64, 0x45, 0x63, 0xc6, 0x9f, 0xd0, 0xac, 0xd9, 0xa0, 0x49, 0x32, 0x5b ], [ 0xb8, 0x7c, 0x92, 0x1b, 0x91, 0x82, 0x9e, 0xf3, 0xb1, 0x3c, 0xa5, 0x41, 0xee, 0x11, 0x30, 0xa6 ], [ 0x2e, 0x65, 0xeb, 0x6b, 0x6e, 0xa3, 0x83, 0xe1, 0x09, 0xac, 0xcc, 0xe8, 0x32, 0x6b, 0x03, 0x93 ], [ 0x9c, 0xa5, 0x47, 0xf7, 0x43, 0x9e, 0xdc, 0x3e, 0x25, 0x5c, 0x0f, 0x4d, 0x49, 0xaa, 0x89, 0x90 ], [ 0xa5, 0xe6, 0x52, 0x61, 0x4c, 0x93, 0x00, 0xf3, 0x78, 0x16, 0xb1, 0xf9, 0xfd, 0x0c, 0x87, 0xf9 ], [ 0x14, 0x95, 0x4f, 0x0b, 0x46, 0x97, 0x77, 0x6f, 0x44, 0x49, 0x4f, 0xe4, 0x58, 0xd8, 0x14, 0xed ], [ 0x7c, 0x8d, 0x9a, 0xb6, 0xc2, 0x76, 0x17, 0x23, 0xfe, 0x42, 0xf8, 0xbb, 0x50, 0x6c, 0xbc, 0xf7 ], [ 0xdb, 0x7e, 0x19, 0x32, 0x67, 0x9f, 0xdd, 0x99, 0x74, 0x2a, 0xab, 0x04, 0xaa, 0x0d, 0x5a, 0x80 ], [ 0x4c, 0x6a, 0x1c, 0x83, 0xe5, 0x68, 0xcd, 0x10, 0xf2, 0x7c, 0x2d, 0x73, 0xde, 0xd1, 0x9c, 0x28 ], [ 0x90, 0xec, 0xbe, 0x61, 0x77, 0xe6, 0x74, 0xc9, 0x8d, 0xe4, 0x12, 0x41, 0x3f, 0x7a, 0xc9, 0x15 ], [ 0x90, 0x68, 0x4a, 0x2a, 0xc5, 0x5f, 0xe1, 0xec, 0x2b, 0x8e, 0xbd, 0x56, 0x22, 0x52, 0x0b, 0x73 ], [ 0x74, 0x72, 0xf9, 0xa7, 0x98, 0x86, 0x07, 0xca, 0x79, 0x70, 0x77, 0x95, 0x99, 0x10, 0x35, 0xe6 ], [ 0x56, 0xaf, 0xf0, 0x89, 0x87, 0x8b, 0xf3, 0x35, 0x2f, 0x8d, 0xf1, 0x72, 0xa3, 0xae, 0x47, 0xd8 ], [ 0x65, 0xc0, 0x52, 0x6c, 0xbe, 0x40, 0x16, 0x1b, 0x80, 0x19, 0xa2, 0xa3, 0x17, 0x1a, 0xbd, 0x23 ], [ 0x37, 0x7b, 0xe0, 0xbe, 0x33, 0xb4, 0xe3, 0xe3, 0x10, 0xb4, 0xaa, 0xbd, 0xa1, 0x73, 0xf8, 0x4f ], [ 0x94, 0x02, 0xe9, 0xaa, 0x6f, 0x69, 0xde, 0x65, 0x04, 0xda, 0x8d, 0x20, 0xc4, 0xfc, 0xaa, 0x2f ], [ 0x12, 0x3c, 0x1f, 0x4a, 0xf3, 0x13, 0xad, 0x8c, 0x2c, 0xe6, 0x48, 0xb2, 0xe7, 0x1f, 0xb6, 0xe1 ], [ 0x1f, 0xfc, 0x62, 0x6d, 0x30, 0x20, 0x3d, 0xcd, 0xb0, 0x01, 0x9f, 0xb8, 0x0f, 0x72, 0x6c, 0xf4 ], [ 0x76, 0xda, 0x1f, 0xbe, 0x3a, 0x50, 0x72, 0x8c, 0x50, 0xfd, 0x2e, 0x62, 0x1b, 0x5a, 0xd8, 0x85 ], [ 0x08, 0x2e, 0xb8, 0xbe, 0x35, 0xf4, 0x42, 0xfb, 0x52, 0x66, 0x8e, 0x16, 0xa5, 0x91, 0xd1, 0xd6 ], [ 0xe6, 0x56, 0xf9, 0xec, 0xf5, 0xfe, 0x27, 0xec, 0x3e, 0x4a, 0x73, 0xd0, 0x0c, 0x28, 0x2f, 0xb3 ], [ 0x2c, 0xa8, 0x20, 0x9d, 0x63, 0x27, 0x4c, 0xd9, 0xa2, 0x9b, 0xb7, 0x4b, 0xcd, 0x77, 0x68, 0x3a ], [ 0x79, 0xbf, 0x5d, 0xce, 0x14, 0xbb, 0x7d, 0xd7, 0x3a, 0x8e, 0x36, 0x11, 0xde, 0x7c, 0xe0, 0x26 ], [ 0x3c, 0x84, 0x99, 0x39, 0xa5, 0xd2, 0x93, 0x99, 0xf3, 0x44, 0xc4, 0xa0, 0xec, 0xa8, 0xa5, 0x76 ], [ 0xed, 0x3c, 0x0a, 0x94, 0xd5, 0x9b, 0xec, 0xe9, 0x88, 0x35, 0xda, 0x7a, 0xa4, 0xf0, 0x7c, 0xa2 ], [ 0x63, 0x91, 0x9e, 0xd4, 0xce, 0x10, 0x19, 0x64, 0x38, 0xb6, 0xad, 0x09, 0xd9, 0x9c, 0xd7, 0x95 ], [ 0x76, 0x78, 0xf3, 0xa8, 0x33, 0xf1, 0x9f, 0xea, 0x95, 0xf3, 0xc6, 0x02, 0x9e, 0x2b, 0xc6, 0x10 ], [ 0x3a, 0xa4, 0x26, 0x83, 0x10, 0x67, 0xd3, 0x6b, 0x92, 0xbe, 0x7c, 0x5f, 0x81, 0xc1, 0x3c, 0x56 ], [ 0x92, 0x72, 0xe2, 0xd2, 0xcd, 0xd1, 0x10, 0x50, 0x99, 0x8c, 0x84, 0x50, 0x77, 0xa3, 0x0e, 0xa0 ], [ 0x08, 0x8c, 0x4b, 0x53, 0xf5, 0xec, 0x0f, 0xf8, 0x14, 0xc1, 0x9a, 0xda, 0xe7, 0xf6, 0x24, 0x6c ], [ 0x40, 0x10, 0xa5, 0xe4, 0x01, 0xfd, 0xf0, 0xa0, 0x35, 0x4d, 0xdb, 0xcc, 0x0d, 0x01, 0x2b, 0x17 ], [ 0xa8, 0x7a, 0x38, 0x57, 0x36, 0xc0, 0xa6, 0x18, 0x9b, 0xd6, 0x58, 0x9b, 0xd8, 0x44, 0x5a, 0x93 ], [ 0x54, 0x5f, 0x2b, 0x83, 0xd9, 0x61, 0x6d, 0xcc, 0xf6, 0x0f, 0xa9, 0x83, 0x0e, 0x9c, 0xd2, 0x87 ], [ 0x4b, 0x70, 0x6f, 0x7f, 0x92, 0x40, 0x63, 0x52, 0x39, 0x40, 0x37, 0xa6, 0xd4, 0xf4, 0x68, 0x8d ], [ 0xb7, 0x97, 0x2b, 0x39, 0x41, 0xc4, 0x4b, 0x90, 0xaf, 0xa7, 0xb2, 0x64, 0xbf, 0xba, 0x73, 0x87 ], [ 0x6f, 0x45, 0x73, 0x2c, 0xf1, 0x08, 0x81, 0x54, 0x6f, 0x0f, 0xd2, 0x38, 0x96, 0xd2, 0xbb, 0x60 ], [ 0x2e, 0x35, 0x79, 0xca, 0x15, 0xaf, 0x27, 0xf6, 0x4b, 0x3c, 0x95, 0x5a, 0x5b, 0xfc, 0x30, 0xba ], [ 0x34, 0xa2, 0xc5, 0xa9, 0x1a, 0xe2, 0xae, 0xc9, 0x9b, 0x7d, 0x1b, 0x5f, 0xa6, 0x78, 0x04, 0x47 ], [ 0xa4, 0xd6, 0x61, 0x6b, 0xd0, 0x4f, 0x87, 0x33, 0x5b, 0x0e, 0x53, 0x35, 0x12, 0x27, 0xa9, 0xee ], [ 0x7f, 0x69, 0x2b, 0x03, 0x94, 0x58, 0x67, 0xd1, 0x61, 0x79, 0xa8, 0xce, 0xfc, 0x83, 0xea, 0x3f ], [ 0x3b, 0xd1, 0x41, 0xee, 0x84, 0xa0, 0xe6, 0x41, 0x4a, 0x26, 0xe7, 0xa4, 0xf2, 0x81, 0xf8, 0xa2 ], [ 0xd1, 0x78, 0x8f, 0x57, 0x2d, 0x98, 0xb2, 0xb1, 0x6e, 0xc5, 0xd5, 0xf3, 0x92, 0x2b, 0x99, 0xbc ], [ 0x08, 0x33, 0xff, 0x6f, 0x61, 0xd9, 0x8a, 0x57, 0xb2, 0x88, 0xe8, 0xc3, 0x58, 0x6b, 0x85, 0xa6 ], [ 0x85, 0x68, 0x26, 0x17, 0x97, 0xde, 0x17, 0x6b, 0xf0, 0xb4, 0x3b, 0xec, 0xc6, 0x28, 0x5a, 0xfb ], [ 0xf9, 0xb0, 0xfd, 0xa0, 0xc4, 0xa8, 0x98, 0xf5, 0xb9, 0xe6, 0xf6, 0x61, 0xc4, 0xce, 0x4d, 0x07 ], [ 0x8a, 0xde, 0x89, 0x59, 0x13, 0x68, 0x5c, 0x67, 0xc5, 0x26, 0x9f, 0x8a, 0xae, 0x42, 0x98, 0x3e ], [ 0x39, 0xbd, 0xe6, 0x7d, 0x5c, 0x8e, 0xd8, 0xa8, 0xb1, 0xc3, 0x7e, 0xb8, 0xfa, 0x9f, 0x5a, 0xc0 ], [ 0x5c, 0x00, 0x5e, 0x72, 0xc1, 0x41, 0x8c, 0x44, 0xf5, 0x69, 0xf2, 0xea, 0x33, 0xba, 0x54, 0xf3 ], [ 0x3f, 0x5b, 0x8c, 0xc9, 0xea, 0x85, 0x5a, 0x0a, 0xfa, 0x73, 0x47, 0xd2, 0x3e, 0x8d, 0x66, 0x4e ] ]; # Values from NIST KAT-AES ECBVarKey128.rsp cipher_texts2_128bit = [ [ 0x0e, 0xdd, 0x33, 0xd3, 0xc6, 0x21, 0xe5, 0x46, 0x45, 0x5b, 0xd8, 0xba, 0x14, 0x18, 0xbe, 0xc8 ], [ 0x4b, 0xc3, 0xf8, 0x83, 0x45, 0x0c, 0x11, 0x3c, 0x64, 0xca, 0x42, 0xe1, 0x11, 0x2a, 0x9e, 0x87 ], [ 0x72, 0xa1, 0xda, 0x77, 0x0f, 0x5d, 0x7a, 0xc4, 0xc9, 0xef, 0x94, 0xd8, 0x22, 0xaf, 0xfd, 0x97 ], [ 0x97, 0x00, 0x14, 0xd6, 0x34, 0xe2, 0xb7, 0x65, 0x07, 0x77, 0xe8, 0xe8, 0x4d, 0x03, 0xcc, 0xd8 ], [ 0xf1, 0x7e, 0x79, 0xae, 0xd0, 0xdb, 0x7e, 0x27, 0x9e, 0x95, 0x5b, 0x5f, 0x49, 0x38, 0x75, 0xa7 ], [ 0x9e, 0xd5, 0xa7, 0x51, 0x36, 0xa9, 0x40, 0xd0, 0x96, 0x3d, 0xa3, 0x79, 0xdb, 0x4a, 0xf2, 0x6a ], [ 0xc4, 0x29, 0x5f, 0x83, 0x46, 0x5c, 0x77, 0x55, 0xe8, 0xfa, 0x36, 0x4b, 0xac, 0x6a, 0x7e, 0xa5 ], [ 0xb1, 0xd7, 0x58, 0x25, 0x6b, 0x28, 0xfd, 0x85, 0x0a, 0xd4, 0x94, 0x42, 0x08, 0xcf, 0x11, 0x55 ], [ 0x42, 0xff, 0xb3, 0x4c, 0x74, 0x3d, 0xe4, 0xd8, 0x8c, 0xa3, 0x80, 0x11, 0xc9, 0x90, 0x89, 0x0b ], [ 0x99, 0x58, 0xf0, 0xec, 0xea, 0x8b, 0x21, 0x72, 0xc0, 0xc1, 0x99, 0x5f, 0x91, 0x82, 0xc0, 0xf3 ], [ 0x95, 0x6d, 0x77, 0x98, 0xfa, 0xc2, 0x0f, 0x82, 0xa8, 0x82, 0x3f, 0x98, 0x4d, 0x06, 0xf7, 0xf5 ], [ 0xa0, 0x1b, 0xf4, 0x4f, 0x2d, 0x16, 0xbe, 0x92, 0x8c, 0xa4, 0x4a, 0xaf, 0x7b, 0x9b, 0x10, 0x6b ], [ 0xb5, 0xf1, 0xa3, 0x3e, 0x50, 0xd4, 0x0d, 0x10, 0x37, 0x64, 0xc7, 0x6b, 0xd4, 0xc6, 0xb6, 0xf8 ], [ 0x26, 0x37, 0x05, 0x0c, 0x9f, 0xc0, 0xd4, 0x81, 0x7e, 0x2d, 0x69, 0xde, 0x87, 0x8a, 0xee, 0x8d ], [ 0x11, 0x3e, 0xcb, 0xe4, 0xa4, 0x53, 0x26, 0x9a, 0x0d, 0xd2, 0x60, 0x69, 0x46, 0x7f, 0xb5, 0xb5 ], [ 0x97, 0xd0, 0x75, 0x4f, 0xe6, 0x8f, 0x11, 0xb9, 0xe3, 0x75, 0xd0, 0x70, 0xa6, 0x08, 0xc8, 0x84 ], [ 0xc6, 0xa0, 0xb3, 0xe9, 0x98, 0xd0, 0x50, 0x68, 0xa5, 0x39, 0x97, 0x78, 0x40, 0x52, 0x00, 0xb4 ], [ 0xdf, 0x55, 0x6a, 0x33, 0x43, 0x8d, 0xb8, 0x7b, 0xc4, 0x1b, 0x17, 0x52, 0xc5, 0x5e, 0x5e, 0x49 ], [ 0x90, 0xfb, 0x12, 0x8d, 0x3a, 0x1a, 0xf6, 0xe5, 0x48, 0x52, 0x1b, 0xb9, 0x62, 0xbf, 0x1f, 0x05 ], [ 0x26, 0x29, 0x8e, 0x9c, 0x1d, 0xb5, 0x17, 0xc2, 0x15, 0xfa, 0xdf, 0xb7, 0xd2, 0xa8, 0xd6, 0x91 ], [ 0xa6, 0xcb, 0x76, 0x1d, 0x61, 0xf8, 0x29, 0x2d, 0x0d, 0xf3, 0x93, 0xa2, 0x79, 0xad, 0x03, 0x80 ], [ 0x12, 0xac, 0xd8, 0x9b, 0x13, 0xcd, 0x5f, 0x87, 0x26, 0xe3, 0x4d, 0x44, 0xfd, 0x48, 0x61, 0x08 ], [ 0x95, 0xb1, 0x70, 0x3f, 0xc5, 0x7b, 0xa0, 0x9f, 0xe0, 0xc3, 0x58, 0x0f, 0xeb, 0xdd, 0x7e, 0xd4 ], [ 0xde, 0x11, 0x72, 0x2d, 0x89, 0x3e, 0x9f, 0x91, 0x21, 0xc3, 0x81, 0xbe, 0xcc, 0x1d, 0xa5, 0x9a ], [ 0x6d, 0x11, 0x4c, 0xcb, 0x27, 0xbf, 0x39, 0x10, 0x12, 0xe8, 0x97, 0x4c, 0x54, 0x6d, 0x9b, 0xf2 ], [ 0x5c, 0xe3, 0x7e, 0x17, 0xeb, 0x46, 0x46, 0xec, 0xfa, 0xc2, 0x9b, 0x9c, 0xc3, 0x8d, 0x93, 0x40 ], [ 0x18, 0xc1, 0xb6, 0xe2, 0x15, 0x71, 0x22, 0x05, 0x6d, 0x02, 0x43, 0xd8, 0xa1, 0x65, 0xcd, 0xdb ], [ 0x99, 0x69, 0x3e, 0x6a, 0x59, 0xd1, 0x36, 0x6c, 0x74, 0xd8, 0x23, 0x56, 0x2d, 0x7e, 0x14, 0x31 ], [ 0x6c, 0x7c, 0x64, 0xdc, 0x84, 0xa8, 0xbb, 0xa7, 0x58, 0xed, 0x17, 0xeb, 0x02, 0x5a, 0x57, 0xe3 ], [ 0xe1, 0x7b, 0xc7, 0x9f, 0x30, 0xea, 0xab, 0x2f, 0xac, 0x2c, 0xbb, 0xe3, 0x45, 0x8d, 0x68, 0x7a ], [ 0x11, 0x14, 0xbc, 0x20, 0x28, 0x00, 0x9b, 0x92, 0x3f, 0x0b, 0x01, 0x91, 0x5c, 0xe5, 0xe7, 0xc4 ], [ 0x9c, 0x28, 0x52, 0x4a, 0x16, 0xa1, 0xe1, 0xc1, 0x45, 0x29, 0x71, 0xca, 0xa8, 0xd1, 0x34, 0x76 ], [ 0xed, 0x62, 0xe1, 0x63, 0x63, 0x63, 0x83, 0x60, 0xfd, 0xd6, 0xad, 0x62, 0x11, 0x27, 0x94, 0xf0 ], [ 0x5a, 0x86, 0x88, 0xf0, 0xb2, 0xa2, 0xc1, 0x62, 0x24, 0xc1, 0x61, 0x65, 0x8f, 0xfd, 0x40, 0x44 ], [ 0x23, 0xf7, 0x10, 0x84, 0x2b, 0x9b, 0xb9, 0xc3, 0x2f, 0x26, 0x64, 0x8c, 0x78, 0x68, 0x07, 0xca ], [ 0x44, 0xa9, 0x8b, 0xf1, 0x1e, 0x16, 0x3f, 0x63, 0x2c, 0x47, 0xec, 0x6a, 0x49, 0x68, 0x3a, 0x89 ], [ 0x0f, 0x18, 0xaf, 0xf9, 0x42, 0x74, 0x69, 0x6d, 0x9b, 0x61, 0x84, 0x8b, 0xd5, 0x0a, 0xc5, 0xe5 ], [ 0x82, 0x40, 0x85, 0x71, 0xc3, 0xe2, 0x42, 0x45, 0x40, 0x20, 0x7f, 0x83, 0x3b, 0x6d, 0xda, 0x69 ], [ 0x30, 0x3f, 0xf9, 0x96, 0x94, 0x7f, 0x0c, 0x7d, 0x1f, 0x43, 0xc8, 0xf3, 0x02, 0x7b, 0x9b, 0x75 ], [ 0x7d, 0xf4, 0xda, 0xf4, 0xad, 0x29, 0xa3, 0x61, 0x5a, 0x9b, 0x6e, 0xce, 0x5c, 0x99, 0x51, 0x8a ], [ 0xc7, 0x29, 0x54, 0xa4, 0x8d, 0x07, 0x74, 0xdb, 0x0b, 0x49, 0x71, 0xc5, 0x26, 0x26, 0x04, 0x15 ], [ 0x1d, 0xf9, 0xb7, 0x61, 0x12, 0xdc, 0x65, 0x31, 0xe0, 0x7d, 0x2c, 0xfd, 0xa0, 0x44, 0x11, 0xf0 ], [ 0x8e, 0x4d, 0x8e, 0x69, 0x91, 0x19, 0xe1, 0xfc, 0x87, 0x54, 0x5a, 0x64, 0x7f, 0xb1, 0xd3, 0x4f ], [ 0xe6, 0xc4, 0x80, 0x7a, 0xe1, 0x1f, 0x36, 0xf0, 0x91, 0xc5, 0x7d, 0x9f, 0xb6, 0x85, 0x48, 0xd1 ], [ 0x8e, 0xbf, 0x73, 0xaa, 0xd4, 0x9c, 0x82, 0x00, 0x7f, 0x77, 0xa5, 0xc1, 0xcc, 0xec, 0x6a, 0xb4 ], [ 0x4f, 0xb2, 0x88, 0xcc, 0x20, 0x40, 0x04, 0x90, 0x01, 0xd2, 0xc7, 0x58, 0x5a, 0xd1, 0x23, 0xfc ], [ 0x04, 0x49, 0x71, 0x10, 0xef, 0xb9, 0xdc, 0xeb, 0x13, 0xe2, 0xb1, 0x3f, 0xb4, 0x46, 0x55, 0x64 ], [ 0x75, 0x55, 0x0e, 0x6c, 0xb5, 0xa8, 0x8e, 0x49, 0x63, 0x4c, 0x9a, 0xb6, 0x9e, 0xda, 0x04, 0x30 ], [ 0xb6, 0x76, 0x84, 0x73, 0xce, 0x98, 0x43, 0xea, 0x66, 0xa8, 0x14, 0x05, 0xdd, 0x50, 0xb3, 0x45 ], [ 0xcb, 0x2f, 0x43, 0x03, 0x83, 0xf9, 0x08, 0x4e, 0x03, 0xa6, 0x53, 0x57, 0x1e, 0x06, 0x5d, 0xe6 ], [ 0xff, 0x4e, 0x66, 0xc0, 0x7b, 0xae, 0x3e, 0x79, 0xfb, 0x7d, 0x21, 0x08, 0x47, 0xa3, 0xb0, 0xba ], [ 0x7b, 0x90, 0x78, 0x51, 0x25, 0x50, 0x5f, 0xad, 0x59, 0xb1, 0x3c, 0x18, 0x6d, 0xd6, 0x6c, 0xe3 ], [ 0x8b, 0x52, 0x7a, 0x6a, 0xeb, 0xda, 0xec, 0x9e, 0xae, 0xf8, 0xed, 0xa2, 0xcb, 0x77, 0x83, 0xe5 ], [ 0x43, 0xfd, 0xaf, 0x53, 0xeb, 0xbc, 0x98, 0x80, 0xc2, 0x28, 0x61, 0x7d, 0x6a, 0x9b, 0x54, 0x8b ], [ 0x53, 0x78, 0x61, 0x04, 0xb9, 0x74, 0x4b, 0x98, 0xf0, 0x52, 0xc4, 0x6f, 0x1c, 0x85, 0x0d, 0x0b ], [ 0xb5, 0xab, 0x30, 0x13, 0xdd, 0x1e, 0x61, 0xdf, 0x06, 0xcb, 0xaf, 0x34, 0xca, 0x2a, 0xee, 0x78 ], [ 0x74, 0x70, 0x46, 0x9b, 0xe9, 0x72, 0x30, 0x30, 0xfd, 0xcc, 0x73, 0xa8, 0xcd, 0x4f, 0xbb, 0x10 ], [ 0xa3, 0x5a, 0x63, 0xf5, 0x34, 0x3e, 0xbe, 0x9e, 0xf8, 0x16, 0x7b, 0xcb, 0x48, 0xad, 0x12, 0x2e ], [ 0xfd, 0x86, 0x87, 0xf0, 0x75, 0x7a, 0x21, 0x0e, 0x9f, 0xdf, 0x18, 0x12, 0x04, 0xc3, 0x08, 0x63 ], [ 0x7a, 0x18, 0x1e, 0x84, 0xbd, 0x54, 0x57, 0xd2, 0x6a, 0x88, 0xfb, 0xae, 0x96, 0x01, 0x8f, 0xb0 ], [ 0x65, 0x33, 0x17, 0xb9, 0x36, 0x2b, 0x6f, 0x9b, 0x9e, 0x1a, 0x58, 0x0e, 0x68, 0xd4, 0x94, 0xb5 ], [ 0x99, 0x5c, 0x9d, 0xc0, 0xb6, 0x89, 0xf0, 0x3c, 0x45, 0x86, 0x7b, 0x5f, 0xaa, 0x5c, 0x18, 0xd1 ], [ 0x77, 0xa4, 0xd9, 0x6d, 0x56, 0xdd, 0xa3, 0x98, 0xb9, 0xaa, 0xbe, 0xcf, 0xc7, 0x57, 0x29, 0xfd ], [ 0x84, 0xbe, 0x19, 0xe0, 0x53, 0x63, 0x5f, 0x09, 0xf2, 0x66, 0x5e, 0x7b, 0xae, 0x85, 0xb4, 0x2d ], [ 0x32, 0xcd, 0x65, 0x28, 0x42, 0x92, 0x6a, 0xea, 0x4a, 0xa6, 0x13, 0x7b, 0xb2, 0xbe, 0x2b, 0x5e ], [ 0x49, 0x3d, 0x4a, 0x4f, 0x38, 0xeb, 0xb3, 0x37, 0xd1, 0x0a, 0xa8, 0x4e, 0x91, 0x71, 0xa5, 0x54 ], [ 0xd9, 0xbf, 0xf7, 0xff, 0x45, 0x4b, 0x0e, 0xc5, 0xa4, 0xa2, 0xa6, 0x95, 0x66, 0xe2, 0xcb, 0x84 ], [ 0x35, 0x35, 0xd5, 0x65, 0xac, 0xe3, 0xf3, 0x1e, 0xb2, 0x49, 0xba, 0x2c, 0xc6, 0x76, 0x5d, 0x7a ], [ 0xf6, 0x0e, 0x91, 0xfc, 0x32, 0x69, 0xee, 0xcf, 0x32, 0x31, 0xc6, 0xe9, 0x94, 0x56, 0x97, 0xc6 ], [ 0xab, 0x69, 0xcf, 0xad, 0xf5, 0x1f, 0x8e, 0x60, 0x4d, 0x9c, 0xc3, 0x71, 0x82, 0xf6, 0x63, 0x5a ], [ 0x78, 0x66, 0x37, 0x3f, 0x24, 0xa0, 0xb6, 0xed, 0x56, 0xe0, 0xd9, 0x6f, 0xcd, 0xaf, 0xb8, 0x77 ], [ 0x1e, 0xa4, 0x48, 0xc2, 0xaa, 0xc9, 0x54, 0xf5, 0xd8, 0x12, 0xe9, 0xd7, 0x84, 0x94, 0x44, 0x6a ], [ 0xac, 0xc5, 0x59, 0x9d, 0xd8, 0xac, 0x02, 0x23, 0x9a, 0x0f, 0xef, 0x4a, 0x36, 0xdd, 0x16, 0x68 ], [ 0xd8, 0x76, 0x44, 0x68, 0xbb, 0x10, 0x38, 0x28, 0xcf, 0x7e, 0x14, 0x73, 0xce, 0x89, 0x50, 0x73 ], [ 0x1b, 0x0d, 0x02, 0x89, 0x36, 0x83, 0xb9, 0xf1, 0x80, 0x45, 0x8e, 0x4a, 0xa6, 0xb7, 0x39, 0x82 ], [ 0x96, 0xd9, 0xb0, 0x17, 0xd3, 0x02, 0xdf, 0x41, 0x0a, 0x93, 0x7d, 0xcd, 0xb8, 0xbb, 0x6e, 0x43 ], [ 0xef, 0x16, 0x23, 0xcc, 0x44, 0x31, 0x3c, 0xff, 0x44, 0x0b, 0x15, 0x94, 0xa7, 0xe2, 0x1c, 0xc6 ], [ 0x28, 0x4c, 0xa2, 0xfa, 0x35, 0x80, 0x7b, 0x8b, 0x0a, 0xe4, 0xd1, 0x9e, 0x11, 0xd7, 0xdb, 0xd7 ], [ 0xf2, 0xe9, 0x76, 0x87, 0x57, 0x55, 0xf9, 0x40, 0x1d, 0x54, 0xf3, 0x6e, 0x2a, 0x23, 0xa5, 0x94 ], [ 0xec, 0x19, 0x8a, 0x18, 0xe1, 0x0e, 0x53, 0x24, 0x03, 0xb7, 0xe2, 0x08, 0x87, 0xc8, 0xdd, 0x80 ], [ 0x54, 0x5d, 0x50, 0xeb, 0xd9, 0x19, 0xe4, 0xa6, 0x94, 0x9d, 0x96, 0xad, 0x47, 0xe4, 0x6a, 0x80 ], [ 0xdb, 0xdf, 0xb5, 0x27, 0x06, 0x0e, 0x0a, 0x71, 0x00, 0x9c, 0x7b, 0xb0, 0xc6, 0x8f, 0x1d, 0x44 ], [ 0x9c, 0xfa, 0x13, 0x22, 0xea, 0x33, 0xda, 0x21, 0x73, 0xa0, 0x24, 0xf2, 0xff, 0x0d, 0x89, 0x6d ], [ 0x87, 0x85, 0xb1, 0xa7, 0x5b, 0x0f, 0x3b, 0xd9, 0x58, 0xdc, 0xd0, 0xe2, 0x93, 0x18, 0xc5, 0x21 ], [ 0x38, 0xf6, 0x7b, 0x9e, 0x98, 0xe4, 0xa9, 0x7b, 0x6d, 0xf0, 0x30, 0xa9, 0xfc, 0xdd, 0x01, 0x04 ], [ 0x19, 0x2a, 0xff, 0xfb, 0x2c, 0x88, 0x0e, 0x82, 0xb0, 0x59, 0x26, 0xd0, 0xfc, 0x6c, 0x44, 0x8b ], [ 0x6a, 0x79, 0x80, 0xce, 0x7b, 0x10, 0x5c, 0xf5, 0x30, 0x95, 0x2d, 0x74, 0xda, 0xaf, 0x79, 0x8c ], [ 0xea, 0x36, 0x95, 0xe1, 0x35, 0x1b, 0x9d, 0x68, 0x58, 0xbd, 0x95, 0x8c, 0xf5, 0x13, 0xef, 0x6c ], [ 0x6d, 0xa0, 0x49, 0x0b, 0xa0, 0xba, 0x03, 0x43, 0xb9, 0x35, 0x68, 0x1d, 0x2c, 0xce, 0x5b, 0xa1 ], [ 0xf0, 0xea, 0x23, 0xaf, 0x08, 0x53, 0x40, 0x11, 0xc6, 0x00, 0x09, 0xab, 0x29, 0xad, 0xa2, 0xf1 ], [ 0xff, 0x13, 0x80, 0x6c, 0xf1, 0x9c, 0xc3, 0x87, 0x21, 0x55, 0x4d, 0x7c, 0x0f, 0xcd, 0xcd, 0x4b ], [ 0x68, 0x38, 0xaf, 0x1f, 0x4f, 0x69, 0xba, 0xe9, 0xd8, 0x5d, 0xd1, 0x88, 0xdc, 0xdf, 0x06, 0x88 ], [ 0x36, 0xcf, 0x44, 0xc9, 0x2d, 0x55, 0x0b, 0xfb, 0x1e, 0xd2, 0x8e, 0xf5, 0x83, 0xdd, 0xf5, 0xd7 ], [ 0xd0, 0x6e, 0x31, 0x95, 0xb5, 0x37, 0x6f, 0x10, 0x9d, 0x5c, 0x4e, 0xc6, 0xc5, 0xd6, 0x2c, 0xed ], [ 0xc4, 0x40, 0xde, 0x01, 0x4d, 0x3d, 0x61, 0x07, 0x07, 0x27, 0x9b, 0x13, 0x24, 0x2a, 0x5c, 0x36 ], [ 0xf0, 0xc5, 0xc6, 0xff, 0xa5, 0xe0, 0xbd, 0x3a, 0x94, 0xc8, 0x8f, 0x6b, 0x6f, 0x7c, 0x16, 0xb9 ], [ 0x3e, 0x40, 0xc3, 0x90, 0x1c, 0xd7, 0xef, 0xfc, 0x22, 0xbf, 0xfc, 0x35, 0xde, 0xe0, 0xb4, 0xd9 ], [ 0xb6, 0x33, 0x05, 0xc7, 0x2b, 0xed, 0xfa, 0xb9, 0x73, 0x82, 0xc4, 0x06, 0xd0, 0xc4, 0x9b, 0xc6 ], [ 0x36, 0xbb, 0xaa, 0xb2, 0x2a, 0x6b, 0xd4, 0x92, 0x5a, 0x99, 0xa2, 0xb4, 0x08, 0xd2, 0xdb, 0xae ], [ 0x30, 0x7c, 0x5b, 0x8f, 0xcd, 0x05, 0x33, 0xab, 0x98, 0xbc, 0x51, 0xe2, 0x7a, 0x6c, 0xe4, 0x61 ], [ 0x82, 0x9c, 0x04, 0xff, 0x4c, 0x07, 0x51, 0x3c, 0x0b, 0x3e, 0xf0, 0x5c, 0x03, 0xe3, 0x37, 0xb5 ], [ 0xf1, 0x7a, 0xf0, 0xe8, 0x95, 0xdd, 0xa5, 0xeb, 0x98, 0xef, 0xc6, 0x80, 0x66, 0xe8, 0x4c, 0x54 ], [ 0x27, 0x71, 0x67, 0xf3, 0x81, 0x2a, 0xff, 0xf1, 0xff, 0xac, 0xb4, 0xa9, 0x34, 0x37, 0x9f, 0xc3 ], [ 0x2c, 0xb1, 0xdc, 0x3a, 0x9c, 0x72, 0x97, 0x2e, 0x42, 0x5a, 0xe2, 0xef, 0x3e, 0xb5, 0x97, 0xcd ], [ 0x36, 0xae, 0xaa, 0x3a, 0x21, 0x3e, 0x96, 0x8d, 0x4b, 0x5b, 0x67, 0x9d, 0x3a, 0x2c, 0x97, 0xfe ], [ 0x92, 0x41, 0xda, 0xca, 0x4f, 0xdd, 0x03, 0x4a, 0x82, 0x37, 0x2d, 0xb5, 0x0e, 0x1a, 0x0f, 0x3f ], [ 0xc1, 0x45, 0x74, 0xd9, 0xcd, 0x00, 0xcf, 0x2b, 0x5a, 0x7f, 0x77, 0xe5, 0x3c, 0xd5, 0x78, 0x85 ], [ 0x79, 0x3d, 0xe3, 0x92, 0x36, 0x57, 0x0a, 0xba, 0x83, 0xab, 0x9b, 0x73, 0x7c, 0xb5, 0x21, 0xc9 ], [ 0x16, 0x59, 0x1c, 0x0f, 0x27, 0xd6, 0x0e, 0x29, 0xb8, 0x5a, 0x96, 0xc3, 0x38, 0x61, 0xa7, 0xef ], [ 0x44, 0xfb, 0x5c, 0x4d, 0x4f, 0x5c, 0xb7, 0x9b, 0xe5, 0xc1, 0x74, 0xa3, 0xb1, 0xc9, 0x73, 0x48 ], [ 0x67, 0x4d, 0x2b, 0x61, 0x63, 0x3d, 0x16, 0x2b, 0xe5, 0x9d, 0xde, 0x04, 0x22, 0x2f, 0x47, 0x40 ], [ 0xb4, 0x75, 0x0f, 0xf2, 0x63, 0xa6, 0x5e, 0x1f, 0x9e, 0x92, 0x4c, 0xcf, 0xd9, 0x8f, 0x3e, 0x37 ], [ 0x62, 0xd0, 0x66, 0x2d, 0x6e, 0xae, 0xdd, 0xed, 0xeb, 0xae, 0x7f, 0x7e, 0xa3, 0xa4, 0xf6, 0xb6 ], [ 0x70, 0xc4, 0x6b, 0xb3, 0x06, 0x92, 0xbe, 0x65, 0x7f, 0x7e, 0xaa, 0x93, 0xeb, 0xad, 0x98, 0x97 ], [ 0x32, 0x39, 0x94, 0xcf, 0xb9, 0xda, 0x28, 0x5a, 0x5d, 0x96, 0x42, 0xe1, 0x75, 0x9b, 0x22, 0x4a ], [ 0x1d, 0xbf, 0x57, 0x87, 0x7b, 0x7b, 0x17, 0x38, 0x5c, 0x85, 0xd0, 0xb5, 0x48, 0x51, 0xe3, 0x71 ], [ 0xdf, 0xa5, 0xc0, 0x97, 0xcd, 0xc1, 0x53, 0x2a, 0xc0, 0x71, 0xd5, 0x7b, 0x1d, 0x28, 0xd1, 0xbd ], [ 0x3a, 0x0c, 0x53, 0xfa, 0x37, 0x31, 0x1f, 0xc1, 0x0b, 0xd2, 0xa9, 0x98, 0x1f, 0x51, 0x31, 0x74 ], [ 0xba, 0x4f, 0x97, 0x0c, 0x0a, 0x25, 0xc4, 0x18, 0x14, 0xbd, 0xae, 0x2e, 0x50, 0x6b, 0xe3, 0xb4 ], [ 0x2d, 0xce, 0x3a, 0xcb, 0x72, 0x7c, 0xd1, 0x3c, 0xcd, 0x76, 0xd4, 0x25, 0xea, 0x56, 0xe4, 0xf6 ], [ 0x51, 0x60, 0x47, 0x4d, 0x50, 0x4b, 0x9b, 0x3e, 0xef, 0xb6, 0x8d, 0x35, 0xf2, 0x45, 0xf4, 0xb3 ], [ 0x41, 0xa8, 0xa9, 0x47, 0x76, 0x66, 0x35, 0xde, 0xc3, 0x75, 0x53, 0xd9, 0xa6, 0xc0, 0xcb, 0xb7 ], [ 0x25, 0xd6, 0xcf, 0xe6, 0x88, 0x1f, 0x2b, 0xf4, 0x97, 0xdd, 0x14, 0xcd, 0x4d, 0xdf, 0x44, 0x5b ], [ 0x41, 0xc7, 0x8c, 0x13, 0x5e, 0xd9, 0xe9, 0x8c, 0x09, 0x66, 0x40, 0x64, 0x72, 0x65, 0xda, 0x1e ], [ 0x5a, 0x4d, 0x40, 0x4d, 0x89, 0x17, 0xe3, 0x53, 0xe9, 0x2a, 0x21, 0x07, 0x2c, 0x3b, 0x23, 0x05 ], [ 0x02, 0xbc, 0x96, 0x84, 0x6b, 0x3f, 0xdc, 0x71, 0x64, 0x3f, 0x38, 0x4c, 0xd3, 0xcc, 0x3e, 0xaf ], [ 0x9b, 0xa4, 0xa9, 0x14, 0x3f, 0x4e, 0x5d, 0x40, 0x48, 0x52, 0x1c, 0x4f, 0x88, 0x77, 0xd8, 0x8e ], [ 0xa1, 0xf6, 0x25, 0x8c, 0x87, 0x7d, 0x5f, 0xcd, 0x89, 0x64, 0x48, 0x45, 0x38, 0xbf, 0xc9, 0x2c ] ]; # Values from NIST KAT-AES ECBVarTxt192.rsp cipher_texts1_192bit = [ [ 0x6c, 0xd0, 0x25, 0x13, 0xe8, 0xd4, 0xdc, 0x98, 0x6b, 0x4a, 0xfe, 0x08, 0x7a, 0x60, 0xbd, 0x0c ], [ 0x2c, 0xe1, 0xf8, 0xb7, 0xe3, 0x06, 0x27, 0xc1, 0xc4, 0x51, 0x9e, 0xad, 0xa4, 0x4b, 0xc4, 0x36 ], [ 0x99, 0x46, 0xb5, 0xf8, 0x7a, 0xf4, 0x46, 0xf5, 0x79, 0x6c, 0x1f, 0xee, 0x63, 0xa2, 0xda, 0x24 ], [ 0x2a, 0x56, 0x03, 0x64, 0xce, 0x52, 0x9e, 0xfc, 0x21, 0x78, 0x87, 0x79, 0x56, 0x8d, 0x55, 0x55 ], [ 0x35, 0xc1, 0x47, 0x18, 0x37, 0xaf, 0x44, 0x61, 0x53, 0xbc, 0xe5, 0x5d, 0x5b, 0xa7, 0x2a, 0x0a ], [ 0xce, 0x60, 0xbc, 0x52, 0x38, 0x62, 0x34, 0xf1, 0x58, 0xf8, 0x43, 0x41, 0xe5, 0x34, 0xcd, 0x9e ], [ 0x8c, 0x7c, 0x27, 0xff, 0x32, 0xbc, 0xf8, 0xdc, 0x2d, 0xc5, 0x7c, 0x90, 0xc2, 0x90, 0x39, 0x61 ], [ 0x32, 0xbb, 0x6a, 0x7e, 0xc8, 0x44, 0x99, 0xe1, 0x66, 0xf9, 0x36, 0x00, 0x3d, 0x55, 0xa5, 0xbb ], [ 0xa5, 0xc7, 0x72, 0xe5, 0xc6, 0x26, 0x31, 0xef, 0x66, 0x0e, 0xe1, 0xd5, 0x87, 0x7f, 0x6d, 0x1b ], [ 0x03, 0x0d, 0x7e, 0x5b, 0x64, 0xf3, 0x80, 0xa7, 0xe4, 0xea, 0x53, 0x87, 0xb5, 0xcd, 0x7f, 0x49 ], [ 0x0d, 0xc9, 0xa2, 0x61, 0x00, 0x37, 0x00, 0x9b, 0x69, 0x8f, 0x11, 0xbb, 0x7e, 0x86, 0xc8, 0x3e ], [ 0x00, 0x46, 0x61, 0x2c, 0x76, 0x6d, 0x18, 0x40, 0xc2, 0x26, 0x36, 0x4f, 0x1f, 0xa7, 0xed, 0x72 ], [ 0x48, 0x80, 0xc7, 0xe0, 0x8f, 0x27, 0xbe, 0xfe, 0x78, 0x59, 0x07, 0x43, 0xc0, 0x5e, 0x69, 0x8b ], [ 0x25, 0x20, 0xce, 0x82, 0x9a, 0x26, 0x57, 0x7f, 0x0f, 0x48, 0x22, 0xc4, 0xec, 0xc8, 0x74, 0x01 ], [ 0x87, 0x65, 0xe8, 0xac, 0xc1, 0x69, 0x75, 0x83, 0x19, 0xcb, 0x46, 0xdc, 0x7b, 0xcf, 0x3d, 0xca ], [ 0xe9, 0x8f, 0x4b, 0xa4, 0xf0, 0x73, 0xdf, 0x4b, 0xaa, 0x11, 0x6d, 0x01, 0x1d, 0xc2, 0x4a, 0x28 ], [ 0xf3, 0x78, 0xf6, 0x8c, 0x5d, 0xbf, 0x59, 0xe2, 0x11, 0xb3, 0xa6, 0x59, 0xa7, 0x31, 0x7d, 0x94 ], [ 0x28, 0x3d, 0x3b, 0x06, 0x9d, 0x8e, 0xb9, 0xfb, 0x43, 0x2d, 0x74, 0xb9, 0x6c, 0xa7, 0x62, 0xb4 ], [ 0xa7, 0xe1, 0x84, 0x2e, 0x8a, 0x87, 0x86, 0x1c, 0x22, 0x1a, 0x50, 0x08, 0x83, 0x24, 0x5c, 0x51 ], [ 0x77, 0xaa, 0x27, 0x04, 0x71, 0x88, 0x1b, 0xe0, 0x70, 0xfb, 0x52, 0xc7, 0x06, 0x7c, 0xe7, 0x32 ], [ 0x01, 0xb0, 0xf4, 0x76, 0xd4, 0x84, 0xf4, 0x3f, 0x1a, 0xeb, 0x6e, 0xfa, 0x93, 0x61, 0xa8, 0xac ], [ 0x1c, 0x3a, 0x94, 0xf1, 0xc0, 0x52, 0xc5, 0x5c, 0x2d, 0x83, 0x59, 0xaf, 0xf2, 0x16, 0x3b, 0x4f ], [ 0xe8, 0xa0, 0x67, 0xb6, 0x04, 0xd5, 0x37, 0x3d, 0x8b, 0x0f, 0x2e, 0x05, 0xa0, 0x3b, 0x34, 0x1b ], [ 0xa7, 0x87, 0x6e, 0xc8, 0x7f, 0x5a, 0x09, 0xbf, 0xea, 0x42, 0xc7, 0x7d, 0xa3, 0x0f, 0xd5, 0x0e ], [ 0x0c, 0xf3, 0xe9, 0xd3, 0xa4, 0x2b, 0xe5, 0xb8, 0x54, 0xca, 0x65, 0xb1, 0x3f, 0x35, 0xf4, 0x8d ], [ 0x6c, 0x62, 0xf6, 0xbb, 0xca, 0xb7, 0xc3, 0xe8, 0x21, 0xc9, 0x29, 0x0f, 0x08, 0x89, 0x2d, 0xda ], [ 0x7f, 0x5e, 0x05, 0xbd, 0x20, 0x68, 0x73, 0x81, 0x96, 0xfe, 0xe7, 0x9a, 0xce, 0x7e, 0x3a, 0xec ], [ 0x44, 0x0e, 0x0d, 0x73, 0x32, 0x55, 0xcd, 0xa9, 0x2f, 0xb4, 0x6e, 0x84, 0x2f, 0xe5, 0x80, 0x54 ], [ 0xaa, 0x5d, 0x5b, 0x1c, 0x4e, 0xa1, 0xb7, 0xa2, 0x2e, 0x55, 0x83, 0xac, 0x2e, 0x9e, 0xd8, 0xa7 ], [ 0x77, 0xe5, 0x37, 0xe8, 0x9e, 0x84, 0x91, 0xe8, 0x66, 0x2a, 0xae, 0x3b, 0xc8, 0x09, 0x42, 0x1d ], [ 0x99, 0x7d, 0xd3, 0xe9, 0xf1, 0x59, 0x8b, 0xfa, 0x73, 0xf7, 0x59, 0x73, 0xf7, 0xe9, 0x3b, 0x76 ], [ 0x1b, 0x38, 0xd4, 0xf7, 0x45, 0x2a, 0xfe, 0xfc, 0xb7, 0xfc, 0x72, 0x12, 0x44, 0xe4, 0xb7, 0x2e ], [ 0x0b, 0xe2, 0xb1, 0x82, 0x52, 0xe7, 0x74, 0xdd, 0xa3, 0x0c, 0xdd, 0xa0, 0x2c, 0x69, 0x06, 0xe3 ], [ 0xd2, 0x69, 0x5e, 0x59, 0xc2, 0x03, 0x61, 0xd8, 0x26, 0x52, 0xd7, 0xd5, 0x8b, 0x6f, 0x11, 0xb2 ], [ 0x90, 0x2d, 0x88, 0xd1, 0x3e, 0xae, 0x52, 0x08, 0x9a, 0xbd, 0x61, 0x43, 0xcf, 0xe3, 0x94, 0xe9 ], [ 0xd4, 0x9b, 0xce, 0xb3, 0xb8, 0x23, 0xfe, 0xdd, 0x60, 0x2c, 0x30, 0x53, 0x45, 0x73, 0x4b, 0xd2 ], [ 0x70, 0x7b, 0x1d, 0xbb, 0x0f, 0xfa, 0x40, 0xef, 0x7d, 0x95, 0xde, 0xf4, 0x21, 0x23, 0x3f, 0xae ], [ 0x7c, 0xa0, 0xc1, 0xd9, 0x33, 0x56, 0xd9, 0xeb, 0x8a, 0xa9, 0x52, 0x08, 0x4d, 0x75, 0xf9, 0x13 ], [ 0xf2, 0xcb, 0xf9, 0xcb, 0x18, 0x6e, 0x27, 0x0d, 0xd7, 0xbd, 0xb0, 0xc2, 0x8f, 0xeb, 0xc5, 0x7d ], [ 0xc9, 0x43, 0x37, 0xc3, 0x7c, 0x4e, 0x79, 0x0a, 0xb4, 0x57, 0x80, 0xbd, 0x9c, 0x36, 0x74, 0xa0 ], [ 0x8e, 0x35, 0x58, 0xc1, 0x35, 0x25, 0x2f, 0xb9, 0xc9, 0xf3, 0x67, 0xed, 0x60, 0x94, 0x67, 0xa1 ], [ 0x1b, 0x72, 0xee, 0xae, 0xe4, 0x89, 0x9b, 0x44, 0x39, 0x14, 0xe5, 0xb3, 0xa5, 0x7f, 0xba, 0x92 ], [ 0x01, 0x18, 0x65, 0xf9, 0x1b, 0xc5, 0x68, 0x68, 0xd0, 0x51, 0xe5, 0x2c, 0x9e, 0xfd, 0x59, 0xb7 ], [ 0xe4, 0x77, 0x13, 0x18, 0xad, 0x7a, 0x63, 0xdd, 0x68, 0x0f, 0x6e, 0x58, 0x3b, 0x77, 0x47, 0xea ], [ 0x61, 0xe3, 0xd1, 0x94, 0x08, 0x8d, 0xc8, 0xd9, 0x7e, 0x9e, 0x6d, 0xb3, 0x74, 0x57, 0xea, 0xc5 ], [ 0x36, 0xff, 0x1e, 0xc9, 0xcc, 0xfb, 0xc3, 0x49, 0xe5, 0xd3, 0x56, 0xd0, 0x63, 0x69, 0x3a, 0xd6 ], [ 0x3c, 0xc9, 0xe9, 0xa9, 0xbe, 0x8c, 0xc3, 0xf6, 0xfb, 0x2e, 0xa2, 0x40, 0x88, 0xe9, 0xbb, 0x19 ], [ 0x1e, 0xe5, 0xab, 0x00, 0x3d, 0xc8, 0x72, 0x2e, 0x74, 0x90, 0x5d, 0x9a, 0x8f, 0xe3, 0xd3, 0x50 ], [ 0x24, 0x53, 0x39, 0x31, 0x95, 0x84, 0xb0, 0xa4, 0x12, 0x41, 0x28, 0x69, 0xd6, 0xc2, 0xea, 0xda ], [ 0x7b, 0xd4, 0x96, 0x91, 0x81, 0x15, 0xd1, 0x4e, 0xd5, 0x38, 0x08, 0x52, 0x71, 0x6c, 0x88, 0x14 ], [ 0x27, 0x3a, 0xb2, 0xf2, 0xb4, 0xa3, 0x66, 0xa5, 0x7d, 0x58, 0x2a, 0x33, 0x93, 0x13, 0xc8, 0xb1 ], [ 0x11, 0x33, 0x65, 0xa9, 0xff, 0xbe, 0x3b, 0x0c, 0xa6, 0x1e, 0x98, 0x50, 0x75, 0x54, 0x16, 0x8b ], [ 0xaf, 0xa9, 0x9c, 0x99, 0x7a, 0xc4, 0x78, 0xa0, 0xde, 0xa4, 0x11, 0x9c, 0x9e, 0x45, 0xf8, 0xb1 ], [ 0x92, 0x16, 0x30, 0x9a, 0x78, 0x42, 0x43, 0x0b, 0x83, 0xff, 0xb9, 0x86, 0x38, 0x01, 0x15, 0x12 ], [ 0x62, 0xab, 0xc7, 0x92, 0x28, 0x82, 0x58, 0x49, 0x2a, 0x7c, 0xb4, 0x51, 0x45, 0xf4, 0xb7, 0x59 ], [ 0x53, 0x49, 0x23, 0xc1, 0x69, 0xd5, 0x04, 0xd7, 0x51, 0x9c, 0x15, 0xd3, 0x0e, 0x75, 0x6c, 0x50 ], [ 0xfa, 0x75, 0xe0, 0x5b, 0xcd, 0xc7, 0xe0, 0x0c, 0x27, 0x3f, 0xa3, 0x3f, 0x6e, 0xe4, 0x41, 0xd2 ], [ 0x7d, 0x35, 0x0f, 0xa6, 0x05, 0x70, 0x80, 0xf1, 0x08, 0x6a, 0x56, 0xb1, 0x7e, 0xc2, 0x40, 0xdb ], [ 0xf3, 0x4e, 0x4a, 0x63, 0x24, 0xea, 0x4a, 0x5c, 0x39, 0xa6, 0x61, 0xc8, 0xfe, 0x5a, 0xda, 0x8f ], [ 0x08, 0x82, 0xa1, 0x6f, 0x44, 0x08, 0x8d, 0x42, 0x44, 0x7a, 0x29, 0xac, 0x09, 0x0e, 0xc1, 0x7e ], [ 0x3a, 0x3c, 0x15, 0xbf, 0xc1, 0x1a, 0x95, 0x37, 0xc1, 0x30, 0x68, 0x70, 0x04, 0xe1, 0x36, 0xee ], [ 0x22, 0xc0, 0xa7, 0x67, 0x8d, 0xc6, 0xd8, 0xcf, 0x5c, 0x8a, 0x6d, 0x5a, 0x99, 0x60, 0x76, 0x7c ], [ 0xb4, 0x6b, 0x09, 0x80, 0x9d, 0x68, 0xb9, 0xa4, 0x56, 0x43, 0x2a, 0x79, 0xbd, 0xc2, 0xe3, 0x8c ], [ 0x93, 0xba, 0xaf, 0xfb, 0x35, 0xfb, 0xe7, 0x39, 0xc1, 0x7c, 0x6a, 0xc2, 0x2e, 0xec, 0xf1, 0x8f ], [ 0xc8, 0xaa, 0x80, 0xa7, 0x85, 0x06, 0x75, 0xbc, 0x00, 0x7c, 0x46, 0xdf, 0x06, 0xb4, 0x98, 0x68 ], [ 0x12, 0xc6, 0xf3, 0x87, 0x7a, 0xf4, 0x21, 0xa9, 0x18, 0xa8, 0x4b, 0x77, 0x58, 0x58, 0x02, 0x1d ], [ 0x33, 0xf1, 0x23, 0x28, 0x2c, 0x5d, 0x63, 0x39, 0x24, 0xf7, 0xd5, 0xba, 0x3f, 0x3c, 0xab, 0x11 ], [ 0xa8, 0xf1, 0x61, 0x00, 0x27, 0x33, 0xe9, 0x3c, 0xa4, 0x52, 0x7d, 0x22, 0xc1, 0xa0, 0xc5, 0xbb ], [ 0xb7, 0x2f, 0x70, 0xeb, 0xf3, 0xe3, 0xfd, 0xa2, 0x3f, 0x50, 0x8e, 0xec, 0x76, 0xb4, 0x2c, 0x02 ], [ 0x6a, 0x9d, 0x96, 0x5e, 0x62, 0x74, 0x14, 0x3f, 0x25, 0xaf, 0xdc, 0xfc, 0x88, 0xff, 0xd7, 0x7c ], [ 0xa0, 0xc7, 0x4f, 0xd0, 0xb9, 0x36, 0x17, 0x64, 0xce, 0x91, 0xc5, 0x20, 0x0b, 0x09, 0x53, 0x57 ], [ 0x09, 0x1d, 0x1f, 0xdc, 0x2b, 0xd2, 0xc3, 0x46, 0xcd, 0x50, 0x46, 0xa8, 0xc6, 0x20, 0x91, 0x46 ], [ 0xe2, 0xa3, 0x75, 0x80, 0x11, 0x6c, 0xfb, 0x71, 0x85, 0x62, 0x54, 0x49, 0x6a, 0xb0, 0xac, 0xa8 ], [ 0xe0, 0xb3, 0xa0, 0x07, 0x85, 0x91, 0x7c, 0x7e, 0xfc, 0x9a, 0xdb, 0xa3, 0x22, 0x81, 0x35, 0x71 ], [ 0x73, 0x3d, 0x41, 0xf4, 0x72, 0x7b, 0x5e, 0xf0, 0xdf, 0x4a, 0xf4, 0xcf, 0x3c, 0xff, 0xa0, 0xcb ], [ 0xa9, 0x9e, 0xbb, 0x03, 0x02, 0x60, 0x82, 0x6f, 0x98, 0x1a, 0xd3, 0xe6, 0x44, 0x90, 0xaa, 0x4f ], [ 0x73, 0xf3, 0x4c, 0x7d, 0x3e, 0xae, 0x5e, 0x80, 0x08, 0x2c, 0x16, 0x47, 0x52, 0x43, 0x08, 0xee ], [ 0x40, 0xeb, 0xd5, 0xad, 0x08, 0x23, 0x45, 0xb7, 0xa2, 0x09, 0x7c, 0xcd, 0x34, 0x64, 0xda, 0x02 ], [ 0x7c, 0xc4, 0xae, 0x9a, 0x42, 0x4b, 0x2c, 0xec, 0x90, 0xc9, 0x71, 0x53, 0xc2, 0x45, 0x7e, 0xc5 ], [ 0x54, 0xd6, 0x32, 0xd0, 0x3a, 0xba, 0x0b, 0xd0, 0xf9, 0x18, 0x77, 0xeb, 0xdd, 0x4d, 0x09, 0xcb ], [ 0xd3, 0x42, 0x7b, 0xe7, 0xe4, 0xd2, 0x7c, 0xd5, 0x4f, 0x5f, 0xe3, 0x7b, 0x03, 0xcf, 0x08, 0x97 ], [ 0xb2, 0x09, 0x97, 0x95, 0xe8, 0x8c, 0xc1, 0x58, 0xfd, 0x75, 0xea, 0x13, 0x3d, 0x7e, 0x7f, 0xbe ], [ 0xa6, 0xca, 0xe4, 0x6f, 0xb6, 0xfa, 0xdf, 0xe7, 0xa2, 0xc3, 0x02, 0xa3, 0x42, 0x42, 0x81, 0x7b ], [ 0x02, 0x6a, 0x70, 0x24, 0xd6, 0xa9, 0x02, 0xe0, 0xb3, 0xff, 0xcc, 0xba, 0xa9, 0x10, 0xcc, 0x3f ], [ 0x15, 0x6f, 0x07, 0x76, 0x7a, 0x85, 0xa4, 0x31, 0x23, 0x21, 0xf6, 0x39, 0x68, 0x33, 0x8a, 0x01 ], [ 0x15, 0xee, 0xc9, 0xeb, 0xf4, 0x2b, 0x9c, 0xa7, 0x68, 0x97, 0xd2, 0xcd, 0x6c, 0x5a, 0x12, 0xe2 ], [ 0xdb, 0x0d, 0x3a, 0x6f, 0xdc, 0xc1, 0x3f, 0x91, 0x5e, 0x2b, 0x30, 0x2c, 0xee, 0xb7, 0x0f, 0xd8 ], [ 0x71, 0xdb, 0xf3, 0x7e, 0x87, 0xa2, 0xe3, 0x4d, 0x15, 0xb2, 0x0e, 0x8f, 0x10, 0xe4, 0x89, 0x24 ], [ 0xc7, 0x45, 0xc4, 0x51, 0xe9, 0x6f, 0xf3, 0xc0, 0x45, 0xe4, 0x36, 0x7c, 0x83, 0x3e, 0x3b, 0x54 ], [ 0x34, 0x0d, 0xa0, 0x9c, 0x2d, 0xd1, 0x1c, 0x3b, 0x67, 0x9d, 0x08, 0xcc, 0xd2, 0x7d, 0xd5, 0x95 ], [ 0x82, 0x79, 0xf7, 0xc0, 0xc2, 0xa0, 0x3e, 0xe6, 0x60, 0xc6, 0xd3, 0x92, 0xdb, 0x02, 0x5d, 0x18 ], [ 0xa4, 0xb2, 0xc7, 0xd8, 0xeb, 0xa5, 0x31, 0xff, 0x47, 0xc5, 0x04, 0x1a, 0x55, 0xfb, 0xd1, 0xec ], [ 0x74, 0x56, 0x9a, 0x2c, 0xa5, 0xa7, 0xbd, 0x51, 0x31, 0xce, 0x8d, 0xc7, 0xcb, 0xfb, 0xf7, 0x2f ], [ 0x37, 0x13, 0xda, 0x0c, 0x02, 0x19, 0xb6, 0x34, 0x54, 0x03, 0x56, 0x13, 0xb5, 0xa4, 0x03, 0xdd ], [ 0x88, 0x27, 0x55, 0x1d, 0xdc, 0xc9, 0xdf, 0x23, 0xfa, 0x72, 0xa3, 0xde, 0x4e, 0x9f, 0x0b, 0x07 ], [ 0x2e, 0x3f, 0xeb, 0xfd, 0x62, 0x5b, 0xfc, 0xd0, 0xa2, 0xc0, 0x6e, 0xb4, 0x60, 0xda, 0x17, 0x32 ], [ 0xee, 0x82, 0xe6, 0xba, 0x48, 0x81, 0x56, 0xf7, 0x64, 0x96, 0x31, 0x1d, 0xa6, 0x94, 0x1d, 0xeb ], [ 0x47, 0x70, 0x44, 0x6f, 0x01, 0xd1, 0xf3, 0x91, 0x25, 0x6e, 0x85, 0xa1, 0xb3, 0x0d, 0x89, 0xd3 ], [ 0xaf, 0x04, 0xb6, 0x8f, 0x10, 0x4f, 0x21, 0xef, 0x2a, 0xfb, 0x47, 0x67, 0xcf, 0x74, 0x14, 0x3c ], [ 0xcf, 0x35, 0x79, 0xa9, 0xba, 0x38, 0xc8, 0xe4, 0x36, 0x53, 0x17, 0x3e, 0x14, 0xf3, 0xa4, 0xc6 ], [ 0xb3, 0xbb, 0xa9, 0x04, 0xf4, 0x95, 0x3e, 0x09, 0xb5, 0x48, 0x00, 0xaf, 0x2f, 0x62, 0xe7, 0xd4 ], [ 0xfc, 0x42, 0x49, 0x65, 0x6e, 0x14, 0xb2, 0x9e, 0xb9, 0xc4, 0x48, 0x29, 0xb4, 0xc5, 0x9a, 0x46 ], [ 0x9b, 0x31, 0x56, 0x8f, 0xeb, 0xe8, 0x1c, 0xfc, 0x2e, 0x65, 0xaf, 0x1c, 0x86, 0xd1, 0xa3, 0x08 ], [ 0x9c, 0xa0, 0x9c, 0x25, 0xf2, 0x73, 0xa7, 0x66, 0xdb, 0x98, 0xa4, 0x80, 0xce, 0x8d, 0xfe, 0xdc ], [ 0xb9, 0x09, 0x92, 0x57, 0x86, 0xf3, 0x4c, 0x3c, 0x92, 0xd9, 0x71, 0x88, 0x3c, 0x9f, 0xbe, 0xdf ], [ 0x82, 0x64, 0x7f, 0x13, 0x32, 0xfe, 0x57, 0x0a, 0x9d, 0x4d, 0x92, 0xb2, 0xee, 0x77, 0x1d, 0x3b ], [ 0x36, 0x04, 0xa7, 0xe8, 0x08, 0x32, 0xb3, 0xa9, 0x99, 0x54, 0xbc, 0xa6, 0xf5, 0xb9, 0xf5, 0x01 ], [ 0x88, 0x46, 0x07, 0xb1, 0x28, 0xc5, 0xde, 0x3a, 0xb3, 0x9a, 0x52, 0x9a, 0x1e, 0xf5, 0x1b, 0xef ], [ 0x67, 0x0c, 0xfa, 0x09, 0x3d, 0x1d, 0xbd, 0xb2, 0x31, 0x70, 0x41, 0x40, 0x41, 0x02, 0x43, 0x5e ], [ 0x7a, 0x86, 0x71, 0x95, 0xf3, 0xce, 0x87, 0x69, 0xcb, 0xd3, 0x36, 0x50, 0x2f, 0xbb, 0x51, 0x30 ], [ 0x52, 0xef, 0xcf, 0x64, 0xc7, 0x2b, 0x2f, 0x7c, 0xa5, 0xb3, 0xc8, 0x36, 0xb1, 0x07, 0x8c, 0x15 ], [ 0x40, 0x19, 0x25, 0x0f, 0x6e, 0xef, 0xb2, 0xac, 0x5c, 0xcb, 0xca, 0xe0, 0x44, 0xe7, 0x5c, 0x7e ], [ 0x02, 0x2c, 0x4f, 0x6f, 0x5a, 0x01, 0x7d, 0x29, 0x27, 0x85, 0x62, 0x76, 0x67, 0xdd, 0xef, 0x24 ], [ 0xe9, 0xc2, 0x10, 0x78, 0xa2, 0xeb, 0x7e, 0x03, 0x25, 0x0f, 0x71, 0x00, 0x0f, 0xa9, 0xe3, 0xed ], [ 0xa1, 0x3e, 0xae, 0xeb, 0x9c, 0xd3, 0x91, 0xda, 0x4e, 0x2b, 0x09, 0x49, 0x0b, 0x3e, 0x7f, 0xad ], [ 0xc9, 0x58, 0xa1, 0x71, 0xdc, 0xa1, 0xd4, 0xed, 0x53, 0xe1, 0xaf, 0x1d, 0x38, 0x08, 0x03, 0xa9 ], [ 0x21, 0x44, 0x2e, 0x07, 0xa1, 0x10, 0x66, 0x7f, 0x25, 0x83, 0xea, 0xee, 0xee, 0x44, 0xdc, 0x8c ], [ 0x59, 0xbb, 0xb3, 0x53, 0xcf, 0x1d, 0xd8, 0x67, 0xa6, 0xe3, 0x37, 0x37, 0xaf, 0x65, 0x5e, 0x99 ], [ 0x43, 0xcd, 0x3b, 0x25, 0x37, 0x5d, 0x0c, 0xe4, 0x10, 0x87, 0xff, 0x9f, 0xe2, 0x82, 0x96, 0x39 ], [ 0x6b, 0x98, 0xb1, 0x7e, 0x80, 0xd1, 0x11, 0x8e, 0x35, 0x16, 0xbd, 0x76, 0x8b, 0x28, 0x5a, 0x84 ], [ 0xae, 0x47, 0xed, 0x36, 0x76, 0xca, 0x0c, 0x08, 0xde, 0xea, 0x02, 0xd9, 0x5b, 0x81, 0xdb, 0x58 ], [ 0x34, 0xec, 0x40, 0xdc, 0x20, 0x41, 0x37, 0x95, 0xed, 0x53, 0x62, 0x8e, 0xa7, 0x48, 0x72, 0x0b ], [ 0x4d, 0xc6, 0x81, 0x63, 0xf8, 0xe9, 0x83, 0x54, 0x73, 0x25, 0x35, 0x42, 0xc8, 0xa6, 0x5d, 0x46 ], [ 0x2a, 0xab, 0xb9, 0x99, 0xf4, 0x36, 0x93, 0x17, 0x5a, 0xf6, 0x5c, 0x6c, 0x61, 0x2c, 0x46, 0xfb ], [ 0xe0, 0x1f, 0x94, 0x49, 0x9d, 0xac, 0x35, 0x47, 0x51, 0x5c, 0x5b, 0x1d, 0x75, 0x6f, 0x0f, 0x58 ], [ 0x9d, 0x12, 0x43, 0x5a, 0x46, 0x48, 0x0c, 0xe0, 0x0e, 0xa3, 0x49, 0xf7, 0x17, 0x99, 0xdf, 0x9a ], [ 0xce, 0xf4, 0x1d, 0x16, 0xd2, 0x66, 0xbd, 0xfe, 0x46, 0x93, 0x8a, 0xd7, 0x88, 0x4c, 0xc0, 0xcf ], [ 0xb1, 0x3d, 0xb4, 0xda, 0x1f, 0x71, 0x8b, 0xc6, 0x90, 0x47, 0x97, 0xc8, 0x2b, 0xcf, 0x2d, 0x32 ], ]; # Values from NIST KAT-AES ECBVarKey192.rsp cipher_texts2_192bit = [ [ 0xde, 0x88, 0x5d, 0xc8, 0x7f, 0x5a, 0x92, 0x59, 0x40, 0x82, 0xd0, 0x2c, 0xc1, 0xe1, 0xb4, 0x2c ], [ 0x13, 0x2b, 0x07, 0x4e, 0x80, 0xf2, 0xa5, 0x97, 0xbf, 0x5f, 0xeb, 0xd8, 0xea, 0x5d, 0xa5, 0x5e ], [ 0x6e, 0xcc, 0xed, 0xf8, 0xde, 0x59, 0x2c, 0x22, 0xfb, 0x81, 0x34, 0x7b, 0x79, 0xf2, 0xdb, 0x1f ], [ 0x18, 0x0b, 0x09, 0xf2, 0x67, 0xc4, 0x51, 0x45, 0xdb, 0x2f, 0x82, 0x6c, 0x25, 0x82, 0xd3, 0x5c ], [ 0xed, 0xd8, 0x07, 0xef, 0x76, 0x52, 0xd7, 0xeb, 0x0e, 0x13, 0xc8, 0xb5, 0xe1, 0x5b, 0x3b, 0xc0 ], [ 0x99, 0x78, 0xbc, 0xf8, 0xdd, 0x8f, 0xd7, 0x22, 0x41, 0x22, 0x3a, 0xd2, 0x4b, 0x31, 0xb8, 0xa4 ], [ 0x53, 0x10, 0xf6, 0x54, 0x34, 0x3e, 0x8f, 0x27, 0xe1, 0x2c, 0x83, 0xa4, 0x8d, 0x24, 0xff, 0x81 ], [ 0x83, 0x3f, 0x71, 0x25, 0x8d, 0x53, 0x03, 0x6b, 0x02, 0x95, 0x2c, 0x76, 0xc7, 0x44, 0xf5, 0xa1 ], [ 0xeb, 0xa8, 0x3f, 0xf2, 0x00, 0xcf, 0xf9, 0x31, 0x8a, 0x92, 0xf8, 0x69, 0x1a, 0x06, 0xb0, 0x9f ], [ 0xff, 0x62, 0x0c, 0xcb, 0xe9, 0xf3, 0x29, 0x2a, 0xbd, 0xf2, 0x17, 0x6b, 0x09, 0xf0, 0x4e, 0xba ], [ 0x7a, 0xba, 0xbc, 0x4b, 0x3f, 0x51, 0x6c, 0x9a, 0xaf, 0xb3, 0x5f, 0x41, 0x40, 0xb5, 0x48, 0xf9 ], [ 0xaa, 0x18, 0x78, 0x24, 0xd9, 0xc4, 0x58, 0x2b, 0x09, 0x16, 0x49, 0x3e, 0xcb, 0xde, 0x8c, 0x57 ], [ 0x1c, 0x0a, 0xd5, 0x53, 0x17, 0x7f, 0xd5, 0xea, 0x10, 0x92, 0xc9, 0xd6, 0x26, 0xa2, 0x9d, 0xc4 ], [ 0xa5, 0xdc, 0x46, 0xc3, 0x72, 0x61, 0x19, 0x41, 0x24, 0xec, 0xae, 0xbd, 0x68, 0x04, 0x08, 0xec ], [ 0xe4, 0xf2, 0xf2, 0xae, 0x23, 0xe9, 0xb1, 0x0b, 0xac, 0xfa, 0x58, 0x60, 0x15, 0x31, 0xba, 0x54 ], [ 0xb7, 0xd6, 0x7c, 0xf1, 0xa1, 0xe9, 0x1e, 0x8f, 0xf3, 0xa5, 0x7a, 0x17, 0x2c, 0x7b, 0xf4, 0x12 ], [ 0x26, 0x70, 0x6b, 0xe0, 0x69, 0x67, 0x88, 0x4e, 0x84, 0x7d, 0x13, 0x71, 0x28, 0xce, 0x47, 0xb3 ], [ 0xb2, 0xf8, 0xb4, 0x09, 0xb0, 0x58, 0x59, 0x09, 0xaa, 0xd3, 0xa7, 0xb5, 0xa2, 0x19, 0x07, 0x2a ], [ 0x5e, 0x4b, 0x7b, 0xff, 0x02, 0x90, 0xc7, 0x83, 0x44, 0xc5, 0x4a, 0x23, 0xb7, 0x22, 0xcd, 0x20 ], [ 0x07, 0x09, 0x36, 0x57, 0x55, 0x2d, 0x44, 0x14, 0x22, 0x7c, 0xe1, 0x61, 0xe9, 0xeb, 0xf7, 0xdd ], [ 0xe1, 0xaf, 0x1e, 0x7d, 0x8b, 0xc2, 0x25, 0xed, 0x4d, 0xff, 0xb7, 0x71, 0xec, 0xbb, 0x9e, 0x67 ], [ 0xef, 0x65, 0x55, 0x25, 0x36, 0x35, 0xd8, 0x43, 0x21, 0x56, 0xcf, 0xd9, 0xc1, 0x1b, 0x14, 0x5a ], [ 0xfb, 0x40, 0x35, 0x07, 0x4a, 0x5d, 0x42, 0x60, 0xc9, 0x0c, 0xbd, 0x6d, 0xa6, 0xc3, 0xfc, 0xeb ], [ 0x44, 0x6e, 0xe4, 0x16, 0xf9, 0xad, 0x1c, 0x10, 0x3e, 0xb0, 0xcc, 0x96, 0x75, 0x1c, 0x88, 0xe1 ], [ 0x19, 0x8a, 0xe2, 0xa4, 0x63, 0x7a, 0xc0, 0xa7, 0x89, 0x0a, 0x8f, 0xd1, 0x48, 0x54, 0x45, 0xc9 ], [ 0x56, 0x20, 0x12, 0xec, 0x8f, 0xad, 0xed, 0x08, 0x25, 0xfb, 0x2f, 0xa7, 0x0a, 0xb3, 0x0c, 0xbd ], [ 0xcc, 0x8a, 0x64, 0xb4, 0x6b, 0x5d, 0x88, 0xbf, 0x7f, 0x24, 0x7d, 0x4d, 0xba, 0xf3, 0x8f, 0x05 ], [ 0xa1, 0x68, 0x25, 0x37, 0x62, 0xe2, 0xcc, 0x81, 0xb4, 0x2d, 0x1e, 0x50, 0x01, 0x76, 0x26, 0x99 ], [ 0x1b, 0x41, 0xf8, 0x3b, 0x38, 0xce, 0x50, 0x32, 0xc6, 0xcd, 0x7a, 0xf9, 0x8c, 0xf6, 0x20, 0x61 ], [ 0x61, 0xa8, 0x99, 0x90, 0xcd, 0x14, 0x11, 0x75, 0x0d, 0x5f, 0xb0, 0xdc, 0x98, 0x84, 0x47, 0xd4 ], [ 0xb5, 0xac, 0xcc, 0x8e, 0xd6, 0x29, 0xed, 0xf8, 0xc6, 0x8a, 0x53, 0x91, 0x83, 0xb1, 0xea, 0x82 ], [ 0xb1, 0x6f, 0xa7, 0x1f, 0x84, 0x6b, 0x81, 0xa1, 0x3f, 0x36, 0x1c, 0x43, 0xa8, 0x51, 0xf2, 0x90 ], [ 0x4f, 0xad, 0x6e, 0xfd, 0xff, 0x59, 0x75, 0xae, 0xe7, 0x69, 0x22, 0x34, 0xbc, 0xd5, 0x44, 0x88 ], [ 0xeb, 0xfd, 0xb0, 0x5a, 0x78, 0x3d, 0x03, 0x08, 0x2d, 0xfe, 0x5f, 0xdd, 0x80, 0xa0, 0x0b, 0x17 ], [ 0xeb, 0x81, 0xb5, 0x84, 0x76, 0x69, 0x97, 0xaf, 0x6b, 0xa5, 0x52, 0x9d, 0x3b, 0xdd, 0x86, 0x09 ], [ 0x0c, 0xf4, 0xff, 0x4f, 0x49, 0xc8, 0xa0, 0xca, 0x06, 0x0c, 0x44, 0x34, 0x99, 0xe2, 0x93, 0x13 ], [ 0xcc, 0x4b, 0xa8, 0xa8, 0xe0, 0x29, 0xf8, 0xb2, 0x6d, 0x8a, 0xff, 0xf9, 0xdf, 0x13, 0x3b, 0xb6 ], [ 0xfe, 0xfe, 0xbf, 0x64, 0x36, 0x0f, 0x38, 0xe4, 0xe6, 0x35, 0x58, 0xf0, 0xff, 0xc5, 0x50, 0xc3 ], [ 0x12, 0xad, 0x98, 0xcb, 0xf7, 0x25, 0x13, 0x7d, 0x6a, 0x81, 0x08, 0xc2, 0xbe, 0xd9, 0x93, 0x22 ], [ 0x6a, 0xfa, 0xa9, 0x96, 0x22, 0x61, 0x98, 0xb3, 0xe2, 0x61, 0x04, 0x13, 0xce, 0x1b, 0x3f, 0x78 ], [ 0x2a, 0x8c, 0xe6, 0x74, 0x7a, 0x7e, 0x39, 0x36, 0x78, 0x28, 0xe2, 0x90, 0x84, 0x85, 0x02, 0xd9 ], [ 0x22, 0x37, 0x36, 0xe8, 0xb8, 0xf8, 0x9c, 0xa1, 0xe3, 0x7b, 0x6d, 0xea, 0xb4, 0x0f, 0xac, 0xf1 ], [ 0xc0, 0xf7, 0x97, 0xe5, 0x04, 0x18, 0xb9, 0x5f, 0xa6, 0x01, 0x33, 0x33, 0x91, 0x7a, 0x94, 0x80 ], [ 0xa7, 0x58, 0xde, 0x37, 0xc2, 0xec, 0xe2, 0xa0, 0x2c, 0x73, 0xc0, 0x1f, 0xed, 0xc9, 0xa1, 0x32 ], [ 0x3a, 0x9b, 0x87, 0xae, 0x77, 0xba, 0xe7, 0x06, 0x80, 0x39, 0x66, 0xc6, 0x6c, 0x73, 0xad, 0xbd ], [ 0xd3, 0x65, 0xab, 0x8d, 0xf8, 0xff, 0xd7, 0x82, 0xe3, 0x58, 0x12, 0x1a, 0x4a, 0x4f, 0xc5, 0x41 ], [ 0xc8, 0xdc, 0xd9, 0xe6, 0xf7, 0x5e, 0x6c, 0x36, 0xc8, 0xda, 0xee, 0x04, 0x66, 0xf0, 0xed, 0x74 ], [ 0xc7, 0x9a, 0x63, 0x7b, 0xeb, 0x1c, 0x03, 0x04, 0xf1, 0x40, 0x14, 0xc0, 0x37, 0xe7, 0x36, 0xdd ], [ 0x10, 0x5f, 0x0a, 0x25, 0xe8, 0x4a, 0xc9, 0x30, 0xd9, 0x96, 0x28, 0x1a, 0x5f, 0x95, 0x4d, 0xd9 ], [ 0x42, 0xe4, 0x07, 0x4b, 0x29, 0x27, 0x97, 0x3e, 0x8d, 0x17, 0xff, 0xa9, 0x2f, 0x7f, 0xe6, 0x15 ], [ 0x4f, 0xe2, 0xa9, 0xd2, 0xc1, 0x82, 0x44, 0x49, 0xc6, 0x9e, 0x3e, 0x03, 0x98, 0xf1, 0x29, 0x63 ], [ 0xb7, 0xf2, 0x9c, 0x1e, 0x1f, 0x62, 0x84, 0x7a, 0x15, 0x25, 0x3b, 0x28, 0xa1, 0xe9, 0xd7, 0x12 ], [ 0x36, 0xed, 0x5d, 0x29, 0xb9, 0x03, 0xf3, 0x1e, 0x89, 0x83, 0xef, 0x8b, 0x0a, 0x2b, 0xf9, 0x90 ], [ 0x27, 0xb8, 0x07, 0x02, 0x70, 0x81, 0x0f, 0x9d, 0x02, 0x3f, 0x9d, 0xd7, 0xff, 0x3b, 0x4a, 0xa2 ], [ 0x94, 0xd4, 0x6e, 0x15, 0x5c, 0x12, 0x28, 0xf6, 0x1d, 0x1a, 0x0d, 0xb4, 0x81, 0x5e, 0xcc, 0x4b ], [ 0xca, 0x61, 0x08, 0xd1, 0xd9, 0x80, 0x71, 0x42, 0x8e, 0xec, 0xee, 0xf1, 0x71, 0x4b, 0x96, 0xdd ], [ 0xdc, 0x5b, 0x25, 0xb7, 0x1b, 0x62, 0x96, 0xcf, 0x73, 0xdd, 0x2c, 0xdc, 0xac, 0x2f, 0x70, 0xb1 ], [ 0x44, 0xab, 0xa9, 0x5e, 0x8a, 0x06, 0xa2, 0xd9, 0xd3, 0x53, 0x0d, 0x26, 0x77, 0x87, 0x8c, 0x80 ], [ 0xa5, 0x70, 0xd2, 0x0e, 0x89, 0xb4, 0x67, 0xe8, 0xf5, 0x17, 0x60, 0x61, 0xb8, 0x1d, 0xd3, 0x96 ], [ 0x75, 0x8f, 0x44, 0x67, 0xa5, 0xd8, 0xf1, 0xe7, 0x30, 0x7d, 0xc3, 0x0b, 0x34, 0xe4, 0x04, 0xf4 ], [ 0xbc, 0xea, 0x28, 0xe9, 0x07, 0x1b, 0x5a, 0x23, 0x02, 0x97, 0x0f, 0xf3, 0x52, 0x45, 0x1b, 0xc5 ], [ 0x75, 0x23, 0xc0, 0x0b, 0xc1, 0x77, 0xd3, 0x31, 0xad, 0x31, 0x2e, 0x09, 0xc9, 0x01, 0x5c, 0x1c ], [ 0xcc, 0xac, 0x61, 0xe3, 0x18, 0x37, 0x47, 0xb3, 0xf5, 0x83, 0x6d, 0xa2, 0x1a, 0x1b, 0xc4, 0xf4 ], [ 0x70, 0x7b, 0x07, 0x57, 0x91, 0x87, 0x88, 0x80, 0xb4, 0x41, 0x89, 0xd3, 0x52, 0x2b, 0x8c, 0x30 ], [ 0x71, 0x32, 0xd0, 0xc0, 0xe4, 0xa0, 0x75, 0x93, 0xcf, 0x12, 0xeb, 0xb1, 0x2b, 0xe7, 0x68, 0x8c ], [ 0xef, 0xfb, 0xac, 0x16, 0x44, 0xde, 0xb0, 0xc7, 0x84, 0x27, 0x5f, 0xe5, 0x6e, 0x19, 0xea, 0xd3 ], [ 0xa0, 0x05, 0x06, 0x3f, 0x30, 0xf4, 0x22, 0x8b, 0x37, 0x4e, 0x24, 0x59, 0x73, 0x8f, 0x26, 0xbb ], [ 0x29, 0x97, 0x5b, 0x5f, 0x48, 0xbb, 0x68, 0xfc, 0xbb, 0xc7, 0xce, 0xa9, 0x3b, 0x45, 0x2e, 0xd7 ], [ 0xcf, 0x3f, 0x25, 0x76, 0xe2, 0xaf, 0xed, 0xc7, 0x4b, 0xb1, 0xca, 0x7e, 0xee, 0xc1, 0xc0, 0xe7 ], [ 0x07, 0xc4, 0x03, 0xf5, 0xf9, 0x66, 0xe0, 0xe3, 0xd9, 0xf2, 0x96, 0xd6, 0x22, 0x6d, 0xca, 0x28 ], [ 0xc8, 0xc2, 0x09, 0x08, 0x24, 0x9a, 0xb4, 0xa3, 0x4d, 0x6d, 0xd0, 0xa3, 0x13, 0x27, 0xff, 0x1a ], [ 0xc0, 0x54, 0x13, 0x29, 0xec, 0xb6, 0x15, 0x9a, 0xb2, 0x3b, 0x7f, 0xc5, 0xe6, 0xa2, 0x1b, 0xca ], [ 0x7a, 0xa1, 0xac, 0xf1, 0xa2, 0xed, 0x9b, 0xa7, 0x2b, 0xc6, 0xde, 0xb3, 0x1d, 0x88, 0xb8, 0x63 ], [ 0x80, 0x8b, 0xd8, 0xed, 0xda, 0xbb, 0x6f, 0x3b, 0xf0, 0xd5, 0xa8, 0xa2, 0x7b, 0xe1, 0xfe, 0x8a ], [ 0x27, 0x3c, 0x7d, 0x76, 0x85, 0xe1, 0x4e, 0xc6, 0x6b, 0xbb, 0x96, 0xb8, 0xf0, 0x5b, 0x6d, 0xdd ], [ 0x32, 0x75, 0x2e, 0xef, 0xc8, 0xc2, 0xa9, 0x3f, 0x91, 0xb6, 0xe7, 0x3e, 0xb0, 0x7c, 0xca, 0x6e ], [ 0xd8, 0x93, 0xe7, 0xd6, 0x2f, 0x6c, 0xe5, 0x02, 0xc6, 0x4f, 0x75, 0xe2, 0x81, 0xf9, 0xc0, 0x00 ], [ 0x8d, 0xfd, 0x99, 0x9b, 0xe5, 0xd0, 0xcf, 0xa3, 0x57, 0x32, 0xc0, 0xdd, 0xc8, 0x8f, 0xf5, 0xa5 ], [ 0x02, 0x64, 0x7c, 0x76, 0xa3, 0x00, 0xc3, 0x17, 0x3b, 0x84, 0x14, 0x87, 0xeb, 0x2b, 0xae, 0x9f ], [ 0x17, 0x2d, 0xf8, 0xb0, 0x2f, 0x04, 0xb5, 0x3a, 0xda, 0xb0, 0x28, 0xb4, 0xe0, 0x1a, 0xcd, 0x87 ], [ 0x05, 0x4b, 0x3b, 0xf4, 0x99, 0x8a, 0xeb, 0x05, 0xaf, 0xd8, 0x7e, 0xc5, 0x36, 0x53, 0x3a, 0x36 ], [ 0x37, 0x83, 0xf7, 0xbf, 0x44, 0xc9, 0x7f, 0x06, 0x52, 0x58, 0xa6, 0x66, 0xca, 0xe0, 0x30, 0x20 ], [ 0xaa, 0xd4, 0xc8, 0xa6, 0x3f, 0x80, 0x95, 0x41, 0x04, 0xde, 0x7b, 0x92, 0xce, 0xde, 0x1b, 0xe1 ], [ 0xcb, 0xfe, 0x61, 0x81, 0x0f, 0xd5, 0x46, 0x7c, 0xcd, 0xac, 0xb7, 0x58, 0x00, 0xf3, 0xac, 0x07 ], [ 0x83, 0x0d, 0x8a, 0x25, 0x90, 0xf7, 0xd8, 0xe1, 0xb5, 0x5a, 0x73, 0x7f, 0x4a, 0xf4, 0x5f, 0x34 ], [ 0xff, 0xfc, 0xd4, 0x68, 0x3f, 0x85, 0x80, 0x58, 0xe7, 0x43, 0x14, 0x67, 0x1d, 0x43, 0xfa, 0x2c ], [ 0x52, 0x3d, 0x0b, 0xab, 0xbb, 0x82, 0xf4, 0x6e, 0xbc, 0x9e, 0x70, 0xb1, 0xcd, 0x41, 0xdd, 0xd0 ], [ 0x34, 0x4a, 0xab, 0x37, 0x08, 0x0d, 0x74, 0x86, 0xf7, 0xd5, 0x42, 0xa3, 0x09, 0xe5, 0x3e, 0xed ], [ 0x56, 0xc5, 0x60, 0x9d, 0x09, 0x06, 0xb2, 0x3a, 0xb9, 0xca, 0xca, 0x81, 0x6f, 0x5d, 0xbe, 0xbd ], [ 0x70, 0x26, 0x02, 0x6e, 0xed, 0xd9, 0x1a, 0xdc, 0x6d, 0x83, 0x1c, 0xdf, 0x98, 0x94, 0xbd, 0xc6 ], [ 0x88, 0x33, 0x0b, 0xaa, 0x4f, 0x2b, 0x61, 0x8f, 0xc9, 0xd9, 0xb0, 0x21, 0xbf, 0x50, 0x3d, 0x5a ], [ 0xfc, 0x9e, 0x0e, 0xa2, 0x24, 0x80, 0xb0, 0xba, 0xc9, 0x35, 0xc8, 0xa8, 0xeb, 0xef, 0xcd, 0xcf ], [ 0x29, 0xca, 0x77, 0x9f, 0x39, 0x8f, 0xb0, 0x4f, 0x86, 0x7d, 0xa7, 0xe8, 0xa4, 0x47, 0x56, 0xcb ], [ 0x51, 0xf8, 0x9c, 0x42, 0x98, 0x57, 0x86, 0xbf, 0xc4, 0x3c, 0x6d, 0xf8, 0xad, 0xa3, 0x68, 0x32 ], [ 0x6a, 0xc1, 0xde, 0x5f, 0xb8, 0xf2, 0x1d, 0x87, 0x4e, 0x91, 0xc5, 0x3b, 0x56, 0x0c, 0x50, 0xe3 ], [ 0x03, 0xaa, 0x90, 0x58, 0x49, 0x0e, 0xda, 0x30, 0x60, 0x01, 0xa8, 0xa9, 0xf4, 0x8d, 0x0c, 0xa7 ], [ 0xe3, 0x4e, 0xc7, 0x1d, 0x61, 0x28, 0xd4, 0x87, 0x18, 0x65, 0xd6, 0x17, 0xc3, 0x0b, 0x37, 0xe3 ], [ 0x14, 0xbe, 0x1c, 0x53, 0x5b, 0x17, 0xca, 0xbd, 0x0c, 0x4d, 0x93, 0x52, 0x9d, 0x69, 0xbf, 0x47 ], [ 0xc9, 0xef, 0x67, 0x75, 0x65, 0x07, 0xbe, 0xec, 0x9d, 0xd3, 0x86, 0x28, 0x83, 0x47, 0x80, 0x44 ], [ 0x40, 0xe2, 0x31, 0xfa, 0x5a, 0x59, 0x48, 0xce, 0x21, 0x34, 0xe9, 0x2f, 0xc0, 0x66, 0x4d, 0x4b ], [ 0x03, 0x19, 0x4b, 0x8e, 0x5d, 0xda, 0x55, 0x30, 0xd0, 0xc6, 0x78, 0xc0, 0xb4, 0x8f, 0x5d, 0x92 ], [ 0x90, 0xbd, 0x08, 0x6f, 0x23, 0x7c, 0xc4, 0xfd, 0x99, 0xf4, 0xd7, 0x6b, 0xde, 0x6b, 0x48, 0x26 ], [ 0x19, 0x25, 0x97, 0x61, 0xca, 0x17, 0x13, 0x0d, 0x6e, 0xd8, 0x6d, 0x57, 0xcd, 0x79, 0x51, 0xee ], [ 0xd7, 0xcb, 0xb3, 0xf3, 0x4b, 0x9b, 0x45, 0x0f, 0x24, 0xb0, 0xe8, 0x51, 0x8e, 0x54, 0xda, 0x6d ], [ 0x72, 0x5b, 0x9c, 0xae, 0xbe, 0x9f, 0x7f, 0x41, 0x7f, 0x40, 0x68, 0xd0, 0xd2, 0xee, 0x20, 0xb3 ], [ 0x9d, 0x92, 0x4b, 0x93, 0x4a, 0x90, 0xce, 0x1f, 0xd3, 0x9b, 0x8a, 0x97, 0x94, 0xf8, 0x26, 0x72 ], [ 0xc5, 0x05, 0x62, 0xbf, 0x09, 0x45, 0x26, 0xa9, 0x1c, 0x5b, 0xc6, 0x3c, 0x0c, 0x22, 0x49, 0x95 ], [ 0xd2, 0xf1, 0x18, 0x05, 0x04, 0x67, 0x43, 0xbd, 0x74, 0xf5, 0x71, 0x88, 0xd9, 0x18, 0x8d, 0xf7 ], [ 0x8d, 0xd2, 0x74, 0xbd, 0x0f, 0x1b, 0x58, 0xae, 0x34, 0x5d, 0x9e, 0x72, 0x33, 0xf9, 0xb8, 0xf3 ], [ 0x9d, 0x6b, 0xdc, 0x8f, 0x4c, 0xe5, 0xfe, 0xb0, 0xf3, 0xbe, 0xd2, 0xe4, 0xb9, 0xa9, 0xbb, 0x0b ], [ 0xfd, 0x55, 0x48, 0xbc, 0xf3, 0xf4, 0x25, 0x65, 0xf7, 0xef, 0xa9, 0x45, 0x62, 0x52, 0x8d, 0x46 ], [ 0xd2, 0xcc, 0xae, 0xbd, 0x3a, 0x4c, 0x3e, 0x80, 0xb0, 0x63, 0x74, 0x81, 0x31, 0xba, 0x4a, 0x71 ], [ 0xe0, 0x3c, 0xb2, 0x3d, 0x9e, 0x11, 0xc9, 0xd9, 0x3f, 0x11, 0x7e, 0x9c, 0x0a, 0x91, 0xb5, 0x76 ], [ 0x78, 0xf9, 0x33, 0xa2, 0x08, 0x1a, 0xc1, 0xdb, 0x84, 0xf6, 0x9d, 0x10, 0xf4, 0x52, 0x3f, 0xe0 ], [ 0x40, 0x61, 0xf7, 0x41, 0x2e, 0xd3, 0x20, 0xde, 0x0e, 0xdc, 0x88, 0x51, 0xc2, 0xe2, 0x43, 0x6f ], [ 0x90, 0x64, 0xba, 0x1c, 0xd0, 0x4c, 0xe6, 0xba, 0xb9, 0x84, 0x74, 0x33, 0x08, 0x14, 0xb4, 0xd4 ], [ 0x48, 0x39, 0x1b, 0xff, 0xb9, 0xcf, 0xff, 0x80, 0xac, 0x23, 0x8c, 0x88, 0x6e, 0xf0, 0xa4, 0x61 ], [ 0xb8, 0xd2, 0xa6, 0x7d, 0xf5, 0xa9, 0x99, 0xfd, 0xbf, 0x93, 0xed, 0xd0, 0x34, 0x32, 0x96, 0xc9 ], [ 0xaa, 0xca, 0x73, 0x67, 0x39, 0x6b, 0x69, 0xa2, 0x21, 0xbd, 0x63, 0x2b, 0xea, 0x38, 0x6e, 0xec ], [ 0xa8, 0x0f, 0xd5, 0x02, 0x0d, 0xfe, 0x65, 0xf5, 0xf1, 0x62, 0x93, 0xec, 0x92, 0xc6, 0xfd, 0x89 ], [ 0x21, 0x62, 0x99, 0x5b, 0x82, 0x17, 0xa6, 0x7f, 0x1a, 0xbc, 0x34, 0x2e, 0x14, 0x64, 0x06, 0xf8 ], [ 0xc6, 0xa6, 0x16, 0x4b, 0x7a, 0x60, 0xba, 0xe4, 0xe9, 0x86, 0xff, 0xac, 0x28, 0xdf, 0xad, 0xd9 ], [ 0x64, 0xe0, 0xd7, 0xf9, 0x00, 0xe3, 0xd9, 0xc8, 0x3e, 0x4b, 0x8f, 0x96, 0x71, 0x7b, 0x21, 0x46 ], [ 0x1a, 0xd2, 0x56, 0x1d, 0xe8, 0xc1, 0x23, 0x2f, 0x5d, 0x8d, 0xba, 0xb4, 0x73, 0x9b, 0x6c, 0xbb ], [ 0x27, 0x96, 0x89, 0xe9, 0xa5, 0x57, 0xf5, 0x8b, 0x1c, 0x3b, 0xf4, 0x0c, 0x97, 0xa9, 0x09, 0x64 ], [ 0xc4, 0x63, 0x7e, 0x4a, 0x5e, 0x63, 0x77, 0xf9, 0xcc, 0x5a, 0x86, 0x38, 0x04, 0x5d, 0xe0, 0x29 ], [ 0x49, 0x2e, 0x60, 0x7e, 0x5a, 0xea, 0x46, 0x88, 0x59, 0x4b, 0x45, 0xf3, 0xae, 0xe3, 0xdf, 0x90 ], [ 0xe8, 0xc4, 0xe4, 0x38, 0x1f, 0xee, 0xc7, 0x40, 0x54, 0x95, 0x4c, 0x05, 0xb7, 0x77, 0xa0, 0x0a ], [ 0x91, 0x54, 0x95, 0x14, 0x60, 0x5f, 0x38, 0x24, 0x6c, 0x9b, 0x72, 0x4a, 0xd8, 0x39, 0xf0, 0x1d ], [ 0x74, 0xb2, 0x4e, 0x3b, 0x6f, 0xef, 0xe4, 0x0a, 0x4f, 0x9e, 0xf7, 0xac, 0x6e, 0x44, 0xd7, 0x6a ], [ 0x24, 0x37, 0xa6, 0x83, 0xdc, 0x5d, 0x4b, 0x52, 0xab, 0xb4, 0xa1, 0x23, 0xa8, 0xdf, 0x86, 0xc6 ], [ 0xbb, 0x28, 0x52, 0xc8, 0x91, 0xc5, 0x94, 0x7d, 0x2e, 0xd4, 0x40, 0x32, 0xc4, 0x21, 0xb8, 0x5f ], [ 0x1b, 0x9f, 0x5f, 0xbd, 0x5e, 0x8a, 0x42, 0x64, 0xc0, 0xa8, 0x5b, 0x80, 0x40, 0x9a, 0xfa, 0x5e ], [ 0x30, 0xda, 0xb8, 0x09, 0xf8, 0x5a, 0x91, 0x7f, 0xe9, 0x24, 0x73, 0x3f, 0x42, 0x4a, 0xc5, 0x89 ], [ 0xea, 0xef, 0x5c, 0x1f, 0x8d, 0x60, 0x51, 0x92, 0x64, 0x66, 0x95, 0xce, 0xad, 0xc6, 0x5f, 0x32 ], [ 0xb8, 0xaa, 0x90, 0x04, 0x0b, 0x4c, 0x15, 0xa1, 0x23, 0x16, 0xb7, 0x8e, 0x0f, 0x95, 0x86, 0xfc ], [ 0x97, 0xfa, 0xc8, 0x29, 0x7c, 0xea, 0xab, 0xc8, 0x7d, 0x45, 0x43, 0x50, 0x60, 0x1e, 0x06, 0x73 ], [ 0x9b, 0x47, 0xef, 0x56, 0x7a, 0xc2, 0x8d, 0xfe, 0x48, 0x84, 0x92, 0xf1, 0x57, 0xe2, 0xb2, 0xe0 ], [ 0x1b, 0x84, 0x26, 0x02, 0x7d, 0xdb, 0x96, 0x2b, 0x5c, 0x5b, 0xa7, 0xeb, 0x8b, 0xc9, 0xab, 0x63 ], [ 0xe9, 0x17, 0xfc, 0x77, 0xe7, 0x19, 0x92, 0xa1, 0x2d, 0xbe, 0x4c, 0x18, 0x06, 0x8b, 0xec, 0x82 ], [ 0xdc, 0xee, 0xbb, 0xc9, 0x88, 0x40, 0xf8, 0xae, 0x6d, 0xaf, 0x76, 0x57, 0x3b, 0x7e, 0x56, 0xf4 ], [ 0x4e, 0x11, 0xa9, 0xf7, 0x42, 0x05, 0x12, 0x5b, 0x61, 0xe0, 0xae, 0xe0, 0x47, 0xec, 0xa2, 0x0d ], [ 0xf6, 0x04, 0x67, 0xf5, 0x5a, 0x1f, 0x17, 0xea, 0xb8, 0x8e, 0x80, 0x01, 0x20, 0xcb, 0xc2, 0x84 ], [ 0xd4, 0x36, 0x64, 0x9f, 0x60, 0x0b, 0x44, 0x9e, 0xe2, 0x76, 0x53, 0x0f, 0x0c, 0xd8, 0x3c, 0x11 ], [ 0x3b, 0xc0, 0xe3, 0x65, 0x6a, 0x9e, 0x3a, 0xc7, 0xcd, 0x37, 0x8a, 0x73, 0x7f, 0x53, 0xb6, 0x37 ], [ 0x6b, 0xac, 0xae, 0x63, 0xd3, 0x3b, 0x92, 0x8a, 0xa8, 0x38, 0x0f, 0x8d, 0x54, 0xd8, 0x8c, 0x17 ], [ 0x89, 0x35, 0xff, 0xbc, 0x75, 0xae, 0x62, 0x51, 0xbf, 0x8e, 0x85, 0x9f, 0x08, 0x5a, 0xdc, 0xb9 ], [ 0x93, 0xdc, 0x49, 0x70, 0xfe, 0x35, 0xf6, 0x77, 0x47, 0xcb, 0x05, 0x62, 0xc0, 0x6d, 0x87, 0x5a ], [ 0x14, 0xf9, 0xdf, 0x85, 0x89, 0x75, 0x85, 0x17, 0x97, 0xba, 0x60, 0x4f, 0xb0, 0xd1, 0x6c, 0xc7 ], [ 0x02, 0xea, 0x0c, 0x98, 0xdc, 0xa1, 0x0b, 0x38, 0xc2, 0x1b, 0x3b, 0x14, 0xe8, 0xd1, 0xb7, 0x1f ], [ 0x8f, 0x09, 0x1b, 0x1b, 0x5b, 0x07, 0x49, 0xb2, 0xad, 0xc8, 0x03, 0xe6, 0x3d, 0xda, 0x9b, 0x72 ], [ 0x05, 0xb3, 0x89, 0xe3, 0x32, 0x2c, 0x6d, 0xa0, 0x83, 0x84, 0x34, 0x5a, 0x41, 0x37, 0xfd, 0x08 ], [ 0x38, 0x13, 0x08, 0xc4, 0x38, 0xf3, 0x5b, 0x39, 0x9f, 0x10, 0xad, 0x71, 0xb0, 0x50, 0x27, 0xd8 ], [ 0x68, 0xc2, 0x30, 0xfc, 0xfa, 0x92, 0x79, 0xc3, 0x40, 0x9f, 0xc4, 0x23, 0xe2, 0xac, 0xbe, 0x04 ], [ 0x1c, 0x84, 0xa4, 0x75, 0xac, 0xb0, 0x11, 0xf3, 0xf5, 0x9f, 0x4f, 0x46, 0xb7, 0x62, 0x74, 0xc0 ], [ 0x45, 0x11, 0x9b, 0x68, 0xcb, 0x3f, 0x83, 0x99, 0xee, 0x60, 0x06, 0x6b, 0x56, 0x11, 0xa4, 0xd7 ], [ 0x94, 0x23, 0x76, 0x2f, 0x52, 0x7a, 0x40, 0x60, 0xff, 0xca, 0x31, 0x2d, 0xcc, 0xa2, 0x2a, 0x16 ], [ 0xf3, 0x61, 0xa2, 0x74, 0x5a, 0x33, 0xf0, 0x56, 0xa5, 0xac, 0x6a, 0xce, 0x2f, 0x08, 0xe3, 0x44 ], [ 0x5e, 0xf1, 0x45, 0x76, 0x6e, 0xca, 0x84, 0x9f, 0x5d, 0x01, 0x15, 0x36, 0xa6, 0x55, 0x7f, 0xdb ], [ 0xc9, 0xaf, 0x27, 0xb2, 0xc8, 0x9c, 0x9b, 0x4c, 0xf4, 0xa0, 0xc4, 0x10, 0x6a, 0xc8, 0x03, 0x18 ], [ 0xfb, 0x9c, 0x4f, 0x16, 0xc6, 0x21, 0xf4, 0xea, 0xb7, 0xe9, 0xac, 0x1d, 0x75, 0x51, 0xdd, 0x57 ], [ 0x13, 0x8e, 0x06, 0xfb, 0xa4, 0x66, 0xfa, 0x70, 0x85, 0x4d, 0x8c, 0x2e, 0x52, 0x4c, 0xff, 0xb2 ], [ 0xfb, 0x4b, 0xc7, 0x8b, 0x22, 0x50, 0x70, 0x77, 0x3f, 0x04, 0xc4, 0x04, 0x66, 0xd4, 0xe9, 0x0c ], [ 0x8b, 0x2c, 0xbf, 0xf1, 0xed, 0x01, 0x50, 0xfe, 0xda, 0x8a, 0x47, 0x99, 0xbe, 0x94, 0x55, 0x1f ], [ 0x08, 0xb3, 0x0d, 0x7b, 0x3f, 0x27, 0x96, 0x27, 0x09, 0xa3, 0x6b, 0xca, 0xdf, 0xb9, 0x74, 0xbd ], [ 0xfd, 0xf6, 0xd3, 0x2e, 0x04, 0x4d, 0x77, 0xad, 0xcf, 0x37, 0xfb, 0x97, 0xac, 0x21, 0x33, 0x26 ], [ 0x93, 0xcb, 0x28, 0x4e, 0xcd, 0xcf, 0xd7, 0x81, 0xa8, 0xaf, 0xe3, 0x20, 0x77, 0x94, 0x9e, 0x88 ], [ 0x7b, 0x01, 0x7b, 0xb0, 0x2e, 0xc8, 0x7b, 0x2b, 0x94, 0xc9, 0x6e, 0x40, 0xa2, 0x6f, 0xc7, 0x1a ], [ 0xc5, 0xc0, 0x38, 0xb6, 0x99, 0x06, 0x64, 0xab, 0x08, 0xa3, 0xaa, 0xa5, 0xdf, 0x9f, 0x32, 0x66 ], [ 0x4b, 0x70, 0x20, 0xbe, 0x37, 0xfa, 0xb6, 0x25, 0x9b, 0x2a, 0x27, 0xf4, 0xec, 0x55, 0x15, 0x76 ], [ 0x60, 0x13, 0x67, 0x03, 0x37, 0x4f, 0x64, 0xe8, 0x60, 0xb4, 0x8c, 0xe3, 0x1f, 0x93, 0x07, 0x16 ], [ 0x8d, 0x63, 0xa2, 0x69, 0xb1, 0x4d, 0x50, 0x6c, 0xcc, 0x40, 0x1a, 0xb8, 0xa9, 0xf1, 0xb5, 0x91 ], [ 0xd3, 0x17, 0xf8, 0x1d, 0xc6, 0xaa, 0x45, 0x4a, 0xee, 0x4b, 0xd4, 0xa5, 0xa5, 0xcf, 0xf4, 0xbd ], [ 0xdd, 0xde, 0xce, 0xcd, 0x53, 0x54, 0xf0, 0x4d, 0x53, 0x0d, 0x76, 0xed, 0x88, 0x42, 0x46, 0xeb ], [ 0x41, 0xc5, 0x20, 0x5c, 0xc8, 0xfd, 0x8e, 0xda, 0x9a, 0x3c, 0xff, 0xd2, 0x51, 0x8f, 0x36, 0x5a ], [ 0xcf, 0x42, 0xfb, 0x47, 0x42, 0x93, 0xd9, 0x6e, 0xca, 0x9d, 0xb1, 0xb3, 0x7b, 0x1b, 0xa6, 0x76 ], [ 0xa2, 0x31, 0x69, 0x26, 0x07, 0x16, 0x9b, 0x4e, 0xcd, 0xea, 0xd5, 0xcd, 0x3b, 0x10, 0xdb, 0x3e ], [ 0xac, 0xe4, 0xb9, 0x1c, 0x9c, 0x66, 0x9e, 0x77, 0xe7, 0xac, 0xac, 0xd1, 0x98, 0x59, 0xed, 0x49 ], [ 0x75, 0xdb, 0x7c, 0xfd, 0x4a, 0x7b, 0x2b, 0x62, 0xab, 0x78, 0xa4, 0x8f, 0x3d, 0xda, 0xf4, 0xaf ], [ 0xc1, 0xfa, 0xba, 0x2d, 0x46, 0xe2, 0x59, 0xcf, 0x48, 0x0d, 0x7c, 0x38, 0xe4, 0x57, 0x2a, 0x58 ], [ 0x24, 0x1c, 0x45, 0xbc, 0x6a, 0xe1, 0x6d, 0xee, 0x6e, 0xb7, 0xbe, 0xa1, 0x28, 0x70, 0x15, 0x82 ], [ 0x8f, 0xd0, 0x30, 0x57, 0xcf, 0x13, 0x64, 0x42, 0x0c, 0x2b, 0x78, 0x06, 0x9a, 0x3e, 0x25, 0x02 ], [ 0xdd, 0xb5, 0x05, 0xe6, 0xcc, 0x13, 0x84, 0xcb, 0xae, 0xc1, 0xdf, 0x90, 0xb8, 0x0b, 0xeb, 0x20 ], [ 0x56, 0x74, 0xa3, 0xbe, 0xd2, 0x7b, 0xf4, 0xbd, 0x36, 0x22, 0xf9, 0xf5, 0xfe, 0x20, 0x83, 0x06 ], [ 0xb6, 0x87, 0xf2, 0x6a, 0x89, 0xcf, 0xbf, 0xbb, 0x8e, 0x5e, 0xea, 0xc5, 0x40, 0x55, 0x31, 0x5e ], [ 0x05, 0x47, 0xdd, 0x32, 0xd3, 0xb2, 0x9a, 0xb6, 0xa4, 0xca, 0xeb, 0x60, 0x6c, 0x5b, 0x6f, 0x78 ], [ 0x18, 0x68, 0x61, 0xf8, 0xbc, 0x53, 0x86, 0xd3, 0x1f, 0xb7, 0x7f, 0x72, 0x0c, 0x32, 0x26, 0xe6 ], [ 0xea, 0xcf, 0x1e, 0x6c, 0x42, 0x24, 0xef, 0xb3, 0x89, 0x00, 0xb1, 0x85, 0xab, 0x1d, 0xfd, 0x42 ], [ 0xd2, 0x41, 0xaa, 0xb0, 0x5a, 0x42, 0xd3, 0x19, 0xde, 0x81, 0xd8, 0x74, 0xf5, 0xc7, 0xb9, 0x0d ], [ 0x5e, 0xb9, 0xbc, 0x75, 0x9e, 0x2a, 0xd8, 0xd2, 0x14, 0x0a, 0x6c, 0x76, 0x2a, 0xe9, 0xe1, 0xab ], [ 0x01, 0x85, 0x96, 0xe1, 0x5e, 0x78, 0xe2, 0xc0, 0x64, 0x15, 0x9d, 0xef, 0xce, 0x5f, 0x30, 0x85 ], [ 0xdd, 0x8a, 0x49, 0x35, 0x14, 0x23, 0x1c, 0xbf, 0x56, 0xec, 0xce, 0xe4, 0xc4, 0x08, 0x89, 0xfb ] ]; # Values from NIST KAT-AES ECBVarTxt256.rsp cipher_texts1_256bit = [ [ 0xdd, 0xc6, 0xbf, 0x79, 0x0c, 0x15, 0x76, 0x0d, 0x8d, 0x9a, 0xeb, 0x6f, 0x9a, 0x75, 0xfd, 0x4e ], [ 0x0a, 0x6b, 0xdc, 0x6d, 0x4c, 0x1e, 0x62, 0x80, 0x30, 0x1f, 0xd8, 0xe9, 0x7d, 0xdb, 0xe6, 0x01 ], [ 0x9b, 0x80, 0xee, 0xfb, 0x7e, 0xbe, 0x2d, 0x2b, 0x16, 0x24, 0x7a, 0xa0, 0xef, 0xc7, 0x2f, 0x5d ], [ 0x7f, 0x2c, 0x5e, 0xce, 0x07, 0xa9, 0x8d, 0x8b, 0xee, 0x13, 0xc5, 0x11, 0x77, 0x39, 0x5f, 0xf7 ], [ 0x78, 0x18, 0xd8, 0x00, 0xdc, 0xf6, 0xf4, 0xbe, 0x1e, 0x0e, 0x94, 0xf4, 0x03, 0xd1, 0xe4, 0xc2 ], [ 0xe7, 0x4c, 0xd1, 0xc9, 0x2f, 0x09, 0x19, 0xc3, 0x5a, 0x03, 0x24, 0x12, 0x3d, 0x61, 0x77, 0xd3 ], [ 0x80, 0x92, 0xa4, 0xdc, 0xf2, 0xda, 0x7e, 0x77, 0xe9, 0x3b, 0xdd, 0x37, 0x1d, 0xfe, 0xd8, 0x2e ], [ 0x49, 0xaf, 0x6b, 0x37, 0x21, 0x35, 0xac, 0xef, 0x10, 0x13, 0x2e, 0x54, 0x8f, 0x21, 0x7b, 0x17 ], [ 0x8b, 0xcd, 0x40, 0xf9, 0x4e, 0xbb, 0x63, 0xb9, 0xf7, 0x90, 0x96, 0x76, 0xe6, 0x67, 0xf1, 0xe7 ], [ 0xfe, 0x1c, 0xff, 0xb8, 0x3f, 0x45, 0xdc, 0xfb, 0x38, 0xb2, 0x9b, 0xe4, 0x38, 0xdb, 0xd3, 0xab ], [ 0x0d, 0xc5, 0x8a, 0x8d, 0x88, 0x66, 0x23, 0x70, 0x5a, 0xec, 0x15, 0xcb, 0x1e, 0x70, 0xdc, 0x0e ], [ 0xc2, 0x18, 0xfa, 0xa1, 0x60, 0x56, 0xbd, 0x07, 0x74, 0xc3, 0xe8, 0xd7, 0x9c, 0x35, 0xa5, 0xe4 ], [ 0x04, 0x7b, 0xba, 0x83, 0xf7, 0xaa, 0x84, 0x17, 0x31, 0x50, 0x4e, 0x01, 0x22, 0x08, 0xfc, 0x9e ], [ 0xdc, 0x8f, 0x0e, 0x49, 0x15, 0xfd, 0x81, 0xba, 0x70, 0xa3, 0x31, 0x31, 0x08, 0x82, 0xf6, 0xda ], [ 0x15, 0x69, 0x85, 0x9e, 0xa6, 0xb7, 0x20, 0x6c, 0x30, 0xbf, 0x4f, 0xd0, 0xcb, 0xfa, 0xc3, 0x3c ], [ 0x30, 0x0a, 0xde, 0x92, 0xf8, 0x8f, 0x48, 0xfa, 0x2d, 0xf7, 0x30, 0xec, 0x16, 0xef, 0x44, 0xcd ], [ 0x1f, 0xe6, 0xcc, 0x3c, 0x05, 0x96, 0x5d, 0xc0, 0x8e, 0xb0, 0x59, 0x0c, 0x95, 0xac, 0x71, 0xd0 ], [ 0x59, 0xe8, 0x58, 0xea, 0xaa, 0x97, 0xfe, 0xc3, 0x81, 0x11, 0x27, 0x5b, 0x6c, 0xf5, 0xab, 0xc0 ], [ 0x22, 0x39, 0x45, 0x5e, 0x7a, 0xfe, 0x3b, 0x06, 0x16, 0x10, 0x02, 0x88, 0xcc, 0x5a, 0x72, 0x3b ], [ 0x3e, 0xe5, 0x00, 0xc5, 0xc8, 0xd6, 0x34, 0x79, 0x71, 0x71, 0x63, 0xe5, 0x5c, 0x5c, 0x45, 0x22 ], [ 0xd5, 0xe3, 0x8b, 0xf1, 0x5f, 0x16, 0xd9, 0x0e, 0x3e, 0x21, 0x40, 0x41, 0xd7, 0x74, 0xda, 0xa8 ], [ 0xb1, 0xf4, 0x06, 0x6e, 0x6f, 0x4f, 0x18, 0x7d, 0xfe, 0x5f, 0x2a, 0xd1, 0xb1, 0x78, 0x19, 0xd0 ], [ 0x6e, 0xf4, 0xcc, 0x4d, 0xe4, 0x9b, 0x11, 0x06, 0x5d, 0x7a, 0xf2, 0x90, 0x98, 0x54, 0x79, 0x4a ], [ 0xac, 0x86, 0xbc, 0x60, 0x6b, 0x66, 0x40, 0xc3, 0x09, 0xe7, 0x82, 0xf2, 0x32, 0xbf, 0x36, 0x7f ], [ 0x36, 0xaf, 0xf0, 0xef, 0x7b, 0xf3, 0x28, 0x07, 0x72, 0xcf, 0x4c, 0xac, 0x80, 0xa0, 0xd2, 0xb2 ], [ 0x1f, 0x8e, 0xed, 0xea, 0x0f, 0x62, 0xa1, 0x40, 0x6d, 0x58, 0xcf, 0xc3, 0xec, 0xea, 0x72, 0xcf ], [ 0xab, 0xf4, 0x15, 0x4a, 0x33, 0x75, 0xa1, 0xd3, 0xe6, 0xb1, 0xd4, 0x54, 0x43, 0x8f, 0x95, 0xa6 ], [ 0x96, 0xf9, 0x6e, 0x9d, 0x60, 0x7f, 0x66, 0x15, 0xfc, 0x19, 0x20, 0x61, 0xee, 0x64, 0x8b, 0x07 ], [ 0xcf, 0x37, 0xcd, 0xaa, 0xa0, 0xd2, 0xd5, 0x36, 0xc7, 0x18, 0x57, 0x63, 0x4c, 0x79, 0x20, 0x64 ], [ 0xfb, 0xd6, 0x64, 0x0c, 0x80, 0x24, 0x5c, 0x2b, 0x80, 0x53, 0x73, 0xf1, 0x30, 0x70, 0x31, 0x27 ], [ 0x8d, 0x6a, 0x8a, 0xfe, 0x55, 0xa6, 0xe4, 0x81, 0xba, 0xda, 0xe0, 0xd1, 0x46, 0xf4, 0x36, 0xdb ], [ 0x6a, 0x49, 0x81, 0xf2, 0x91, 0x5e, 0x3e, 0x68, 0xaf, 0x6c, 0x22, 0x38, 0x5d, 0xd0, 0x67, 0x56 ], [ 0x42, 0xa1, 0x13, 0x6e, 0x5f, 0x8d, 0x8d, 0x21, 0xd3, 0x10, 0x19, 0x98, 0x64, 0x2d, 0x57, 0x3b ], [ 0x9b, 0x47, 0x15, 0x96, 0xdc, 0x69, 0xae, 0x15, 0x86, 0xce, 0xe6, 0x15, 0x8b, 0x0b, 0x01, 0x81 ], [ 0x75, 0x36, 0x65, 0xc4, 0xaf, 0x1e, 0xff, 0x33, 0xaa, 0x8b, 0x62, 0x8b, 0xf8, 0x74, 0x1c, 0xfd ], [ 0x9a, 0x68, 0x2a, 0xcf, 0x40, 0xbe, 0x01, 0xf5, 0xb2, 0xa4, 0x19, 0x3c, 0x9a, 0x82, 0x40, 0x4d ], [ 0x54, 0xfa, 0xfe, 0x26, 0xe4, 0x28, 0x7f, 0x17, 0xd1, 0x93, 0x5f, 0x87, 0xeb, 0x9a, 0xde, 0x01 ], [ 0x49, 0xd5, 0x41, 0xb2, 0xe7, 0x4c, 0xfe, 0x73, 0xe6, 0xa8, 0xe8, 0x22, 0x5f, 0x7b, 0xd4, 0x49 ], [ 0x11, 0xa4, 0x55, 0x30, 0xf6, 0x24, 0xff, 0x6f, 0x76, 0xa1, 0xb3, 0x82, 0x66, 0x26, 0xff, 0x7b ], [ 0xf9, 0x6b, 0x0c, 0x4a, 0x8b, 0xc6, 0xc8, 0x61, 0x30, 0x28, 0x9f, 0x60, 0xb4, 0x3b, 0x8f, 0xba ], [ 0x48, 0xc7, 0xd0, 0xe8, 0x08, 0x34, 0xeb, 0xdc, 0x35, 0xb6, 0x73, 0x5f, 0x76, 0xb4, 0x6c, 0x8b ], [ 0x24, 0x63, 0x53, 0x1a, 0xb5, 0x4d, 0x66, 0x95, 0x5e, 0x73, 0xed, 0xc4, 0xcb, 0x8e, 0xaa, 0x45 ], [ 0xac, 0x9b, 0xd8, 0xe2, 0x53, 0x04, 0x69, 0x13, 0x4b, 0x9d, 0x5b, 0x06, 0x5d, 0x4f, 0x56, 0x5b ], [ 0x3f, 0x5f, 0x91, 0x06, 0xd0, 0xe5, 0x2f, 0x97, 0x3d, 0x48, 0x90, 0xe6, 0xf3, 0x7e, 0x8a, 0x00 ], [ 0x20, 0xeb, 0xc8, 0x6f, 0x13, 0x04, 0xd2, 0x72, 0xe2, 0xe2, 0x07, 0xe5, 0x9d, 0xb6, 0x39, 0xf0 ], [ 0xe6, 0x7a, 0xe6, 0x42, 0x6b, 0xf9, 0x52, 0x6c, 0x97, 0x2c, 0xff, 0x07, 0x2b, 0x52, 0x25, 0x2c ], [ 0x1a, 0x51, 0x8d, 0xdd, 0xaf, 0x9e, 0xfa, 0x0d, 0x00, 0x2c, 0xc5, 0x8d, 0x10, 0x7e, 0xdf, 0xc8 ], [ 0xea, 0xd7, 0x31, 0xaf, 0x4d, 0x3a, 0x2f, 0xe3, 0xb3, 0x4b, 0xed, 0x04, 0x79, 0x42, 0xa4, 0x9f ], [ 0xb1, 0xd4, 0xef, 0xe4, 0x02, 0x42, 0xf8, 0x3e, 0x93, 0xb6, 0xc8, 0xd7, 0xef, 0xb5, 0xea, 0xe9 ], [ 0xcd, 0x2b, 0x1f, 0xec, 0x11, 0xfd, 0x90, 0x6c, 0x5c, 0x76, 0x30, 0x09, 0x94, 0x43, 0x61, 0x0a ], [ 0xa1, 0x85, 0x3f, 0xe4, 0x7f, 0xe2, 0x92, 0x89, 0xd1, 0x53, 0x16, 0x1d, 0x06, 0x38, 0x7d, 0x21 ], [ 0x46, 0x32, 0x15, 0x41, 0x79, 0xa5, 0x55, 0xc1, 0x7e, 0xa6, 0x04, 0xd0, 0x88, 0x9f, 0xab, 0x14 ], [ 0xdd, 0x27, 0xca, 0xc6, 0x40, 0x1a, 0x02, 0x2e, 0x8f, 0x38, 0xf9, 0xf9, 0x3e, 0x77, 0x44, 0x17 ], [ 0xc0, 0x90, 0x31, 0x3e, 0xb9, 0x86, 0x74, 0xf3, 0x5f, 0x31, 0x23, 0x38, 0x5f, 0xb9, 0x5d, 0x4d ], [ 0xcc, 0x35, 0x26, 0x26, 0x2b, 0x92, 0xf0, 0x2e, 0xdc, 0xe5, 0x48, 0xf7, 0x16, 0xb9, 0xf4, 0x5c ], [ 0xc0, 0x83, 0x8d, 0x1a, 0x2b, 0x16, 0xa7, 0xc7, 0xf0, 0xdf, 0xcc, 0x43, 0x3c, 0x39, 0x9c, 0x33 ], [ 0x0d, 0x9a, 0xc7, 0x56, 0xeb, 0x29, 0x76, 0x95, 0xee, 0xd4, 0xd3, 0x82, 0xeb, 0x12, 0x6d, 0x26 ], [ 0x56, 0xed, 0xe9, 0xdd, 0xa3, 0xf6, 0xf1, 0x41, 0xbf, 0xf1, 0x75, 0x7f, 0xa6, 0x89, 0xc3, 0xe1 ], [ 0x76, 0x8f, 0x52, 0x0e, 0xfe, 0x0f, 0x23, 0xe6, 0x1d, 0x3e, 0xc8, 0xad, 0x9c, 0xe9, 0x17, 0x74 ], [ 0xb1, 0x14, 0x4d, 0xdf, 0xa7, 0x57, 0x55, 0x21, 0x33, 0x90, 0xe7, 0xc5, 0x96, 0x66, 0x04, 0x90 ], [ 0x1d, 0x7c, 0x0c, 0x40, 0x40, 0xb3, 0x55, 0xb9, 0xd1, 0x07, 0xa9, 0x93, 0x25, 0xe3, 0xb0, 0x50 ], [ 0xd8, 0xe2, 0xbb, 0x1a, 0xe8, 0xee, 0x3d, 0xcf, 0x5b, 0xf7, 0xd6, 0xc3, 0x8d, 0xa8, 0x2a, 0x1a ], [ 0xfa, 0xf8, 0x2d, 0x17, 0x8a, 0xf2, 0x5a, 0x98, 0x86, 0xa4, 0x7e, 0x7f, 0x78, 0x9b, 0x98, 0xd7 ], [ 0x9b, 0x58, 0xdb, 0xfd, 0x77, 0xfe, 0x5a, 0xca, 0x9c, 0xfc, 0x19, 0x0c, 0xd1, 0xb8, 0x2d, 0x19 ], [ 0x77, 0xf3, 0x92, 0x08, 0x90, 0x42, 0xe4, 0x78, 0xac, 0x16, 0xc0, 0xc8, 0x6a, 0x0b, 0x5d, 0xb5 ], [ 0x19, 0xf0, 0x8e, 0x34, 0x20, 0xee, 0x69, 0xb4, 0x77, 0xca, 0x14, 0x20, 0x28, 0x1c, 0x47, 0x82 ], [ 0xa1, 0xb1, 0x9b, 0xee, 0xe4, 0xe1, 0x17, 0x13, 0x9f, 0x74, 0xb3, 0xc5, 0x3f, 0xdc, 0xb8, 0x75 ], [ 0xa3, 0x7a, 0x58, 0x69, 0xb2, 0x18, 0xa9, 0xf3, 0xa0, 0x86, 0x8d, 0x19, 0xae, 0xa0, 0xad, 0x6a ], [ 0xbc, 0x35, 0x94, 0xe8, 0x65, 0xbc, 0xd0, 0x26, 0x1b, 0x13, 0x20, 0x27, 0x31, 0xf3, 0x35, 0x80 ], [ 0x81, 0x14, 0x41, 0xce, 0x1d, 0x30, 0x9e, 0xee, 0x71, 0x85, 0xe8, 0xc7, 0x52, 0xc0, 0x75, 0x57 ], [ 0x95, 0x99, 0x71, 0xce, 0x41, 0x34, 0x19, 0x05, 0x63, 0x51, 0x8e, 0x70, 0x0b, 0x98, 0x74, 0xd1 ], [ 0x76, 0xb5, 0x61, 0x4a, 0x04, 0x27, 0x07, 0xc9, 0x8e, 0x21, 0x32, 0xe2, 0xe8, 0x05, 0xfe, 0x63 ], [ 0x7d, 0x9f, 0xa6, 0xa5, 0x75, 0x30, 0xd0, 0xf0, 0x36, 0xfe, 0xc3, 0x1c, 0x23, 0x0b, 0x0c, 0xc6 ], [ 0x96, 0x41, 0x53, 0xa8, 0x3b, 0xf6, 0x98, 0x9a, 0x4b, 0xa8, 0x0d, 0xaa, 0x91, 0xc3, 0xe0, 0x81 ], [ 0xa0, 0x13, 0x01, 0x4d, 0x4c, 0xe8, 0x05, 0x4c, 0xf2, 0x59, 0x1d, 0x06, 0xf6, 0xf2, 0xf1, 0x76 ], [ 0xd1, 0xc5, 0xf6, 0x39, 0x9b, 0xf3, 0x82, 0x50, 0x2e, 0x38, 0x5e, 0xee, 0x14, 0x74, 0xa8, 0x69 ], [ 0x00, 0x07, 0xe2, 0x0b, 0x82, 0x98, 0xec, 0x35, 0x4f, 0x0f, 0x5f, 0xe7, 0x47, 0x0f, 0x36, 0xbd ], [ 0xb9, 0x5b, 0xa0, 0x5b, 0x33, 0x2d, 0xa6, 0x1e, 0xf6, 0x3a, 0x2b, 0x31, 0xfc, 0xad, 0x98, 0x79 ], [ 0x46, 0x20, 0xa4, 0x9b, 0xd9, 0x67, 0x49, 0x15, 0x61, 0x66, 0x9a, 0xb2, 0x5d, 0xce, 0x45, 0xf4 ], [ 0x12, 0xe7, 0x12, 0x14, 0xae, 0x8e, 0x04, 0xf0, 0xbb, 0x63, 0xd7, 0x42, 0x5c, 0x6f, 0x14, 0xd5 ], [ 0x4c, 0xc4, 0x2f, 0xc1, 0x40, 0x7b, 0x00, 0x8f, 0xe3, 0x50, 0x90, 0x7c, 0x09, 0x2e, 0x80, 0xac ], [ 0x08, 0xb2, 0x44, 0xce, 0x7c, 0xbc, 0x8e, 0xe9, 0x7f, 0xbb, 0xa8, 0x08, 0xcb, 0x14, 0x6f, 0xda ], [ 0x39, 0xb3, 0x33, 0xe8, 0x69, 0x4f, 0x21, 0x54, 0x6a, 0xd1, 0xed, 0xd9, 0xd8, 0x7e, 0xd9, 0x5b ], [ 0x3b, 0x27, 0x1f, 0x8a, 0xb2, 0xe6, 0xe4, 0xa2, 0x0b, 0xa8, 0x09, 0x0f, 0x43, 0xba, 0x78, 0xf3 ], [ 0x9a, 0xd9, 0x83, 0xf3, 0xbf, 0x65, 0x1c, 0xd0, 0x39, 0x3f, 0x0a, 0x73, 0xcc, 0xcd, 0xea, 0x50 ], [ 0x8f, 0x47, 0x6c, 0xbf, 0xf7, 0x5c, 0x1f, 0x72, 0x5c, 0xe1, 0x8e, 0x4b, 0xbc, 0xd1, 0x9b, 0x32 ], [ 0x90, 0x5b, 0x62, 0x67, 0xf1, 0xd6, 0xab, 0x53, 0x20, 0x83, 0x5a, 0x13, 0x3f, 0x09, 0x6f, 0x2a ], [ 0x14, 0x5b, 0x60, 0xd6, 0xd0, 0x19, 0x3c, 0x23, 0xf4, 0x22, 0x18, 0x48, 0xa8, 0x92, 0xd6, 0x1a ], [ 0x55, 0xcf, 0xb3, 0xfb, 0x6d, 0x75, 0xca, 0xd0, 0x44, 0x5b, 0xbc, 0x8d, 0xaf, 0xa2, 0x5b, 0x0f ], [ 0x7b, 0x8e, 0x70, 0x98, 0xe3, 0x57, 0xef, 0x71, 0x23, 0x7d, 0x46, 0xd8, 0xb0, 0x75, 0xb0, 0xf5 ], [ 0x2b, 0xf2, 0x72, 0x29, 0x90, 0x1e, 0xb4, 0x0f, 0x2d, 0xf9, 0xd8, 0x39, 0x8d, 0x15, 0x05, 0xae ], [ 0x83, 0xa6, 0x34, 0x02, 0xa7, 0x7f, 0x9a, 0xd5, 0xc1, 0xe9, 0x31, 0xa9, 0x31, 0xec, 0xd7, 0x06 ], [ 0x6f, 0x8b, 0xa6, 0x52, 0x11, 0x52, 0xd3, 0x1f, 0x2b, 0xad, 0xa1, 0x84, 0x3e, 0x26, 0xb9, 0x73 ], [ 0xe5, 0xc3, 0xb8, 0xe3, 0x0f, 0xd2, 0xd8, 0xe6, 0x23, 0x9b, 0x17, 0xb4, 0x4b, 0xd2, 0x3b, 0xbd ], [ 0x1a, 0xc1, 0xf7, 0x10, 0x2c, 0x59, 0x93, 0x3e, 0x8b, 0x2d, 0xdc, 0x3f, 0x14, 0xe9, 0x4b, 0xaa ], [ 0x21, 0xd9, 0xba, 0x49, 0xf2, 0x76, 0xb4, 0x5f, 0x11, 0xaf, 0x8f, 0xc7, 0x1a, 0x08, 0x8e, 0x3d ], [ 0x64, 0x9f, 0x1c, 0xdd, 0xc3, 0x79, 0x2b, 0x46, 0x38, 0x63, 0x5a, 0x39, 0x2b, 0xc9, 0xba, 0xde ], [ 0xe2, 0x77, 0x5e, 0x4b, 0x59, 0xc1, 0xbc, 0x2e, 0x31, 0xa2, 0x07, 0x8c, 0x11, 0xb5, 0xa0, 0x8c ], [ 0x2b, 0xe1, 0xfa, 0xe5, 0x04, 0x8a, 0x25, 0x58, 0x2a, 0x67, 0x9c, 0xa1, 0x09, 0x05, 0xeb, 0x80 ], [ 0xda, 0x86, 0xf2, 0x92, 0xc6, 0xf4, 0x1e, 0xa3, 0x4f, 0xb2, 0x06, 0x8d, 0xf7, 0x5e, 0xcc, 0x29 ], [ 0x22, 0x0d, 0xf1, 0x9f, 0x85, 0xd6, 0x9b, 0x1b, 0x56, 0x2f, 0xa6, 0x9a, 0x3c, 0x5b, 0xec, 0xa5 ], [ 0x1f, 0x11, 0xd5, 0xd0, 0x35, 0x5e, 0x0b, 0x55, 0x6c, 0xcd, 0xb6, 0xc7, 0xf5, 0x08, 0x3b, 0x4d ], [ 0x62, 0x52, 0x6b, 0x78, 0xbe, 0x79, 0xcb, 0x38, 0x46, 0x33, 0xc9, 0x1f, 0x83, 0xb4, 0x15, 0x1b ], [ 0x90, 0xdd, 0xbc, 0xb9, 0x50, 0x84, 0x35, 0x92, 0xdd, 0x47, 0xbb, 0xef, 0x00, 0xfd, 0xc8, 0x76 ], [ 0x2f, 0xd0, 0xe4, 0x1c, 0x5b, 0x84, 0x02, 0x27, 0x73, 0x54, 0xa7, 0x39, 0x1d, 0x26, 0x18, 0xe2 ], [ 0x3c, 0xdf, 0x13, 0xe7, 0x2d, 0xee, 0x4c, 0x58, 0x1b, 0xaf, 0xec, 0x70, 0xb8, 0x5f, 0x96, 0x60 ], [ 0xaf, 0xa2, 0xff, 0xc1, 0x37, 0x57, 0x70, 0x92, 0xe2, 0xb6, 0x54, 0xfa, 0x19, 0x9d, 0x2c, 0x43 ], [ 0x8d, 0x68, 0x3e, 0xe6, 0x3e, 0x60, 0xd2, 0x08, 0xe3, 0x43, 0xce, 0x48, 0xdb, 0xc4, 0x4c, 0xac ], [ 0x70, 0x5a, 0x4e, 0xf8, 0xba, 0x21, 0x33, 0x72, 0x9c, 0x20, 0x18, 0x5c, 0x3d, 0x3a, 0x47, 0x63 ], [ 0x08, 0x61, 0xa8, 0x61, 0xc3, 0xdb, 0x4e, 0x94, 0x19, 0x42, 0x11, 0xb7, 0x7e, 0xd7, 0x61, 0xb9 ], [ 0x4b, 0x00, 0xc2, 0x7e, 0x8b, 0x26, 0xda, 0x7e, 0xab, 0x9d, 0x3a, 0x88, 0xde, 0xc8, 0xb0, 0x31 ], [ 0x5f, 0x39, 0x7b, 0xf0, 0x30, 0x84, 0x82, 0x0c, 0xc8, 0x81, 0x0d, 0x52, 0xe5, 0xb6, 0x66, 0xe9 ], [ 0x63, 0xfa, 0xfa, 0xbb, 0x72, 0xc0, 0x7b, 0xfb, 0xd3, 0xdd, 0xc9, 0xb1, 0x20, 0x31, 0x04, 0xb8 ], [ 0x68, 0x3e, 0x21, 0x40, 0x58, 0x5b, 0x18, 0x45, 0x2d, 0xd4, 0xff, 0xbb, 0x93, 0xc9, 0x5d, 0xf9 ], [ 0x28, 0x68, 0x94, 0xe4, 0x8e, 0x53, 0x7f, 0x87, 0x63, 0xb5, 0x67, 0x07, 0xd7, 0xd1, 0x55, 0xc8 ], [ 0xa4, 0x23, 0xde, 0xab, 0xc1, 0x73, 0xdc, 0xf7, 0xe2, 0xc4, 0xc5, 0x3e, 0x77, 0xd3, 0x7c, 0xd1 ], [ 0xeb, 0x81, 0x68, 0x31, 0x3e, 0x1c, 0xfd, 0xfd, 0xb5, 0xe9, 0x86, 0xd5, 0x42, 0x9c, 0xf1, 0x72 ], [ 0x27, 0x12, 0x7d, 0xaa, 0xfc, 0x9a, 0xcc, 0xd2, 0xfb, 0x33, 0x4e, 0xc3, 0xeb, 0xa5, 0x23, 0x23 ], [ 0xee, 0x07, 0x15, 0xb9, 0x6f, 0x72, 0xe3, 0xf7, 0xa2, 0x2a, 0x50, 0x64, 0xfc, 0x59, 0x2f, 0x4c ], [ 0x29, 0xee, 0x52, 0x67, 0x70, 0xf2, 0xa1, 0x1d, 0xcf, 0xa9, 0x89, 0xd1, 0xce, 0x88, 0x83, 0x0f ], [ 0x04, 0x93, 0x37, 0x0e, 0x05, 0x4b, 0x09, 0x87, 0x11, 0x30, 0xfe, 0x49, 0xaf, 0x73, 0x0a, 0x5a ], [ 0x9b, 0x7b, 0x94, 0x0f, 0x6c, 0x50, 0x9f, 0x9e, 0x44, 0xa4, 0xee, 0x14, 0x04, 0x48, 0xee, 0x46 ], [ 0x29, 0x15, 0xbe, 0x4a, 0x1e, 0xcf, 0xdc, 0xbe, 0x3e, 0x02, 0x38, 0x11, 0xa1, 0x2b, 0xb6, 0xc7 ], [ 0x72, 0x40, 0xe5, 0x24, 0xbc, 0x51, 0xd8, 0xc4, 0xd4, 0x40, 0xb1, 0xbe, 0x55, 0xd1, 0x06, 0x2c ], [ 0xda, 0x63, 0x03, 0x9d, 0x38, 0xcb, 0x46, 0x12, 0xb2, 0xdc, 0x36, 0xba, 0x26, 0x68, 0x4b, 0x93 ], [ 0x0f, 0x59, 0xcb, 0x5a, 0x4b, 0x52, 0x2e, 0x2a, 0xc5, 0x6c, 0x1a, 0x64, 0xf5, 0x58, 0xad, 0x9a ], [ 0x7b, 0xfe, 0x9d, 0x87, 0x6c, 0x6d, 0x63, 0xc1, 0xd0, 0x35, 0xda, 0x8f, 0xe2, 0x1c, 0x40, 0x9d ], [ 0xac, 0xda, 0xce, 0x80, 0x78, 0xa3, 0x2b, 0x1a, 0x18, 0x2b, 0xfa, 0x49, 0x87, 0xca, 0x13, 0x47 ] ]; # Values from NIST KAT-AES ECBVarKey256.rsp cipher_texts2_256bit = [ [ 0xe3, 0x5a, 0x6d, 0xcb, 0x19, 0xb2, 0x01, 0xa0, 0x1e, 0xbc, 0xfa, 0x8a, 0xa2, 0x2b, 0x57, 0x59 ], [ 0xb2, 0x91, 0x69, 0xcd, 0xcf, 0x2d, 0x83, 0xe8, 0x38, 0x12, 0x5a, 0x12, 0xee, 0x6a, 0xa4, 0x00 ], [ 0xd8, 0xf3, 0xa7, 0x2f, 0xc3, 0xcd, 0xf7, 0x4d, 0xfa, 0xf6, 0xc3, 0xe6, 0xb9, 0x7b, 0x2f, 0xa6 ], [ 0x1c, 0x77, 0x76, 0x79, 0xd5, 0x00, 0x37, 0xc7, 0x94, 0x91, 0xa9, 0x4d, 0xa7, 0x6a, 0x9a, 0x35 ], [ 0x9c, 0xf4, 0x89, 0x3e, 0xca, 0xfa, 0x0a, 0x02, 0x47, 0xa8, 0x98, 0xe0, 0x40, 0x69, 0x15, 0x59 ], [ 0x8f, 0xbb, 0x41, 0x37, 0x03, 0x73, 0x53, 0x26, 0x31, 0x0a, 0x26, 0x9b, 0xd3, 0xaa, 0x94, 0xb2 ], [ 0x60, 0xe3, 0x22, 0x46, 0xbe, 0xd2, 0xb0, 0xe8, 0x59, 0xe5, 0x5c, 0x1c, 0xc6, 0xb2, 0x65, 0x02 ], [ 0xec, 0x52, 0xa2, 0x12, 0xf8, 0x0a, 0x09, 0xdf, 0x63, 0x17, 0x02, 0x1b, 0xc2, 0xa9, 0x81, 0x9e ], [ 0xf2, 0x3e, 0x5b, 0x60, 0x0e, 0xb7, 0x0d, 0xbc, 0xcf, 0x6c, 0x0b, 0x1d, 0x9a, 0x68, 0x18, 0x2c ], [ 0xa3, 0xf5, 0x99, 0xd6, 0x3a, 0x82, 0xa9, 0x68, 0xc3, 0x3f, 0xe2, 0x65, 0x90, 0x74, 0x59, 0x70 ], [ 0xd1, 0xcc, 0xb9, 0xb1, 0x33, 0x70, 0x02, 0xcb, 0xac, 0x42, 0xc5, 0x20, 0xb5, 0xd6, 0x77, 0x22 ], [ 0xcc, 0x11, 0x1f, 0x6c, 0x37, 0xcf, 0x40, 0xa1, 0x15, 0x9d, 0x00, 0xfb, 0x59, 0xfb, 0x04, 0x88 ], [ 0xdc, 0x43, 0xb5, 0x1a, 0xb6, 0x09, 0x05, 0x23, 0x72, 0x98, 0x9a, 0x26, 0xe9, 0xcd, 0xd7, 0x14 ], [ 0x4d, 0xce, 0xde, 0x8d, 0xa9, 0xe2, 0x57, 0x8f, 0x39, 0x70, 0x3d, 0x44, 0x33, 0xdc, 0x64, 0x59 ], [ 0x1a, 0x4c, 0x1c, 0x26, 0x3b, 0xbc, 0xcf, 0xaf, 0xc1, 0x17, 0x82, 0x89, 0x46, 0x85, 0xe3, 0xa8 ], [ 0x93, 0x7a, 0xd8, 0x48, 0x80, 0xdb, 0x50, 0x61, 0x34, 0x23, 0xd6, 0xd5, 0x27, 0xa2, 0x82, 0x3d ], [ 0x61, 0x0b, 0x71, 0xdf, 0xc6, 0x88, 0xe1, 0x50, 0xd8, 0x15, 0x2c, 0x5b, 0x35, 0xeb, 0xc1, 0x4d ], [ 0x27, 0xef, 0x24, 0x95, 0xda, 0xbf, 0x32, 0x38, 0x85, 0xaa, 0xb3, 0x9c, 0x80, 0xf1, 0x8d, 0x8b ], [ 0x63, 0x3c, 0xaf, 0xea, 0x39, 0x5b, 0xc0, 0x3a, 0xda, 0xe3, 0xa1, 0xe2, 0x06, 0x8e, 0x4b, 0x4e ], [ 0x6e, 0x1b, 0x48, 0x2b, 0x53, 0x76, 0x1c, 0xf6, 0x31, 0x81, 0x9b, 0x74, 0x9a, 0x6f, 0x37, 0x24 ], [ 0x97, 0x6e, 0x6f, 0x85, 0x1a, 0xb5, 0x2c, 0x77, 0x19, 0x98, 0xdb, 0xb2, 0xd7, 0x1c, 0x75, 0xa9 ], [ 0x85, 0xf2, 0xba, 0x84, 0xf8, 0xc3, 0x07, 0xcf, 0x52, 0x5e, 0x12, 0x4c, 0x3e, 0x22, 0xe6, 0xcc ], [ 0x6b, 0xcc, 0xa9, 0x8b, 0xf6, 0xa8, 0x35, 0xfa, 0x64, 0x95, 0x5f, 0x72, 0xde, 0x41, 0x15, 0xfe ], [ 0x2c, 0x75, 0xe2, 0xd3, 0x6e, 0xeb, 0xd6, 0x54, 0x11, 0xf1, 0x4f, 0xd0, 0xeb, 0x1d, 0x2a, 0x06 ], [ 0xbd, 0x49, 0x29, 0x50, 0x06, 0x25, 0x0f, 0xfc, 0xa5, 0x10, 0x0b, 0x60, 0x07, 0xa0, 0xea, 0xde ], [ 0xa1, 0x90, 0x52, 0x7d, 0x0e, 0xf7, 0xc7, 0x0f, 0x45, 0x9c, 0xd3, 0x94, 0x0d, 0xf3, 0x16, 0xec ], [ 0xbb, 0xd1, 0x09, 0x7a, 0x62, 0x43, 0x3f, 0x79, 0x44, 0x9f, 0xa9, 0x7d, 0x4e, 0xe8, 0x0d, 0xbf ], [ 0x07, 0x05, 0x8e, 0x40, 0x8f, 0x5b, 0x99, 0xb0, 0xe0, 0xf0, 0x61, 0xa1, 0x76, 0x1b, 0x5b, 0x3b ], [ 0x5f, 0xd1, 0xf1, 0x3f, 0xa0, 0xf3, 0x1e, 0x37, 0xfa, 0xbd, 0xe3, 0x28, 0xf8, 0x94, 0xea, 0xc2 ], [ 0xfc, 0x4a, 0xf7, 0xc9, 0x48, 0xdf, 0x26, 0xe2, 0xef, 0x3e, 0x01, 0xc1, 0xee, 0x5b, 0x8f, 0x6f ], [ 0x82, 0x9f, 0xd7, 0x20, 0x8f, 0xb9, 0x2d, 0x44, 0xa0, 0x74, 0xa6, 0x77, 0xee, 0x98, 0x61, 0xac ], [ 0xad, 0x9f, 0xc6, 0x13, 0xa7, 0x03, 0x25, 0x1b, 0x54, 0xc6, 0x4a, 0x0e, 0x76, 0x43, 0x17, 0x11 ], [ 0x33, 0xac, 0x9e, 0xcc, 0xc4, 0xcc, 0x75, 0xe2, 0x71, 0x16, 0x18, 0xf8, 0x0b, 0x15, 0x48, 0xe8 ], [ 0x20, 0x25, 0xc7, 0x4b, 0x8a, 0xd8, 0xf4, 0xcd, 0xa1, 0x7e, 0xe2, 0x04, 0x9c, 0x4c, 0x90, 0x2d ], [ 0xf8, 0x5c, 0xa0, 0x5f, 0xe5, 0x28, 0xf1, 0xce, 0x9b, 0x79, 0x01, 0x66, 0xe8, 0xd5, 0x51, 0xe7 ], [ 0x6f, 0x62, 0x38, 0xd8, 0x96, 0x60, 0x48, 0xd4, 0x96, 0x71, 0x54, 0xe0, 0xda, 0xd5, 0xa6, 0xc9 ], [ 0xf2, 0xb2, 0x1b, 0x4e, 0x76, 0x40, 0xa9, 0xb3, 0x34, 0x6d, 0xe8, 0xb8, 0x2f, 0xb4, 0x1e, 0x49 ], [ 0xf8, 0x36, 0xf2, 0x51, 0xad, 0x1d, 0x11, 0xd4, 0x9d, 0xc3, 0x44, 0x62, 0x8b, 0x18, 0x84, 0xe1 ], [ 0x07, 0x7e, 0x94, 0x70, 0xae, 0x7a, 0xbe, 0xa5, 0xa9, 0x76, 0x9d, 0x49, 0x18, 0x26, 0x28, 0xc3 ], [ 0xe0, 0xdc, 0xc2, 0xd2, 0x7f, 0xc9, 0x86, 0x56, 0x33, 0xf8, 0x52, 0x23, 0xcf, 0x0d, 0x61, 0x1f ], [ 0xbe, 0x66, 0xcf, 0xea, 0x2f, 0xec, 0xd6, 0xbf, 0x0e, 0xc7, 0xb4, 0x35, 0x2c, 0x99, 0xbc, 0xaa ], [ 0xdf, 0x31, 0x14, 0x4f, 0x87, 0xa2, 0xef, 0x52, 0x3f, 0xac, 0xdc, 0xf2, 0x1a, 0x42, 0x78, 0x04 ], [ 0xb5, 0xbb, 0x0f, 0x56, 0x29, 0xfb, 0x6a, 0xae, 0x5e, 0x18, 0x39, 0xa3, 0xc3, 0x62, 0x5d, 0x63 ], [ 0x3c, 0x9d, 0xb3, 0x33, 0x53, 0x06, 0xfe, 0x1e, 0xc6, 0x12, 0xbd, 0xbf, 0xae, 0x6b, 0x60, 0x28 ], [ 0x3d, 0xd5, 0xc3, 0x46, 0x34, 0xa7, 0x9d, 0x3c, 0xfc, 0xc8, 0x33, 0x97, 0x60, 0xe6, 0xf5, 0xf4 ], [ 0x82, 0xbd, 0xa1, 0x18, 0xa3, 0xed, 0x7a, 0xf3, 0x14, 0xfa, 0x2c, 0xcc, 0x5c, 0x07, 0xb7, 0x61 ], [ 0x29, 0x37, 0xa6, 0x4f, 0x7d, 0x4f, 0x46, 0xfe, 0x6f, 0xea, 0x3b, 0x34, 0x9e, 0xc7, 0x8e, 0x38 ], [ 0x22, 0x5f, 0x06, 0x8c, 0x28, 0x47, 0x66, 0x05, 0x73, 0x5a, 0xd6, 0x71, 0xbb, 0x8f, 0x39, 0xf3 ], [ 0xae, 0x68, 0x2c, 0x5e, 0xcd, 0x71, 0x89, 0x8e, 0x08, 0x94, 0x2a, 0xc9, 0xaa, 0x89, 0x87, 0x5c ], [ 0x5e, 0x03, 0x1c, 0xb9, 0xd6, 0x76, 0xc3, 0x02, 0x2d, 0x7f, 0x26, 0x22, 0x7e, 0x85, 0xc3, 0x8f ], [ 0xa7, 0x84, 0x63, 0xfb, 0x06, 0x4d, 0xb5, 0xd5, 0x2b, 0xb6, 0x4b, 0xfe, 0xf6, 0x4f, 0x2d, 0xda ], [ 0x8a, 0xa9, 0xb7, 0x5e, 0x78, 0x45, 0x93, 0x87, 0x6c, 0x53, 0xa0, 0x0e, 0xae, 0x5a, 0xf5, 0x2b ], [ 0x3f, 0x84, 0x56, 0x6d, 0xf2, 0x3d, 0xa4, 0x8a, 0xf6, 0x92, 0x72, 0x2f, 0xe9, 0x80, 0x57, 0x3a ], [ 0x31, 0x69, 0x0b, 0x5e, 0xd4, 0x1c, 0x7e, 0xb4, 0x2a, 0x1e, 0x83, 0x27, 0x0a, 0x7f, 0xf0, 0xe6 ], [ 0x77, 0xdd, 0x77, 0x02, 0x64, 0x6d, 0x55, 0xf0, 0x83, 0x65, 0xe4, 0x77, 0xd3, 0x59, 0x0e, 0xda ], [ 0x4c, 0x02, 0x2a, 0xc6, 0x2b, 0x3c, 0xb7, 0x8d, 0x73, 0x9c, 0xc6, 0x7b, 0x3e, 0x20, 0xbb, 0x7e ], [ 0x09, 0x2f, 0xa1, 0x37, 0xce, 0x18, 0xb5, 0xdf, 0xe7, 0x90, 0x6f, 0x55, 0x0b, 0xb1, 0x33, 0x70 ], [ 0x3e, 0x0c, 0xda, 0xdf, 0x2e, 0x68, 0x35, 0x3c, 0x00, 0x27, 0x67, 0x2c, 0x97, 0x14, 0x4d, 0xd3 ], [ 0xd8, 0xc4, 0xb2, 0x00, 0xb3, 0x83, 0xfc, 0x1f, 0x2b, 0x2e, 0xa6, 0x77, 0x61, 0x8a, 0x1d, 0x27 ], [ 0x11, 0x82, 0x5f, 0x99, 0xb0, 0xe9, 0xbb, 0x34, 0x77, 0xc1, 0xc0, 0x71, 0x3b, 0x01, 0x5a, 0xac ], [ 0xf8, 0xb9, 0xff, 0xfb, 0x5c, 0x18, 0x7f, 0x7d, 0xdc, 0x7a, 0xb1, 0x0f, 0x4f, 0xb7, 0x75, 0x76 ], [ 0xff, 0xb4, 0xe8, 0x7a, 0x32, 0xb3, 0x7d, 0x6f, 0x2c, 0x83, 0x28, 0xd3, 0xb5, 0x37, 0x78, 0x02 ], [ 0xd2, 0x76, 0xc1, 0x3a, 0x5d, 0x22, 0x0f, 0x4d, 0xa9, 0x22, 0x4e, 0x74, 0x89, 0x63, 0x91, 0xce ], [ 0x94, 0xef, 0xe7, 0xa0, 0xe2, 0xe0, 0x31, 0xe2, 0x53, 0x6d, 0xa0, 0x1d, 0xf7, 0x99, 0xc9, 0x27 ], [ 0x8f, 0x8f, 0xd8, 0x22, 0x68, 0x0a, 0x85, 0x97, 0x4e, 0x53, 0xa5, 0xa8, 0xeb, 0x9d, 0x38, 0xde ], [ 0xe0, 0xf0, 0xa9, 0x1b, 0x2e, 0x45, 0xf8, 0xcc, 0x37, 0xb7, 0x80, 0x5a, 0x30, 0x42, 0x58, 0x8d ], [ 0x59, 0x7a, 0x62, 0x52, 0x25, 0x5e, 0x46, 0xd6, 0x36, 0x4d, 0xbe, 0xed, 0xa3, 0x1e, 0x27, 0x9c ], [ 0xf5, 0x1a, 0x0f, 0x69, 0x44, 0x42, 0xb8, 0xf0, 0x55, 0x71, 0x79, 0x7f, 0xec, 0x7e, 0xe8, 0xbf ], [ 0x9f, 0xf0, 0x71, 0xb1, 0x65, 0xb5, 0x19, 0x8a, 0x93, 0xdd, 0xde, 0xeb, 0xc5, 0x4d, 0x09, 0xb5 ], [ 0xc2, 0x0a, 0x19, 0xfd, 0x57, 0x58, 0xb0, 0xc4, 0xbc, 0x1a, 0x5d, 0xf8, 0x9c, 0xf7, 0x38, 0x77 ], [ 0x97, 0x12, 0x01, 0x66, 0x30, 0x71, 0x19, 0xca, 0x22, 0x80, 0xe9, 0x31, 0x56, 0x68, 0xe9, 0x6f ], [ 0x4b, 0x3b, 0x9f, 0x1e, 0x09, 0x9c, 0x2a, 0x09, 0xdc, 0x09, 0x1e, 0x90, 0xe4, 0xf1, 0x8f, 0x0a ], [ 0xeb, 0x04, 0x0b, 0x89, 0x1d, 0x4b, 0x37, 0xf6, 0x85, 0x1f, 0x7e, 0xc2, 0x19, 0xcd, 0x3f, 0x6d ], [ 0x9f, 0x0f, 0xde, 0xc0, 0x8b, 0x7f, 0xd7, 0x9a, 0xa3, 0x95, 0x35, 0xbe, 0xa4, 0x2d, 0xb9, 0x2a ], [ 0x2e, 0x70, 0xf1, 0x68, 0xfc, 0x74, 0xbf, 0x91, 0x1d, 0xf2, 0x40, 0xbc, 0xd2, 0xce, 0xf2, 0x36 ], [ 0x46, 0x2c, 0xcd, 0x7f, 0x5f, 0xd1, 0x10, 0x8d, 0xbc, 0x15, 0x2f, 0x3c, 0xac, 0xad, 0x32, 0x8b ], [ 0xa4, 0xaf, 0x53, 0x4a, 0x7d, 0x0b, 0x64, 0x3a, 0x01, 0x86, 0x87, 0x85, 0xd8, 0x6d, 0xfb, 0x95 ], [ 0xab, 0x98, 0x02, 0x96, 0x19, 0x7e, 0x1a, 0x50, 0x22, 0x32, 0x6c, 0x31, 0xda, 0x4b, 0xf6, 0xf3 ], [ 0xf9, 0x7d, 0x57, 0xb3, 0x33, 0x3b, 0x62, 0x81, 0xb0, 0x7d, 0x48, 0x6d, 0xb2, 0xd4, 0xe2, 0x0c ], [ 0xf3, 0x3f, 0xa3, 0x67, 0x20, 0x23, 0x1a, 0xfe, 0x4c, 0x75, 0x9a, 0xde, 0x6b, 0xd6, 0x2e, 0xb6 ], [ 0xfd, 0xcf, 0xac, 0x0c, 0x02, 0xca, 0x53, 0x83, 0x43, 0xc6, 0x81, 0x17, 0xe0, 0xa1, 0x59, 0x38 ], [ 0xad, 0x49, 0x16, 0xf5, 0xee, 0x57, 0x72, 0xbe, 0x76, 0x4f, 0xc0, 0x27, 0xb8, 0xa6, 0xe5, 0x39 ], [ 0x2e, 0x16, 0x87, 0x3e, 0x16, 0x78, 0x61, 0x0d, 0x7e, 0x14, 0xc0, 0x2d, 0x00, 0x2e, 0xa8, 0x45 ], [ 0x4e, 0x6e, 0x62, 0x7c, 0x1a, 0xcc, 0x51, 0x34, 0x00, 0x53, 0xa8, 0x23, 0x6d, 0x57, 0x95, 0x76 ], [ 0xab, 0x0c, 0x84, 0x10, 0xae, 0xee, 0xad, 0x92, 0xfe, 0xec, 0x1e, 0xb4, 0x30, 0xd6, 0x52, 0xcb ], [ 0xe8, 0x6f, 0x7e, 0x23, 0xe8, 0x35, 0xe1, 0x14, 0x97, 0x7f, 0x60, 0xe1, 0xa5, 0x92, 0x20, 0x2e ], [ 0xe6, 0x8a, 0xd5, 0x05, 0x5a, 0x36, 0x70, 0x41, 0xfa, 0xde, 0x09, 0xd9, 0xa7, 0x0a, 0x79, 0x4b ], [ 0x07, 0x91, 0x82, 0x3a, 0x3c, 0x66, 0x6b, 0xb6, 0x16, 0x28, 0x25, 0xe7, 0x86, 0x06, 0xa7, 0xfe ], [ 0xdc, 0xca, 0x36, 0x6a, 0x9b, 0xf4, 0x7b, 0x7b, 0x86, 0x8b, 0x77, 0xe2, 0x5c, 0x18, 0xa3, 0x64 ], [ 0x68, 0x4c, 0x9e, 0xfc, 0x23, 0x7e, 0x4a, 0x44, 0x29, 0x65, 0xf8, 0x4b, 0xce, 0x20, 0x24, 0x7a ], [ 0xa8, 0x58, 0x41, 0x1f, 0xfb, 0xe6, 0x3f, 0xdb, 0x9c, 0x8a, 0xa1, 0xbf, 0xae, 0xd6, 0x7b, 0x52 ], [ 0x04, 0xbc, 0x3d, 0xa2, 0x17, 0x9c, 0x30, 0x15, 0x49, 0x8b, 0x0e, 0x03, 0x91, 0x0d, 0xb5, 0xb8 ], [ 0x40, 0x07, 0x1e, 0xea, 0xb3, 0xf9, 0x35, 0xdb, 0xc2, 0x5d, 0x00, 0x84, 0x14, 0x60, 0x26, 0x0f ], [ 0x0e, 0xbd, 0x7c, 0x30, 0xed, 0x20, 0x16, 0xe0, 0x8b, 0xa8, 0x06, 0xdd, 0xb0, 0x08, 0xbc, 0xc8 ], [ 0x15, 0xc6, 0xbe, 0xcf, 0x0f, 0x4c, 0xec, 0x71, 0x29, 0xcb, 0xd2, 0x2d, 0x1a, 0x79, 0xb1, 0xb8 ], [ 0x0a, 0xee, 0xde, 0x5b, 0x91, 0xf7, 0x21, 0x70, 0x0e, 0x9e, 0x62, 0xed, 0xbf, 0x60, 0xb7, 0x81 ], [ 0x26, 0x65, 0x81, 0xaf, 0x0d, 0xcf, 0xbe, 0xd1, 0x58, 0x5e, 0x0a, 0x24, 0x2c, 0x64, 0xb8, 0xdf ], [ 0x66, 0x93, 0xdc, 0x91, 0x16, 0x62, 0xae, 0x47, 0x32, 0x16, 0xba, 0x22, 0x18, 0x9a, 0x51, 0x1a ], [ 0x76, 0x06, 0xfa, 0x36, 0xd8, 0x64, 0x73, 0xe6, 0xfb, 0x3a, 0x1b, 0xb0, 0xe2, 0xc0, 0xad, 0xf5 ], [ 0x11, 0x20, 0x78, 0xe9, 0xe1, 0x1f, 0xbb, 0x78, 0xe2, 0x6f, 0xfb, 0x88, 0x99, 0xe9, 0x6b, 0x9a ], [ 0x40, 0xb2, 0x64, 0xe9, 0x21, 0xe9, 0xe4, 0xa8, 0x26, 0x94, 0x58, 0x9e, 0xf3, 0x79, 0x82, 0x62 ], [ 0x8d, 0x45, 0x95, 0xcb, 0x4f, 0xa7, 0x02, 0x67, 0x15, 0xf5, 0x5b, 0xd6, 0x8e, 0x28, 0x82, 0xf9 ], [ 0xb5, 0x88, 0xa3, 0x02, 0xbd, 0xbc, 0x09, 0x19, 0x7d, 0xf1, 0xed, 0xae, 0x68, 0x92, 0x6e, 0xd9 ], [ 0x33, 0xf7, 0x50, 0x23, 0x90, 0xb8, 0xa4, 0xa2, 0x21, 0xcf, 0xec, 0xd0, 0x66, 0x66, 0x24, 0xba ], [ 0x3d, 0x20, 0x25, 0x3a, 0xdb, 0xce, 0x3b, 0xe2, 0x37, 0x37, 0x67, 0xc4, 0xd8, 0x22, 0xc5, 0x66 ], [ 0xa4, 0x27, 0x34, 0xa3, 0x92, 0x9b, 0xf8, 0x4c, 0xf0, 0x11, 0x6c, 0x98, 0x56, 0xa3, 0xc1, 0x8c ], [ 0xe3, 0xab, 0xc4, 0x93, 0x94, 0x57, 0x42, 0x2b, 0xb9, 0x57, 0xda, 0x3c, 0x56, 0x93, 0x8c, 0x6d ], [ 0x97, 0x2b, 0xdd, 0x2e, 0x7c, 0x52, 0x51, 0x30, 0xfa, 0xdc, 0x8f, 0x76, 0xfc, 0x6f, 0x4b, 0x3f ], [ 0x84, 0xa8, 0x3d, 0x7b, 0x94, 0xc6, 0x99, 0xcb, 0xcb, 0x8a, 0x7d, 0x9b, 0x61, 0xf6, 0x40, 0x93 ], [ 0xce, 0x61, 0xd6, 0x35, 0x14, 0xad, 0xed, 0x03, 0xd4, 0x3e, 0x6e, 0xbf, 0xc3, 0xa9, 0x00, 0x1f ], [ 0x6c, 0x83, 0x9d, 0xd5, 0x8e, 0xea, 0xe6, 0xb8, 0xa3, 0x6a, 0xf4, 0x8e, 0xd6, 0x3d, 0x2d, 0xc9 ], [ 0xcd, 0x5e, 0xce, 0x55, 0xb8, 0xda, 0x3b, 0xf6, 0x22, 0xc4, 0x10, 0x0d, 0xf5, 0xde, 0x46, 0xf9 ], [ 0x3b, 0x6f, 0x46, 0xf4, 0x0e, 0x0a, 0xc5, 0xfc, 0x0a, 0x9c, 0x11, 0x05, 0xf8, 0x00, 0xf4, 0x8d ], [ 0xba, 0x26, 0xd4, 0x7d, 0xa3, 0xae, 0xb0, 0x28, 0xde, 0x4f, 0xb5, 0xb3, 0xa8, 0x54, 0xa2, 0x4b ], [ 0x87, 0xf5, 0x3b, 0xf6, 0x20, 0xd3, 0x67, 0x72, 0x68, 0x44, 0x52, 0x12, 0x90, 0x43, 0x89, 0xd5 ], [ 0x10, 0x61, 0x7d, 0x28, 0xb5, 0xe0, 0xf4, 0x60, 0x54, 0x92, 0xb1, 0x82, 0xa5, 0xd7, 0xf9, 0xf6 ], [ 0x9a, 0xae, 0xc4, 0xfa, 0xbb, 0xf6, 0xfa, 0xe2, 0xa7, 0x1f, 0xef, 0xf0, 0x2e, 0x37, 0x2b, 0x39 ], [ 0x3a, 0x90, 0xc6, 0x2d, 0x88, 0xb5, 0xc4, 0x28, 0x09, 0xab, 0xf7, 0x82, 0x48, 0x8e, 0xd1, 0x30 ], [ 0xf1, 0xf1, 0xc5, 0xa4, 0x08, 0x99, 0xe1, 0x57, 0x72, 0x85, 0x7c, 0xcb, 0x65, 0xc7, 0xa0, 0x9a ], [ 0x19, 0x08, 0x43, 0xd2, 0x9b, 0x25, 0xa3, 0x89, 0x7c, 0x69, 0x2c, 0xe1, 0xdd, 0x81, 0xee, 0x52 ], [ 0xa8, 0x66, 0xbc, 0x65, 0xb6, 0x94, 0x1d, 0x86, 0xe8, 0x42, 0x0a, 0x7f, 0xfb, 0x09, 0x64, 0xdb ], [ 0x81, 0x93, 0xc6, 0xff, 0x85, 0x22, 0x5c, 0xed, 0x42, 0x55, 0xe9, 0x2f, 0x6e, 0x07, 0x8a, 0x14 ], [ 0x96, 0x61, 0xcb, 0x24, 0x24, 0xd7, 0xd4, 0xa3, 0x80, 0xd5, 0x47, 0xf9, 0xe7, 0xec, 0x1c, 0xb9 ], [ 0x86, 0xf9, 0x3d, 0x9e, 0xc0, 0x84, 0x53, 0xa0, 0x71, 0xe2, 0xe2, 0x87, 0x78, 0x77, 0xa9, 0xc8 ], [ 0x27, 0xee, 0xfa, 0x80, 0xce, 0x6a, 0x4a, 0x9d, 0x59, 0x8e, 0x3f, 0xec, 0x36, 0x54, 0x34, 0xd2 ], [ 0xd6, 0x20, 0x68, 0x44, 0x45, 0x78, 0xe3, 0xab, 0x39, 0xce, 0x7e, 0xc9, 0x5d, 0xd0, 0x45, 0xdc ], [ 0xb5, 0xf7, 0x1d, 0x4d, 0xd9, 0xa7, 0x1f, 0xe5, 0xd8, 0xbc, 0x8b, 0xa7, 0xe6, 0xea, 0x30, 0x48 ], [ 0x68, 0x25, 0xa3, 0x47, 0xac, 0x47, 0x9d, 0x4f, 0x9d, 0x95, 0xc5, 0xcb, 0x8d, 0x3f, 0xd7, 0xe9 ], [ 0xe3, 0x71, 0x4e, 0x94, 0xa5, 0x77, 0x89, 0x55, 0xcc, 0x03, 0x46, 0x35, 0x8e, 0x94, 0x78, 0x3a ], [ 0xd8, 0x36, 0xb4, 0x4b, 0xb2, 0x9e, 0x0c, 0x7d, 0x89, 0xfa, 0x4b, 0x2d, 0x4b, 0x67, 0x7d, 0x2a ], [ 0x5d, 0x45, 0x4b, 0x75, 0x02, 0x1d, 0x76, 0xd4, 0xb8, 0x4f, 0x87, 0x3a, 0x8f, 0x87, 0x7b, 0x92 ], [ 0xc3, 0x49, 0x8f, 0x7e, 0xce, 0xd2, 0x09, 0x53, 0x14, 0xfc, 0x28, 0x11, 0x58, 0x85, 0xb3, 0x3f ], [ 0x6e, 0x66, 0x88, 0x56, 0x53, 0x9a, 0xd8, 0xe4, 0x05, 0xbd, 0x12, 0x3f, 0xe6, 0xc8, 0x85, 0x30 ], [ 0x86, 0x80, 0xdb, 0x7f, 0x3a, 0x87, 0xb8, 0x60, 0x55, 0x43, 0xcf, 0xdb, 0xe6, 0x75, 0x40, 0x76 ], [ 0x6c, 0x5d, 0x03, 0xb1, 0x30, 0x69, 0xc3, 0x65, 0x8b, 0x31, 0x79, 0xbe, 0x91, 0xb0, 0x80, 0x0c ], [ 0xef, 0x1b, 0x38, 0x4a, 0xc4, 0xd9, 0x3e, 0xda, 0x00, 0xc9, 0x2a, 0xdd, 0x09, 0x95, 0xea, 0x5f ], [ 0xbf, 0x81, 0x15, 0x80, 0x54, 0x71, 0x74, 0x1b, 0xd5, 0xad, 0x20, 0xa0, 0x39, 0x44, 0x79, 0x0f ], [ 0xc6, 0x4c, 0x24, 0xb6, 0x89, 0x4b, 0x03, 0x8b, 0x3c, 0x0d, 0x09, 0xb1, 0xdf, 0x06, 0x8b, 0x0b ], [ 0x39, 0x67, 0xa1, 0x0c, 0xff, 0xe2, 0x7d, 0x01, 0x78, 0x54, 0x5f, 0xbf, 0x6a, 0x40, 0x54, 0x4b ], [ 0x7c, 0x85, 0xe9, 0xc9, 0x5d, 0xe1, 0xa9, 0xec, 0x5a, 0x53, 0x63, 0xa8, 0xa0, 0x53, 0x47, 0x2d ], [ 0xa9, 0xee, 0xc0, 0x3c, 0x8a, 0xbe, 0xc7, 0xba, 0x68, 0x31, 0x5c, 0x2c, 0x8c, 0x23, 0x16, 0xe0 ], [ 0xca, 0xc8, 0xe4, 0x14, 0xc2, 0xf3, 0x88, 0x22, 0x7a, 0xe1, 0x49, 0x86, 0xfc, 0x98, 0x35, 0x24 ], [ 0x5d, 0x94, 0x2b, 0x7f, 0x46, 0x22, 0xce, 0x05, 0x6c, 0x3c, 0xe3, 0xce, 0x5f, 0x1d, 0xd9, 0xd6 ], [ 0xd2, 0x40, 0xd6, 0x48, 0xce, 0x21, 0xa3, 0x02, 0x02, 0x82, 0xc3, 0xf1, 0xb5, 0x28, 0xa0, 0xb6 ], [ 0x45, 0xd0, 0x89, 0xc3, 0x6d, 0x5c, 0x5a, 0x4e, 0xfc, 0x68, 0x9e, 0x3b, 0x0d, 0xe1, 0x0d, 0xd5 ], [ 0xb4, 0xda, 0x5d, 0xf4, 0xbe, 0xcb, 0x54, 0x62, 0xe0, 0x3a, 0x0e, 0xd0, 0x0d, 0x29, 0x56, 0x29 ], [ 0xdc, 0xf4, 0xe1, 0x29, 0x13, 0x6c, 0x1a, 0x4b, 0x7a, 0x0f, 0x38, 0x93, 0x5c, 0xc3, 0x4b, 0x2b ], [ 0xd9, 0xa4, 0xc7, 0x61, 0x8b, 0x0c, 0xe4, 0x8a, 0x3d, 0x5a, 0xee, 0x1a, 0x1c, 0x01, 0x14, 0xc4 ], [ 0xca, 0x35, 0x2d, 0xf0, 0x25, 0xc6, 0x5c, 0x7b, 0x0b, 0xf3, 0x06, 0xfb, 0xee, 0x0f, 0x36, 0xba ], [ 0x23, 0x8a, 0xca, 0x23, 0xfd, 0x34, 0x09, 0xf3, 0x8a, 0xf6, 0x33, 0x78, 0xed, 0x2f, 0x54, 0x73 ], [ 0x59, 0x83, 0x6a, 0x0e, 0x06, 0xa7, 0x96, 0x91, 0xb3, 0x66, 0x67, 0xd5, 0x38, 0x0d, 0x81, 0x88 ], [ 0x33, 0x90, 0x50, 0x80, 0xf7, 0xac, 0xf1, 0xcd, 0xae, 0x0a, 0x91, 0xfc, 0x3e, 0x85, 0xae, 0xe4 ], [ 0x72, 0xc9, 0xe4, 0x64, 0x6d, 0xbc, 0x3d, 0x63, 0x20, 0xfc, 0x66, 0x89, 0xd9, 0x3e, 0x88, 0x33 ], [ 0xba, 0x77, 0x41, 0x3d, 0xea, 0x59, 0x25, 0xb7, 0xf5, 0x41, 0x7e, 0xa4, 0x7f, 0xf1, 0x9f, 0x59 ], [ 0x6c, 0xae, 0x81, 0x29, 0xf8, 0x43, 0xd8, 0x6d, 0xc7, 0x86, 0xa0, 0xfb, 0x1a, 0x18, 0x49, 0x70 ], [ 0xfc, 0xfe, 0xfb, 0x53, 0x41, 0x00, 0x79, 0x6e, 0xeb, 0xbd, 0x99, 0x02, 0x06, 0x75, 0x4e, 0x19 ], [ 0x8c, 0x79, 0x1d, 0x5f, 0xdd, 0xdf, 0x47, 0x0d, 0xa0, 0x4f, 0x3e, 0x6d, 0xc4, 0xa5, 0xb5, 0xb5 ], [ 0xc9, 0x3b, 0xbd, 0xc0, 0x7a, 0x46, 0x11, 0xae, 0x4b, 0xb2, 0x66, 0xea, 0x50, 0x34, 0xa3, 0x87 ], [ 0xc1, 0x02, 0xe3, 0x8e, 0x48, 0x9a, 0xa7, 0x47, 0x62, 0xf3, 0xef, 0xc5, 0xbb, 0x23, 0x20, 0x5a ], [ 0x93, 0x20, 0x14, 0x81, 0x66, 0x5c, 0xba, 0xfc, 0x1f, 0xcc, 0x22, 0x0b, 0xc5, 0x45, 0xfb, 0x3d ], [ 0x49, 0x60, 0x75, 0x7e, 0xc6, 0xce, 0x68, 0xcf, 0x19, 0x5e, 0x45, 0x4c, 0xfd, 0x0f, 0x32, 0xca ], [ 0xfe, 0xec, 0x7c, 0xe6, 0xa6, 0xcb, 0xd0, 0x7c, 0x04, 0x34, 0x16, 0x73, 0x7f, 0x1b, 0xbb, 0x33 ], [ 0x11, 0xc5, 0x41, 0x39, 0x04, 0x48, 0x7a, 0x80, 0x5d, 0x70, 0xa8, 0xed, 0xd9, 0xc3, 0x55, 0x27 ], [ 0x34, 0x78, 0x46, 0xb2, 0xb2, 0xe3, 0x6f, 0x1f, 0x03, 0x24, 0xc8, 0x6f, 0x7f, 0x1b, 0x98, 0xe2 ], [ 0x33, 0x2e, 0xee, 0x1a, 0x0c, 0xbd, 0x19, 0xca, 0x2d, 0x69, 0xb4, 0x26, 0x89, 0x40, 0x44, 0xf0 ], [ 0x86, 0x6b, 0x5b, 0x39, 0x77, 0xba, 0x6e, 0xfa, 0x51, 0x28, 0xef, 0xbd, 0xa9, 0xff, 0x03, 0xcd ], [ 0xcc, 0x14, 0x45, 0xee, 0x94, 0xc0, 0xf0, 0x8c, 0xde, 0xe5, 0xc3, 0x44, 0xec, 0xd1, 0xe2, 0x33 ], [ 0xbe, 0x28, 0x83, 0x19, 0x02, 0x93, 0x63, 0xc2, 0x62, 0x2f, 0xeb, 0xa4, 0xb0, 0x5d, 0xfd, 0xfe ], [ 0xcf, 0xd1, 0x87, 0x55, 0x23, 0xf3, 0xcd, 0x21, 0xc3, 0x95, 0x65, 0x1e, 0x6e, 0xe1, 0x5e, 0x56 ], [ 0xcb, 0x5a, 0x40, 0x86, 0x57, 0x83, 0x7c, 0x53, 0xbf, 0x16, 0xf9, 0xd8, 0x46, 0x5d, 0xce, 0x19 ], [ 0xca, 0x0b, 0xf4, 0x2c, 0xb1, 0x07, 0xf5, 0x5c, 0xcf, 0xf2, 0xfc, 0x09, 0xee, 0x08, 0xca, 0x15 ], [ 0xfd, 0xd9, 0xbb, 0xb4, 0xa7, 0xdc, 0x2e, 0x4a, 0x23, 0x53, 0x6a, 0x58, 0x80, 0xa2, 0xdb, 0x67 ], [ 0xed, 0xe4, 0x47, 0xb3, 0x62, 0xc4, 0x84, 0x99, 0x3d, 0xec, 0x94, 0x42, 0xa3, 0xb4, 0x6a, 0xef ], [ 0x10, 0xdf, 0xfb, 0x05, 0x90, 0x4b, 0xff, 0x7c, 0x47, 0x81, 0xdf, 0x78, 0x0a, 0xd2, 0x68, 0x37 ], [ 0xc3, 0x3b, 0xc1, 0x3e, 0x8d, 0xe8, 0x8a, 0xc2, 0x52, 0x32, 0xaa, 0x74, 0x96, 0x39, 0x87, 0x83 ], [ 0xca, 0x35, 0x9c, 0x70, 0x80, 0x3a, 0x3b, 0x2a, 0x3d, 0x54, 0x2e, 0x87, 0x81, 0xde, 0xa9, 0x75 ], [ 0xbc, 0xc6, 0x5b, 0x52, 0x6f, 0x88, 0xd0, 0x5b, 0x89, 0xce, 0x8a, 0x52, 0x02, 0x1f, 0xdb, 0x06 ], [ 0xdb, 0x91, 0xa3, 0x88, 0x55, 0xc8, 0xc4, 0x64, 0x38, 0x51, 0xfb, 0xfb, 0x35, 0x8b, 0x01, 0x09 ], [ 0xca, 0x6e, 0x88, 0x93, 0xa1, 0x14, 0xae, 0x8e, 0x27, 0xd5, 0xab, 0x03, 0xa5, 0x49, 0x96, 0x10 ], [ 0x66, 0x29, 0xd2, 0xb8, 0xdf, 0x97, 0xda, 0x72, 0x8c, 0xdd, 0x8b, 0x1e, 0x7f, 0x94, 0x50, 0x77 ], [ 0x45, 0x70, 0xa5, 0xa1, 0x8c, 0xfc, 0x0d, 0xd5, 0x82, 0xf1, 0xd8, 0x8d, 0x5c, 0x9a, 0x17, 0x20 ], [ 0x72, 0xbc, 0x65, 0xaa, 0x8e, 0x89, 0x56, 0x2e, 0x3f, 0x27, 0x4d, 0x45, 0xaf, 0x1c, 0xd1, 0x0b ], [ 0x98, 0x55, 0x1d, 0xa1, 0xa6, 0x50, 0x32, 0x76, 0xae, 0x1c, 0x77, 0x62, 0x5f, 0x9e, 0xa6, 0x15 ], [ 0x0d, 0xdf, 0xe5, 0x1c, 0xed, 0x7e, 0x3f, 0x4a, 0xe9, 0x27, 0xda, 0xa3, 0xfe, 0x45, 0x2c, 0xee ], [ 0xdb, 0x82, 0x62, 0x51, 0xe4, 0xce, 0x38, 0x4b, 0x80, 0x21, 0x8b, 0x0e, 0x1d, 0xa1, 0xdd, 0x4c ], [ 0x2c, 0xac, 0xf7, 0x28, 0xb8, 0x8a, 0xbb, 0xad, 0x70, 0x11, 0xed, 0x0e, 0x64, 0xa1, 0x68, 0x0c ], [ 0x33, 0x0d, 0x8e, 0xe7, 0xc5, 0x67, 0x7e, 0x09, 0x9a, 0xc7, 0x4c, 0x99, 0x94, 0xee, 0x4c, 0xfb ], [ 0xed, 0xf6, 0x1a, 0xe3, 0x62, 0xe8, 0x82, 0xdd, 0xc0, 0x16, 0x74, 0x74, 0xa7, 0xa7, 0x7f, 0x3a ], [ 0x61, 0x68, 0xb0, 0x0b, 0xa7, 0x85, 0x9e, 0x09, 0x70, 0xec, 0xfd, 0x75, 0x7e, 0xfe, 0xcf, 0x7c ], [ 0xd1, 0x41, 0x54, 0x47, 0x86, 0x62, 0x30, 0xd2, 0x8b, 0xb1, 0xea, 0x18, 0xa4, 0xcd, 0xfd, 0x02 ], [ 0x51, 0x61, 0x83, 0x39, 0x2f, 0x7a, 0x87, 0x63, 0xaf, 0xec, 0x68, 0xa0, 0x60, 0x26, 0x41, 0x41 ], [ 0x77, 0x56, 0x5c, 0x8d, 0x73, 0xcf, 0xd4, 0x13, 0x0b, 0x4a, 0xa1, 0x4d, 0x89, 0x11, 0x71, 0x0f ], [ 0x37, 0x23, 0x2a, 0x4e, 0xd2, 0x1c, 0xcc, 0x27, 0xc1, 0x9c, 0x96, 0x10, 0x07, 0x8c, 0xab, 0xac ], [ 0x80, 0x4f, 0x32, 0xea, 0x71, 0x82, 0x8c, 0x7d, 0x32, 0x90, 0x77, 0xe7, 0x12, 0x23, 0x16, 0x66 ], [ 0xd6, 0x44, 0x24, 0xf2, 0x3c, 0xb9, 0x72, 0x15, 0xe9, 0xc2, 0xc6, 0xf2, 0x8d, 0x29, 0xea, 0xb7 ], [ 0x02, 0x3e, 0x82, 0xb5, 0x33, 0xf6, 0x8c, 0x75, 0xc2, 0x38, 0xce, 0xbd, 0xb2, 0xee, 0x89, 0xa2 ], [ 0x19, 0x3a, 0x3d, 0x24, 0x15, 0x7a, 0x51, 0xf1, 0xee, 0x08, 0x93, 0xf6, 0x77, 0x74, 0x17, 0xe7 ], [ 0x84, 0xec, 0xac, 0xfc, 0xd4, 0x00, 0x08, 0x4d, 0x07, 0x86, 0x12, 0xb1, 0x94, 0x5f, 0x2e, 0xf5 ], [ 0x1d, 0xcd, 0x8b, 0xb1, 0x73, 0x25, 0x9e, 0xb3, 0x3a, 0x52, 0x42, 0xb0, 0xde, 0x31, 0xa4, 0x55 ], [ 0x35, 0xe9, 0xed, 0xdb, 0xc3, 0x75, 0xe7, 0x92, 0xc1, 0x99, 0x92, 0xc1, 0x91, 0x65, 0x01, 0x2b ], [ 0x8a, 0x77, 0x22, 0x31, 0xc0, 0x1d, 0xfd, 0xd7, 0xc9, 0x8e, 0x4c, 0xfd, 0xdc, 0xc0, 0x80, 0x7a ], [ 0x6e, 0xda, 0x7f, 0xf6, 0xb8, 0x31, 0x91, 0x80, 0xff, 0x0d, 0x6e, 0x65, 0x62, 0x9d, 0x01, 0xc3 ], [ 0xc2, 0x67, 0xef, 0x0e, 0x2d, 0x01, 0xa9, 0x93, 0x94, 0x4d, 0xd3, 0x97, 0x10, 0x14, 0x13, 0xcb ], [ 0xe9, 0xf8, 0x0e, 0x9d, 0x84, 0x5b, 0xcc, 0x0f, 0x62, 0x92, 0x6a, 0xf7, 0x2e, 0xab, 0xca, 0x39 ], [ 0x67, 0x02, 0x99, 0x07, 0x27, 0xaa, 0x08, 0x78, 0x63, 0x7b, 0x45, 0xdc, 0xd3, 0xa3, 0xb0, 0x74 ], [ 0x2e, 0x2e, 0x64, 0x7d, 0x53, 0x60, 0xe0, 0x92, 0x30, 0xa5, 0xd7, 0x38, 0xca, 0x33, 0x47, 0x1e ], [ 0x1f, 0x56, 0x41, 0x3c, 0x7a, 0xdd, 0x6f, 0x43, 0xd1, 0xd5, 0x6e, 0x4f, 0x02, 0x19, 0x03, 0x30 ], [ 0x69, 0xcd, 0x06, 0x06, 0xe1, 0x5a, 0xf7, 0x29, 0xd6, 0xbc, 0xa1, 0x43, 0x01, 0x6d, 0x98, 0x42 ], [ 0xa0, 0x85, 0xd7, 0xc1, 0xa5, 0x00, 0x87, 0x3a, 0x20, 0x09, 0x9c, 0x4c, 0xaa, 0x3c, 0x3f, 0x5b ], [ 0x4f, 0xc0, 0xd2, 0x30, 0xf8, 0x89, 0x14, 0x15, 0xb8, 0x7b, 0x83, 0xf9, 0x5f, 0x2e, 0x09, 0xd1 ], [ 0x43, 0x27, 0xd0, 0x8c, 0x52, 0x3d, 0x8e, 0xba, 0x69, 0x7a, 0x43, 0x36, 0x50, 0x7d, 0x1f, 0x42 ], [ 0x7a, 0x15, 0xaa, 0xb8, 0x27, 0x01, 0xef, 0xa5, 0xae, 0x36, 0xab, 0x1d, 0x6b, 0x76, 0x29, 0x0f ], [ 0x5b, 0xf0, 0x05, 0x18, 0x93, 0xa1, 0x8b, 0xb3, 0x0e, 0x13, 0x9a, 0x58, 0xfe, 0xd0, 0xfa, 0x54 ], [ 0x97, 0xe8, 0xad, 0xf6, 0x56, 0x38, 0xfd, 0x9c, 0xdf, 0x3b, 0xc2, 0x2c, 0x17, 0xfe, 0x4d, 0xbd ], [ 0x1e, 0xe6, 0xee, 0x32, 0x65, 0x83, 0xa0, 0x58, 0x64, 0x91, 0xc9, 0x64, 0x18, 0xd1, 0xa3, 0x5d ], [ 0x26, 0xb5, 0x49, 0xc2, 0xec, 0x75, 0x6f, 0x82, 0xec, 0xc4, 0x80, 0x08, 0xe5, 0x29, 0x95, 0x6b ], [ 0x70, 0x37, 0x7b, 0x6d, 0xa6, 0x69, 0xb0, 0x72, 0x12, 0x9e, 0x05, 0x7c, 0xc2, 0x8e, 0x9c, 0xa5 ], [ 0x9c, 0x94, 0xb8, 0xb0, 0xcb, 0x8b, 0xcc, 0x91, 0x90, 0x72, 0x26, 0x2b, 0x3f, 0xa0, 0x5a, 0xd9 ], [ 0x2f, 0xbb, 0x83, 0xdf, 0xd0, 0xd7, 0xab, 0xcb, 0x05, 0xcd, 0x28, 0xca, 0xd2, 0xdf, 0xb5, 0x23 ], [ 0x96, 0x87, 0x78, 0x03, 0xde, 0x77, 0x74, 0x4b, 0xb9, 0x70, 0xd0, 0xa9, 0x1f, 0x4d, 0xeb, 0xae ], [ 0x73, 0x79, 0xf3, 0x37, 0x0c, 0xf6, 0xe5, 0xce, 0x12, 0xae, 0x59, 0x69, 0xc8, 0xee, 0xa3, 0x12 ], [ 0x02, 0xdc, 0x99, 0xfa, 0x3d, 0x4f, 0x98, 0xce, 0x80, 0x98, 0x5e, 0x72, 0x33, 0x88, 0x93, 0x13 ], [ 0x1e, 0x38, 0xe7, 0x59, 0x07, 0x5b, 0xa5, 0xca, 0xb6, 0x45, 0x7d, 0xa5, 0x18, 0x44, 0x29, 0x5a ], [ 0x70, 0xbe, 0xd8, 0xdb, 0xf6, 0x15, 0x86, 0x8a, 0x1f, 0x9d, 0x9b, 0x05, 0xd3, 0xe7, 0xa2, 0x67 ], [ 0x23, 0x4b, 0x14, 0x8b, 0x8c, 0xb1, 0xd8, 0xc3, 0x2b, 0x28, 0x7e, 0x89, 0x69, 0x03, 0xd1, 0x50 ], [ 0x29, 0x4b, 0x03, 0x3d, 0xf4, 0xda, 0x85, 0x3f, 0x4b, 0xe3, 0xe2, 0x43, 0xf7, 0xe5, 0x13, 0xf4 ], [ 0x3f, 0x58, 0xc9, 0x50, 0xf0, 0x36, 0x71, 0x60, 0xad, 0xec, 0x45, 0xf2, 0x44, 0x1e, 0x74, 0x11 ], [ 0x37, 0xf6, 0x55, 0x53, 0x6a, 0x70, 0x4e, 0x5a, 0xce, 0x18, 0x2d, 0x74, 0x2a, 0x82, 0x0c, 0xf4 ], [ 0xea, 0x7b, 0xd6, 0xbb, 0x63, 0x41, 0x87, 0x31, 0xae, 0xac, 0x79, 0x0f, 0xe4, 0x2d, 0x61, 0xe8 ], [ 0xe7, 0x4a, 0x4c, 0x99, 0x9b, 0x4c, 0x06, 0x4e, 0x48, 0xbb, 0x1e, 0x41, 0x3f, 0x51, 0xe5, 0xea ], [ 0xba, 0x9e, 0xbe, 0xfd, 0xb4, 0xcc, 0xf3, 0x0f, 0x29, 0x6c, 0xec, 0xb3, 0xbc, 0x19, 0x43, 0xe8 ], [ 0x31, 0x94, 0x36, 0x7a, 0x48, 0x98, 0xc5, 0x02, 0xc1, 0x3b, 0xb7, 0x47, 0x86, 0x40, 0xa7, 0x2d ], [ 0xda, 0x79, 0x77, 0x13, 0x26, 0x3d, 0x6f, 0x33, 0xa5, 0x47, 0x8a, 0x65, 0xef, 0x60, 0xd4, 0x12 ], [ 0xd1, 0xac, 0x39, 0xbb, 0x1e, 0xf8, 0x6b, 0x9c, 0x13, 0x44, 0xf2, 0x14, 0x67, 0x9a, 0xa3, 0x76 ], [ 0x2f, 0xde, 0xa9, 0xe6, 0x50, 0x53, 0x2b, 0xe5, 0xbc, 0x0e, 0x73, 0x25, 0x33, 0x7f, 0xd3, 0x63 ], [ 0xd3, 0xa2, 0x04, 0xdb, 0xd9, 0xc2, 0xaf, 0x15, 0x8b, 0x6c, 0xa6, 0x7a, 0x51, 0x56, 0xce, 0x4a ], [ 0x3a, 0x0a, 0x0e, 0x75, 0xa8, 0xda, 0x36, 0x73, 0x5a, 0xee, 0x66, 0x84, 0xd9, 0x65, 0xa7, 0x78 ], [ 0x52, 0xfc, 0x3e, 0x62, 0x04, 0x92, 0xea, 0x99, 0x64, 0x1e, 0xa1, 0x68, 0xda, 0x5b, 0x6d, 0x52 ], [ 0xd2, 0xe0, 0xc7, 0xf1, 0x5b, 0x47, 0x72, 0x46, 0x7d, 0x2c, 0xfc, 0x87, 0x30, 0x00, 0xb2, 0xca ], [ 0x56, 0x35, 0x31, 0x13, 0x5e, 0x0c, 0x4d, 0x70, 0xa3, 0x8f, 0x8b, 0xdb, 0x19, 0x0b, 0xa0, 0x4e ], [ 0xa8, 0xa3, 0x9a, 0x0f, 0x56, 0x63, 0xf4, 0xc0, 0xfe, 0x5f, 0x2d, 0x3c, 0xaf, 0xff, 0x42, 0x1a ], [ 0xd9, 0x4b, 0x5e, 0x90, 0xdb, 0x35, 0x4c, 0x1e, 0x42, 0xf6, 0x1f, 0xab, 0xe1, 0x67, 0xb2, 0xc0 ], [ 0x50, 0xe6, 0xd3, 0xc9, 0xb6, 0x69, 0x8a, 0x7c, 0xd2, 0x76, 0xf9, 0x6b, 0x14, 0x73, 0xf3, 0x5a ], [ 0x93, 0x38, 0xf0, 0x8e, 0x0e, 0xbe, 0xe9, 0x69, 0x05, 0xd8, 0xf2, 0xe8, 0x25, 0x20, 0x8f, 0x43 ], [ 0x8b, 0x37, 0x8c, 0x86, 0x67, 0x2a, 0xa5, 0x4a, 0x3a, 0x26, 0x6b, 0xa1, 0x9d, 0x25, 0x80, 0xca ], [ 0xcc, 0xa7, 0xc3, 0x08, 0x6f, 0x5f, 0x95, 0x11, 0xb3, 0x12, 0x33, 0xda, 0x7c, 0xab, 0x91, 0x60 ], [ 0x5b, 0x40, 0xff, 0x4e, 0xc9, 0xbe, 0x53, 0x6b, 0xa2, 0x30, 0x35, 0xfa, 0x4f, 0x06, 0x06, 0x4c ], [ 0x60, 0xeb, 0x5a, 0xf8, 0x41, 0x6b, 0x25, 0x71, 0x49, 0x37, 0x21, 0x94, 0xe8, 0xb8, 0x87, 0x49 ], [ 0x2f, 0x00, 0x5a, 0x8a, 0xed, 0x8a, 0x36, 0x1c, 0x92, 0xe4, 0x40, 0xc1, 0x55, 0x20, 0xcb, 0xd1 ], [ 0x7b, 0x03, 0x62, 0x76, 0x11, 0x67, 0x8a, 0x99, 0x77, 0x17, 0x57, 0x88, 0x07, 0xa8, 0x00, 0xe2 ], [ 0xcf, 0x78, 0x61, 0x8f, 0x74, 0xf6, 0xf3, 0x69, 0x6e, 0x0a, 0x47, 0x79, 0xb9, 0x0b, 0x5a, 0x77 ], [ 0x03, 0x72, 0x03, 0x71, 0xa0, 0x49, 0x62, 0xea, 0xea, 0x0a, 0x85, 0x2e, 0x69, 0x97, 0x28, 0x58 ], [ 0x1f, 0x8a, 0x81, 0x33, 0xaa, 0x8c, 0xcf, 0x70, 0xe2, 0xbd, 0x32, 0x85, 0x83, 0x1c, 0xa6, 0xb7 ], [ 0x27, 0x93, 0x6b, 0xd2, 0x7f, 0xb1, 0x46, 0x8f, 0xc8, 0xb4, 0x8b, 0xc4, 0x83, 0x32, 0x17, 0x25 ], [ 0xb0, 0x7d, 0x4f, 0x3e, 0x2c, 0xd2, 0xef, 0x2e, 0xb5, 0x45, 0x98, 0x07, 0x54, 0xdf, 0xea, 0x0f ], [ 0x4b, 0xf8, 0x5f, 0x1b, 0x5d, 0x54, 0xad, 0xbc, 0x30, 0x7b, 0x0a, 0x04, 0x83, 0x89, 0xad, 0xcb ] ]; # Values from NIST KAT-AES ECBVarTxt128.rsp, ECBVarTxt192.rsp and ECBVarTxt256.rsp plain_texts1 = [ [ 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x00 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0x80 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xc0 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xe0 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf0 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xf8 ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfc ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xfe ], [ 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff ] ]; key = [ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ]; plain_text = [ 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00, 0x00 ]; print("Testing AES-ECB 128-bit decryption\t"), result = True for test_index in range(0, 128): test_key = bytes(bytearray(key[:16])) test_cipher_text = bytes(bytearray(cipher_texts1_128bit[test_index])) test_plain_text = bytes(bytearray(plain_texts1[test_index])) result = pycaes_test_crypt_ecb( pycaes.crypt_modes.DECRYPT, test_key, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False print("Testing AES-ECB 128-bit decryption\t"), result = True for test_index in range(0, 128): test_key = bytes(bytearray(keys[test_index][:16])) test_cipher_text = bytes(bytearray(cipher_texts2_128bit[test_index])) test_plain_text = bytes(bytearray(plain_text)) result = pycaes_test_crypt_ecb( pycaes.crypt_modes.DECRYPT, test_key, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False print("Testing AES-ECB 192-bit decryption\t"), result = True for test_index in range(0, 128): test_key = bytes(bytearray(key[:24])) test_cipher_text = bytes(bytearray(cipher_texts1_192bit[test_index])) test_plain_text = bytes(bytearray(plain_texts1[test_index])) result = pycaes_test_crypt_ecb( pycaes.crypt_modes.DECRYPT, test_key, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False print("Testing AES-ECB 192-bit decryption\t"), result = True for test_index in range(0, 128): test_key = bytes(bytearray(keys[test_index][:24])) test_cipher_text = bytes(bytearray(cipher_texts2_192bit[test_index])) test_plain_text = bytes(bytearray(plain_text)) result = pycaes_test_crypt_ecb( pycaes.crypt_modes.DECRYPT, test_key, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False print("Testing AES-ECB 256-bit decryption\t"), result = True for test_index in range(0, 128): test_key = bytes(bytearray(key)) test_cipher_text = bytes(bytearray(cipher_texts1_256bit[test_index])) test_plain_text = bytes(bytearray(plain_texts1[test_index])) result = pycaes_test_crypt_ecb( pycaes.crypt_modes.DECRYPT, test_key, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False print("Testing AES-ECB 256-bit decryption\t"), result = True for test_index in range(0, 128): test_key = bytes(bytearray(keys[test_index])) test_cipher_text = bytes(bytearray(cipher_texts2_256bit[test_index])) test_plain_text = bytes(bytearray(plain_text)) result = pycaes_test_crypt_ecb( pycaes.crypt_modes.DECRYPT, test_key, test_cipher_text, test_plain_text) if not result: break if not result: print("(FAIL)") else: print("(PASS)") if not result: return False # TODO: add encryption tests. return True if __name__ == "__main__": if not main(): sys.exit(1) else: sys.exit(0) libcaes-20240413/tests/Makefile.in0000644000175000017500000012277314606477627017461 0ustar00lordyestalordyesta# Makefile.in generated by automake 1.16.5 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2021 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ check_PROGRAMS = caes_test_context$(EXEEXT) \ caes_test_crypt_cbc$(EXEEXT) caes_test_crypt_ccm$(EXEEXT) \ caes_test_crypt_xts$(EXEEXT) caes_test_error$(EXEEXT) \ caes_test_support$(EXEEXT) caes_test_tweaked_context$(EXEEXT) subdir = tests ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/common.m4 \ $(top_srcdir)/m4/gettext.m4 $(top_srcdir)/m4/host-cpu-c-abi.m4 \ $(top_srcdir)/m4/iconv.m4 $(top_srcdir)/m4/intlmacosx.m4 \ $(top_srcdir)/m4/lib-ld.m4 $(top_srcdir)/m4/lib-link.m4 \ $(top_srcdir)/m4/lib-prefix.m4 $(top_srcdir)/m4/libcerror.m4 \ $(top_srcdir)/m4/libcrypto.m4 $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/nls.m4 $(top_srcdir)/m4/po.m4 \ $(top_srcdir)/m4/progtest.m4 $(top_srcdir)/m4/python.m4 \ $(top_srcdir)/m4/tests.m4 $(top_srcdir)/m4/types.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/common/config.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am_caes_test_context_OBJECTS = caes_test_context.$(OBJEXT) \ caes_test_memory.$(OBJEXT) caes_test_context_OBJECTS = $(am_caes_test_context_OBJECTS) caes_test_context_DEPENDENCIES = ../libcaes/libcaes.la AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = am_caes_test_crypt_cbc_OBJECTS = caes_test_crypt_cbc.$(OBJEXT) caes_test_crypt_cbc_OBJECTS = $(am_caes_test_crypt_cbc_OBJECTS) caes_test_crypt_cbc_DEPENDENCIES = ../libcaes/libcaes.la am_caes_test_crypt_ccm_OBJECTS = caes_test_crypt_ccm.$(OBJEXT) caes_test_crypt_ccm_OBJECTS = $(am_caes_test_crypt_ccm_OBJECTS) caes_test_crypt_ccm_DEPENDENCIES = ../libcaes/libcaes.la am_caes_test_crypt_xts_OBJECTS = caes_test_crypt_xts.$(OBJEXT) caes_test_crypt_xts_OBJECTS = $(am_caes_test_crypt_xts_OBJECTS) caes_test_crypt_xts_DEPENDENCIES = ../libcaes/libcaes.la am_caes_test_error_OBJECTS = caes_test_error.$(OBJEXT) caes_test_error_OBJECTS = $(am_caes_test_error_OBJECTS) caes_test_error_DEPENDENCIES = ../libcaes/libcaes.la am_caes_test_support_OBJECTS = caes_test_support.$(OBJEXT) caes_test_support_OBJECTS = $(am_caes_test_support_OBJECTS) caes_test_support_DEPENDENCIES = ../libcaes/libcaes.la am_caes_test_tweaked_context_OBJECTS = caes_test_memory.$(OBJEXT) \ caes_test_tweaked_context.$(OBJEXT) caes_test_tweaked_context_OBJECTS = \ $(am_caes_test_tweaked_context_OBJECTS) caes_test_tweaked_context_DEPENDENCIES = ../libcaes/libcaes.la AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)/common depcomp = $(SHELL) $(top_srcdir)/depcomp am__maybe_remake_depfiles = depfiles am__depfiles_remade = ./$(DEPDIR)/caes_test_context.Po \ ./$(DEPDIR)/caes_test_crypt_cbc.Po \ ./$(DEPDIR)/caes_test_crypt_ccm.Po \ ./$(DEPDIR)/caes_test_crypt_xts.Po \ ./$(DEPDIR)/caes_test_error.Po ./$(DEPDIR)/caes_test_memory.Po \ ./$(DEPDIR)/caes_test_support.Po \ ./$(DEPDIR)/caes_test_tweaked_context.Po am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(caes_test_context_SOURCES) $(caes_test_crypt_cbc_SOURCES) \ $(caes_test_crypt_ccm_SOURCES) $(caes_test_crypt_xts_SOURCES) \ $(caes_test_error_SOURCES) $(caes_test_support_SOURCES) \ $(caes_test_tweaked_context_SOURCES) DIST_SOURCES = $(caes_test_context_SOURCES) \ $(caes_test_crypt_cbc_SOURCES) $(caes_test_crypt_ccm_SOURCES) \ $(caes_test_crypt_xts_SOURCES) $(caes_test_error_SOURCES) \ $(caes_test_support_SOURCES) \ $(caes_test_tweaked_context_SOURCES) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__extra_recursive_targets = sources-recursive splint-recursive am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` am__tty_colors_dummy = \ mgn= red= grn= lgn= blu= brg= std=; \ am__color_tests=no am__tty_colors = { \ $(am__tty_colors_dummy); \ if test "X$(AM_COLOR_TESTS)" = Xno; then \ am__color_tests=no; \ elif test "X$(AM_COLOR_TESTS)" = Xalways; then \ am__color_tests=yes; \ elif test "X$$TERM" != Xdumb && { test -t 1; } 2>/dev/null; then \ am__color_tests=yes; \ fi; \ if test $$am__color_tests = yes; then \ red=''; \ grn=''; \ lgn=''; \ blu=''; \ mgn=''; \ brg=''; \ std=''; \ fi; \ } am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__recheck_rx = ^[ ]*:recheck:[ ]* am__global_test_result_rx = ^[ ]*:global-test-result:[ ]* am__copy_in_global_log_rx = ^[ ]*:copy-in-global-log:[ ]* # A command that, given a newline-separated list of test names on the # standard input, print the name of the tests that are to be re-run # upon "make recheck". am__list_recheck_tests = $(AWK) '{ \ recheck = 1; \ while ((rc = (getline line < ($$0 ".trs"))) != 0) \ { \ if (rc < 0) \ { \ if ((getline line2 < ($$0 ".log")) < 0) \ recheck = 0; \ break; \ } \ else if (line ~ /$(am__recheck_rx)[nN][Oo]/) \ { \ recheck = 0; \ break; \ } \ else if (line ~ /$(am__recheck_rx)[yY][eE][sS]/) \ { \ break; \ } \ }; \ if (recheck) \ print $$0; \ close ($$0 ".trs"); \ close ($$0 ".log"); \ }' # A command that, given a newline-separated list of test names on the # standard input, create the global log from their .trs and .log files. am__create_global_log = $(AWK) ' \ function fatal(msg) \ { \ print "fatal: making $@: " msg | "cat >&2"; \ exit 1; \ } \ function rst_section(header) \ { \ print header; \ len = length(header); \ for (i = 1; i <= len; i = i + 1) \ printf "="; \ printf "\n\n"; \ } \ { \ copy_in_global_log = 1; \ global_test_result = "RUN"; \ while ((rc = (getline line < ($$0 ".trs"))) != 0) \ { \ if (rc < 0) \ fatal("failed to read from " $$0 ".trs"); \ if (line ~ /$(am__global_test_result_rx)/) \ { \ sub("$(am__global_test_result_rx)", "", line); \ sub("[ ]*$$", "", line); \ global_test_result = line; \ } \ else if (line ~ /$(am__copy_in_global_log_rx)[nN][oO]/) \ copy_in_global_log = 0; \ }; \ if (copy_in_global_log) \ { \ rst_section(global_test_result ": " $$0); \ while ((rc = (getline line < ($$0 ".log"))) != 0) \ { \ if (rc < 0) \ fatal("failed to read from " $$0 ".log"); \ print line; \ }; \ printf "\n"; \ }; \ close ($$0 ".trs"); \ close ($$0 ".log"); \ }' # Restructured Text title. am__rst_title = { sed 's/.*/ & /;h;s/./=/g;p;x;s/ *$$//;p;g' && echo; } # Solaris 10 'make', and several other traditional 'make' implementations, # pass "-e" to $(SHELL), and POSIX 2008 even requires this. Work around it # by disabling -e (using the XSI extension "set +e") if it's set. am__sh_e_setup = case $$- in *e*) set +e;; esac # Default flags passed to test drivers. am__common_driver_flags = \ --color-tests "$$am__color_tests" \ --enable-hard-errors "$$am__enable_hard_errors" \ --expect-failure "$$am__expect_failure" # To be inserted before the command running the test. Creates the # directory for the log if needed. Stores in $dir the directory # containing $f, in $tst the test, in $log the log. Executes the # developer- defined test setup AM_TESTS_ENVIRONMENT (if any), and # passes TESTS_ENVIRONMENT. Set up options for the wrapper that # will run the test scripts (or their associated LOG_COMPILER, if # thy have one). am__check_pre = \ $(am__sh_e_setup); \ $(am__vpath_adj_setup) $(am__vpath_adj) \ $(am__tty_colors); \ srcdir=$(srcdir); export srcdir; \ case "$@" in \ */*) am__odir=`echo "./$@" | sed 's|/[^/]*$$||'`;; \ *) am__odir=.;; \ esac; \ test "x$$am__odir" = x"." || test -d "$$am__odir" \ || $(MKDIR_P) "$$am__odir" || exit $$?; \ if test -f "./$$f"; then dir=./; \ elif test -f "$$f"; then dir=; \ else dir="$(srcdir)/"; fi; \ tst=$$dir$$f; log='$@'; \ if test -n '$(DISABLE_HARD_ERRORS)'; then \ am__enable_hard_errors=no; \ else \ am__enable_hard_errors=yes; \ fi; \ case " $(XFAIL_TESTS) " in \ *[\ \ ]$$f[\ \ ]* | *[\ \ ]$$dir$$f[\ \ ]*) \ am__expect_failure=yes;; \ *) \ am__expect_failure=no;; \ esac; \ $(AM_TESTS_ENVIRONMENT) $(TESTS_ENVIRONMENT) # A shell command to get the names of the tests scripts with any registered # extension removed (i.e., equivalently, the names of the test logs, with # the '.log' extension removed). The result is saved in the shell variable # '$bases'. This honors runtime overriding of TESTS and TEST_LOGS. Sadly, # we cannot use something simpler, involving e.g., "$(TEST_LOGS:.log=)", # since that might cause problem with VPATH rewrites for suffix-less tests. # See also 'test-harness-vpath-rewrite.sh' and 'test-trs-basic.sh'. am__set_TESTS_bases = \ bases='$(TEST_LOGS)'; \ bases=`for i in $$bases; do echo $$i; done | sed 's/\.log$$//'`; \ bases=`echo $$bases` AM_TESTSUITE_SUMMARY_HEADER = ' for $(PACKAGE_STRING)' RECHECK_LOGS = $(TEST_LOGS) AM_RECURSIVE_TARGETS = check recheck TEST_SUITE_LOG = test-suite.log TEST_EXTENSIONS = @EXEEXT@ .test LOG_DRIVER = $(SHELL) $(top_srcdir)/test-driver LOG_COMPILE = $(LOG_COMPILER) $(AM_LOG_FLAGS) $(LOG_FLAGS) am__set_b = \ case '$@' in \ */*) \ case '$*' in \ */*) b='$*';; \ *) b=`echo '$@' | sed 's/\.log$$//'`; \ esac;; \ *) \ b='$*';; \ esac am__test_logs1 = $(TESTS:=.log) am__test_logs2 = $(am__test_logs1:@EXEEXT@.log=.log) TEST_LOGS = $(am__test_logs2:.test.log=.log) TEST_LOG_DRIVER = $(SHELL) $(top_srcdir)/test-driver TEST_LOG_COMPILE = $(TEST_LOG_COMPILER) $(AM_TEST_LOG_FLAGS) \ $(TEST_LOG_FLAGS) am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp \ $(top_srcdir)/test-driver DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CSCOPE = @CSCOPE@ CTAGS = @CTAGS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DPKG_DATE = @DPKG_DATE@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ ETAGS = @ETAGS@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ FILECMD = @FILECMD@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GREP = @GREP@ HAVE_DLLMAIN = @HAVE_DLLMAIN@ HAVE_INTTYPES_H = @HAVE_INTTYPES_H@ HAVE_LIBCERROR = @HAVE_LIBCERROR@ HAVE_LOCAL_LIBCERROR = @HAVE_LOCAL_LIBCERROR@ HAVE_OFF64_T = @HAVE_OFF64_T@ HAVE_OPENSSL_EVP_H = @HAVE_OPENSSL_EVP_H@ HAVE_SIZE32_T = @HAVE_SIZE32_T@ HAVE_SIZE64_T = @HAVE_SIZE64_T@ HAVE_SSIZE32_T = @HAVE_SSIZE32_T@ HAVE_SSIZE64_T = @HAVE_SSIZE64_T@ HAVE_STDINT_H = @HAVE_STDINT_H@ HAVE_SYS_TYPES_H = @HAVE_SYS_TYPES_H@ HAVE_WCHAR_H = @HAVE_WCHAR_H@ HAVE_WIDE_CHARACTER_TYPE = @HAVE_WIDE_CHARACTER_TYPE@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBCAES_DLL_EXPORT = @LIBCAES_DLL_EXPORT@ LIBCAES_DLL_IMPORT = @LIBCAES_DLL_IMPORT@ LIBCERROR_CPPFLAGS = @LIBCERROR_CPPFLAGS@ LIBCERROR_LIBADD = @LIBCERROR_LIBADD@ LIBCRYPTO_CPPFLAGS = @LIBCRYPTO_CPPFLAGS@ LIBCRYPTO_LIBADD = @LIBCRYPTO_LIBADD@ LIBDL_LIBADD = @LIBDL_LIBADD@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIB_FUZZING_ENGINE = @LIB_FUZZING_ENGINE@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGMERGE = @MSGMERGE@ MSGMERGE_FOR_MSGFMT_OPTION = @MSGMERGE_FOR_MSGFMT_OPTION@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ PKGCONFIG = @PKGCONFIG@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ PYTHON = @PYTHON@ PYTHON_CONFIG = @PYTHON_CONFIG@ PYTHON_CPPFLAGS = @PYTHON_CPPFLAGS@ PYTHON_EXEC_PREFIX = @PYTHON_EXEC_PREFIX@ PYTHON_LDFLAGS = @PYTHON_LDFLAGS@ PYTHON_LIBRARY_DIR = @PYTHON_LIBRARY_DIR@ PYTHON_PACKAGE_DIR = @PYTHON_PACKAGE_DIR@ PYTHON_PLATFORM = @PYTHON_PLATFORM@ PYTHON_PREFIX = @PYTHON_PREFIX@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ SPEC_DATE = @SPEC_DATE@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ ax_libcerror_pc_libs_private = @ax_libcerror_pc_libs_private@ ax_libcerror_spec_build_requires = @ax_libcerror_spec_build_requires@ ax_libcerror_spec_requires = @ax_libcerror_spec_requires@ ax_libcrypto_pc_libs_private = @ax_libcrypto_pc_libs_private@ ax_libcrypto_spec_build_requires = @ax_libcrypto_spec_build_requires@ ax_libcrypto_spec_requires = @ax_libcrypto_spec_requires@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libcaes_spec_requires = @libcaes_spec_requires@ libcerror_CFLAGS = @libcerror_CFLAGS@ libcerror_LIBS = @libcerror_LIBS@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ openssl_CFLAGS = @openssl_CFLAGS@ openssl_LIBS = @openssl_LIBS@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ pyexecdir = @pyexecdir@ pythondir = @pythondir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ AM_CPPFLAGS = \ -I../include -I$(top_srcdir)/include \ -I../common -I$(top_srcdir)/common \ @LIBCERROR_CPPFLAGS@ \ @LIBCRYPTO_CPPFLAGS@ \ @LIBCAES_DLL_IMPORT@ @HAVE_PYTHON_TESTS_TRUE@TESTS_PYCAES = \ @HAVE_PYTHON_TESTS_TRUE@ test_python_module.sh TESTS = \ test_library.sh \ $(TESTS_PYCAES) check_SCRIPTS = \ pycaes_test_crypt_cbc.py \ pycaes_test_crypt_ccm.py \ pycaes_test_crypt_ecb.py \ pycaes_test_crypt_xts.py \ pycaes_test_support.py \ test_library.sh \ test_manpage.sh \ test_python_module.sh \ test_runner.sh EXTRA_DIST = \ $(check_SCRIPTS) caes_test_context_SOURCES = \ caes_test_context.c \ caes_test_libcaes.h \ caes_test_libcerror.h \ caes_test_macros.h \ caes_test_memory.c caes_test_memory.h \ caes_test_unused.h caes_test_context_LDADD = \ ../libcaes/libcaes.la \ @LIBCERROR_LIBADD@ caes_test_crypt_cbc_SOURCES = \ caes_test_crypt_cbc.c \ caes_test_libcaes.h \ caes_test_libcerror.h \ caes_test_unused.h caes_test_crypt_cbc_LDADD = \ ../libcaes/libcaes.la \ @LIBCERROR_LIBADD@ caes_test_crypt_ccm_SOURCES = \ caes_test_crypt_ccm.c \ caes_test_libcaes.h \ caes_test_libcerror.h \ caes_test_unused.h caes_test_crypt_ccm_LDADD = \ ../libcaes/libcaes.la \ @LIBCERROR_LIBADD@ caes_test_crypt_xts_SOURCES = \ caes_test_crypt_xts.c \ caes_test_libcaes.h \ caes_test_libcerror.h \ caes_test_unused.h caes_test_crypt_xts_LDADD = \ ../libcaes/libcaes.la \ @LIBCERROR_LIBADD@ caes_test_error_SOURCES = \ caes_test_error.c \ caes_test_libcaes.h \ caes_test_macros.h \ caes_test_unused.h caes_test_error_LDADD = \ ../libcaes/libcaes.la caes_test_support_SOURCES = \ caes_test_libcaes.h \ caes_test_macros.h \ caes_test_support.c \ caes_test_unused.h caes_test_support_LDADD = \ ../libcaes/libcaes.la caes_test_tweaked_context_SOURCES = \ caes_test_libcaes.h \ caes_test_libcerror.h \ caes_test_macros.h \ caes_test_memory.c caes_test_memory.h \ caes_test_tweaked_context.c \ caes_test_unused.h caes_test_tweaked_context_LDADD = \ ../libcaes/libcaes.la \ @LIBCERROR_LIBADD@ DISTCLEANFILES = \ Makefile \ Makefile.in all: all-am .SUFFIXES: .SUFFIXES: .c .lo .log .o .obj .test .test$(EXEEXT) .trs $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu tests/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu tests/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): clean-checkPROGRAMS: @list='$(check_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list caes_test_context$(EXEEXT): $(caes_test_context_OBJECTS) $(caes_test_context_DEPENDENCIES) $(EXTRA_caes_test_context_DEPENDENCIES) @rm -f caes_test_context$(EXEEXT) $(AM_V_CCLD)$(LINK) $(caes_test_context_OBJECTS) $(caes_test_context_LDADD) $(LIBS) caes_test_crypt_cbc$(EXEEXT): $(caes_test_crypt_cbc_OBJECTS) $(caes_test_crypt_cbc_DEPENDENCIES) $(EXTRA_caes_test_crypt_cbc_DEPENDENCIES) @rm -f caes_test_crypt_cbc$(EXEEXT) $(AM_V_CCLD)$(LINK) $(caes_test_crypt_cbc_OBJECTS) $(caes_test_crypt_cbc_LDADD) $(LIBS) caes_test_crypt_ccm$(EXEEXT): $(caes_test_crypt_ccm_OBJECTS) $(caes_test_crypt_ccm_DEPENDENCIES) $(EXTRA_caes_test_crypt_ccm_DEPENDENCIES) @rm -f caes_test_crypt_ccm$(EXEEXT) $(AM_V_CCLD)$(LINK) $(caes_test_crypt_ccm_OBJECTS) $(caes_test_crypt_ccm_LDADD) $(LIBS) caes_test_crypt_xts$(EXEEXT): $(caes_test_crypt_xts_OBJECTS) $(caes_test_crypt_xts_DEPENDENCIES) $(EXTRA_caes_test_crypt_xts_DEPENDENCIES) @rm -f caes_test_crypt_xts$(EXEEXT) $(AM_V_CCLD)$(LINK) $(caes_test_crypt_xts_OBJECTS) $(caes_test_crypt_xts_LDADD) $(LIBS) caes_test_error$(EXEEXT): $(caes_test_error_OBJECTS) $(caes_test_error_DEPENDENCIES) $(EXTRA_caes_test_error_DEPENDENCIES) @rm -f caes_test_error$(EXEEXT) $(AM_V_CCLD)$(LINK) $(caes_test_error_OBJECTS) $(caes_test_error_LDADD) $(LIBS) caes_test_support$(EXEEXT): $(caes_test_support_OBJECTS) $(caes_test_support_DEPENDENCIES) $(EXTRA_caes_test_support_DEPENDENCIES) @rm -f caes_test_support$(EXEEXT) $(AM_V_CCLD)$(LINK) $(caes_test_support_OBJECTS) $(caes_test_support_LDADD) $(LIBS) caes_test_tweaked_context$(EXEEXT): $(caes_test_tweaked_context_OBJECTS) $(caes_test_tweaked_context_DEPENDENCIES) $(EXTRA_caes_test_tweaked_context_DEPENDENCIES) @rm -f caes_test_tweaked_context$(EXEEXT) $(AM_V_CCLD)$(LINK) $(caes_test_tweaked_context_OBJECTS) $(caes_test_tweaked_context_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/caes_test_context.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/caes_test_crypt_cbc.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/caes_test_crypt_ccm.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/caes_test_crypt_xts.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/caes_test_error.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/caes_test_memory.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/caes_test_support.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/caes_test_tweaked_context.Po@am__quote@ # am--include-marker $(am__depfiles_remade): @$(MKDIR_P) $(@D) @echo '# dummy' >$@-t && $(am__mv) $@-t $@ am--depfiles: $(am__depfiles_remade) .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs sources-local: splint-local: ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags # Recover from deleted '.trs' file; this should ensure that # "rm -f foo.log; make foo.trs" re-run 'foo.test', and re-create # both 'foo.log' and 'foo.trs'. Break the recipe in two subshells # to avoid problems with "make -n". .log.trs: rm -f $< $@ $(MAKE) $(AM_MAKEFLAGS) $< # Leading 'am--fnord' is there to ensure the list of targets does not # expand to empty, as could happen e.g. with make check TESTS=''. am--fnord $(TEST_LOGS) $(TEST_LOGS:.log=.trs): $(am__force_recheck) am--force-recheck: @: $(TEST_SUITE_LOG): $(TEST_LOGS) @$(am__set_TESTS_bases); \ am__f_ok () { test -f "$$1" && test -r "$$1"; }; \ redo_bases=`for i in $$bases; do \ am__f_ok $$i.trs && am__f_ok $$i.log || echo $$i; \ done`; \ if test -n "$$redo_bases"; then \ redo_logs=`for i in $$redo_bases; do echo $$i.log; done`; \ redo_results=`for i in $$redo_bases; do echo $$i.trs; done`; \ if $(am__make_dryrun); then :; else \ rm -f $$redo_logs && rm -f $$redo_results || exit 1; \ fi; \ fi; \ if test -n "$$am__remaking_logs"; then \ echo "fatal: making $(TEST_SUITE_LOG): possible infinite" \ "recursion detected" >&2; \ elif test -n "$$redo_logs"; then \ am__remaking_logs=yes $(MAKE) $(AM_MAKEFLAGS) $$redo_logs; \ fi; \ if $(am__make_dryrun); then :; else \ st=0; \ errmsg="fatal: making $(TEST_SUITE_LOG): failed to create"; \ for i in $$redo_bases; do \ test -f $$i.trs && test -r $$i.trs \ || { echo "$$errmsg $$i.trs" >&2; st=1; }; \ test -f $$i.log && test -r $$i.log \ || { echo "$$errmsg $$i.log" >&2; st=1; }; \ done; \ test $$st -eq 0 || exit 1; \ fi @$(am__sh_e_setup); $(am__tty_colors); $(am__set_TESTS_bases); \ ws='[ ]'; \ results=`for b in $$bases; do echo $$b.trs; done`; \ test -n "$$results" || results=/dev/null; \ all=` grep "^$$ws*:test-result:" $$results | wc -l`; \ pass=` grep "^$$ws*:test-result:$$ws*PASS" $$results | wc -l`; \ fail=` grep "^$$ws*:test-result:$$ws*FAIL" $$results | wc -l`; \ skip=` grep "^$$ws*:test-result:$$ws*SKIP" $$results | wc -l`; \ xfail=`grep "^$$ws*:test-result:$$ws*XFAIL" $$results | wc -l`; \ xpass=`grep "^$$ws*:test-result:$$ws*XPASS" $$results | wc -l`; \ error=`grep "^$$ws*:test-result:$$ws*ERROR" $$results | wc -l`; \ if test `expr $$fail + $$xpass + $$error` -eq 0; then \ success=true; \ else \ success=false; \ fi; \ br='==================='; br=$$br$$br$$br$$br; \ result_count () \ { \ if test x"$$1" = x"--maybe-color"; then \ maybe_colorize=yes; \ elif test x"$$1" = x"--no-color"; then \ maybe_colorize=no; \ else \ echo "$@: invalid 'result_count' usage" >&2; exit 4; \ fi; \ shift; \ desc=$$1 count=$$2; \ if test $$maybe_colorize = yes && test $$count -gt 0; then \ color_start=$$3 color_end=$$std; \ else \ color_start= color_end=; \ fi; \ echo "$${color_start}# $$desc $$count$${color_end}"; \ }; \ create_testsuite_report () \ { \ result_count $$1 "TOTAL:" $$all "$$brg"; \ result_count $$1 "PASS: " $$pass "$$grn"; \ result_count $$1 "SKIP: " $$skip "$$blu"; \ result_count $$1 "XFAIL:" $$xfail "$$lgn"; \ result_count $$1 "FAIL: " $$fail "$$red"; \ result_count $$1 "XPASS:" $$xpass "$$red"; \ result_count $$1 "ERROR:" $$error "$$mgn"; \ }; \ { \ echo "$(PACKAGE_STRING): $(subdir)/$(TEST_SUITE_LOG)" | \ $(am__rst_title); \ create_testsuite_report --no-color; \ echo; \ echo ".. contents:: :depth: 2"; \ echo; \ for b in $$bases; do echo $$b; done \ | $(am__create_global_log); \ } >$(TEST_SUITE_LOG).tmp || exit 1; \ mv $(TEST_SUITE_LOG).tmp $(TEST_SUITE_LOG); \ if $$success; then \ col="$$grn"; \ else \ col="$$red"; \ test x"$$VERBOSE" = x || cat $(TEST_SUITE_LOG); \ fi; \ echo "$${col}$$br$${std}"; \ echo "$${col}Testsuite summary"$(AM_TESTSUITE_SUMMARY_HEADER)"$${std}"; \ echo "$${col}$$br$${std}"; \ create_testsuite_report --maybe-color; \ echo "$$col$$br$$std"; \ if $$success; then :; else \ echo "$${col}See $(subdir)/$(TEST_SUITE_LOG)$${std}"; \ if test -n "$(PACKAGE_BUGREPORT)"; then \ echo "$${col}Please report to $(PACKAGE_BUGREPORT)$${std}"; \ fi; \ echo "$$col$$br$$std"; \ fi; \ $$success || exit 1 check-TESTS: $(check_PROGRAMS) $(check_SCRIPTS) @list='$(RECHECK_LOGS)'; test -z "$$list" || rm -f $$list @list='$(RECHECK_LOGS:.log=.trs)'; test -z "$$list" || rm -f $$list @test -z "$(TEST_SUITE_LOG)" || rm -f $(TEST_SUITE_LOG) @set +e; $(am__set_TESTS_bases); \ log_list=`for i in $$bases; do echo $$i.log; done`; \ trs_list=`for i in $$bases; do echo $$i.trs; done`; \ log_list=`echo $$log_list`; trs_list=`echo $$trs_list`; \ $(MAKE) $(AM_MAKEFLAGS) $(TEST_SUITE_LOG) TEST_LOGS="$$log_list"; \ exit $$?; recheck: all $(check_PROGRAMS) $(check_SCRIPTS) @test -z "$(TEST_SUITE_LOG)" || rm -f $(TEST_SUITE_LOG) @set +e; $(am__set_TESTS_bases); \ bases=`for i in $$bases; do echo $$i; done \ | $(am__list_recheck_tests)` || exit 1; \ log_list=`for i in $$bases; do echo $$i.log; done`; \ log_list=`echo $$log_list`; \ $(MAKE) $(AM_MAKEFLAGS) $(TEST_SUITE_LOG) \ am__force_recheck=am--force-recheck \ TEST_LOGS="$$log_list"; \ exit $$? test_library.sh.log: test_library.sh @p='test_library.sh'; \ b='test_library.sh'; \ $(am__check_pre) $(LOG_DRIVER) --test-name "$$f" \ --log-file $$b.log --trs-file $$b.trs \ $(am__common_driver_flags) $(AM_LOG_DRIVER_FLAGS) $(LOG_DRIVER_FLAGS) -- $(LOG_COMPILE) \ "$$tst" $(AM_TESTS_FD_REDIRECT) test_python_module.sh.log: test_python_module.sh @p='test_python_module.sh'; \ b='test_python_module.sh'; \ $(am__check_pre) $(LOG_DRIVER) --test-name "$$f" \ --log-file $$b.log --trs-file $$b.trs \ $(am__common_driver_flags) $(AM_LOG_DRIVER_FLAGS) $(LOG_DRIVER_FLAGS) -- $(LOG_COMPILE) \ "$$tst" $(AM_TESTS_FD_REDIRECT) .test.log: @p='$<'; \ $(am__set_b); \ $(am__check_pre) $(TEST_LOG_DRIVER) --test-name "$$f" \ --log-file $$b.log --trs-file $$b.trs \ $(am__common_driver_flags) $(AM_TEST_LOG_DRIVER_FLAGS) $(TEST_LOG_DRIVER_FLAGS) -- $(TEST_LOG_COMPILE) \ "$$tst" $(AM_TESTS_FD_REDIRECT) @am__EXEEXT_TRUE@.test$(EXEEXT).log: @am__EXEEXT_TRUE@ @p='$<'; \ @am__EXEEXT_TRUE@ $(am__set_b); \ @am__EXEEXT_TRUE@ $(am__check_pre) $(TEST_LOG_DRIVER) --test-name "$$f" \ @am__EXEEXT_TRUE@ --log-file $$b.log --trs-file $$b.trs \ @am__EXEEXT_TRUE@ $(am__common_driver_flags) $(AM_TEST_LOG_DRIVER_FLAGS) $(TEST_LOG_DRIVER_FLAGS) -- $(TEST_LOG_COMPILE) \ @am__EXEEXT_TRUE@ "$$tst" $(AM_TESTS_FD_REDIRECT) distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am $(MAKE) $(AM_MAKEFLAGS) $(check_PROGRAMS) $(check_SCRIPTS) $(MAKE) $(AM_MAKEFLAGS) check-TESTS check: check-am all-am: Makefile installdirs: install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: -test -z "$(TEST_LOGS)" || rm -f $(TEST_LOGS) -test -z "$(TEST_LOGS:.log=.trs)" || rm -f $(TEST_LOGS:.log=.trs) -test -z "$(TEST_SUITE_LOG)" || rm -f $(TEST_SUITE_LOG) clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) -test -z "$(DISTCLEANFILES)" || rm -f $(DISTCLEANFILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-checkPROGRAMS clean-generic clean-libtool \ mostlyclean-am distclean: distclean-am -rm -f ./$(DEPDIR)/caes_test_context.Po -rm -f ./$(DEPDIR)/caes_test_crypt_cbc.Po -rm -f ./$(DEPDIR)/caes_test_crypt_ccm.Po -rm -f ./$(DEPDIR)/caes_test_crypt_xts.Po -rm -f ./$(DEPDIR)/caes_test_error.Po -rm -f ./$(DEPDIR)/caes_test_memory.Po -rm -f ./$(DEPDIR)/caes_test_support.Po -rm -f ./$(DEPDIR)/caes_test_tweaked_context.Po -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f ./$(DEPDIR)/caes_test_context.Po -rm -f ./$(DEPDIR)/caes_test_crypt_cbc.Po -rm -f ./$(DEPDIR)/caes_test_crypt_ccm.Po -rm -f ./$(DEPDIR)/caes_test_crypt_xts.Po -rm -f ./$(DEPDIR)/caes_test_error.Po -rm -f ./$(DEPDIR)/caes_test_memory.Po -rm -f ./$(DEPDIR)/caes_test_support.Po -rm -f ./$(DEPDIR)/caes_test_tweaked_context.Po -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: sources: sources-am sources-am: sources-local splint: splint-am splint-am: splint-local uninstall-am: .MAKE: check-am install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am am--depfiles check check-TESTS \ check-am clean clean-checkPROGRAMS clean-generic clean-libtool \ cscopelist-am ctags ctags-am distclean distclean-compile \ distclean-generic distclean-libtool distclean-tags distdir dvi \ dvi-am html html-am info info-am install install-am \ install-data install-data-am install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-info install-info-am install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ recheck sources-am sources-local splint-am splint-local tags \ tags-am uninstall uninstall-am .PRECIOUS: Makefile # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: libcaes-20240413/tests/caes_test_support.c0000644000175000017500000000401014606473413021272 0ustar00lordyestalordyesta/* * Library support functions test program * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include #include #if defined( HAVE_STDLIB_H ) || defined( WINAPI ) #include #endif #include "caes_test_libcaes.h" #include "caes_test_macros.h" #include "caes_test_unused.h" /* Tests the libcaes_get_version function * Returns 1 if successful or 0 if not */ int caes_test_get_version( void ) { const char *version_string = NULL; int result = 0; version_string = libcaes_get_version(); result = narrow_string_compare( version_string, LIBCAES_VERSION_STRING, 9 ); CAES_TEST_ASSERT_EQUAL_INT( "result", result, 0 ); return( 1 ); on_error: return( 0 ); } /* The main program */ #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) int wmain( int argc CAES_TEST_ATTRIBUTE_UNUSED, wchar_t * const argv[] CAES_TEST_ATTRIBUTE_UNUSED ) #else int main( int argc CAES_TEST_ATTRIBUTE_UNUSED, char * const argv[] CAES_TEST_ATTRIBUTE_UNUSED ) #endif { CAES_TEST_UNREFERENCED_PARAMETER( argc ) CAES_TEST_UNREFERENCED_PARAMETER( argv ) CAES_TEST_RUN( "libcaes_get_version", caes_test_get_version ); return( EXIT_SUCCESS ); on_error: return( EXIT_FAILURE ); } libcaes-20240413/tests/test_library.sh0000755000175000017500000000771414606476403020442 0ustar00lordyestalordyesta#!/usr/bin/env bash # Tests library functions and types. # # Version: 20240413 EXIT_SUCCESS=0; EXIT_FAILURE=1; EXIT_IGNORE=77; LIBRARY_TESTS="context error support tweaked_context"; LIBRARY_TESTS_WITH_INPUT=""; OPTION_SETS=(); INPUT_GLOB="*"; run_test() { local TEST_NAME=$1; local TEST_DESCRIPTION="Testing: ${TEST_NAME}"; local TEST_EXECUTABLE="./caes_test_${TEST_NAME}"; if ! test -x "${TEST_EXECUTABLE}"; then TEST_EXECUTABLE="${TEST_EXECUTABLE}.exe"; fi # TODO: add support for TEST_PROFILE and OPTION_SETS? run_test_with_arguments "${TEST_DESCRIPTION}" "${TEST_EXECUTABLE}"; local RESULT=$?; return ${RESULT}; } run_test_with_input() { local TEST_NAME=$1; local TEST_DESCRIPTION="Testing: ${TEST_NAME}"; local TEST_EXECUTABLE="./caes_test_${TEST_NAME}"; if ! test -x "${TEST_EXECUTABLE}"; then TEST_EXECUTABLE="${TEST_EXECUTABLE}.exe"; fi if ! test -d "input"; then echo "Test input directory not found."; return ${EXIT_IGNORE}; fi local RESULT=`ls input/* | tr ' ' '\n' | wc -l`; if test ${RESULT} -eq ${EXIT_SUCCESS}; then echo "No files or directories found in the test input directory"; return ${EXIT_IGNORE}; fi local TEST_PROFILE_DIRECTORY=$(get_test_profile_directory "input" "libcaes"); local IGNORE_LIST=$(read_ignore_list "${TEST_PROFILE_DIRECTORY}"); RESULT=${EXIT_SUCCESS}; for TEST_SET_INPUT_DIRECTORY in input/*; do if ! test -d "${TEST_SET_INPUT_DIRECTORY}"; then continue; fi if check_for_directory_in_ignore_list "${TEST_SET_INPUT_DIRECTORY}" "${IGNORE_LIST}"; then continue; fi local TEST_SET_DIRECTORY=$(get_test_set_directory "${TEST_PROFILE_DIRECTORY}" "${TEST_SET_INPUT_DIRECTORY}"); if test -f "${TEST_SET_DIRECTORY}/files"; then IFS="" read -a INPUT_FILES <<< $(cat ${TEST_SET_DIRECTORY}/files | sed "s?^?${TEST_SET_INPUT_DIRECTORY}/?"); else IFS="" read -a INPUT_FILES <<< $(ls -1d ${TEST_SET_INPUT_DIRECTORY}/${INPUT_GLOB}); fi for INPUT_FILE in "${INPUT_FILES[@]}"; do OPTION_INPUT_FILE="${INPUT_FILE}"; if test "${OSTYPE}" = "msys"; then # A test executable built with MinGW expects a Windows path. INPUT_FILE=`echo ${INPUT_FILE} | sed 's?/?\\\\?g'`; fi local TESTED_WITH_OPTIONS=0; for OPTION_SET in ${OPTION_SETS[@]}; do local TEST_DATA_OPTION_FILE=$(get_test_data_option_file "${TEST_SET_DIRECTORY}" "${OPTION_INPUT_FILE}" "${OPTION_SET}"); if test -f ${TEST_DATA_OPTION_FILE}; then TESTED_WITH_OPTIONS=1; IFS=" " read -a OPTIONS <<< $(read_test_data_option_file "${TEST_SET_DIRECTORY}" "${INPUT_FILE}" "${OPTION_SET}"); run_test_on_input_file "${TEST_SET_DIRECTORY}" "${TEST_DESCRIPTION}" "default" "${OPTION_SET}" "${TEST_EXECUTABLE}" "${INPUT_FILE}" "${OPTIONS[@]}"; RESULT=$?; if test ${RESULT} -ne ${EXIT_SUCCESS}; then break; fi fi done if test ${TESTED_WITH_OPTIONS} -eq 0; then run_test_on_input_file "${TEST_SET_DIRECTORY}" "${TEST_DESCRIPTION}" "default" "" "${TEST_EXECUTABLE}" "${INPUT_FILE}"; RESULT=$?; fi if test ${RESULT} -ne ${EXIT_SUCCESS}; then break; fi done if test ${RESULT} -ne ${EXIT_SUCCESS}; then break; fi done return ${RESULT}; } if test -n "${SKIP_LIBRARY_TESTS}"; then exit ${EXIT_IGNORE}; fi TEST_DIRECTORY=`dirname $0`; TEST_RUNNER="${TEST_DIRECTORY}/test_runner.sh"; if ! test -f "${TEST_RUNNER}"; then echo "Missing test runner: ${TEST_RUNNER}"; exit ${EXIT_FAILURE}; fi source ${TEST_RUNNER}; RESULT=${EXIT_IGNORE}; for TEST_NAME in ${LIBRARY_TESTS}; do run_test "${TEST_NAME}"; RESULT=$?; if test ${RESULT} -ne ${EXIT_SUCCESS}; then break; fi done if test ${RESULT} -ne ${EXIT_SUCCESS} && test ${RESULT} -ne ${EXIT_IGNORE}; then exit ${RESULT}; fi for TEST_NAME in ${LIBRARY_TESTS_WITH_INPUT}; do if test -d "input"; then run_test_with_input "${TEST_NAME}"; RESULT=$?; else run_test "${TEST_NAME}"; RESULT=$?; fi if test ${RESULT} -ne ${EXIT_SUCCESS}; then break; fi done exit ${RESULT}; libcaes-20240413/ossfuzz/0000755000175000017500000000000014606477654015761 5ustar00lordyestalordyestalibcaes-20240413/ossfuzz/crypt_ecb_fuzzer.cc0000644000175000017500000000324514606473412021637 0ustar00lordyestalordyesta/* * OSS-Fuzz target for libcaes AES-ECB crypt function * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include /* Note that some of the OSS-Fuzz engines use C++ */ extern "C" { #include "ossfuzz_libcaes.h" int LLVMFuzzerTestOneInput( const uint8_t *data, size_t size ) { uint8_t encrypted_data[ 64 ]; uint8_t key[ 16 ] = { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }; libcaes_context_t *context = NULL; if( libcaes_context_initialize( &context, NULL ) != 1 ) { return( 0 ); } if( libcaes_context_set_key( context, LIBCAES_CRYPT_MODE_ENCRYPT, key, 128, NULL ) != 1 ) { goto on_error_libcaes; } libcaes_crypt_ecb( context, LIBCAES_CRYPT_MODE_ENCRYPT, data, size, encrypted_data, 64, NULL ); on_error_libcaes: libcaes_context_free( &context, NULL ); return( 0 ); } } /* extern "C" */ libcaes-20240413/ossfuzz/crypt_xts_fuzzer.cc0000644000175000017500000000405514606473412021724 0ustar00lordyestalordyesta/* * OSS-Fuzz target for libcaes AES-ECB crypt function * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include /* Note that some of the OSS-Fuzz engines use C++ */ extern "C" { #include "ossfuzz_libcaes.h" int LLVMFuzzerTestOneInput( const uint8_t *data, size_t size ) { uint8_t encrypted_data[ 64 ]; uint8_t key[ 16 ] = { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }; uint8_t tweak_key[ 16 ] = { 0x80, 0x81, 0x82, 0x83, 0x84, 0x85, 0x86, 0x87, 0x88, 0x89, 0x8a, 0x8b, 0x8c, 0x8d, 0x8e, 0x8f }; uint8_t tweak_value[ 16 ] = { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }; libcaes_tweaked_context_t *tweaked_context = NULL; if( libcaes_tweaked_context_initialize( &tweaked_context, NULL ) != 1 ) { return( 0 ); } if( libcaes_tweaked_context_set_keys( tweaked_context, LIBCAES_CRYPT_MODE_ENCRYPT, key, 128, tweak_key, 128, NULL ) != 1 ) { goto on_error_libcaes; } libcaes_crypt_xts( tweaked_context, LIBCAES_CRYPT_MODE_ENCRYPT, tweak_value, 16, data, size, encrypted_data, 64, NULL ); on_error_libcaes: libcaes_tweaked_context_free( &tweaked_context, NULL ); return( 0 ); } } /* extern "C" */ libcaes-20240413/ossfuzz/crypt_cbc_fuzzer.cc0000644000175000017500000000354314606473412021636 0ustar00lordyestalordyesta/* * OSS-Fuzz target for libcaes AES-CBC crypt function * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include /* Note that some of the OSS-Fuzz engines use C++ */ extern "C" { #include "ossfuzz_libcaes.h" int LLVMFuzzerTestOneInput( const uint8_t *data, size_t size ) { uint8_t encrypted_data[ 64 ]; uint8_t initialization_vector[ 16 ] = { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }; uint8_t key[ 16 ] = { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }; libcaes_context_t *context = NULL; if( libcaes_context_initialize( &context, NULL ) != 1 ) { return( 0 ); } if( libcaes_context_set_key( context, LIBCAES_CRYPT_MODE_ENCRYPT, key, 128, NULL ) != 1 ) { goto on_error_libcaes; } libcaes_crypt_cbc( context, LIBCAES_CRYPT_MODE_ENCRYPT, initialization_vector, 16, data, size, encrypted_data, 64, NULL ); on_error_libcaes: libcaes_context_free( &context, NULL ); return( 0 ); } } /* extern "C" */ libcaes-20240413/ossfuzz/Makefile.am0000644000175000017500000000272614606475365020021 0ustar00lordyestalordyestaif HAVE_LIB_FUZZING_ENGINE AM_CPPFLAGS = \ -I../include -I$(top_srcdir)/include \ -I../common -I$(top_srcdir)/common bin_PROGRAMS = \ crypt_cbc_fuzzer \ crypt_ccm_fuzzer \ crypt_ecb_fuzzer \ crypt_xts_fuzzer crypt_cbc_fuzzer_SOURCES = \ crypt_cbc_fuzzer.cc \ ossfuzz_libcaes.h crypt_cbc_fuzzer_LDADD = \ @LIB_FUZZING_ENGINE@ \ ../libcaes/libcaes.la crypt_ccm_fuzzer_SOURCES = \ crypt_ccm_fuzzer.cc \ ossfuzz_libcaes.h crypt_ccm_fuzzer_LDADD = \ @LIB_FUZZING_ENGINE@ \ ../libcaes/libcaes.la crypt_ecb_fuzzer_SOURCES = \ crypt_ecb_fuzzer.cc \ ossfuzz_libcaes.h crypt_ecb_fuzzer_LDADD = \ @LIB_FUZZING_ENGINE@ \ ../libcaes/libcaes.la crypt_xts_fuzzer_SOURCES = \ crypt_xts_fuzzer.cc \ ossfuzz_libcaes.h crypt_xts_fuzzer_LDADD = \ @LIB_FUZZING_ENGINE@ \ ../libcaes/libcaes.la endif DISTCLEANFILES = \ Makefile \ Makefile.in splint-local: @echo "Running splint on crypt_cbc_fuzzer ..." -splint -preproc -redef $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(crypt_cbc_fuzzer_SOURCES) @echo "Running splint on crypt_ccm_fuzzer ..." -splint -preproc -redef $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(crypt_ccm_fuzzer_SOURCES) @echo "Running splint on crypt_ecb_fuzzer ..." -splint -preproc -redef $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(crypt_ecb_fuzzer_SOURCES) @echo "Running splint on crypt_xts_fuzzer ..." -splint -preproc -redef $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(crypt_xts_fuzzer_SOURCES) libcaes-20240413/ossfuzz/crypt_ccm_fuzzer.cc0000644000175000017500000000340014606473412021641 0ustar00lordyestalordyesta/* * OSS-Fuzz target for libcaes AES-CCM crypt function * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include /* Note that some of the OSS-Fuzz engines use C++ */ extern "C" { #include "ossfuzz_libcaes.h" int LLVMFuzzerTestOneInput( const uint8_t *data, size_t size ) { uint8_t encrypted_data[ 64 ]; uint8_t key[ 16 ] = { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07, 0x08, 0x09, 0x0a, 0x0b, 0x0c, 0x0d, 0x0e, 0x0f }; uint8_t nonce[ 8 ] = { 0x00, 0x01, 0x02, 0x03, 0x04, 0x05, 0x06, 0x07 }; libcaes_context_t *context = NULL; if( libcaes_context_initialize( &context, NULL ) != 1 ) { return( 0 ); } if( libcaes_context_set_key( context, LIBCAES_CRYPT_MODE_ENCRYPT, key, 128, NULL ) != 1 ) { goto on_error_libcaes; } libcaes_crypt_ccm( context, LIBCAES_CRYPT_MODE_ENCRYPT, nonce, 8, data, size, encrypted_data, 64, NULL ); on_error_libcaes: libcaes_context_free( &context, NULL ); return( 0 ); } } /* extern "C" */ libcaes-20240413/ossfuzz/ossfuzz_libcaes.h0000644000175000017500000000170714606473412021330 0ustar00lordyestalordyesta/* * The libcaes header wrapper * * Copyright (C) 2011-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _OSSFUZZ_LIBCAES_H ) #define _OSSFUZZ_LIBCAES_H #include #include #endif /* !defined( _OSSFUZZ_LIBCAES_H ) */ libcaes-20240413/ossfuzz/Makefile.in0000644000175000017500000007107614606477627020041 0ustar00lordyestalordyesta# Makefile.in generated by automake 1.16.5 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2021 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ @HAVE_LIB_FUZZING_ENGINE_TRUE@bin_PROGRAMS = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ crypt_cbc_fuzzer$(EXEEXT) \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ crypt_ccm_fuzzer$(EXEEXT) \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ crypt_ecb_fuzzer$(EXEEXT) \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ crypt_xts_fuzzer$(EXEEXT) subdir = ossfuzz ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/common.m4 \ $(top_srcdir)/m4/gettext.m4 $(top_srcdir)/m4/host-cpu-c-abi.m4 \ $(top_srcdir)/m4/iconv.m4 $(top_srcdir)/m4/intlmacosx.m4 \ $(top_srcdir)/m4/lib-ld.m4 $(top_srcdir)/m4/lib-link.m4 \ $(top_srcdir)/m4/lib-prefix.m4 $(top_srcdir)/m4/libcerror.m4 \ $(top_srcdir)/m4/libcrypto.m4 $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/nls.m4 $(top_srcdir)/m4/po.m4 \ $(top_srcdir)/m4/progtest.m4 $(top_srcdir)/m4/python.m4 \ $(top_srcdir)/m4/tests.m4 $(top_srcdir)/m4/types.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/common/config.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = am__installdirs = "$(DESTDIR)$(bindir)" PROGRAMS = $(bin_PROGRAMS) am__crypt_cbc_fuzzer_SOURCES_DIST = crypt_cbc_fuzzer.cc \ ossfuzz_libcaes.h @HAVE_LIB_FUZZING_ENGINE_TRUE@am_crypt_cbc_fuzzer_OBJECTS = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ crypt_cbc_fuzzer.$(OBJEXT) crypt_cbc_fuzzer_OBJECTS = $(am_crypt_cbc_fuzzer_OBJECTS) @HAVE_LIB_FUZZING_ENGINE_TRUE@crypt_cbc_fuzzer_DEPENDENCIES = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ ../libcaes/libcaes.la AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = am__crypt_ccm_fuzzer_SOURCES_DIST = crypt_ccm_fuzzer.cc \ ossfuzz_libcaes.h @HAVE_LIB_FUZZING_ENGINE_TRUE@am_crypt_ccm_fuzzer_OBJECTS = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ crypt_ccm_fuzzer.$(OBJEXT) crypt_ccm_fuzzer_OBJECTS = $(am_crypt_ccm_fuzzer_OBJECTS) @HAVE_LIB_FUZZING_ENGINE_TRUE@crypt_ccm_fuzzer_DEPENDENCIES = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ ../libcaes/libcaes.la am__crypt_ecb_fuzzer_SOURCES_DIST = crypt_ecb_fuzzer.cc \ ossfuzz_libcaes.h @HAVE_LIB_FUZZING_ENGINE_TRUE@am_crypt_ecb_fuzzer_OBJECTS = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ crypt_ecb_fuzzer.$(OBJEXT) crypt_ecb_fuzzer_OBJECTS = $(am_crypt_ecb_fuzzer_OBJECTS) @HAVE_LIB_FUZZING_ENGINE_TRUE@crypt_ecb_fuzzer_DEPENDENCIES = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ ../libcaes/libcaes.la am__crypt_xts_fuzzer_SOURCES_DIST = crypt_xts_fuzzer.cc \ ossfuzz_libcaes.h @HAVE_LIB_FUZZING_ENGINE_TRUE@am_crypt_xts_fuzzer_OBJECTS = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ crypt_xts_fuzzer.$(OBJEXT) crypt_xts_fuzzer_OBJECTS = $(am_crypt_xts_fuzzer_OBJECTS) @HAVE_LIB_FUZZING_ENGINE_TRUE@crypt_xts_fuzzer_DEPENDENCIES = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ ../libcaes/libcaes.la AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)/common depcomp = $(SHELL) $(top_srcdir)/depcomp am__maybe_remake_depfiles = depfiles am__depfiles_remade = ./$(DEPDIR)/crypt_cbc_fuzzer.Po \ ./$(DEPDIR)/crypt_ccm_fuzzer.Po \ ./$(DEPDIR)/crypt_ecb_fuzzer.Po \ ./$(DEPDIR)/crypt_xts_fuzzer.Po am__mv = mv -f CXXCOMPILE = $(CXX) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) \ $(AM_CPPFLAGS) $(CPPFLAGS) $(AM_CXXFLAGS) $(CXXFLAGS) LTCXXCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CXX $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CXX) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CXXFLAGS) $(CXXFLAGS) AM_V_CXX = $(am__v_CXX_@AM_V@) am__v_CXX_ = $(am__v_CXX_@AM_DEFAULT_V@) am__v_CXX_0 = @echo " CXX " $@; am__v_CXX_1 = CXXLD = $(CXX) CXXLINK = $(LIBTOOL) $(AM_V_lt) --tag=CXX $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CXXLD) $(AM_CXXFLAGS) \ $(CXXFLAGS) $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CXXLD = $(am__v_CXXLD_@AM_V@) am__v_CXXLD_ = $(am__v_CXXLD_@AM_DEFAULT_V@) am__v_CXXLD_0 = @echo " CXXLD " $@; am__v_CXXLD_1 = COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(crypt_cbc_fuzzer_SOURCES) $(crypt_ccm_fuzzer_SOURCES) \ $(crypt_ecb_fuzzer_SOURCES) $(crypt_xts_fuzzer_SOURCES) DIST_SOURCES = $(am__crypt_cbc_fuzzer_SOURCES_DIST) \ $(am__crypt_ccm_fuzzer_SOURCES_DIST) \ $(am__crypt_ecb_fuzzer_SOURCES_DIST) \ $(am__crypt_xts_fuzzer_SOURCES_DIST) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__extra_recursive_targets = sources-recursive splint-recursive am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CSCOPE = @CSCOPE@ CTAGS = @CTAGS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DPKG_DATE = @DPKG_DATE@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ ETAGS = @ETAGS@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ FILECMD = @FILECMD@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GREP = @GREP@ HAVE_DLLMAIN = @HAVE_DLLMAIN@ HAVE_INTTYPES_H = @HAVE_INTTYPES_H@ HAVE_LIBCERROR = @HAVE_LIBCERROR@ HAVE_LOCAL_LIBCERROR = @HAVE_LOCAL_LIBCERROR@ HAVE_OFF64_T = @HAVE_OFF64_T@ HAVE_OPENSSL_EVP_H = @HAVE_OPENSSL_EVP_H@ HAVE_SIZE32_T = @HAVE_SIZE32_T@ HAVE_SIZE64_T = @HAVE_SIZE64_T@ HAVE_SSIZE32_T = @HAVE_SSIZE32_T@ HAVE_SSIZE64_T = @HAVE_SSIZE64_T@ HAVE_STDINT_H = @HAVE_STDINT_H@ HAVE_SYS_TYPES_H = @HAVE_SYS_TYPES_H@ HAVE_WCHAR_H = @HAVE_WCHAR_H@ HAVE_WIDE_CHARACTER_TYPE = @HAVE_WIDE_CHARACTER_TYPE@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBCAES_DLL_EXPORT = @LIBCAES_DLL_EXPORT@ LIBCAES_DLL_IMPORT = @LIBCAES_DLL_IMPORT@ LIBCERROR_CPPFLAGS = @LIBCERROR_CPPFLAGS@ LIBCERROR_LIBADD = @LIBCERROR_LIBADD@ LIBCRYPTO_CPPFLAGS = @LIBCRYPTO_CPPFLAGS@ LIBCRYPTO_LIBADD = @LIBCRYPTO_LIBADD@ LIBDL_LIBADD = @LIBDL_LIBADD@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIB_FUZZING_ENGINE = @LIB_FUZZING_ENGINE@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGMERGE = @MSGMERGE@ MSGMERGE_FOR_MSGFMT_OPTION = @MSGMERGE_FOR_MSGFMT_OPTION@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ PKGCONFIG = @PKGCONFIG@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ PYTHON = @PYTHON@ PYTHON_CONFIG = @PYTHON_CONFIG@ PYTHON_CPPFLAGS = @PYTHON_CPPFLAGS@ PYTHON_EXEC_PREFIX = @PYTHON_EXEC_PREFIX@ PYTHON_LDFLAGS = @PYTHON_LDFLAGS@ PYTHON_LIBRARY_DIR = @PYTHON_LIBRARY_DIR@ PYTHON_PACKAGE_DIR = @PYTHON_PACKAGE_DIR@ PYTHON_PLATFORM = @PYTHON_PLATFORM@ PYTHON_PREFIX = @PYTHON_PREFIX@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ SPEC_DATE = @SPEC_DATE@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ ax_libcerror_pc_libs_private = @ax_libcerror_pc_libs_private@ ax_libcerror_spec_build_requires = @ax_libcerror_spec_build_requires@ ax_libcerror_spec_requires = @ax_libcerror_spec_requires@ ax_libcrypto_pc_libs_private = @ax_libcrypto_pc_libs_private@ ax_libcrypto_spec_build_requires = @ax_libcrypto_spec_build_requires@ ax_libcrypto_spec_requires = @ax_libcrypto_spec_requires@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libcaes_spec_requires = @libcaes_spec_requires@ libcerror_CFLAGS = @libcerror_CFLAGS@ libcerror_LIBS = @libcerror_LIBS@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ openssl_CFLAGS = @openssl_CFLAGS@ openssl_LIBS = @openssl_LIBS@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ pyexecdir = @pyexecdir@ pythondir = @pythondir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ @HAVE_LIB_FUZZING_ENGINE_TRUE@AM_CPPFLAGS = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ -I../include -I$(top_srcdir)/include \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ -I../common -I$(top_srcdir)/common @HAVE_LIB_FUZZING_ENGINE_TRUE@crypt_cbc_fuzzer_SOURCES = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ crypt_cbc_fuzzer.cc \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ ossfuzz_libcaes.h @HAVE_LIB_FUZZING_ENGINE_TRUE@crypt_cbc_fuzzer_LDADD = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ @LIB_FUZZING_ENGINE@ \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ ../libcaes/libcaes.la @HAVE_LIB_FUZZING_ENGINE_TRUE@crypt_ccm_fuzzer_SOURCES = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ crypt_ccm_fuzzer.cc \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ ossfuzz_libcaes.h @HAVE_LIB_FUZZING_ENGINE_TRUE@crypt_ccm_fuzzer_LDADD = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ @LIB_FUZZING_ENGINE@ \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ ../libcaes/libcaes.la @HAVE_LIB_FUZZING_ENGINE_TRUE@crypt_ecb_fuzzer_SOURCES = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ crypt_ecb_fuzzer.cc \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ ossfuzz_libcaes.h @HAVE_LIB_FUZZING_ENGINE_TRUE@crypt_ecb_fuzzer_LDADD = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ @LIB_FUZZING_ENGINE@ \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ ../libcaes/libcaes.la @HAVE_LIB_FUZZING_ENGINE_TRUE@crypt_xts_fuzzer_SOURCES = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ crypt_xts_fuzzer.cc \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ ossfuzz_libcaes.h @HAVE_LIB_FUZZING_ENGINE_TRUE@crypt_xts_fuzzer_LDADD = \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ @LIB_FUZZING_ENGINE@ \ @HAVE_LIB_FUZZING_ENGINE_TRUE@ ../libcaes/libcaes.la DISTCLEANFILES = \ Makefile \ Makefile.in all: all-am .SUFFIXES: .SUFFIXES: .cc .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu ossfuzz/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu ossfuzz/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): install-binPROGRAMS: $(bin_PROGRAMS) @$(NORMAL_INSTALL) @list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(bindir)'"; \ $(MKDIR_P) "$(DESTDIR)$(bindir)" || exit 1; \ fi; \ for p in $$list; do echo "$$p $$p"; done | \ sed 's/$(EXEEXT)$$//' | \ while read p p1; do if test -f $$p \ || test -f $$p1 \ ; then echo "$$p"; echo "$$p"; else :; fi; \ done | \ sed -e 'p;s,.*/,,;n;h' \ -e 's|.*|.|' \ -e 'p;x;s,.*/,,;s/$(EXEEXT)$$//;$(transform);s/$$/$(EXEEXT)/' | \ sed 'N;N;N;s,\n, ,g' | \ $(AWK) 'BEGIN { files["."] = ""; dirs["."] = 1 } \ { d=$$3; if (dirs[d] != 1) { print "d", d; dirs[d] = 1 } \ if ($$2 == $$4) files[d] = files[d] " " $$1; \ else { print "f", $$3 "/" $$4, $$1; } } \ END { for (d in files) print "f", d, files[d] }' | \ while read type dir files; do \ if test "$$dir" = .; then dir=; else dir=/$$dir; fi; \ test -z "$$files" || { \ echo " $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files '$(DESTDIR)$(bindir)$$dir'"; \ $(INSTALL_PROGRAM_ENV) $(LIBTOOL) $(AM_LIBTOOLFLAGS) $(LIBTOOLFLAGS) --mode=install $(INSTALL_PROGRAM) $$files "$(DESTDIR)$(bindir)$$dir" || exit $$?; \ } \ ; done uninstall-binPROGRAMS: @$(NORMAL_UNINSTALL) @list='$(bin_PROGRAMS)'; test -n "$(bindir)" || list=; \ files=`for p in $$list; do echo "$$p"; done | \ sed -e 'h;s,^.*/,,;s/$(EXEEXT)$$//;$(transform)' \ -e 's/$$/$(EXEEXT)/' \ `; \ test -n "$$list" || exit 0; \ echo " ( cd '$(DESTDIR)$(bindir)' && rm -f" $$files ")"; \ cd "$(DESTDIR)$(bindir)" && rm -f $$files clean-binPROGRAMS: @list='$(bin_PROGRAMS)'; test -n "$$list" || exit 0; \ echo " rm -f" $$list; \ rm -f $$list || exit $$?; \ test -n "$(EXEEXT)" || exit 0; \ list=`for p in $$list; do echo "$$p"; done | sed 's/$(EXEEXT)$$//'`; \ echo " rm -f" $$list; \ rm -f $$list crypt_cbc_fuzzer$(EXEEXT): $(crypt_cbc_fuzzer_OBJECTS) $(crypt_cbc_fuzzer_DEPENDENCIES) $(EXTRA_crypt_cbc_fuzzer_DEPENDENCIES) @rm -f crypt_cbc_fuzzer$(EXEEXT) $(AM_V_CXXLD)$(CXXLINK) $(crypt_cbc_fuzzer_OBJECTS) $(crypt_cbc_fuzzer_LDADD) $(LIBS) crypt_ccm_fuzzer$(EXEEXT): $(crypt_ccm_fuzzer_OBJECTS) $(crypt_ccm_fuzzer_DEPENDENCIES) $(EXTRA_crypt_ccm_fuzzer_DEPENDENCIES) @rm -f crypt_ccm_fuzzer$(EXEEXT) $(AM_V_CXXLD)$(CXXLINK) $(crypt_ccm_fuzzer_OBJECTS) $(crypt_ccm_fuzzer_LDADD) $(LIBS) crypt_ecb_fuzzer$(EXEEXT): $(crypt_ecb_fuzzer_OBJECTS) $(crypt_ecb_fuzzer_DEPENDENCIES) $(EXTRA_crypt_ecb_fuzzer_DEPENDENCIES) @rm -f crypt_ecb_fuzzer$(EXEEXT) $(AM_V_CXXLD)$(CXXLINK) $(crypt_ecb_fuzzer_OBJECTS) $(crypt_ecb_fuzzer_LDADD) $(LIBS) crypt_xts_fuzzer$(EXEEXT): $(crypt_xts_fuzzer_OBJECTS) $(crypt_xts_fuzzer_DEPENDENCIES) $(EXTRA_crypt_xts_fuzzer_DEPENDENCIES) @rm -f crypt_xts_fuzzer$(EXEEXT) $(AM_V_CXXLD)$(CXXLINK) $(crypt_xts_fuzzer_OBJECTS) $(crypt_xts_fuzzer_LDADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/crypt_cbc_fuzzer.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/crypt_ccm_fuzzer.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/crypt_ecb_fuzzer.Po@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/crypt_xts_fuzzer.Po@am__quote@ # am--include-marker $(am__depfiles_remade): @$(MKDIR_P) $(@D) @echo '# dummy' >$@-t && $(am__mv) $@-t $@ am--depfiles: $(am__depfiles_remade) .cc.o: @am__fastdepCXX_TRUE@ $(AM_V_CXX)$(CXXCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCXX_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(AM_V_CXX)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCXX_FALSE@ $(AM_V_CXX@am__nodep@)$(CXXCOMPILE) -c -o $@ $< .cc.obj: @am__fastdepCXX_TRUE@ $(AM_V_CXX)$(CXXCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCXX_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(AM_V_CXX)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCXX_FALSE@ $(AM_V_CXX@am__nodep@)$(CXXCOMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .cc.lo: @am__fastdepCXX_TRUE@ $(AM_V_CXX)$(LTCXXCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCXX_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCXX_FALSE@ $(AM_V_CXX)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCXX_FALSE@ DEPDIR=$(DEPDIR) $(CXXDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCXX_FALSE@ $(AM_V_CXX@am__nodep@)$(LTCXXCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs sources-local: splint-local: ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(PROGRAMS) installdirs: for dir in "$(DESTDIR)$(bindir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) -test -z "$(DISTCLEANFILES)" || rm -f $(DISTCLEANFILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-binPROGRAMS clean-generic clean-libtool mostlyclean-am distclean: distclean-am -rm -f ./$(DEPDIR)/crypt_cbc_fuzzer.Po -rm -f ./$(DEPDIR)/crypt_ccm_fuzzer.Po -rm -f ./$(DEPDIR)/crypt_ecb_fuzzer.Po -rm -f ./$(DEPDIR)/crypt_xts_fuzzer.Po -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-binPROGRAMS install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f ./$(DEPDIR)/crypt_cbc_fuzzer.Po -rm -f ./$(DEPDIR)/crypt_ccm_fuzzer.Po -rm -f ./$(DEPDIR)/crypt_ecb_fuzzer.Po -rm -f ./$(DEPDIR)/crypt_xts_fuzzer.Po -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: sources: sources-am sources-am: sources-local splint: splint-am splint-am: splint-local uninstall-am: uninstall-binPROGRAMS .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am am--depfiles check check-am clean \ clean-binPROGRAMS clean-generic clean-libtool cscopelist-am \ ctags ctags-am distclean distclean-compile distclean-generic \ distclean-libtool distclean-tags distdir dvi dvi-am html \ html-am info info-am install install-am install-binPROGRAMS \ install-data install-data-am install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-info install-info-am install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ sources-am sources-local splint-am splint-local tags tags-am \ uninstall uninstall-am uninstall-binPROGRAMS .PRECIOUS: Makefile splint-local: @echo "Running splint on crypt_cbc_fuzzer ..." -splint -preproc -redef $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(crypt_cbc_fuzzer_SOURCES) @echo "Running splint on crypt_ccm_fuzzer ..." -splint -preproc -redef $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(crypt_ccm_fuzzer_SOURCES) @echo "Running splint on crypt_ecb_fuzzer ..." -splint -preproc -redef $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(crypt_ecb_fuzzer_SOURCES) @echo "Running splint on crypt_xts_fuzzer ..." -splint -preproc -redef $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(crypt_xts_fuzzer_SOURCES) # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: libcaes-20240413/ltmain.sh0000644000175000017500000121201014606477623016047 0ustar00lordyestalordyesta#! /usr/bin/env sh ## DO NOT EDIT - This file generated from ./build-aux/ltmain.in ## by inline-source v2019-02-19.15 # libtool (GNU libtool) 2.4.7 # Provide generalized library-building support services. # Written by Gordon Matzigkeit , 1996 # Copyright (C) 1996-2019, 2021-2022 Free Software Foundation, Inc. # This is free software; see the source for copying conditions. There is NO # warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # GNU Libtool 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. # # As a special exception to the GNU General Public License, # if you distribute this file as part of a program or library that # is built using GNU Libtool, you may include this file under the # same distribution terms that you use for the rest of that program. # # GNU Libtool 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 this program. If not, see . PROGRAM=libtool PACKAGE=libtool VERSION=2.4.7 package_revision=2.4.7 ## ------ ## ## Usage. ## ## ------ ## # Run './libtool --help' for help with using this script from the # command line. ## ------------------------------- ## ## User overridable command paths. ## ## ------------------------------- ## # After configure completes, it has a better idea of some of the # shell tools we need than the defaults used by the functions shared # with bootstrap, so set those here where they can still be over- # ridden by the user, but otherwise take precedence. : ${AUTOCONF="autoconf"} : ${AUTOMAKE="automake"} ## -------------------------- ## ## Source external libraries. ## ## -------------------------- ## # Much of our low-level functionality needs to be sourced from external # libraries, which are installed to $pkgauxdir. # Set a version string for this script. scriptversion=2019-02-19.15; # UTC # General shell script boiler plate, and helper functions. # Written by Gary V. Vaughan, 2004 # This is free software. There is NO warranty; not even for # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # # Copyright (C) 2004-2019, 2021 Bootstrap Authors # # This file is dual licensed under the terms of the MIT license # , and GPL version 2 or later # . You must apply one of # these licenses when using or redistributing this software or any of # the files within it. See the URLs above, or the file `LICENSE` # included in the Bootstrap distribution for the full license texts. # Please report bugs or propose patches to: # ## ------ ## ## Usage. ## ## ------ ## # Evaluate this file near the top of your script to gain access to # the functions and variables defined here: # # . `echo "$0" | ${SED-sed} 's|[^/]*$||'`/build-aux/funclib.sh # # If you need to override any of the default environment variable # settings, do that before evaluating this file. ## -------------------- ## ## Shell normalisation. ## ## -------------------- ## # Some shells need a little help to be as Bourne compatible as possible. # Before doing anything else, make sure all that help has been provided! DUALCASE=1; export DUALCASE # for MKS sh if test -n "${ZSH_VERSION+set}" && (emulate sh) >/dev/null 2>&1; then : emulate sh NULLCMD=: # Pre-4.2 versions of Zsh do word splitting on ${1+"$@"}, which # is contrary to our usage. Disable this feature. alias -g '${1+"$@"}'='"$@"' setopt NO_GLOB_SUBST else case `(set -o) 2>/dev/null` in *posix*) set -o posix ;; esac fi # NLS nuisances: We save the old values in case they are required later. _G_user_locale= _G_safe_locale= for _G_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES do eval "if test set = \"\${$_G_var+set}\"; then save_$_G_var=\$$_G_var $_G_var=C export $_G_var _G_user_locale=\"$_G_var=\\\$save_\$_G_var; \$_G_user_locale\" _G_safe_locale=\"$_G_var=C; \$_G_safe_locale\" fi" done # These NLS vars are set unconditionally (bootstrap issue #24). Unset those # in case the environment reset is needed later and the $save_* variant is not # defined (see the code above). LC_ALL=C LANGUAGE=C export LANGUAGE LC_ALL # Make sure IFS has a sensible default sp=' ' nl=' ' IFS="$sp $nl" # There are apparently some retarded systems that use ';' as a PATH separator! if test "${PATH_SEPARATOR+set}" != set; then PATH_SEPARATOR=: (PATH='/bin;/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 && { (PATH='/bin:/bin'; FPATH=$PATH; sh -c :) >/dev/null 2>&1 || PATH_SEPARATOR=';' } fi # func_unset VAR # -------------- # Portably unset VAR. # In some shells, an 'unset VAR' statement leaves a non-zero return # status if VAR is already unset, which might be problematic if the # statement is used at the end of a function (thus poisoning its return # value) or when 'set -e' is active (causing even a spurious abort of # the script in this case). func_unset () { { eval $1=; (eval unset $1) >/dev/null 2>&1 && eval unset $1 || : ; } } # Make sure CDPATH doesn't cause `cd` commands to output the target dir. func_unset CDPATH # Make sure ${,E,F}GREP behave sanely. func_unset GREP_OPTIONS ## ------------------------- ## ## Locate command utilities. ## ## ------------------------- ## # func_executable_p FILE # ---------------------- # Check that FILE is an executable regular file. func_executable_p () { test -f "$1" && test -x "$1" } # func_path_progs PROGS_LIST CHECK_FUNC [PATH] # -------------------------------------------- # Search for either a program that responds to --version with output # containing "GNU", or else returned by CHECK_FUNC otherwise, by # trying all the directories in PATH with each of the elements of # PROGS_LIST. # # CHECK_FUNC should accept the path to a candidate program, and # set $func_check_prog_result if it truncates its output less than # $_G_path_prog_max characters. func_path_progs () { _G_progs_list=$1 _G_check_func=$2 _G_PATH=${3-"$PATH"} _G_path_prog_max=0 _G_path_prog_found=false _G_save_IFS=$IFS; IFS=${PATH_SEPARATOR-:} for _G_dir in $_G_PATH; do IFS=$_G_save_IFS test -z "$_G_dir" && _G_dir=. for _G_prog_name in $_G_progs_list; do for _exeext in '' .EXE; do _G_path_prog=$_G_dir/$_G_prog_name$_exeext func_executable_p "$_G_path_prog" || continue case `"$_G_path_prog" --version 2>&1` in *GNU*) func_path_progs_result=$_G_path_prog _G_path_prog_found=: ;; *) $_G_check_func $_G_path_prog func_path_progs_result=$func_check_prog_result ;; esac $_G_path_prog_found && break 3 done done done IFS=$_G_save_IFS test -z "$func_path_progs_result" && { echo "no acceptable sed could be found in \$PATH" >&2 exit 1 } } # We want to be able to use the functions in this file before configure # has figured out where the best binaries are kept, which means we have # to search for them ourselves - except when the results are already set # where we skip the searches. # Unless the user overrides by setting SED, search the path for either GNU # sed, or the sed that truncates its output the least. test -z "$SED" && { _G_sed_script=s/aaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaaa/bbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbbb/ for _G_i in 1 2 3 4 5 6 7; do _G_sed_script=$_G_sed_script$nl$_G_sed_script done echo "$_G_sed_script" 2>/dev/null | sed 99q >conftest.sed _G_sed_script= func_check_prog_sed () { _G_path_prog=$1 _G_count=0 printf 0123456789 >conftest.in while : do cat conftest.in conftest.in >conftest.tmp mv conftest.tmp conftest.in cp conftest.in conftest.nl echo '' >> conftest.nl "$_G_path_prog" -f conftest.sed conftest.out 2>/dev/null || break diff conftest.out conftest.nl >/dev/null 2>&1 || break _G_count=`expr $_G_count + 1` if test "$_G_count" -gt "$_G_path_prog_max"; then # Best one so far, save it but keep looking for a better one func_check_prog_result=$_G_path_prog _G_path_prog_max=$_G_count fi # 10*(2^10) chars as input seems more than enough test 10 -lt "$_G_count" && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out } func_path_progs "sed gsed" func_check_prog_sed "$PATH:/usr/xpg4/bin" rm -f conftest.sed SED=$func_path_progs_result } # Unless the user overrides by setting GREP, search the path for either GNU # grep, or the grep that truncates its output the least. test -z "$GREP" && { func_check_prog_grep () { _G_path_prog=$1 _G_count=0 _G_path_prog_max=0 printf 0123456789 >conftest.in while : do cat conftest.in conftest.in >conftest.tmp mv conftest.tmp conftest.in cp conftest.in conftest.nl echo 'GREP' >> conftest.nl "$_G_path_prog" -e 'GREP$' -e '-(cannot match)-' conftest.out 2>/dev/null || break diff conftest.out conftest.nl >/dev/null 2>&1 || break _G_count=`expr $_G_count + 1` if test "$_G_count" -gt "$_G_path_prog_max"; then # Best one so far, save it but keep looking for a better one func_check_prog_result=$_G_path_prog _G_path_prog_max=$_G_count fi # 10*(2^10) chars as input seems more than enough test 10 -lt "$_G_count" && break done rm -f conftest.in conftest.tmp conftest.nl conftest.out } func_path_progs "grep ggrep" func_check_prog_grep "$PATH:/usr/xpg4/bin" GREP=$func_path_progs_result } ## ------------------------------- ## ## User overridable command paths. ## ## ------------------------------- ## # All uppercase variable names are used for environment variables. These # variables can be overridden by the user before calling a script that # uses them if a suitable command of that name is not already available # in the command search PATH. : ${CP="cp -f"} : ${ECHO="printf %s\n"} : ${EGREP="$GREP -E"} : ${FGREP="$GREP -F"} : ${LN_S="ln -s"} : ${MAKE="make"} : ${MKDIR="mkdir"} : ${MV="mv -f"} : ${RM="rm -f"} : ${SHELL="${CONFIG_SHELL-/bin/sh}"} ## -------------------- ## ## Useful sed snippets. ## ## -------------------- ## sed_dirname='s|/[^/]*$||' sed_basename='s|^.*/||' # Sed substitution that helps us do robust quoting. It backslashifies # metacharacters that are still active within double-quoted strings. sed_quote_subst='s|\([`"$\\]\)|\\\1|g' # Same as above, but do not quote variable references. sed_double_quote_subst='s/\(["`\\]\)/\\\1/g' # Sed substitution that turns a string into a regex matching for the # string literally. sed_make_literal_regex='s|[].[^$\\*\/]|\\&|g' # Sed substitution that converts a w32 file name or path # that contains forward slashes, into one that contains # (escaped) backslashes. A very naive implementation. sed_naive_backslashify='s|\\\\*|\\|g;s|/|\\|g;s|\\|\\\\|g' # Re-'\' parameter expansions in output of sed_double_quote_subst that # were '\'-ed in input to the same. If an odd number of '\' preceded a # '$' in input to sed_double_quote_subst, that '$' was protected from # expansion. Since each input '\' is now two '\'s, look for any number # of runs of four '\'s followed by two '\'s and then a '$'. '\' that '$'. _G_bs='\\' _G_bs2='\\\\' _G_bs4='\\\\\\\\' _G_dollar='\$' sed_double_backslash="\ s/$_G_bs4/&\\ /g s/^$_G_bs2$_G_dollar/$_G_bs&/ s/\\([^$_G_bs]\\)$_G_bs2$_G_dollar/\\1$_G_bs2$_G_bs$_G_dollar/g s/\n//g" # require_check_ifs_backslash # --------------------------- # Check if we can use backslash as IFS='\' separator, and set # $check_ifs_backshlash_broken to ':' or 'false'. require_check_ifs_backslash=func_require_check_ifs_backslash func_require_check_ifs_backslash () { _G_save_IFS=$IFS IFS='\' _G_check_ifs_backshlash='a\\b' for _G_i in $_G_check_ifs_backshlash do case $_G_i in a) check_ifs_backshlash_broken=false ;; '') break ;; *) check_ifs_backshlash_broken=: break ;; esac done IFS=$_G_save_IFS require_check_ifs_backslash=: } ## ----------------- ## ## Global variables. ## ## ----------------- ## # Except for the global variables explicitly listed below, the following # functions in the '^func_' namespace, and the '^require_' namespace # variables initialised in the 'Resource management' section, sourcing # this file will not pollute your global namespace with anything # else. There's no portable way to scope variables in Bourne shell # though, so actually running these functions will sometimes place # results into a variable named after the function, and often use # temporary variables in the '^_G_' namespace. If you are careful to # avoid using those namespaces casually in your sourcing script, things # should continue to work as you expect. And, of course, you can freely # overwrite any of the functions or variables defined here before # calling anything to customize them. EXIT_SUCCESS=0 EXIT_FAILURE=1 EXIT_MISMATCH=63 # $? = 63 is used to indicate version mismatch to missing. EXIT_SKIP=77 # $? = 77 is used to indicate a skipped test to automake. # Allow overriding, eg assuming that you follow the convention of # putting '$debug_cmd' at the start of all your functions, you can get # bash to show function call trace with: # # debug_cmd='eval echo "${FUNCNAME[0]} $*" >&2' bash your-script-name debug_cmd=${debug_cmd-":"} exit_cmd=: # By convention, finish your script with: # # exit $exit_status # # so that you can set exit_status to non-zero if you want to indicate # something went wrong during execution without actually bailing out at # the point of failure. exit_status=$EXIT_SUCCESS # Work around backward compatibility issue on IRIX 6.5. On IRIX 6.4+, sh # is ksh but when the shell is invoked as "sh" and the current value of # the _XPG environment variable is not equal to 1 (one), the special # positional parameter $0, within a function call, is the name of the # function. progpath=$0 # The name of this program. progname=`$ECHO "$progpath" |$SED "$sed_basename"` # Make sure we have an absolute progpath for reexecution: case $progpath in [\\/]*|[A-Za-z]:\\*) ;; *[\\/]*) progdir=`$ECHO "$progpath" |$SED "$sed_dirname"` progdir=`cd "$progdir" && pwd` progpath=$progdir/$progname ;; *) _G_IFS=$IFS IFS=${PATH_SEPARATOR-:} for progdir in $PATH; do IFS=$_G_IFS test -x "$progdir/$progname" && break done IFS=$_G_IFS test -n "$progdir" || progdir=`pwd` progpath=$progdir/$progname ;; esac ## ----------------- ## ## Standard options. ## ## ----------------- ## # The following options affect the operation of the functions defined # below, and should be set appropriately depending on run-time para- # meters passed on the command line. opt_dry_run=false opt_quiet=false opt_verbose=false # Categories 'all' and 'none' are always available. Append any others # you will pass as the first argument to func_warning from your own # code. warning_categories= # By default, display warnings according to 'opt_warning_types'. Set # 'warning_func' to ':' to elide all warnings, or func_fatal_error to # treat the next displayed warning as a fatal error. warning_func=func_warn_and_continue # Set to 'all' to display all warnings, 'none' to suppress all # warnings, or a space delimited list of some subset of # 'warning_categories' to display only the listed warnings. opt_warning_types=all ## -------------------- ## ## Resource management. ## ## -------------------- ## # This section contains definitions for functions that each ensure a # particular resource (a file, or a non-empty configuration variable for # example) is available, and if appropriate to extract default values # from pertinent package files. Call them using their associated # 'require_*' variable to ensure that they are executed, at most, once. # # It's entirely deliberate that calling these functions can set # variables that don't obey the namespace limitations obeyed by the rest # of this file, in order that that they be as useful as possible to # callers. # require_term_colors # ------------------- # Allow display of bold text on terminals that support it. require_term_colors=func_require_term_colors func_require_term_colors () { $debug_cmd test -t 1 && { # COLORTERM and USE_ANSI_COLORS environment variables take # precedence, because most terminfo databases neglect to describe # whether color sequences are supported. test -n "${COLORTERM+set}" && : ${USE_ANSI_COLORS="1"} if test 1 = "$USE_ANSI_COLORS"; then # Standard ANSI escape sequences tc_reset='' tc_bold=''; tc_standout='' tc_red=''; tc_green='' tc_blue=''; tc_cyan='' else # Otherwise trust the terminfo database after all. test -n "`tput sgr0 2>/dev/null`" && { tc_reset=`tput sgr0` test -n "`tput bold 2>/dev/null`" && tc_bold=`tput bold` tc_standout=$tc_bold test -n "`tput smso 2>/dev/null`" && tc_standout=`tput smso` test -n "`tput setaf 1 2>/dev/null`" && tc_red=`tput setaf 1` test -n "`tput setaf 2 2>/dev/null`" && tc_green=`tput setaf 2` test -n "`tput setaf 4 2>/dev/null`" && tc_blue=`tput setaf 4` test -n "`tput setaf 5 2>/dev/null`" && tc_cyan=`tput setaf 5` } fi } require_term_colors=: } ## ----------------- ## ## Function library. ## ## ----------------- ## # This section contains a variety of useful functions to call in your # scripts. Take note of the portable wrappers for features provided by # some modern shells, which will fall back to slower equivalents on # less featureful shells. # func_append VAR VALUE # --------------------- # Append VALUE onto the existing contents of VAR. # We should try to minimise forks, especially on Windows where they are # unreasonably slow, so skip the feature probes when bash or zsh are # being used: if test set = "${BASH_VERSION+set}${ZSH_VERSION+set}"; then : ${_G_HAVE_ARITH_OP="yes"} : ${_G_HAVE_XSI_OPS="yes"} # The += operator was introduced in bash 3.1 case $BASH_VERSION in [12].* | 3.0 | 3.0*) ;; *) : ${_G_HAVE_PLUSEQ_OP="yes"} ;; esac fi # _G_HAVE_PLUSEQ_OP # Can be empty, in which case the shell is probed, "yes" if += is # useable or anything else if it does not work. test -z "$_G_HAVE_PLUSEQ_OP" \ && (eval 'x=a; x+=" b"; test "a b" = "$x"') 2>/dev/null \ && _G_HAVE_PLUSEQ_OP=yes if test yes = "$_G_HAVE_PLUSEQ_OP" then # This is an XSI compatible shell, allowing a faster implementation... eval 'func_append () { $debug_cmd eval "$1+=\$2" }' else # ...otherwise fall back to using expr, which is often a shell builtin. func_append () { $debug_cmd eval "$1=\$$1\$2" } fi # func_append_quoted VAR VALUE # ---------------------------- # Quote VALUE and append to the end of shell variable VAR, separated # by a space. if test yes = "$_G_HAVE_PLUSEQ_OP"; then eval 'func_append_quoted () { $debug_cmd func_quote_arg pretty "$2" eval "$1+=\\ \$func_quote_arg_result" }' else func_append_quoted () { $debug_cmd func_quote_arg pretty "$2" eval "$1=\$$1\\ \$func_quote_arg_result" } fi # func_append_uniq VAR VALUE # -------------------------- # Append unique VALUE onto the existing contents of VAR, assuming # entries are delimited by the first character of VALUE. For example: # # func_append_uniq options " --another-option option-argument" # # will only append to $options if " --another-option option-argument " # is not already present somewhere in $options already (note spaces at # each end implied by leading space in second argument). func_append_uniq () { $debug_cmd eval _G_current_value='`$ECHO $'$1'`' _G_delim=`expr "$2" : '\(.\)'` case $_G_delim$_G_current_value$_G_delim in *"$2$_G_delim"*) ;; *) func_append "$@" ;; esac } # func_arith TERM... # ------------------ # Set func_arith_result to the result of evaluating TERMs. test -z "$_G_HAVE_ARITH_OP" \ && (eval 'test 2 = $(( 1 + 1 ))') 2>/dev/null \ && _G_HAVE_ARITH_OP=yes if test yes = "$_G_HAVE_ARITH_OP"; then eval 'func_arith () { $debug_cmd func_arith_result=$(( $* )) }' else func_arith () { $debug_cmd func_arith_result=`expr "$@"` } fi # func_basename FILE # ------------------ # Set func_basename_result to FILE with everything up to and including # the last / stripped. if test yes = "$_G_HAVE_XSI_OPS"; then # If this shell supports suffix pattern removal, then use it to avoid # forking. Hide the definitions single quotes in case the shell chokes # on unsupported syntax... _b='func_basename_result=${1##*/}' _d='case $1 in */*) func_dirname_result=${1%/*}$2 ;; * ) func_dirname_result=$3 ;; esac' else # ...otherwise fall back to using sed. _b='func_basename_result=`$ECHO "$1" |$SED "$sed_basename"`' _d='func_dirname_result=`$ECHO "$1" |$SED "$sed_dirname"` if test "X$func_dirname_result" = "X$1"; then func_dirname_result=$3 else func_append func_dirname_result "$2" fi' fi eval 'func_basename () { $debug_cmd '"$_b"' }' # func_dirname FILE APPEND NONDIR_REPLACEMENT # ------------------------------------------- # Compute the dirname of FILE. If nonempty, add APPEND to the result, # otherwise set result to NONDIR_REPLACEMENT. eval 'func_dirname () { $debug_cmd '"$_d"' }' # func_dirname_and_basename FILE APPEND NONDIR_REPLACEMENT # -------------------------------------------------------- # Perform func_basename and func_dirname in a single function # call: # dirname: Compute the dirname of FILE. If nonempty, # add APPEND to the result, otherwise set result # to NONDIR_REPLACEMENT. # value returned in "$func_dirname_result" # basename: Compute filename of FILE. # value retuned in "$func_basename_result" # For efficiency, we do not delegate to the functions above but instead # duplicate the functionality here. eval 'func_dirname_and_basename () { $debug_cmd '"$_b"' '"$_d"' }' # func_echo ARG... # ---------------- # Echo program name prefixed message. func_echo () { $debug_cmd _G_message=$* func_echo_IFS=$IFS IFS=$nl for _G_line in $_G_message; do IFS=$func_echo_IFS $ECHO "$progname: $_G_line" done IFS=$func_echo_IFS } # func_echo_all ARG... # -------------------- # Invoke $ECHO with all args, space-separated. func_echo_all () { $ECHO "$*" } # func_echo_infix_1 INFIX ARG... # ------------------------------ # Echo program name, followed by INFIX on the first line, with any # additional lines not showing INFIX. func_echo_infix_1 () { $debug_cmd $require_term_colors _G_infix=$1; shift _G_indent=$_G_infix _G_prefix="$progname: $_G_infix: " _G_message=$* # Strip color escape sequences before counting printable length for _G_tc in "$tc_reset" "$tc_bold" "$tc_standout" "$tc_red" "$tc_green" "$tc_blue" "$tc_cyan" do test -n "$_G_tc" && { _G_esc_tc=`$ECHO "$_G_tc" | $SED "$sed_make_literal_regex"` _G_indent=`$ECHO "$_G_indent" | $SED "s|$_G_esc_tc||g"` } done _G_indent="$progname: "`echo "$_G_indent" | $SED 's|.| |g'`" " ## exclude from sc_prohibit_nested_quotes func_echo_infix_1_IFS=$IFS IFS=$nl for _G_line in $_G_message; do IFS=$func_echo_infix_1_IFS $ECHO "$_G_prefix$tc_bold$_G_line$tc_reset" >&2 _G_prefix=$_G_indent done IFS=$func_echo_infix_1_IFS } # func_error ARG... # ----------------- # Echo program name prefixed message to standard error. func_error () { $debug_cmd $require_term_colors func_echo_infix_1 " $tc_standout${tc_red}error$tc_reset" "$*" >&2 } # func_fatal_error ARG... # ----------------------- # Echo program name prefixed message to standard error, and exit. func_fatal_error () { $debug_cmd func_error "$*" exit $EXIT_FAILURE } # func_grep EXPRESSION FILENAME # ----------------------------- # Check whether EXPRESSION matches any line of FILENAME, without output. func_grep () { $debug_cmd $GREP "$1" "$2" >/dev/null 2>&1 } # func_len STRING # --------------- # Set func_len_result to the length of STRING. STRING may not # start with a hyphen. test -z "$_G_HAVE_XSI_OPS" \ && (eval 'x=a/b/c; test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \ && _G_HAVE_XSI_OPS=yes if test yes = "$_G_HAVE_XSI_OPS"; then eval 'func_len () { $debug_cmd func_len_result=${#1} }' else func_len () { $debug_cmd func_len_result=`expr "$1" : ".*" 2>/dev/null || echo $max_cmd_len` } fi # func_mkdir_p DIRECTORY-PATH # --------------------------- # Make sure the entire path to DIRECTORY-PATH is available. func_mkdir_p () { $debug_cmd _G_directory_path=$1 _G_dir_list= if test -n "$_G_directory_path" && test : != "$opt_dry_run"; then # Protect directory names starting with '-' case $_G_directory_path in -*) _G_directory_path=./$_G_directory_path ;; esac # While some portion of DIR does not yet exist... while test ! -d "$_G_directory_path"; do # ...make a list in topmost first order. Use a colon delimited # list incase some portion of path contains whitespace. _G_dir_list=$_G_directory_path:$_G_dir_list # If the last portion added has no slash in it, the list is done case $_G_directory_path in */*) ;; *) break ;; esac # ...otherwise throw away the child directory and loop _G_directory_path=`$ECHO "$_G_directory_path" | $SED -e "$sed_dirname"` done _G_dir_list=`$ECHO "$_G_dir_list" | $SED 's|:*$||'` func_mkdir_p_IFS=$IFS; IFS=: for _G_dir in $_G_dir_list; do IFS=$func_mkdir_p_IFS # mkdir can fail with a 'File exist' error if two processes # try to create one of the directories concurrently. Don't # stop in that case! $MKDIR "$_G_dir" 2>/dev/null || : done IFS=$func_mkdir_p_IFS # Bail out if we (or some other process) failed to create a directory. test -d "$_G_directory_path" || \ func_fatal_error "Failed to create '$1'" fi } # func_mktempdir [BASENAME] # ------------------------- # Make a temporary directory that won't clash with other running # libtool processes, and avoids race conditions if possible. If # given, BASENAME is the basename for that directory. func_mktempdir () { $debug_cmd _G_template=${TMPDIR-/tmp}/${1-$progname} if test : = "$opt_dry_run"; then # Return a directory name, but don't create it in dry-run mode _G_tmpdir=$_G_template-$$ else # If mktemp works, use that first and foremost _G_tmpdir=`mktemp -d "$_G_template-XXXXXXXX" 2>/dev/null` if test ! -d "$_G_tmpdir"; then # Failing that, at least try and use $RANDOM to avoid a race _G_tmpdir=$_G_template-${RANDOM-0}$$ func_mktempdir_umask=`umask` umask 0077 $MKDIR "$_G_tmpdir" umask $func_mktempdir_umask fi # If we're not in dry-run mode, bomb out on failure test -d "$_G_tmpdir" || \ func_fatal_error "cannot create temporary directory '$_G_tmpdir'" fi $ECHO "$_G_tmpdir" } # func_normal_abspath PATH # ------------------------ # Remove doubled-up and trailing slashes, "." path components, # and cancel out any ".." path components in PATH after making # it an absolute path. func_normal_abspath () { $debug_cmd # These SED scripts presuppose an absolute path with a trailing slash. _G_pathcar='s|^/\([^/]*\).*$|\1|' _G_pathcdr='s|^/[^/]*||' _G_removedotparts=':dotsl s|/\./|/|g t dotsl s|/\.$|/|' _G_collapseslashes='s|/\{1,\}|/|g' _G_finalslash='s|/*$|/|' # Start from root dir and reassemble the path. func_normal_abspath_result= func_normal_abspath_tpath=$1 func_normal_abspath_altnamespace= case $func_normal_abspath_tpath in "") # Empty path, that just means $cwd. func_stripname '' '/' "`pwd`" func_normal_abspath_result=$func_stripname_result return ;; # The next three entries are used to spot a run of precisely # two leading slashes without using negated character classes; # we take advantage of case's first-match behaviour. ///*) # Unusual form of absolute path, do nothing. ;; //*) # Not necessarily an ordinary path; POSIX reserves leading '//' # and for example Cygwin uses it to access remote file shares # over CIFS/SMB, so we conserve a leading double slash if found. func_normal_abspath_altnamespace=/ ;; /*) # Absolute path, do nothing. ;; *) # Relative path, prepend $cwd. func_normal_abspath_tpath=`pwd`/$func_normal_abspath_tpath ;; esac # Cancel out all the simple stuff to save iterations. We also want # the path to end with a slash for ease of parsing, so make sure # there is one (and only one) here. func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$_G_removedotparts" -e "$_G_collapseslashes" -e "$_G_finalslash"` while :; do # Processed it all yet? if test / = "$func_normal_abspath_tpath"; then # If we ascended to the root using ".." the result may be empty now. if test -z "$func_normal_abspath_result"; then func_normal_abspath_result=/ fi break fi func_normal_abspath_tcomponent=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$_G_pathcar"` func_normal_abspath_tpath=`$ECHO "$func_normal_abspath_tpath" | $SED \ -e "$_G_pathcdr"` # Figure out what to do with it case $func_normal_abspath_tcomponent in "") # Trailing empty path component, ignore it. ;; ..) # Parent dir; strip last assembled component from result. func_dirname "$func_normal_abspath_result" func_normal_abspath_result=$func_dirname_result ;; *) # Actual path component, append it. func_append func_normal_abspath_result "/$func_normal_abspath_tcomponent" ;; esac done # Restore leading double-slash if one was found on entry. func_normal_abspath_result=$func_normal_abspath_altnamespace$func_normal_abspath_result } # func_notquiet ARG... # -------------------- # Echo program name prefixed message only when not in quiet mode. func_notquiet () { $debug_cmd $opt_quiet || func_echo ${1+"$@"} # A bug in bash halts the script if the last line of a function # fails when set -e is in force, so we need another command to # work around that: : } # func_relative_path SRCDIR DSTDIR # -------------------------------- # Set func_relative_path_result to the relative path from SRCDIR to DSTDIR. func_relative_path () { $debug_cmd func_relative_path_result= func_normal_abspath "$1" func_relative_path_tlibdir=$func_normal_abspath_result func_normal_abspath "$2" func_relative_path_tbindir=$func_normal_abspath_result # Ascend the tree starting from libdir while :; do # check if we have found a prefix of bindir case $func_relative_path_tbindir in $func_relative_path_tlibdir) # found an exact match func_relative_path_tcancelled= break ;; $func_relative_path_tlibdir*) # found a matching prefix func_stripname "$func_relative_path_tlibdir" '' "$func_relative_path_tbindir" func_relative_path_tcancelled=$func_stripname_result if test -z "$func_relative_path_result"; then func_relative_path_result=. fi break ;; *) func_dirname $func_relative_path_tlibdir func_relative_path_tlibdir=$func_dirname_result if test -z "$func_relative_path_tlibdir"; then # Have to descend all the way to the root! func_relative_path_result=../$func_relative_path_result func_relative_path_tcancelled=$func_relative_path_tbindir break fi func_relative_path_result=../$func_relative_path_result ;; esac done # Now calculate path; take care to avoid doubling-up slashes. func_stripname '' '/' "$func_relative_path_result" func_relative_path_result=$func_stripname_result func_stripname '/' '/' "$func_relative_path_tcancelled" if test -n "$func_stripname_result"; then func_append func_relative_path_result "/$func_stripname_result" fi # Normalisation. If bindir is libdir, return '.' else relative path. if test -n "$func_relative_path_result"; then func_stripname './' '' "$func_relative_path_result" func_relative_path_result=$func_stripname_result fi test -n "$func_relative_path_result" || func_relative_path_result=. : } # func_quote_portable EVAL ARG # ---------------------------- # Internal function to portably implement func_quote_arg. Note that we still # keep attention to performance here so we as much as possible try to avoid # calling sed binary (so far O(N) complexity as long as func_append is O(1)). func_quote_portable () { $debug_cmd $require_check_ifs_backslash func_quote_portable_result=$2 # one-time-loop (easy break) while true do if $1; then func_quote_portable_result=`$ECHO "$2" | $SED \ -e "$sed_double_quote_subst" -e "$sed_double_backslash"` break fi # Quote for eval. case $func_quote_portable_result in *[\\\`\"\$]*) # Fallback to sed for $func_check_bs_ifs_broken=:, or when the string # contains the shell wildcard characters. case $check_ifs_backshlash_broken$func_quote_portable_result in :*|*[\[\*\?]*) func_quote_portable_result=`$ECHO "$func_quote_portable_result" \ | $SED "$sed_quote_subst"` break ;; esac func_quote_portable_old_IFS=$IFS for _G_char in '\' '`' '"' '$' do # STATE($1) PREV($2) SEPARATOR($3) set start "" "" func_quote_portable_result=dummy"$_G_char$func_quote_portable_result$_G_char"dummy IFS=$_G_char for _G_part in $func_quote_portable_result do case $1 in quote) func_append func_quote_portable_result "$3$2" set quote "$_G_part" "\\$_G_char" ;; start) set first "" "" func_quote_portable_result= ;; first) set quote "$_G_part" "" ;; esac done done IFS=$func_quote_portable_old_IFS ;; *) ;; esac break done func_quote_portable_unquoted_result=$func_quote_portable_result case $func_quote_portable_result in # double-quote args containing shell metacharacters to delay # word splitting, command substitution and variable expansion # for a subsequent eval. # many bourne shells cannot handle close brackets correctly # in scan sets, so we specify it separately. *[\[\~\#\^\&\*\(\)\{\}\|\;\<\>\?\'\ \ ]*|*]*|"") func_quote_portable_result=\"$func_quote_portable_result\" ;; esac } # func_quotefast_eval ARG # ----------------------- # Quote one ARG (internal). This is equivalent to 'func_quote_arg eval ARG', # but optimized for speed. Result is stored in $func_quotefast_eval. if test xyes = `(x=; printf -v x %q yes; echo x"$x") 2>/dev/null`; then printf -v _GL_test_printf_tilde %q '~' if test '\~' = "$_GL_test_printf_tilde"; then func_quotefast_eval () { printf -v func_quotefast_eval_result %q "$1" } else # Broken older Bash implementations. Make those faster too if possible. func_quotefast_eval () { case $1 in '~'*) func_quote_portable false "$1" func_quotefast_eval_result=$func_quote_portable_result ;; *) printf -v func_quotefast_eval_result %q "$1" ;; esac } fi else func_quotefast_eval () { func_quote_portable false "$1" func_quotefast_eval_result=$func_quote_portable_result } fi # func_quote_arg MODEs ARG # ------------------------ # Quote one ARG to be evaled later. MODEs argument may contain zero or more # specifiers listed below separated by ',' character. This function returns two # values: # i) func_quote_arg_result # double-quoted (when needed), suitable for a subsequent eval # ii) func_quote_arg_unquoted_result # has all characters that are still active within double # quotes backslashified. Available only if 'unquoted' is specified. # # Available modes: # ---------------- # 'eval' (default) # - escape shell special characters # 'expand' # - the same as 'eval'; but do not quote variable references # 'pretty' # - request aesthetic output, i.e. '"a b"' instead of 'a\ b'. This might # be used later in func_quote to get output like: 'echo "a b"' instead # of 'echo a\ b'. This is slower than default on some shells. # 'unquoted' # - produce also $func_quote_arg_unquoted_result which does not contain # wrapping double-quotes. # # Examples for 'func_quote_arg pretty,unquoted string': # # string | *_result | *_unquoted_result # ------------+-----------------------+------------------- # " | \" | \" # a b | "a b" | a b # "a b" | "\"a b\"" | \"a b\" # * | "*" | * # z="${x-$y}" | "z=\"\${x-\$y}\"" | z=\"\${x-\$y}\" # # Examples for 'func_quote_arg pretty,unquoted,expand string': # # string | *_result | *_unquoted_result # --------------+---------------------+-------------------- # z="${x-$y}" | "z=\"${x-$y}\"" | z=\"${x-$y}\" func_quote_arg () { _G_quote_expand=false case ,$1, in *,expand,*) _G_quote_expand=: ;; esac case ,$1, in *,pretty,*|*,expand,*|*,unquoted,*) func_quote_portable $_G_quote_expand "$2" func_quote_arg_result=$func_quote_portable_result func_quote_arg_unquoted_result=$func_quote_portable_unquoted_result ;; *) # Faster quote-for-eval for some shells. func_quotefast_eval "$2" func_quote_arg_result=$func_quotefast_eval_result ;; esac } # func_quote MODEs ARGs... # ------------------------ # Quote all ARGs to be evaled later and join them into single command. See # func_quote_arg's description for more info. func_quote () { $debug_cmd _G_func_quote_mode=$1 ; shift func_quote_result= while test 0 -lt $#; do func_quote_arg "$_G_func_quote_mode" "$1" if test -n "$func_quote_result"; then func_append func_quote_result " $func_quote_arg_result" else func_append func_quote_result "$func_quote_arg_result" fi shift done } # func_stripname PREFIX SUFFIX NAME # --------------------------------- # strip PREFIX and SUFFIX from NAME, and store in func_stripname_result. # PREFIX and SUFFIX must not contain globbing or regex special # characters, hashes, percent signs, but SUFFIX may contain a leading # dot (in which case that matches only a dot). if test yes = "$_G_HAVE_XSI_OPS"; then eval 'func_stripname () { $debug_cmd # pdksh 5.2.14 does not do ${X%$Y} correctly if both X and Y are # positional parameters, so assign one to ordinary variable first. func_stripname_result=$3 func_stripname_result=${func_stripname_result#"$1"} func_stripname_result=${func_stripname_result%"$2"} }' else func_stripname () { $debug_cmd case $2 in .*) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%\\\\$2\$%%"`;; *) func_stripname_result=`$ECHO "$3" | $SED -e "s%^$1%%" -e "s%$2\$%%"`;; esac } fi # func_show_eval CMD [FAIL_EXP] # ----------------------------- # Unless opt_quiet is true, then output CMD. Then, if opt_dryrun is # not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP # is given, then evaluate it. func_show_eval () { $debug_cmd _G_cmd=$1 _G_fail_exp=${2-':'} func_quote_arg pretty,expand "$_G_cmd" eval "func_notquiet $func_quote_arg_result" $opt_dry_run || { eval "$_G_cmd" _G_status=$? if test 0 -ne "$_G_status"; then eval "(exit $_G_status); $_G_fail_exp" fi } } # func_show_eval_locale CMD [FAIL_EXP] # ------------------------------------ # Unless opt_quiet is true, then output CMD. Then, if opt_dryrun is # not true, evaluate CMD. If the evaluation of CMD fails, and FAIL_EXP # is given, then evaluate it. Use the saved locale for evaluation. func_show_eval_locale () { $debug_cmd _G_cmd=$1 _G_fail_exp=${2-':'} $opt_quiet || { func_quote_arg expand,pretty "$_G_cmd" eval "func_echo $func_quote_arg_result" } $opt_dry_run || { eval "$_G_user_locale $_G_cmd" _G_status=$? eval "$_G_safe_locale" if test 0 -ne "$_G_status"; then eval "(exit $_G_status); $_G_fail_exp" fi } } # func_tr_sh # ---------- # Turn $1 into a string suitable for a shell variable name. # Result is stored in $func_tr_sh_result. All characters # not in the set a-zA-Z0-9_ are replaced with '_'. Further, # if $1 begins with a digit, a '_' is prepended as well. func_tr_sh () { $debug_cmd case $1 in [0-9]* | *[!a-zA-Z0-9_]*) func_tr_sh_result=`$ECHO "$1" | $SED -e 's/^\([0-9]\)/_\1/' -e 's/[^a-zA-Z0-9_]/_/g'` ;; * ) func_tr_sh_result=$1 ;; esac } # func_verbose ARG... # ------------------- # Echo program name prefixed message in verbose mode only. func_verbose () { $debug_cmd $opt_verbose && func_echo "$*" : } # func_warn_and_continue ARG... # ----------------------------- # Echo program name prefixed warning message to standard error. func_warn_and_continue () { $debug_cmd $require_term_colors func_echo_infix_1 "${tc_red}warning$tc_reset" "$*" >&2 } # func_warning CATEGORY ARG... # ---------------------------- # Echo program name prefixed warning message to standard error. Warning # messages can be filtered according to CATEGORY, where this function # elides messages where CATEGORY is not listed in the global variable # 'opt_warning_types'. func_warning () { $debug_cmd # CATEGORY must be in the warning_categories list! case " $warning_categories " in *" $1 "*) ;; *) func_internal_error "invalid warning category '$1'" ;; esac _G_category=$1 shift case " $opt_warning_types " in *" $_G_category "*) $warning_func ${1+"$@"} ;; esac } # func_sort_ver VER1 VER2 # ----------------------- # 'sort -V' is not generally available. # Note this deviates from the version comparison in automake # in that it treats 1.5 < 1.5.0, and treats 1.4.4a < 1.4-p3a # but this should suffice as we won't be specifying old # version formats or redundant trailing .0 in bootstrap.conf. # If we did want full compatibility then we should probably # use m4_version_compare from autoconf. func_sort_ver () { $debug_cmd printf '%s\n%s\n' "$1" "$2" \ | sort -t. -k 1,1n -k 2,2n -k 3,3n -k 4,4n -k 5,5n -k 6,6n -k 7,7n -k 8,8n -k 9,9n } # func_lt_ver PREV CURR # --------------------- # Return true if PREV and CURR are in the correct order according to # func_sort_ver, otherwise false. Use it like this: # # func_lt_ver "$prev_ver" "$proposed_ver" || func_fatal_error "..." func_lt_ver () { $debug_cmd test "x$1" = x`func_sort_ver "$1" "$2" | $SED 1q` } # Local variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-pattern: "10/scriptversion=%:y-%02m-%02d.%02H; # UTC" # time-stamp-time-zone: "UTC" # End: #! /bin/sh # A portable, pluggable option parser for Bourne shell. # Written by Gary V. Vaughan, 2010 # This is free software. There is NO warranty; not even for # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. # # Copyright (C) 2010-2019, 2021 Bootstrap Authors # # This file is dual licensed under the terms of the MIT license # , and GPL version 2 or later # . You must apply one of # these licenses when using or redistributing this software or any of # the files within it. See the URLs above, or the file `LICENSE` # included in the Bootstrap distribution for the full license texts. # Please report bugs or propose patches to: # # Set a version string for this script. scriptversion=2019-02-19.15; # UTC ## ------ ## ## Usage. ## ## ------ ## # This file is a library for parsing options in your shell scripts along # with assorted other useful supporting features that you can make use # of too. # # For the simplest scripts you might need only: # # #!/bin/sh # . relative/path/to/funclib.sh # . relative/path/to/options-parser # scriptversion=1.0 # func_options ${1+"$@"} # eval set dummy "$func_options_result"; shift # ...rest of your script... # # In order for the '--version' option to work, you will need to have a # suitably formatted comment like the one at the top of this file # starting with '# Written by ' and ending with '# Copyright'. # # For '-h' and '--help' to work, you will also need a one line # description of your script's purpose in a comment directly above the # '# Written by ' line, like the one at the top of this file. # # The default options also support '--debug', which will turn on shell # execution tracing (see the comment above debug_cmd below for another # use), and '--verbose' and the func_verbose function to allow your script # to display verbose messages only when your user has specified # '--verbose'. # # After sourcing this file, you can plug in processing for additional # options by amending the variables from the 'Configuration' section # below, and following the instructions in the 'Option parsing' # section further down. ## -------------- ## ## Configuration. ## ## -------------- ## # You should override these variables in your script after sourcing this # file so that they reflect the customisations you have added to the # option parser. # The usage line for option parsing errors and the start of '-h' and # '--help' output messages. You can embed shell variables for delayed # expansion at the time the message is displayed, but you will need to # quote other shell meta-characters carefully to prevent them being # expanded when the contents are evaled. usage='$progpath [OPTION]...' # Short help message in response to '-h' and '--help'. Add to this or # override it after sourcing this library to reflect the full set of # options your script accepts. usage_message="\ --debug enable verbose shell tracing -W, --warnings=CATEGORY report the warnings falling in CATEGORY [all] -v, --verbose verbosely report processing --version print version information and exit -h, --help print short or long help message and exit " # Additional text appended to 'usage_message' in response to '--help'. long_help_message=" Warning categories include: 'all' show all warnings 'none' turn off all the warnings 'error' warnings are treated as fatal errors" # Help message printed before fatal option parsing errors. fatal_help="Try '\$progname --help' for more information." ## ------------------------- ## ## Hook function management. ## ## ------------------------- ## # This section contains functions for adding, removing, and running hooks # in the main code. A hook is just a list of function names that can be # run in order later on. # func_hookable FUNC_NAME # ----------------------- # Declare that FUNC_NAME will run hooks added with # 'func_add_hook FUNC_NAME ...'. func_hookable () { $debug_cmd func_append hookable_fns " $1" } # func_add_hook FUNC_NAME HOOK_FUNC # --------------------------------- # Request that FUNC_NAME call HOOK_FUNC before it returns. FUNC_NAME must # first have been declared "hookable" by a call to 'func_hookable'. func_add_hook () { $debug_cmd case " $hookable_fns " in *" $1 "*) ;; *) func_fatal_error "'$1' does not accept hook functions." ;; esac eval func_append ${1}_hooks '" $2"' } # func_remove_hook FUNC_NAME HOOK_FUNC # ------------------------------------ # Remove HOOK_FUNC from the list of hook functions to be called by # FUNC_NAME. func_remove_hook () { $debug_cmd eval ${1}_hooks='`$ECHO "\$'$1'_hooks" |$SED "s| '$2'||"`' } # func_propagate_result FUNC_NAME_A FUNC_NAME_B # --------------------------------------------- # If the *_result variable of FUNC_NAME_A _is set_, assign its value to # *_result variable of FUNC_NAME_B. func_propagate_result () { $debug_cmd func_propagate_result_result=: if eval "test \"\${${1}_result+set}\" = set" then eval "${2}_result=\$${1}_result" else func_propagate_result_result=false fi } # func_run_hooks FUNC_NAME [ARG]... # --------------------------------- # Run all hook functions registered to FUNC_NAME. # It's assumed that the list of hook functions contains nothing more # than a whitespace-delimited list of legal shell function names, and # no effort is wasted trying to catch shell meta-characters or preserve # whitespace. func_run_hooks () { $debug_cmd case " $hookable_fns " in *" $1 "*) ;; *) func_fatal_error "'$1' does not support hook functions." ;; esac eval _G_hook_fns=\$$1_hooks; shift for _G_hook in $_G_hook_fns; do func_unset "${_G_hook}_result" eval $_G_hook '${1+"$@"}' func_propagate_result $_G_hook func_run_hooks if $func_propagate_result_result; then eval set dummy "$func_run_hooks_result"; shift fi done } ## --------------- ## ## Option parsing. ## ## --------------- ## # In order to add your own option parsing hooks, you must accept the # full positional parameter list from your hook function. You may remove # or edit any options that you action, and then pass back the remaining # unprocessed options in '_result', escaped # suitably for 'eval'. # # The '_result' variable is automatically unset # before your hook gets called; for best performance, only set the # *_result variable when necessary (i.e. don't call the 'func_quote' # function unnecessarily because it can be an expensive operation on some # machines). # # Like this: # # my_options_prep () # { # $debug_cmd # # # Extend the existing usage message. # usage_message=$usage_message' # -s, --silent don'\''t print informational messages # ' # # No change in '$@' (ignored completely by this hook). Leave # # my_options_prep_result variable intact. # } # func_add_hook func_options_prep my_options_prep # # # my_silent_option () # { # $debug_cmd # # args_changed=false # # # Note that, for efficiency, we parse as many options as we can # # recognise in a loop before passing the remainder back to the # # caller on the first unrecognised argument we encounter. # while test $# -gt 0; do # opt=$1; shift # case $opt in # --silent|-s) opt_silent=: # args_changed=: # ;; # # Separate non-argument short options: # -s*) func_split_short_opt "$_G_opt" # set dummy "$func_split_short_opt_name" \ # "-$func_split_short_opt_arg" ${1+"$@"} # shift # args_changed=: # ;; # *) # Make sure the first unrecognised option "$_G_opt" # # is added back to "$@" in case we need it later, # # if $args_changed was set to 'true'. # set dummy "$_G_opt" ${1+"$@"}; shift; break ;; # esac # done # # # Only call 'func_quote' here if we processed at least one argument. # if $args_changed; then # func_quote eval ${1+"$@"} # my_silent_option_result=$func_quote_result # fi # } # func_add_hook func_parse_options my_silent_option # # # my_option_validation () # { # $debug_cmd # # $opt_silent && $opt_verbose && func_fatal_help "\ # '--silent' and '--verbose' options are mutually exclusive." # } # func_add_hook func_validate_options my_option_validation # # You'll also need to manually amend $usage_message to reflect the extra # options you parse. It's preferable to append if you can, so that # multiple option parsing hooks can be added safely. # func_options_finish [ARG]... # ---------------------------- # Finishing the option parse loop (call 'func_options' hooks ATM). func_options_finish () { $debug_cmd func_run_hooks func_options ${1+"$@"} func_propagate_result func_run_hooks func_options_finish } # func_options [ARG]... # --------------------- # All the functions called inside func_options are hookable. See the # individual implementations for details. func_hookable func_options func_options () { $debug_cmd _G_options_quoted=false for my_func in options_prep parse_options validate_options options_finish do func_unset func_${my_func}_result func_unset func_run_hooks_result eval func_$my_func '${1+"$@"}' func_propagate_result func_$my_func func_options if $func_propagate_result_result; then eval set dummy "$func_options_result"; shift _G_options_quoted=: fi done $_G_options_quoted || { # As we (func_options) are top-level options-parser function and # nobody quoted "$@" for us yet, we need to do it explicitly for # caller. func_quote eval ${1+"$@"} func_options_result=$func_quote_result } } # func_options_prep [ARG]... # -------------------------- # All initialisations required before starting the option parse loop. # Note that when calling hook functions, we pass through the list of # positional parameters. If a hook function modifies that list, and # needs to propagate that back to rest of this script, then the complete # modified list must be put in 'func_run_hooks_result' before returning. func_hookable func_options_prep func_options_prep () { $debug_cmd # Option defaults: opt_verbose=false opt_warning_types= func_run_hooks func_options_prep ${1+"$@"} func_propagate_result func_run_hooks func_options_prep } # func_parse_options [ARG]... # --------------------------- # The main option parsing loop. func_hookable func_parse_options func_parse_options () { $debug_cmd _G_parse_options_requote=false # this just eases exit handling while test $# -gt 0; do # Defer to hook functions for initial option parsing, so they # get priority in the event of reusing an option name. func_run_hooks func_parse_options ${1+"$@"} func_propagate_result func_run_hooks func_parse_options if $func_propagate_result_result; then eval set dummy "$func_parse_options_result"; shift # Even though we may have changed "$@", we passed the "$@" array # down into the hook and it quoted it for us (because we are in # this if-branch). No need to quote it again. _G_parse_options_requote=false fi # Break out of the loop if we already parsed every option. test $# -gt 0 || break # We expect that one of the options parsed in this function matches # and thus we remove _G_opt from "$@" and need to re-quote. _G_match_parse_options=: _G_opt=$1 shift case $_G_opt in --debug|-x) debug_cmd='set -x' func_echo "enabling shell trace mode" >&2 $debug_cmd ;; --no-warnings|--no-warning|--no-warn) set dummy --warnings none ${1+"$@"} shift ;; --warnings|--warning|-W) if test $# = 0 && func_missing_arg $_G_opt; then _G_parse_options_requote=: break fi case " $warning_categories $1" in *" $1 "*) # trailing space prevents matching last $1 above func_append_uniq opt_warning_types " $1" ;; *all) opt_warning_types=$warning_categories ;; *none) opt_warning_types=none warning_func=: ;; *error) opt_warning_types=$warning_categories warning_func=func_fatal_error ;; *) func_fatal_error \ "unsupported warning category: '$1'" ;; esac shift ;; --verbose|-v) opt_verbose=: ;; --version) func_version ;; -\?|-h) func_usage ;; --help) func_help ;; # Separate optargs to long options (plugins may need this): --*=*) func_split_equals "$_G_opt" set dummy "$func_split_equals_lhs" \ "$func_split_equals_rhs" ${1+"$@"} shift ;; # Separate optargs to short options: -W*) func_split_short_opt "$_G_opt" set dummy "$func_split_short_opt_name" \ "$func_split_short_opt_arg" ${1+"$@"} shift ;; # Separate non-argument short options: -\?*|-h*|-v*|-x*) func_split_short_opt "$_G_opt" set dummy "$func_split_short_opt_name" \ "-$func_split_short_opt_arg" ${1+"$@"} shift ;; --) _G_parse_options_requote=: ; break ;; -*) func_fatal_help "unrecognised option: '$_G_opt'" ;; *) set dummy "$_G_opt" ${1+"$@"}; shift _G_match_parse_options=false break ;; esac if $_G_match_parse_options; then _G_parse_options_requote=: fi done if $_G_parse_options_requote; then # save modified positional parameters for caller func_quote eval ${1+"$@"} func_parse_options_result=$func_quote_result fi } # func_validate_options [ARG]... # ------------------------------ # Perform any sanity checks on option settings and/or unconsumed # arguments. func_hookable func_validate_options func_validate_options () { $debug_cmd # Display all warnings if -W was not given. test -n "$opt_warning_types" || opt_warning_types=" $warning_categories" func_run_hooks func_validate_options ${1+"$@"} func_propagate_result func_run_hooks func_validate_options # Bail if the options were screwed! $exit_cmd $EXIT_FAILURE } ## ----------------- ## ## Helper functions. ## ## ----------------- ## # This section contains the helper functions used by the rest of the # hookable option parser framework in ascii-betical order. # func_fatal_help ARG... # ---------------------- # Echo program name prefixed message to standard error, followed by # a help hint, and exit. func_fatal_help () { $debug_cmd eval \$ECHO \""Usage: $usage"\" eval \$ECHO \""$fatal_help"\" func_error ${1+"$@"} exit $EXIT_FAILURE } # func_help # --------- # Echo long help message to standard output and exit. func_help () { $debug_cmd func_usage_message $ECHO "$long_help_message" exit 0 } # func_missing_arg ARGNAME # ------------------------ # Echo program name prefixed message to standard error and set global # exit_cmd. func_missing_arg () { $debug_cmd func_error "Missing argument for '$1'." exit_cmd=exit } # func_split_equals STRING # ------------------------ # Set func_split_equals_lhs and func_split_equals_rhs shell variables # after splitting STRING at the '=' sign. test -z "$_G_HAVE_XSI_OPS" \ && (eval 'x=a/b/c; test 5aa/bb/cc = "${#x}${x%%/*}${x%/*}${x#*/}${x##*/}"') 2>/dev/null \ && _G_HAVE_XSI_OPS=yes if test yes = "$_G_HAVE_XSI_OPS" then # This is an XSI compatible shell, allowing a faster implementation... eval 'func_split_equals () { $debug_cmd func_split_equals_lhs=${1%%=*} func_split_equals_rhs=${1#*=} if test "x$func_split_equals_lhs" = "x$1"; then func_split_equals_rhs= fi }' else # ...otherwise fall back to using expr, which is often a shell builtin. func_split_equals () { $debug_cmd func_split_equals_lhs=`expr "x$1" : 'x\([^=]*\)'` func_split_equals_rhs= test "x$func_split_equals_lhs=" = "x$1" \ || func_split_equals_rhs=`expr "x$1" : 'x[^=]*=\(.*\)$'` } fi #func_split_equals # func_split_short_opt SHORTOPT # ----------------------------- # Set func_split_short_opt_name and func_split_short_opt_arg shell # variables after splitting SHORTOPT after the 2nd character. if test yes = "$_G_HAVE_XSI_OPS" then # This is an XSI compatible shell, allowing a faster implementation... eval 'func_split_short_opt () { $debug_cmd func_split_short_opt_arg=${1#??} func_split_short_opt_name=${1%"$func_split_short_opt_arg"} }' else # ...otherwise fall back to using expr, which is often a shell builtin. func_split_short_opt () { $debug_cmd func_split_short_opt_name=`expr "x$1" : 'x\(-.\)'` func_split_short_opt_arg=`expr "x$1" : 'x-.\(.*\)$'` } fi #func_split_short_opt # func_usage # ---------- # Echo short help message to standard output and exit. func_usage () { $debug_cmd func_usage_message $ECHO "Run '$progname --help |${PAGER-more}' for full usage" exit 0 } # func_usage_message # ------------------ # Echo short help message to standard output. func_usage_message () { $debug_cmd eval \$ECHO \""Usage: $usage"\" echo $SED -n 's|^# || /^Written by/{ x;p;x } h /^Written by/q' < "$progpath" echo eval \$ECHO \""$usage_message"\" } # func_version # ------------ # Echo version message to standard output and exit. # The version message is extracted from the calling file's header # comments, with leading '# ' stripped: # 1. First display the progname and version # 2. Followed by the header comment line matching /^# Written by / # 3. Then a blank line followed by the first following line matching # /^# Copyright / # 4. Immediately followed by any lines between the previous matches, # except lines preceding the intervening completely blank line. # For example, see the header comments of this file. func_version () { $debug_cmd printf '%s\n' "$progname $scriptversion" $SED -n ' /^# Written by /!b s|^# ||; p; n :fwd2blnk /./ { n b fwd2blnk } p; n :holdwrnt s|^# || s|^# *$|| /^Copyright /!{ /./H n b holdwrnt } s|\((C)\)[ 0-9,-]*[ ,-]\([1-9][0-9]* \)|\1 \2| G s|\(\n\)\n*|\1|g p; q' < "$progpath" exit $? } # Local variables: # mode: shell-script # sh-indentation: 2 # eval: (add-hook 'before-save-hook 'time-stamp) # time-stamp-pattern: "30/scriptversion=%:y-%02m-%02d.%02H; # UTC" # time-stamp-time-zone: "UTC" # End: # Set a version string. scriptversion='(GNU libtool) 2.4.7' # func_echo ARG... # ---------------- # Libtool also displays the current mode in messages, so override # funclib.sh func_echo with this custom definition. func_echo () { $debug_cmd _G_message=$* func_echo_IFS=$IFS IFS=$nl for _G_line in $_G_message; do IFS=$func_echo_IFS $ECHO "$progname${opt_mode+: $opt_mode}: $_G_line" done IFS=$func_echo_IFS } # func_warning ARG... # ------------------- # Libtool warnings are not categorized, so override funclib.sh # func_warning with this simpler definition. func_warning () { $debug_cmd $warning_func ${1+"$@"} } ## ---------------- ## ## Options parsing. ## ## ---------------- ## # Hook in the functions to make sure our own options are parsed during # the option parsing loop. usage='$progpath [OPTION]... [MODE-ARG]...' # Short help message in response to '-h'. usage_message="Options: --config show all configuration variables --debug enable verbose shell tracing -n, --dry-run display commands without modifying any files --features display basic configuration information and exit --mode=MODE use operation mode MODE --no-warnings equivalent to '-Wnone' --preserve-dup-deps don't remove duplicate dependency libraries --quiet, --silent don't print informational messages --tag=TAG use configuration variables from tag TAG -v, --verbose print more informational messages than default --version print version information -W, --warnings=CATEGORY report the warnings falling in CATEGORY [all] -h, --help, --help-all print short, long, or detailed help message " # Additional text appended to 'usage_message' in response to '--help'. func_help () { $debug_cmd func_usage_message $ECHO "$long_help_message MODE must be one of the following: clean remove files from the build directory compile compile a source file into a libtool object execute automatically set library path, then run a program finish complete the installation of libtool libraries install install libraries or executables link create a library or an executable uninstall remove libraries from an installed directory MODE-ARGS vary depending on the MODE. When passed as first option, '--mode=MODE' may be abbreviated as 'MODE' or a unique abbreviation of that. Try '$progname --help --mode=MODE' for a more detailed description of MODE. When reporting a bug, please describe a test case to reproduce it and include the following information: host-triplet: $host shell: $SHELL compiler: $LTCC compiler flags: $LTCFLAGS linker: $LD (gnu? $with_gnu_ld) version: $progname (GNU libtool) 2.4.7 automake: `($AUTOMAKE --version) 2>/dev/null |$SED 1q` autoconf: `($AUTOCONF --version) 2>/dev/null |$SED 1q` Report bugs to . GNU libtool home page: . General help using GNU software: ." exit 0 } # func_lo2o OBJECT-NAME # --------------------- # Transform OBJECT-NAME from a '.lo' suffix to the platform specific # object suffix. lo2o=s/\\.lo\$/.$objext/ o2lo=s/\\.$objext\$/.lo/ if test yes = "$_G_HAVE_XSI_OPS"; then eval 'func_lo2o () { case $1 in *.lo) func_lo2o_result=${1%.lo}.$objext ;; * ) func_lo2o_result=$1 ;; esac }' # func_xform LIBOBJ-OR-SOURCE # --------------------------- # Transform LIBOBJ-OR-SOURCE from a '.o' or '.c' (or otherwise) # suffix to a '.lo' libtool-object suffix. eval 'func_xform () { func_xform_result=${1%.*}.lo }' else # ...otherwise fall back to using sed. func_lo2o () { func_lo2o_result=`$ECHO "$1" | $SED "$lo2o"` } func_xform () { func_xform_result=`$ECHO "$1" | $SED 's|\.[^.]*$|.lo|'` } fi # func_fatal_configuration ARG... # ------------------------------- # Echo program name prefixed message to standard error, followed by # a configuration failure hint, and exit. func_fatal_configuration () { func_fatal_error ${1+"$@"} \ "See the $PACKAGE documentation for more information." \ "Fatal configuration error." } # func_config # ----------- # Display the configuration for all the tags in this script. func_config () { re_begincf='^# ### BEGIN LIBTOOL' re_endcf='^# ### END LIBTOOL' # Default configuration. $SED "1,/$re_begincf CONFIG/d;/$re_endcf CONFIG/,\$d" < "$progpath" # Now print the configurations for the tags. for tagname in $taglist; do $SED -n "/$re_begincf TAG CONFIG: $tagname\$/,/$re_endcf TAG CONFIG: $tagname\$/p" < "$progpath" done exit $? } # func_features # ------------- # Display the features supported by this script. func_features () { echo "host: $host" if test yes = "$build_libtool_libs"; then echo "enable shared libraries" else echo "disable shared libraries" fi if test yes = "$build_old_libs"; then echo "enable static libraries" else echo "disable static libraries" fi exit $? } # func_enable_tag TAGNAME # ----------------------- # Verify that TAGNAME is valid, and either flag an error and exit, or # enable the TAGNAME tag. We also add TAGNAME to the global $taglist # variable here. func_enable_tag () { # Global variable: tagname=$1 re_begincf="^# ### BEGIN LIBTOOL TAG CONFIG: $tagname\$" re_endcf="^# ### END LIBTOOL TAG CONFIG: $tagname\$" sed_extractcf=/$re_begincf/,/$re_endcf/p # Validate tagname. case $tagname in *[!-_A-Za-z0-9,/]*) func_fatal_error "invalid tag name: $tagname" ;; esac # Don't test for the "default" C tag, as we know it's # there but not specially marked. case $tagname in CC) ;; *) if $GREP "$re_begincf" "$progpath" >/dev/null 2>&1; then taglist="$taglist $tagname" # Evaluate the configuration. Be careful to quote the path # and the sed script, to avoid splitting on whitespace, but # also don't use non-portable quotes within backquotes within # quotes we have to do it in 2 steps: extractedcf=`$SED -n -e "$sed_extractcf" < "$progpath"` eval "$extractedcf" else func_error "ignoring unknown tag $tagname" fi ;; esac } # func_check_version_match # ------------------------ # Ensure that we are using m4 macros, and libtool script from the same # release of libtool. func_check_version_match () { if test "$package_revision" != "$macro_revision"; then if test "$VERSION" != "$macro_version"; then if test -z "$macro_version"; then cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, but the $progname: definition of this LT_INIT comes from an older release. $progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION $progname: and run autoconf again. _LT_EOF else cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, but the $progname: definition of this LT_INIT comes from $PACKAGE $macro_version. $progname: You should recreate aclocal.m4 with macros from $PACKAGE $VERSION $progname: and run autoconf again. _LT_EOF fi else cat >&2 <<_LT_EOF $progname: Version mismatch error. This is $PACKAGE $VERSION, revision $package_revision, $progname: but the definition of this LT_INIT comes from revision $macro_revision. $progname: You should recreate aclocal.m4 with macros from revision $package_revision $progname: of $PACKAGE $VERSION and run autoconf again. _LT_EOF fi exit $EXIT_MISMATCH fi } # libtool_options_prep [ARG]... # ----------------------------- # Preparation for options parsed by libtool. libtool_options_prep () { $debug_mode # Option defaults: opt_config=false opt_dlopen= opt_dry_run=false opt_help=false opt_mode= opt_preserve_dup_deps=false opt_quiet=false nonopt= preserve_args= _G_rc_lt_options_prep=: # Shorthand for --mode=foo, only valid as the first argument case $1 in clean|clea|cle|cl) shift; set dummy --mode clean ${1+"$@"}; shift ;; compile|compil|compi|comp|com|co|c) shift; set dummy --mode compile ${1+"$@"}; shift ;; execute|execut|execu|exec|exe|ex|e) shift; set dummy --mode execute ${1+"$@"}; shift ;; finish|finis|fini|fin|fi|f) shift; set dummy --mode finish ${1+"$@"}; shift ;; install|instal|insta|inst|ins|in|i) shift; set dummy --mode install ${1+"$@"}; shift ;; link|lin|li|l) shift; set dummy --mode link ${1+"$@"}; shift ;; uninstall|uninstal|uninsta|uninst|unins|unin|uni|un|u) shift; set dummy --mode uninstall ${1+"$@"}; shift ;; *) _G_rc_lt_options_prep=false ;; esac if $_G_rc_lt_options_prep; then # Pass back the list of options. func_quote eval ${1+"$@"} libtool_options_prep_result=$func_quote_result fi } func_add_hook func_options_prep libtool_options_prep # libtool_parse_options [ARG]... # --------------------------------- # Provide handling for libtool specific options. libtool_parse_options () { $debug_cmd _G_rc_lt_parse_options=false # Perform our own loop to consume as many options as possible in # each iteration. while test $# -gt 0; do _G_match_lt_parse_options=: _G_opt=$1 shift case $_G_opt in --dry-run|--dryrun|-n) opt_dry_run=: ;; --config) func_config ;; --dlopen|-dlopen) opt_dlopen="${opt_dlopen+$opt_dlopen }$1" shift ;; --preserve-dup-deps) opt_preserve_dup_deps=: ;; --features) func_features ;; --finish) set dummy --mode finish ${1+"$@"}; shift ;; --help) opt_help=: ;; --help-all) opt_help=': help-all' ;; --mode) test $# = 0 && func_missing_arg $_G_opt && break opt_mode=$1 case $1 in # Valid mode arguments: clean|compile|execute|finish|install|link|relink|uninstall) ;; # Catch anything else as an error *) func_error "invalid argument for $_G_opt" exit_cmd=exit break ;; esac shift ;; --no-silent|--no-quiet) opt_quiet=false func_append preserve_args " $_G_opt" ;; --no-warnings|--no-warning|--no-warn) opt_warning=false func_append preserve_args " $_G_opt" ;; --no-verbose) opt_verbose=false func_append preserve_args " $_G_opt" ;; --silent|--quiet) opt_quiet=: opt_verbose=false func_append preserve_args " $_G_opt" ;; --tag) test $# = 0 && func_missing_arg $_G_opt && break opt_tag=$1 func_append preserve_args " $_G_opt $1" func_enable_tag "$1" shift ;; --verbose|-v) opt_quiet=false opt_verbose=: func_append preserve_args " $_G_opt" ;; # An option not handled by this hook function: *) set dummy "$_G_opt" ${1+"$@"} ; shift _G_match_lt_parse_options=false break ;; esac $_G_match_lt_parse_options && _G_rc_lt_parse_options=: done if $_G_rc_lt_parse_options; then # save modified positional parameters for caller func_quote eval ${1+"$@"} libtool_parse_options_result=$func_quote_result fi } func_add_hook func_parse_options libtool_parse_options # libtool_validate_options [ARG]... # --------------------------------- # Perform any sanity checks on option settings and/or unconsumed # arguments. libtool_validate_options () { # save first non-option argument if test 0 -lt $#; then nonopt=$1 shift fi # preserve --debug test : = "$debug_cmd" || func_append preserve_args " --debug" # Keeping compiler generated duplicates in $postdeps and $predeps is not # harmful, and is necessary in a majority of systems that use it to satisfy # symbol dependencies. opt_duplicate_compiler_generated_deps=: $opt_help || { # Sanity checks first: func_check_version_match test yes != "$build_libtool_libs" \ && test yes != "$build_old_libs" \ && func_fatal_configuration "not configured to build any kind of library" # Darwin sucks eval std_shrext=\"$shrext_cmds\" # Only execute mode is allowed to have -dlopen flags. if test -n "$opt_dlopen" && test execute != "$opt_mode"; then func_error "unrecognized option '-dlopen'" $ECHO "$help" 1>&2 exit $EXIT_FAILURE fi # Change the help message to a mode-specific one. generic_help=$help help="Try '$progname --help --mode=$opt_mode' for more information." } # Pass back the unparsed argument list func_quote eval ${1+"$@"} libtool_validate_options_result=$func_quote_result } func_add_hook func_validate_options libtool_validate_options # Process options as early as possible so that --help and --version # can return quickly. func_options ${1+"$@"} eval set dummy "$func_options_result"; shift ## ----------- ## ## Main. ## ## ----------- ## magic='%%%MAGIC variable%%%' magic_exe='%%%MAGIC EXE variable%%%' # Global variables. extracted_archives= extracted_serial=0 # If this variable is set in any of the actions, the command in it # will be execed at the end. This prevents here-documents from being # left over by shells. exec_cmd= # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF $1 _LTECHO_EOF' } # func_generated_by_libtool # True iff stdin has been generated by Libtool. This function is only # a basic sanity check; it will hardly flush out determined imposters. func_generated_by_libtool_p () { $GREP "^# Generated by .*$PACKAGE" > /dev/null 2>&1 } # func_lalib_p file # True iff FILE is a libtool '.la' library or '.lo' object file. # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_lalib_p () { test -f "$1" && $SED -e 4q "$1" 2>/dev/null | func_generated_by_libtool_p } # func_lalib_unsafe_p file # True iff FILE is a libtool '.la' library or '.lo' object file. # This function implements the same check as func_lalib_p without # resorting to external programs. To this end, it redirects stdin and # closes it afterwards, without saving the original file descriptor. # As a safety measure, use it only where a negative result would be # fatal anyway. Works if 'file' does not exist. func_lalib_unsafe_p () { lalib_p=no if test -f "$1" && test -r "$1" && exec 5<&0 <"$1"; then for lalib_p_l in 1 2 3 4 do read lalib_p_line case $lalib_p_line in \#\ Generated\ by\ *$PACKAGE* ) lalib_p=yes; break;; esac done exec 0<&5 5<&- fi test yes = "$lalib_p" } # func_ltwrapper_script_p file # True iff FILE is a libtool wrapper script # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_script_p () { test -f "$1" && $lt_truncate_bin < "$1" 2>/dev/null | func_generated_by_libtool_p } # func_ltwrapper_executable_p file # True iff FILE is a libtool wrapper executable # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_executable_p () { func_ltwrapper_exec_suffix= case $1 in *.exe) ;; *) func_ltwrapper_exec_suffix=.exe ;; esac $GREP "$magic_exe" "$1$func_ltwrapper_exec_suffix" >/dev/null 2>&1 } # func_ltwrapper_scriptname file # Assumes file is an ltwrapper_executable # uses $file to determine the appropriate filename for a # temporary ltwrapper_script. func_ltwrapper_scriptname () { func_dirname_and_basename "$1" "" "." func_stripname '' '.exe' "$func_basename_result" func_ltwrapper_scriptname_result=$func_dirname_result/$objdir/${func_stripname_result}_ltshwrapper } # func_ltwrapper_p file # True iff FILE is a libtool wrapper script or wrapper executable # This function is only a basic sanity check; it will hardly flush out # determined imposters. func_ltwrapper_p () { func_ltwrapper_script_p "$1" || func_ltwrapper_executable_p "$1" } # func_execute_cmds commands fail_cmd # Execute tilde-delimited COMMANDS. # If FAIL_CMD is given, eval that upon failure. # FAIL_CMD may read-access the current command in variable CMD! func_execute_cmds () { $debug_cmd save_ifs=$IFS; IFS='~' for cmd in $1; do IFS=$sp$nl eval cmd=\"$cmd\" IFS=$save_ifs func_show_eval "$cmd" "${2-:}" done IFS=$save_ifs } # func_source file # Source FILE, adding directory component if necessary. # Note that it is not necessary on cygwin/mingw to append a dot to # FILE even if both FILE and FILE.exe exist: automatic-append-.exe # behavior happens only for exec(3), not for open(2)! Also, sourcing # 'FILE.' does not work on cygwin managed mounts. func_source () { $debug_cmd case $1 in */* | *\\*) . "$1" ;; *) . "./$1" ;; esac } # func_resolve_sysroot PATH # Replace a leading = in PATH with a sysroot. Store the result into # func_resolve_sysroot_result func_resolve_sysroot () { func_resolve_sysroot_result=$1 case $func_resolve_sysroot_result in =*) func_stripname '=' '' "$func_resolve_sysroot_result" func_resolve_sysroot_result=$lt_sysroot$func_stripname_result ;; esac } # func_replace_sysroot PATH # If PATH begins with the sysroot, replace it with = and # store the result into func_replace_sysroot_result. func_replace_sysroot () { case $lt_sysroot:$1 in ?*:"$lt_sysroot"*) func_stripname "$lt_sysroot" '' "$1" func_replace_sysroot_result='='$func_stripname_result ;; *) # Including no sysroot. func_replace_sysroot_result=$1 ;; esac } # func_infer_tag arg # Infer tagged configuration to use if any are available and # if one wasn't chosen via the "--tag" command line option. # Only attempt this if the compiler in the base compile # command doesn't match the default compiler. # arg is usually of the form 'gcc ...' func_infer_tag () { $debug_cmd if test -n "$available_tags" && test -z "$tagname"; then CC_quoted= for arg in $CC; do func_append_quoted CC_quoted "$arg" done CC_expanded=`func_echo_all $CC` CC_quoted_expanded=`func_echo_all $CC_quoted` case $@ in # Blanks in the command may have been stripped by the calling shell, # but not from the CC environment variable when configure was run. " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \ " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) ;; # Blanks at the start of $base_compile will cause this to fail # if we don't check for them as well. *) for z in $available_tags; do if $GREP "^# ### BEGIN LIBTOOL TAG CONFIG: $z$" < "$progpath" > /dev/null; then # Evaluate the configuration. eval "`$SED -n -e '/^# ### BEGIN LIBTOOL TAG CONFIG: '$z'$/,/^# ### END LIBTOOL TAG CONFIG: '$z'$/p' < $progpath`" CC_quoted= for arg in $CC; do # Double-quote args containing other shell metacharacters. func_append_quoted CC_quoted "$arg" done CC_expanded=`func_echo_all $CC` CC_quoted_expanded=`func_echo_all $CC_quoted` case "$@ " in " $CC "* | "$CC "* | " $CC_expanded "* | "$CC_expanded "* | \ " $CC_quoted"* | "$CC_quoted "* | " $CC_quoted_expanded "* | "$CC_quoted_expanded "*) # The compiler in the base compile command matches # the one in the tagged configuration. # Assume this is the tagged configuration we want. tagname=$z break ;; esac fi done # If $tagname still isn't set, then no tagged configuration # was found and let the user know that the "--tag" command # line option must be used. if test -z "$tagname"; then func_echo "unable to infer tagged configuration" func_fatal_error "specify a tag with '--tag'" # else # func_verbose "using $tagname tagged configuration" fi ;; esac fi } # func_write_libtool_object output_name pic_name nonpic_name # Create a libtool object file (analogous to a ".la" file), # but don't create it if we're doing a dry run. func_write_libtool_object () { write_libobj=$1 if test yes = "$build_libtool_libs"; then write_lobj=\'$2\' else write_lobj=none fi if test yes = "$build_old_libs"; then write_oldobj=\'$3\' else write_oldobj=none fi $opt_dry_run || { cat >${write_libobj}T </dev/null` if test "$?" -eq 0 && test -n "$func_convert_core_file_wine_to_w32_tmp"; then func_convert_core_file_wine_to_w32_result=`$ECHO "$func_convert_core_file_wine_to_w32_tmp" | $SED -e "$sed_naive_backslashify"` else func_convert_core_file_wine_to_w32_result= fi fi } # end: func_convert_core_file_wine_to_w32 # func_convert_core_path_wine_to_w32 ARG # Helper function used by path conversion functions when $build is *nix, and # $host is mingw, cygwin, or some other w32 environment. Relies on a correctly # configured wine environment available, with the winepath program in $build's # $PATH. Assumes ARG has no leading or trailing path separator characters. # # ARG is path to be converted from $build format to win32. # Result is available in $func_convert_core_path_wine_to_w32_result. # Unconvertible file (directory) names in ARG are skipped; if no directory names # are convertible, then the result may be empty. func_convert_core_path_wine_to_w32 () { $debug_cmd # unfortunately, winepath doesn't convert paths, only file names func_convert_core_path_wine_to_w32_result= if test -n "$1"; then oldIFS=$IFS IFS=: for func_convert_core_path_wine_to_w32_f in $1; do IFS=$oldIFS func_convert_core_file_wine_to_w32 "$func_convert_core_path_wine_to_w32_f" if test -n "$func_convert_core_file_wine_to_w32_result"; then if test -z "$func_convert_core_path_wine_to_w32_result"; then func_convert_core_path_wine_to_w32_result=$func_convert_core_file_wine_to_w32_result else func_append func_convert_core_path_wine_to_w32_result ";$func_convert_core_file_wine_to_w32_result" fi fi done IFS=$oldIFS fi } # end: func_convert_core_path_wine_to_w32 # func_cygpath ARGS... # Wrapper around calling the cygpath program via LT_CYGPATH. This is used when # when (1) $build is *nix and Cygwin is hosted via a wine environment; or (2) # $build is MSYS and $host is Cygwin, or (3) $build is Cygwin. In case (1) or # (2), returns the Cygwin file name or path in func_cygpath_result (input # file name or path is assumed to be in w32 format, as previously converted # from $build's *nix or MSYS format). In case (3), returns the w32 file name # or path in func_cygpath_result (input file name or path is assumed to be in # Cygwin format). Returns an empty string on error. # # ARGS are passed to cygpath, with the last one being the file name or path to # be converted. # # Specify the absolute *nix (or w32) name to cygpath in the LT_CYGPATH # environment variable; do not put it in $PATH. func_cygpath () { $debug_cmd if test -n "$LT_CYGPATH" && test -f "$LT_CYGPATH"; then func_cygpath_result=`$LT_CYGPATH "$@" 2>/dev/null` if test "$?" -ne 0; then # on failure, ensure result is empty func_cygpath_result= fi else func_cygpath_result= func_error "LT_CYGPATH is empty or specifies non-existent file: '$LT_CYGPATH'" fi } #end: func_cygpath # func_convert_core_msys_to_w32 ARG # Convert file name or path ARG from MSYS format to w32 format. Return # result in func_convert_core_msys_to_w32_result. func_convert_core_msys_to_w32 () { $debug_cmd # awkward: cmd appends spaces to result func_convert_core_msys_to_w32_result=`( cmd //c echo "$1" ) 2>/dev/null | $SED -e 's/[ ]*$//' -e "$sed_naive_backslashify"` } #end: func_convert_core_msys_to_w32 # func_convert_file_check ARG1 ARG2 # Verify that ARG1 (a file name in $build format) was converted to $host # format in ARG2. Otherwise, emit an error message, but continue (resetting # func_to_host_file_result to ARG1). func_convert_file_check () { $debug_cmd if test -z "$2" && test -n "$1"; then func_error "Could not determine host file name corresponding to" func_error " '$1'" func_error "Continuing, but uninstalled executables may not work." # Fallback: func_to_host_file_result=$1 fi } # end func_convert_file_check # func_convert_path_check FROM_PATHSEP TO_PATHSEP FROM_PATH TO_PATH # Verify that FROM_PATH (a path in $build format) was converted to $host # format in TO_PATH. Otherwise, emit an error message, but continue, resetting # func_to_host_file_result to a simplistic fallback value (see below). func_convert_path_check () { $debug_cmd if test -z "$4" && test -n "$3"; then func_error "Could not determine the host path corresponding to" func_error " '$3'" func_error "Continuing, but uninstalled executables may not work." # Fallback. This is a deliberately simplistic "conversion" and # should not be "improved". See libtool.info. if test "x$1" != "x$2"; then lt_replace_pathsep_chars="s|$1|$2|g" func_to_host_path_result=`echo "$3" | $SED -e "$lt_replace_pathsep_chars"` else func_to_host_path_result=$3 fi fi } # end func_convert_path_check # func_convert_path_front_back_pathsep FRONTPAT BACKPAT REPL ORIG # Modifies func_to_host_path_result by prepending REPL if ORIG matches FRONTPAT # and appending REPL if ORIG matches BACKPAT. func_convert_path_front_back_pathsep () { $debug_cmd case $4 in $1 ) func_to_host_path_result=$3$func_to_host_path_result ;; esac case $4 in $2 ) func_append func_to_host_path_result "$3" ;; esac } # end func_convert_path_front_back_pathsep ################################################## # $build to $host FILE NAME CONVERSION FUNCTIONS # ################################################## # invoked via '$to_host_file_cmd ARG' # # In each case, ARG is the path to be converted from $build to $host format. # Result will be available in $func_to_host_file_result. # func_to_host_file ARG # Converts the file name ARG from $build format to $host format. Return result # in func_to_host_file_result. func_to_host_file () { $debug_cmd $to_host_file_cmd "$1" } # end func_to_host_file # func_to_tool_file ARG LAZY # converts the file name ARG from $build format to toolchain format. Return # result in func_to_tool_file_result. If the conversion in use is listed # in (the comma separated) LAZY, no conversion takes place. func_to_tool_file () { $debug_cmd case ,$2, in *,"$to_tool_file_cmd",*) func_to_tool_file_result=$1 ;; *) $to_tool_file_cmd "$1" func_to_tool_file_result=$func_to_host_file_result ;; esac } # end func_to_tool_file # func_convert_file_noop ARG # Copy ARG to func_to_host_file_result. func_convert_file_noop () { func_to_host_file_result=$1 } # end func_convert_file_noop # func_convert_file_msys_to_w32 ARG # Convert file name ARG from (mingw) MSYS to (mingw) w32 format; automatic # conversion to w32 is not available inside the cwrapper. Returns result in # func_to_host_file_result. func_convert_file_msys_to_w32 () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then func_convert_core_msys_to_w32 "$1" func_to_host_file_result=$func_convert_core_msys_to_w32_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_msys_to_w32 # func_convert_file_cygwin_to_w32 ARG # Convert file name ARG from Cygwin to w32 format. Returns result in # func_to_host_file_result. func_convert_file_cygwin_to_w32 () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then # because $build is cygwin, we call "the" cygpath in $PATH; no need to use # LT_CYGPATH in this case. func_to_host_file_result=`cygpath -m "$1"` fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_cygwin_to_w32 # func_convert_file_nix_to_w32 ARG # Convert file name ARG from *nix to w32 format. Requires a wine environment # and a working winepath. Returns result in func_to_host_file_result. func_convert_file_nix_to_w32 () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then func_convert_core_file_wine_to_w32 "$1" func_to_host_file_result=$func_convert_core_file_wine_to_w32_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_nix_to_w32 # func_convert_file_msys_to_cygwin ARG # Convert file name ARG from MSYS to Cygwin format. Requires LT_CYGPATH set. # Returns result in func_to_host_file_result. func_convert_file_msys_to_cygwin () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then func_convert_core_msys_to_w32 "$1" func_cygpath -u "$func_convert_core_msys_to_w32_result" func_to_host_file_result=$func_cygpath_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_msys_to_cygwin # func_convert_file_nix_to_cygwin ARG # Convert file name ARG from *nix to Cygwin format. Requires Cygwin installed # in a wine environment, working winepath, and LT_CYGPATH set. Returns result # in func_to_host_file_result. func_convert_file_nix_to_cygwin () { $debug_cmd func_to_host_file_result=$1 if test -n "$1"; then # convert from *nix to w32, then use cygpath to convert from w32 to cygwin. func_convert_core_file_wine_to_w32 "$1" func_cygpath -u "$func_convert_core_file_wine_to_w32_result" func_to_host_file_result=$func_cygpath_result fi func_convert_file_check "$1" "$func_to_host_file_result" } # end func_convert_file_nix_to_cygwin ############################################# # $build to $host PATH CONVERSION FUNCTIONS # ############################################# # invoked via '$to_host_path_cmd ARG' # # In each case, ARG is the path to be converted from $build to $host format. # The result will be available in $func_to_host_path_result. # # Path separators are also converted from $build format to $host format. If # ARG begins or ends with a path separator character, it is preserved (but # converted to $host format) on output. # # All path conversion functions are named using the following convention: # file name conversion function : func_convert_file_X_to_Y () # path conversion function : func_convert_path_X_to_Y () # where, for any given $build/$host combination the 'X_to_Y' value is the # same. If conversion functions are added for new $build/$host combinations, # the two new functions must follow this pattern, or func_init_to_host_path_cmd # will break. # func_init_to_host_path_cmd # Ensures that function "pointer" variable $to_host_path_cmd is set to the # appropriate value, based on the value of $to_host_file_cmd. to_host_path_cmd= func_init_to_host_path_cmd () { $debug_cmd if test -z "$to_host_path_cmd"; then func_stripname 'func_convert_file_' '' "$to_host_file_cmd" to_host_path_cmd=func_convert_path_$func_stripname_result fi } # func_to_host_path ARG # Converts the path ARG from $build format to $host format. Return result # in func_to_host_path_result. func_to_host_path () { $debug_cmd func_init_to_host_path_cmd $to_host_path_cmd "$1" } # end func_to_host_path # func_convert_path_noop ARG # Copy ARG to func_to_host_path_result. func_convert_path_noop () { func_to_host_path_result=$1 } # end func_convert_path_noop # func_convert_path_msys_to_w32 ARG # Convert path ARG from (mingw) MSYS to (mingw) w32 format; automatic # conversion to w32 is not available inside the cwrapper. Returns result in # func_to_host_path_result. func_convert_path_msys_to_w32 () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # Remove leading and trailing path separator characters from ARG. MSYS # behavior is inconsistent here; cygpath turns them into '.;' and ';.'; # and winepath ignores them completely. func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_msys_to_w32 "$func_to_host_path_tmp1" func_to_host_path_result=$func_convert_core_msys_to_w32_result func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_msys_to_w32 # func_convert_path_cygwin_to_w32 ARG # Convert path ARG from Cygwin to w32 format. Returns result in # func_to_host_file_result. func_convert_path_cygwin_to_w32 () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_to_host_path_result=`cygpath -m -p "$func_to_host_path_tmp1"` func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_cygwin_to_w32 # func_convert_path_nix_to_w32 ARG # Convert path ARG from *nix to w32 format. Requires a wine environment and # a working winepath. Returns result in func_to_host_file_result. func_convert_path_nix_to_w32 () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1" func_to_host_path_result=$func_convert_core_path_wine_to_w32_result func_convert_path_check : ";" \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" ";" "$1" fi } # end func_convert_path_nix_to_w32 # func_convert_path_msys_to_cygwin ARG # Convert path ARG from MSYS to Cygwin format. Requires LT_CYGPATH set. # Returns result in func_to_host_file_result. func_convert_path_msys_to_cygwin () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # See func_convert_path_msys_to_w32: func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_msys_to_w32 "$func_to_host_path_tmp1" func_cygpath -u -p "$func_convert_core_msys_to_w32_result" func_to_host_path_result=$func_cygpath_result func_convert_path_check : : \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" : "$1" fi } # end func_convert_path_msys_to_cygwin # func_convert_path_nix_to_cygwin ARG # Convert path ARG from *nix to Cygwin format. Requires Cygwin installed in a # a wine environment, working winepath, and LT_CYGPATH set. Returns result in # func_to_host_file_result. func_convert_path_nix_to_cygwin () { $debug_cmd func_to_host_path_result=$1 if test -n "$1"; then # Remove leading and trailing path separator characters from # ARG. msys behavior is inconsistent here, cygpath turns them # into '.;' and ';.', and winepath ignores them completely. func_stripname : : "$1" func_to_host_path_tmp1=$func_stripname_result func_convert_core_path_wine_to_w32 "$func_to_host_path_tmp1" func_cygpath -u -p "$func_convert_core_path_wine_to_w32_result" func_to_host_path_result=$func_cygpath_result func_convert_path_check : : \ "$func_to_host_path_tmp1" "$func_to_host_path_result" func_convert_path_front_back_pathsep ":*" "*:" : "$1" fi } # end func_convert_path_nix_to_cygwin # func_dll_def_p FILE # True iff FILE is a Windows DLL '.def' file. # Keep in sync with _LT_DLL_DEF_P in libtool.m4 func_dll_def_p () { $debug_cmd func_dll_def_p_tmp=`$SED -n \ -e 's/^[ ]*//' \ -e '/^\(;.*\)*$/d' \ -e 's/^\(EXPORTS\|LIBRARY\)\([ ].*\)*$/DEF/p' \ -e q \ "$1"` test DEF = "$func_dll_def_p_tmp" } # func_mode_compile arg... func_mode_compile () { $debug_cmd # Get the compilation command and the source file. base_compile= srcfile=$nonopt # always keep a non-empty value in "srcfile" suppress_opt=yes suppress_output= arg_mode=normal libobj= later= pie_flag= for arg do case $arg_mode in arg ) # do not "continue". Instead, add this to base_compile lastarg=$arg arg_mode=normal ;; target ) libobj=$arg arg_mode=normal continue ;; normal ) # Accept any command-line options. case $arg in -o) test -n "$libobj" && \ func_fatal_error "you cannot specify '-o' more than once" arg_mode=target continue ;; -pie | -fpie | -fPIE) func_append pie_flag " $arg" continue ;; -shared | -static | -prefer-pic | -prefer-non-pic) func_append later " $arg" continue ;; -no-suppress) suppress_opt=no continue ;; -Xcompiler) arg_mode=arg # the next one goes into the "base_compile" arg list continue # The current "srcfile" will either be retained or ;; # replaced later. I would guess that would be a bug. -Wc,*) func_stripname '-Wc,' '' "$arg" args=$func_stripname_result lastarg= save_ifs=$IFS; IFS=, for arg in $args; do IFS=$save_ifs func_append_quoted lastarg "$arg" done IFS=$save_ifs func_stripname ' ' '' "$lastarg" lastarg=$func_stripname_result # Add the arguments to base_compile. func_append base_compile " $lastarg" continue ;; *) # Accept the current argument as the source file. # The previous "srcfile" becomes the current argument. # lastarg=$srcfile srcfile=$arg ;; esac # case $arg ;; esac # case $arg_mode # Aesthetically quote the previous argument. func_append_quoted base_compile "$lastarg" done # for arg case $arg_mode in arg) func_fatal_error "you must specify an argument for -Xcompile" ;; target) func_fatal_error "you must specify a target with '-o'" ;; *) # Get the name of the library object. test -z "$libobj" && { func_basename "$srcfile" libobj=$func_basename_result } ;; esac # Recognize several different file suffixes. # If the user specifies -o file.o, it is replaced with file.lo case $libobj in *.[cCFSifmso] | \ *.ada | *.adb | *.ads | *.asm | \ *.c++ | *.cc | *.ii | *.class | *.cpp | *.cxx | \ *.[fF][09]? | *.for | *.java | *.go | *.obj | *.sx | *.cu | *.cup) func_xform "$libobj" libobj=$func_xform_result ;; esac case $libobj in *.lo) func_lo2o "$libobj"; obj=$func_lo2o_result ;; *) func_fatal_error "cannot determine name of library object from '$libobj'" ;; esac func_infer_tag $base_compile for arg in $later; do case $arg in -shared) test yes = "$build_libtool_libs" \ || func_fatal_configuration "cannot build a shared library" build_old_libs=no continue ;; -static) build_libtool_libs=no build_old_libs=yes continue ;; -prefer-pic) pic_mode=yes continue ;; -prefer-non-pic) pic_mode=no continue ;; esac done func_quote_arg pretty "$libobj" test "X$libobj" != "X$func_quote_arg_result" \ && $ECHO "X$libobj" | $GREP '[]~#^*{};<>?"'"'"' &()|`$[]' \ && func_warning "libobj name '$libobj' may not contain shell special characters." func_dirname_and_basename "$obj" "/" "" objname=$func_basename_result xdir=$func_dirname_result lobj=$xdir$objdir/$objname test -z "$base_compile" && \ func_fatal_help "you must specify a compilation command" # Delete any leftover library objects. if test yes = "$build_old_libs"; then removelist="$obj $lobj $libobj ${libobj}T" else removelist="$lobj $libobj ${libobj}T" fi # On Cygwin there's no "real" PIC flag so we must build both object types case $host_os in cygwin* | mingw* | pw32* | os2* | cegcc*) pic_mode=default ;; esac if test no = "$pic_mode" && test pass_all != "$deplibs_check_method"; then # non-PIC code in shared libraries is not supported pic_mode=default fi # Calculate the filename of the output object if compiler does # not support -o with -c if test no = "$compiler_c_o"; then output_obj=`$ECHO "$srcfile" | $SED 's%^.*/%%; s%\.[^.]*$%%'`.$objext lockfile=$output_obj.lock else output_obj= need_locks=no lockfile= fi # Lock this critical section if it is needed # We use this script file to make the link, it avoids creating a new file if test yes = "$need_locks"; then until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do func_echo "Waiting for $lockfile to be removed" sleep 2 done elif test warn = "$need_locks"; then if test -f "$lockfile"; then $ECHO "\ *** ERROR, $lockfile exists and contains: `cat $lockfile 2>/dev/null` This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support '-c' and '-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi func_append removelist " $output_obj" $ECHO "$srcfile" > "$lockfile" fi $opt_dry_run || $RM $removelist func_append removelist " $lockfile" trap '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' 1 2 15 func_to_tool_file "$srcfile" func_convert_file_msys_to_w32 srcfile=$func_to_tool_file_result func_quote_arg pretty "$srcfile" qsrcfile=$func_quote_arg_result # Only build a PIC object if we are building libtool libraries. if test yes = "$build_libtool_libs"; then # Without this assignment, base_compile gets emptied. fbsd_hideous_sh_bug=$base_compile if test no != "$pic_mode"; then command="$base_compile $qsrcfile $pic_flag" else # Don't build PIC code command="$base_compile $qsrcfile" fi func_mkdir_p "$xdir$objdir" if test -z "$output_obj"; then # Place PIC objects in $objdir func_append command " -o $lobj" fi func_show_eval_locale "$command" \ 'test -n "$output_obj" && $RM $removelist; exit $EXIT_FAILURE' if test warn = "$need_locks" && test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then $ECHO "\ *** ERROR, $lockfile contains: `cat $lockfile 2>/dev/null` but it should contain: $srcfile This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support '-c' and '-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi # Just move the object if needed, then go on to compile the next one if test -n "$output_obj" && test "X$output_obj" != "X$lobj"; then func_show_eval '$MV "$output_obj" "$lobj"' \ 'error=$?; $opt_dry_run || $RM $removelist; exit $error' fi # Allow error messages only from the first compilation. if test yes = "$suppress_opt"; then suppress_output=' >/dev/null 2>&1' fi fi # Only build a position-dependent object if we build old libraries. if test yes = "$build_old_libs"; then if test yes != "$pic_mode"; then # Don't build PIC code command="$base_compile $qsrcfile$pie_flag" else command="$base_compile $qsrcfile $pic_flag" fi if test yes = "$compiler_c_o"; then func_append command " -o $obj" fi # Suppress compiler output if we already did a PIC compilation. func_append command "$suppress_output" func_show_eval_locale "$command" \ '$opt_dry_run || $RM $removelist; exit $EXIT_FAILURE' if test warn = "$need_locks" && test "X`cat $lockfile 2>/dev/null`" != "X$srcfile"; then $ECHO "\ *** ERROR, $lockfile contains: `cat $lockfile 2>/dev/null` but it should contain: $srcfile This indicates that another process is trying to use the same temporary object file, and libtool could not work around it because your compiler does not support '-c' and '-o' together. If you repeat this compilation, it may succeed, by chance, but you had better avoid parallel builds (make -j) in this platform, or get a better compiler." $opt_dry_run || $RM $removelist exit $EXIT_FAILURE fi # Just move the object if needed if test -n "$output_obj" && test "X$output_obj" != "X$obj"; then func_show_eval '$MV "$output_obj" "$obj"' \ 'error=$?; $opt_dry_run || $RM $removelist; exit $error' fi fi $opt_dry_run || { func_write_libtool_object "$libobj" "$objdir/$objname" "$objname" # Unlock the critical section if it was locked if test no != "$need_locks"; then removelist=$lockfile $RM "$lockfile" fi } exit $EXIT_SUCCESS } $opt_help || { test compile = "$opt_mode" && func_mode_compile ${1+"$@"} } func_mode_help () { # We need to display help for each of the modes. case $opt_mode in "") # Generic help is extracted from the usage comments # at the start of this file. func_help ;; clean) $ECHO \ "Usage: $progname [OPTION]... --mode=clean RM [RM-OPTION]... FILE... Remove files from the build directory. RM is the name of the program to use to delete files associated with each FILE (typically '/bin/rm'). RM-OPTIONS are options (such as '-f') to be passed to RM. If FILE is a libtool library, object or program, all the files associated with it are deleted. Otherwise, only FILE itself is deleted using RM." ;; compile) $ECHO \ "Usage: $progname [OPTION]... --mode=compile COMPILE-COMMAND... SOURCEFILE Compile a source file into a libtool library object. This mode accepts the following additional options: -o OUTPUT-FILE set the output file name to OUTPUT-FILE -no-suppress do not suppress compiler output for multiple passes -prefer-pic try to build PIC objects only -prefer-non-pic try to build non-PIC objects only -shared do not build a '.o' file suitable for static linking -static only build a '.o' file suitable for static linking -Wc,FLAG -Xcompiler FLAG pass FLAG directly to the compiler COMPILE-COMMAND is a command to be used in creating a 'standard' object file from the given SOURCEFILE. The output file name is determined by removing the directory component from SOURCEFILE, then substituting the C source code suffix '.c' with the library object suffix, '.lo'." ;; execute) $ECHO \ "Usage: $progname [OPTION]... --mode=execute COMMAND [ARGS]... Automatically set library path, then run a program. This mode accepts the following additional options: -dlopen FILE add the directory containing FILE to the library path This mode sets the library path environment variable according to '-dlopen' flags. If any of the ARGS are libtool executable wrappers, then they are translated into their corresponding uninstalled binary, and any of their required library directories are added to the library path. Then, COMMAND is executed, with ARGS as arguments." ;; finish) $ECHO \ "Usage: $progname [OPTION]... --mode=finish [LIBDIR]... Complete the installation of libtool libraries. Each LIBDIR is a directory that contains libtool libraries. The commands that this mode executes may require superuser privileges. Use the '--dry-run' option if you just want to see what would be executed." ;; install) $ECHO \ "Usage: $progname [OPTION]... --mode=install INSTALL-COMMAND... Install executables or libraries. INSTALL-COMMAND is the installation command. The first component should be either the 'install' or 'cp' program. The following components of INSTALL-COMMAND are treated specially: -inst-prefix-dir PREFIX-DIR Use PREFIX-DIR as a staging area for installation The rest of the components are interpreted as arguments to that command (only BSD-compatible install options are recognized)." ;; link) $ECHO \ "Usage: $progname [OPTION]... --mode=link LINK-COMMAND... Link object files or libraries together to form another library, or to create an executable program. LINK-COMMAND is a command using the C compiler that you would use to create a program from several object files. The following components of LINK-COMMAND are treated specially: -all-static do not do any dynamic linking at all -avoid-version do not add a version suffix if possible -bindir BINDIR specify path to binaries directory (for systems where libraries must be found in the PATH setting at runtime) -dlopen FILE '-dlpreopen' FILE if it cannot be dlopened at runtime -dlpreopen FILE link in FILE and add its symbols to lt_preloaded_symbols -export-dynamic allow symbols from OUTPUT-FILE to be resolved with dlsym(3) -export-symbols SYMFILE try to export only the symbols listed in SYMFILE -export-symbols-regex REGEX try to export only the symbols matching REGEX -LLIBDIR search LIBDIR for required installed libraries -lNAME OUTPUT-FILE requires the installed library libNAME -module build a library that can dlopened -no-fast-install disable the fast-install mode -no-install link a not-installable executable -no-undefined declare that a library does not refer to external symbols -o OUTPUT-FILE create OUTPUT-FILE from the specified objects -objectlist FILE use a list of object files found in FILE to specify objects -os2dllname NAME force a short DLL name on OS/2 (no effect on other OSes) -precious-files-regex REGEX don't remove output files matching REGEX -release RELEASE specify package release information -rpath LIBDIR the created library will eventually be installed in LIBDIR -R[ ]LIBDIR add LIBDIR to the runtime path of programs and libraries -shared only do dynamic linking of libtool libraries -shrext SUFFIX override the standard shared library file extension -static do not do any dynamic linking of uninstalled libtool libraries -static-libtool-libs do not do any dynamic linking of libtool libraries -version-info CURRENT[:REVISION[:AGE]] specify library version info [each variable defaults to 0] -weak LIBNAME declare that the target provides the LIBNAME interface -Wc,FLAG -Xcompiler FLAG pass linker-specific FLAG directly to the compiler -Wa,FLAG -Xassembler FLAG pass linker-specific FLAG directly to the assembler -Wl,FLAG -Xlinker FLAG pass linker-specific FLAG directly to the linker -XCClinker FLAG pass link-specific FLAG to the compiler driver (CC) All other options (arguments beginning with '-') are ignored. Every other argument is treated as a filename. Files ending in '.la' are treated as uninstalled libtool libraries, other files are standard or library object files. If the OUTPUT-FILE ends in '.la', then a libtool library is created, only library objects ('.lo' files) may be specified, and '-rpath' is required, except when creating a convenience library. If OUTPUT-FILE ends in '.a' or '.lib', then a standard library is created using 'ar' and 'ranlib', or on Windows using 'lib'. If OUTPUT-FILE ends in '.lo' or '.$objext', then a reloadable object file is created, otherwise an executable program is created." ;; uninstall) $ECHO \ "Usage: $progname [OPTION]... --mode=uninstall RM [RM-OPTION]... FILE... Remove libraries from an installation directory. RM is the name of the program to use to delete files associated with each FILE (typically '/bin/rm'). RM-OPTIONS are options (such as '-f') to be passed to RM. If FILE is a libtool library, all the files associated with it are deleted. Otherwise, only FILE itself is deleted using RM." ;; *) func_fatal_help "invalid operation mode '$opt_mode'" ;; esac echo $ECHO "Try '$progname --help' for more information about other modes." } # Now that we've collected a possible --mode arg, show help if necessary if $opt_help; then if test : = "$opt_help"; then func_mode_help else { func_help noexit for opt_mode in compile link execute install finish uninstall clean; do func_mode_help done } | $SED -n '1p; 2,$s/^Usage:/ or: /p' { func_help noexit for opt_mode in compile link execute install finish uninstall clean; do echo func_mode_help done } | $SED '1d /^When reporting/,/^Report/{ H d } $x /information about other modes/d /more detailed .*MODE/d s/^Usage:.*--mode=\([^ ]*\) .*/Description of \1 mode:/' fi exit $? fi # func_mode_execute arg... func_mode_execute () { $debug_cmd # The first argument is the command name. cmd=$nonopt test -z "$cmd" && \ func_fatal_help "you must specify a COMMAND" # Handle -dlopen flags immediately. for file in $opt_dlopen; do test -f "$file" \ || func_fatal_help "'$file' is not a file" dir= case $file in *.la) func_resolve_sysroot "$file" file=$func_resolve_sysroot_result # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$file" \ || func_fatal_help "'$lib' is not a valid libtool archive" # Read the libtool library. dlname= library_names= func_source "$file" # Skip this library if it cannot be dlopened. if test -z "$dlname"; then # Warn if it was a shared library. test -n "$library_names" && \ func_warning "'$file' was not linked with '-export-dynamic'" continue fi func_dirname "$file" "" "." dir=$func_dirname_result if test -f "$dir/$objdir/$dlname"; then func_append dir "/$objdir" else if test ! -f "$dir/$dlname"; then func_fatal_error "cannot find '$dlname' in '$dir' or '$dir/$objdir'" fi fi ;; *.lo) # Just add the directory containing the .lo file. func_dirname "$file" "" "." dir=$func_dirname_result ;; *) func_warning "'-dlopen' is ignored for non-libtool libraries and objects" continue ;; esac # Get the absolute pathname. absdir=`cd "$dir" && pwd` test -n "$absdir" && dir=$absdir # Now add the directory to shlibpath_var. if eval "test -z \"\$$shlibpath_var\""; then eval "$shlibpath_var=\"\$dir\"" else eval "$shlibpath_var=\"\$dir:\$$shlibpath_var\"" fi done # This variable tells wrapper scripts just to set shlibpath_var # rather than running their programs. libtool_execute_magic=$magic # Check if any of the arguments is a wrapper script. args= for file do case $file in -* | *.la | *.lo ) ;; *) # Do a test to see if this is really a libtool program. if func_ltwrapper_script_p "$file"; then func_source "$file" # Transform arg to wrapped name. file=$progdir/$program elif func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" func_source "$func_ltwrapper_scriptname_result" # Transform arg to wrapped name. file=$progdir/$program fi ;; esac # Quote arguments (to preserve shell metacharacters). func_append_quoted args "$file" done if $opt_dry_run; then # Display what would be done. if test -n "$shlibpath_var"; then eval "\$ECHO \"\$shlibpath_var=\$$shlibpath_var\"" echo "export $shlibpath_var" fi $ECHO "$cmd$args" exit $EXIT_SUCCESS else if test -n "$shlibpath_var"; then # Export the shlibpath_var. eval "export $shlibpath_var" fi # Restore saved environment variables for lt_var in LANG LANGUAGE LC_ALL LC_CTYPE LC_COLLATE LC_MESSAGES do eval "if test \"\${save_$lt_var+set}\" = set; then $lt_var=\$save_$lt_var; export $lt_var else $lt_unset $lt_var fi" done # Now prepare to actually exec the command. exec_cmd=\$cmd$args fi } test execute = "$opt_mode" && func_mode_execute ${1+"$@"} # func_mode_finish arg... func_mode_finish () { $debug_cmd libs= libdirs= admincmds= for opt in "$nonopt" ${1+"$@"} do if test -d "$opt"; then func_append libdirs " $opt" elif test -f "$opt"; then if func_lalib_unsafe_p "$opt"; then func_append libs " $opt" else func_warning "'$opt' is not a valid libtool archive" fi else func_fatal_error "invalid argument '$opt'" fi done if test -n "$libs"; then if test -n "$lt_sysroot"; then sysroot_regex=`$ECHO "$lt_sysroot" | $SED "$sed_make_literal_regex"` sysroot_cmd="s/\([ ']\)$sysroot_regex/\1/g;" else sysroot_cmd= fi # Remove sysroot references if $opt_dry_run; then for lib in $libs; do echo "removing references to $lt_sysroot and '=' prefixes from $lib" done else tmpdir=`func_mktempdir` for lib in $libs; do $SED -e "$sysroot_cmd s/\([ ']-[LR]\)=/\1/g; s/\([ ']\)=/\1/g" $lib \ > $tmpdir/tmp-la mv -f $tmpdir/tmp-la $lib done ${RM}r "$tmpdir" fi fi if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then for libdir in $libdirs; do if test -n "$finish_cmds"; then # Do each command in the finish commands. func_execute_cmds "$finish_cmds" 'admincmds="$admincmds '"$cmd"'"' fi if test -n "$finish_eval"; then # Do the single finish_eval. eval cmds=\"$finish_eval\" $opt_dry_run || eval "$cmds" || func_append admincmds " $cmds" fi done fi # Exit here if they wanted silent mode. $opt_quiet && exit $EXIT_SUCCESS if test -n "$finish_cmds$finish_eval" && test -n "$libdirs"; then echo "----------------------------------------------------------------------" echo "Libraries have been installed in:" for libdir in $libdirs; do $ECHO " $libdir" done echo echo "If you ever happen to want to link against installed libraries" echo "in a given directory, LIBDIR, you must either use libtool, and" echo "specify the full pathname of the library, or use the '-LLIBDIR'" echo "flag during linking and do at least one of the following:" if test -n "$shlibpath_var"; then echo " - add LIBDIR to the '$shlibpath_var' environment variable" echo " during execution" fi if test -n "$runpath_var"; then echo " - add LIBDIR to the '$runpath_var' environment variable" echo " during linking" fi if test -n "$hardcode_libdir_flag_spec"; then libdir=LIBDIR eval flag=\"$hardcode_libdir_flag_spec\" $ECHO " - use the '$flag' linker flag" fi if test -n "$admincmds"; then $ECHO " - have your system administrator run these commands:$admincmds" fi if test -f /etc/ld.so.conf; then echo " - have your system administrator add LIBDIR to '/etc/ld.so.conf'" fi echo echo "See any operating system documentation about shared libraries for" case $host in solaris2.[6789]|solaris2.1[0-9]) echo "more information, such as the ld(1), crle(1) and ld.so(8) manual" echo "pages." ;; *) echo "more information, such as the ld(1) and ld.so(8) manual pages." ;; esac echo "----------------------------------------------------------------------" fi exit $EXIT_SUCCESS } test finish = "$opt_mode" && func_mode_finish ${1+"$@"} # func_mode_install arg... func_mode_install () { $debug_cmd # There may be an optional sh(1) argument at the beginning of # install_prog (especially on Windows NT). if test "$SHELL" = "$nonopt" || test /bin/sh = "$nonopt" || # Allow the use of GNU shtool's install command. case $nonopt in *shtool*) :;; *) false;; esac then # Aesthetically quote it. func_quote_arg pretty "$nonopt" install_prog="$func_quote_arg_result " arg=$1 shift else install_prog= arg=$nonopt fi # The real first argument should be the name of the installation program. # Aesthetically quote it. func_quote_arg pretty "$arg" func_append install_prog "$func_quote_arg_result" install_shared_prog=$install_prog case " $install_prog " in *[\\\ /]cp\ *) install_cp=: ;; *) install_cp=false ;; esac # We need to accept at least all the BSD install flags. dest= files= opts= prev= install_type= isdir=false stripme= no_mode=: for arg do arg2= if test -n "$dest"; then func_append files " $dest" dest=$arg continue fi case $arg in -d) isdir=: ;; -f) if $install_cp; then :; else prev=$arg fi ;; -g | -m | -o) prev=$arg ;; -s) stripme=" -s" continue ;; -*) ;; *) # If the previous option needed an argument, then skip it. if test -n "$prev"; then if test X-m = "X$prev" && test -n "$install_override_mode"; then arg2=$install_override_mode no_mode=false fi prev= else dest=$arg continue fi ;; esac # Aesthetically quote the argument. func_quote_arg pretty "$arg" func_append install_prog " $func_quote_arg_result" if test -n "$arg2"; then func_quote_arg pretty "$arg2" fi func_append install_shared_prog " $func_quote_arg_result" done test -z "$install_prog" && \ func_fatal_help "you must specify an install program" test -n "$prev" && \ func_fatal_help "the '$prev' option requires an argument" if test -n "$install_override_mode" && $no_mode; then if $install_cp; then :; else func_quote_arg pretty "$install_override_mode" func_append install_shared_prog " -m $func_quote_arg_result" fi fi if test -z "$files"; then if test -z "$dest"; then func_fatal_help "no file or destination specified" else func_fatal_help "you must specify a destination" fi fi # Strip any trailing slash from the destination. func_stripname '' '/' "$dest" dest=$func_stripname_result # Check to see that the destination is a directory. test -d "$dest" && isdir=: if $isdir; then destdir=$dest destname= else func_dirname_and_basename "$dest" "" "." destdir=$func_dirname_result destname=$func_basename_result # Not a directory, so check to see that there is only one file specified. set dummy $files; shift test "$#" -gt 1 && \ func_fatal_help "'$dest' is not a directory" fi case $destdir in [\\/]* | [A-Za-z]:[\\/]*) ;; *) for file in $files; do case $file in *.lo) ;; *) func_fatal_help "'$destdir' must be an absolute directory name" ;; esac done ;; esac # This variable tells wrapper scripts just to set variables rather # than running their programs. libtool_install_magic=$magic staticlibs= future_libdirs= current_libdirs= for file in $files; do # Do each installation. case $file in *.$libext) # Do the static libraries later. func_append staticlibs " $file" ;; *.la) func_resolve_sysroot "$file" file=$func_resolve_sysroot_result # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$file" \ || func_fatal_help "'$file' is not a valid libtool archive" library_names= old_library= relink_command= func_source "$file" # Add the libdir to current_libdirs if it is the destination. if test "X$destdir" = "X$libdir"; then case "$current_libdirs " in *" $libdir "*) ;; *) func_append current_libdirs " $libdir" ;; esac else # Note the libdir as a future libdir. case "$future_libdirs " in *" $libdir "*) ;; *) func_append future_libdirs " $libdir" ;; esac fi func_dirname "$file" "/" "" dir=$func_dirname_result func_append dir "$objdir" if test -n "$relink_command"; then # Determine the prefix the user has applied to our future dir. inst_prefix_dir=`$ECHO "$destdir" | $SED -e "s%$libdir\$%%"` # Don't allow the user to place us outside of our expected # location b/c this prevents finding dependent libraries that # are installed to the same prefix. # At present, this check doesn't affect windows .dll's that # are installed into $libdir/../bin (currently, that works fine) # but it's something to keep an eye on. test "$inst_prefix_dir" = "$destdir" && \ func_fatal_error "error: cannot install '$file' to a directory not ending in $libdir" if test -n "$inst_prefix_dir"; then # Stick the inst_prefix_dir data into the link command. relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%-inst-prefix-dir $inst_prefix_dir%"` else relink_command=`$ECHO "$relink_command" | $SED "s%@inst_prefix_dir@%%"` fi func_warning "relinking '$file'" func_show_eval "$relink_command" \ 'func_fatal_error "error: relink '\''$file'\'' with the above command before installing it"' fi # See the names of the shared library. set dummy $library_names; shift if test -n "$1"; then realname=$1 shift srcname=$realname test -n "$relink_command" && srcname=${realname}T # Install the shared library and build the symlinks. func_show_eval "$install_shared_prog $dir/$srcname $destdir/$realname" \ 'exit $?' tstripme=$stripme case $host_os in cygwin* | mingw* | pw32* | cegcc*) case $realname in *.dll.a) tstripme= ;; esac ;; os2*) case $realname in *_dll.a) tstripme= ;; esac ;; esac if test -n "$tstripme" && test -n "$striplib"; then func_show_eval "$striplib $destdir/$realname" 'exit $?' fi if test "$#" -gt 0; then # Delete the old symlinks, and create new ones. # Try 'ln -sf' first, because the 'ln' binary might depend on # the symlink we replace! Solaris /bin/ln does not understand -f, # so we also need to try rm && ln -s. for linkname do test "$linkname" != "$realname" \ && func_show_eval "(cd $destdir && { $LN_S -f $realname $linkname || { $RM $linkname && $LN_S $realname $linkname; }; })" done fi # Do each command in the postinstall commands. lib=$destdir/$realname func_execute_cmds "$postinstall_cmds" 'exit $?' fi # Install the pseudo-library for information purposes. func_basename "$file" name=$func_basename_result instname=$dir/${name}i func_show_eval "$install_prog $instname $destdir/$name" 'exit $?' # Maybe install the static library, too. test -n "$old_library" && func_append staticlibs " $dir/$old_library" ;; *.lo) # Install (i.e. copy) a libtool object. # Figure out destination file name, if it wasn't already specified. if test -n "$destname"; then destfile=$destdir/$destname else func_basename "$file" destfile=$func_basename_result destfile=$destdir/$destfile fi # Deduce the name of the destination old-style object file. case $destfile in *.lo) func_lo2o "$destfile" staticdest=$func_lo2o_result ;; *.$objext) staticdest=$destfile destfile= ;; *) func_fatal_help "cannot copy a libtool object to '$destfile'" ;; esac # Install the libtool object if requested. test -n "$destfile" && \ func_show_eval "$install_prog $file $destfile" 'exit $?' # Install the old object if enabled. if test yes = "$build_old_libs"; then # Deduce the name of the old-style object file. func_lo2o "$file" staticobj=$func_lo2o_result func_show_eval "$install_prog \$staticobj \$staticdest" 'exit $?' fi exit $EXIT_SUCCESS ;; *) # Figure out destination file name, if it wasn't already specified. if test -n "$destname"; then destfile=$destdir/$destname else func_basename "$file" destfile=$func_basename_result destfile=$destdir/$destfile fi # If the file is missing, and there is a .exe on the end, strip it # because it is most likely a libtool script we actually want to # install stripped_ext= case $file in *.exe) if test ! -f "$file"; then func_stripname '' '.exe' "$file" file=$func_stripname_result stripped_ext=.exe fi ;; esac # Do a test to see if this is really a libtool program. case $host in *cygwin* | *mingw*) if func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" wrapper=$func_ltwrapper_scriptname_result else func_stripname '' '.exe' "$file" wrapper=$func_stripname_result fi ;; *) wrapper=$file ;; esac if func_ltwrapper_script_p "$wrapper"; then notinst_deplibs= relink_command= func_source "$wrapper" # Check the variables that should have been set. test -z "$generated_by_libtool_version" && \ func_fatal_error "invalid libtool wrapper script '$wrapper'" finalize=: for lib in $notinst_deplibs; do # Check to see that each library is installed. libdir= if test -f "$lib"; then func_source "$lib" fi libfile=$libdir/`$ECHO "$lib" | $SED 's%^.*/%%g'` if test -n "$libdir" && test ! -f "$libfile"; then func_warning "'$lib' has not been installed in '$libdir'" finalize=false fi done relink_command= func_source "$wrapper" outputname= if test no = "$fast_install" && test -n "$relink_command"; then $opt_dry_run || { if $finalize; then tmpdir=`func_mktempdir` func_basename "$file$stripped_ext" file=$func_basename_result outputname=$tmpdir/$file # Replace the output file specification. relink_command=`$ECHO "$relink_command" | $SED 's%@OUTPUT@%'"$outputname"'%g'` $opt_quiet || { func_quote_arg expand,pretty "$relink_command" eval "func_echo $func_quote_arg_result" } if eval "$relink_command"; then : else func_error "error: relink '$file' with the above command before installing it" $opt_dry_run || ${RM}r "$tmpdir" continue fi file=$outputname else func_warning "cannot relink '$file'" fi } else # Install the binary that we compiled earlier. file=`$ECHO "$file$stripped_ext" | $SED "s%\([^/]*\)$%$objdir/\1%"` fi fi # remove .exe since cygwin /usr/bin/install will append another # one anyway case $install_prog,$host in */usr/bin/install*,*cygwin*) case $file:$destfile in *.exe:*.exe) # this is ok ;; *.exe:*) destfile=$destfile.exe ;; *:*.exe) func_stripname '' '.exe' "$destfile" destfile=$func_stripname_result ;; esac ;; esac func_show_eval "$install_prog\$stripme \$file \$destfile" 'exit $?' $opt_dry_run || if test -n "$outputname"; then ${RM}r "$tmpdir" fi ;; esac done for file in $staticlibs; do func_basename "$file" name=$func_basename_result # Set up the ranlib parameters. oldlib=$destdir/$name func_to_tool_file "$oldlib" func_convert_file_msys_to_w32 tool_oldlib=$func_to_tool_file_result func_show_eval "$install_prog \$file \$oldlib" 'exit $?' if test -n "$stripme" && test -n "$old_striplib"; then func_show_eval "$old_striplib $tool_oldlib" 'exit $?' fi # Do each command in the postinstall commands. func_execute_cmds "$old_postinstall_cmds" 'exit $?' done test -n "$future_libdirs" && \ func_warning "remember to run '$progname --finish$future_libdirs'" if test -n "$current_libdirs"; then # Maybe just do a dry run. $opt_dry_run && current_libdirs=" -n$current_libdirs" exec_cmd='$SHELL "$progpath" $preserve_args --finish$current_libdirs' else exit $EXIT_SUCCESS fi } test install = "$opt_mode" && func_mode_install ${1+"$@"} # func_generate_dlsyms outputname originator pic_p # Extract symbols from dlprefiles and create ${outputname}S.o with # a dlpreopen symbol table. func_generate_dlsyms () { $debug_cmd my_outputname=$1 my_originator=$2 my_pic_p=${3-false} my_prefix=`$ECHO "$my_originator" | $SED 's%[^a-zA-Z0-9]%_%g'` my_dlsyms= if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then if test -n "$NM" && test -n "$global_symbol_pipe"; then my_dlsyms=${my_outputname}S.c else func_error "not configured to extract global symbols from dlpreopened files" fi fi if test -n "$my_dlsyms"; then case $my_dlsyms in "") ;; *.c) # Discover the nlist of each of the dlfiles. nlist=$output_objdir/$my_outputname.nm func_show_eval "$RM $nlist ${nlist}S ${nlist}T" # Parse the name list into a source file. func_verbose "creating $output_objdir/$my_dlsyms" $opt_dry_run || $ECHO > "$output_objdir/$my_dlsyms" "\ /* $my_dlsyms - symbol resolution table for '$my_outputname' dlsym emulation. */ /* Generated by $PROGRAM (GNU $PACKAGE) $VERSION */ #ifdef __cplusplus extern \"C\" { #endif #if defined __GNUC__ && (((__GNUC__ == 4) && (__GNUC_MINOR__ >= 4)) || (__GNUC__ > 4)) #pragma GCC diagnostic ignored \"-Wstrict-prototypes\" #endif /* Keep this code in sync between libtool.m4, ltmain, lt_system.h, and tests. */ #if defined _WIN32 || defined __CYGWIN__ || defined _WIN32_WCE /* DATA imports from DLLs on WIN32 can't be const, because runtime relocations are performed -- see ld's documentation on pseudo-relocs. */ # define LT_DLSYM_CONST #elif defined __osf__ /* This system does not cope well with relocations in const data. */ # define LT_DLSYM_CONST #else # define LT_DLSYM_CONST const #endif #define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0) /* External symbol declarations for the compiler. */\ " if test yes = "$dlself"; then func_verbose "generating symbol list for '$output'" $opt_dry_run || echo ': @PROGRAM@ ' > "$nlist" # Add our own program objects to the symbol list. progfiles=`$ECHO "$objs$old_deplibs" | $SP2NL | $SED "$lo2o" | $NL2SP` for progfile in $progfiles; do func_to_tool_file "$progfile" func_convert_file_msys_to_w32 func_verbose "extracting global C symbols from '$func_to_tool_file_result'" $opt_dry_run || eval "$NM $func_to_tool_file_result | $global_symbol_pipe >> '$nlist'" done if test -n "$exclude_expsyms"; then $opt_dry_run || { eval '$EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' } fi if test -n "$export_symbols_regex"; then $opt_dry_run || { eval '$EGREP -e "$export_symbols_regex" "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' } fi # Prepare the list of exported symbols if test -z "$export_symbols"; then export_symbols=$output_objdir/$outputname.exp $opt_dry_run || { $RM $export_symbols eval "$SED -n -e '/^: @PROGRAM@ $/d' -e 's/^.* \(.*\)$/\1/p' "'< "$nlist" > "$export_symbols"' case $host in *cygwin* | *mingw* | *cegcc* ) eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' eval 'cat "$export_symbols" >> "$output_objdir/$outputname.def"' ;; esac } else $opt_dry_run || { eval "$SED -e 's/\([].[*^$]\)/\\\\\1/g' -e 's/^/ /' -e 's/$/$/'"' < "$export_symbols" > "$output_objdir/$outputname.exp"' eval '$GREP -f "$output_objdir/$outputname.exp" < "$nlist" > "$nlist"T' eval '$MV "$nlist"T "$nlist"' case $host in *cygwin* | *mingw* | *cegcc* ) eval "echo EXPORTS "'> "$output_objdir/$outputname.def"' eval 'cat "$nlist" >> "$output_objdir/$outputname.def"' ;; esac } fi fi for dlprefile in $dlprefiles; do func_verbose "extracting global C symbols from '$dlprefile'" func_basename "$dlprefile" name=$func_basename_result case $host in *cygwin* | *mingw* | *cegcc* ) # if an import library, we need to obtain dlname if func_win32_import_lib_p "$dlprefile"; then func_tr_sh "$dlprefile" eval "curr_lafile=\$libfile_$func_tr_sh_result" dlprefile_dlbasename= if test -n "$curr_lafile" && func_lalib_p "$curr_lafile"; then # Use subshell, to avoid clobbering current variable values dlprefile_dlname=`source "$curr_lafile" && echo "$dlname"` if test -n "$dlprefile_dlname"; then func_basename "$dlprefile_dlname" dlprefile_dlbasename=$func_basename_result else # no lafile. user explicitly requested -dlpreopen . $sharedlib_from_linklib_cmd "$dlprefile" dlprefile_dlbasename=$sharedlib_from_linklib_result fi fi $opt_dry_run || { if test -n "$dlprefile_dlbasename"; then eval '$ECHO ": $dlprefile_dlbasename" >> "$nlist"' else func_warning "Could not compute DLL name from $name" eval '$ECHO ": $name " >> "$nlist"' fi func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe | $SED -e '/I __imp/d' -e 's/I __nm_/D /;s/_nm__//' >> '$nlist'" } else # not an import lib $opt_dry_run || { eval '$ECHO ": $name " >> "$nlist"' func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'" } fi ;; *) $opt_dry_run || { eval '$ECHO ": $name " >> "$nlist"' func_to_tool_file "$dlprefile" func_convert_file_msys_to_w32 eval "$NM \"$func_to_tool_file_result\" 2>/dev/null | $global_symbol_pipe >> '$nlist'" } ;; esac done $opt_dry_run || { # Make sure we have at least an empty file. test -f "$nlist" || : > "$nlist" if test -n "$exclude_expsyms"; then $EGREP -v " ($exclude_expsyms)$" "$nlist" > "$nlist"T $MV "$nlist"T "$nlist" fi # Try sorting and uniquifying the output. if $GREP -v "^: " < "$nlist" | if sort -k 3 /dev/null 2>&1; then sort -k 3 else sort +2 fi | uniq > "$nlist"S; then : else $GREP -v "^: " < "$nlist" > "$nlist"S fi if test -f "$nlist"S; then eval "$global_symbol_to_cdecl"' < "$nlist"S >> "$output_objdir/$my_dlsyms"' else echo '/* NONE */' >> "$output_objdir/$my_dlsyms" fi func_show_eval '$RM "${nlist}I"' if test -n "$global_symbol_to_import"; then eval "$global_symbol_to_import"' < "$nlist"S > "$nlist"I' fi echo >> "$output_objdir/$my_dlsyms" "\ /* The mapping between symbol names and symbols. */ typedef struct { const char *name; void *address; } lt_dlsymlist; extern LT_DLSYM_CONST lt_dlsymlist lt_${my_prefix}_LTX_preloaded_symbols[];\ " if test -s "$nlist"I; then echo >> "$output_objdir/$my_dlsyms" "\ static void lt_syminit(void) { LT_DLSYM_CONST lt_dlsymlist *symbol = lt_${my_prefix}_LTX_preloaded_symbols; for (; symbol->name; ++symbol) {" $SED 's/.*/ if (STREQ (symbol->name, \"&\")) symbol->address = (void *) \&&;/' < "$nlist"I >> "$output_objdir/$my_dlsyms" echo >> "$output_objdir/$my_dlsyms" "\ } }" fi echo >> "$output_objdir/$my_dlsyms" "\ LT_DLSYM_CONST lt_dlsymlist lt_${my_prefix}_LTX_preloaded_symbols[] = { {\"$my_originator\", (void *) 0}," if test -s "$nlist"I; then echo >> "$output_objdir/$my_dlsyms" "\ {\"@INIT@\", (void *) <_syminit}," fi case $need_lib_prefix in no) eval "$global_symbol_to_c_name_address" < "$nlist" >> "$output_objdir/$my_dlsyms" ;; *) eval "$global_symbol_to_c_name_address_lib_prefix" < "$nlist" >> "$output_objdir/$my_dlsyms" ;; esac echo >> "$output_objdir/$my_dlsyms" "\ {0, (void *) 0} }; /* This works around a problem in FreeBSD linker */ #ifdef FREEBSD_WORKAROUND static const void *lt_preloaded_setup() { return lt_${my_prefix}_LTX_preloaded_symbols; } #endif #ifdef __cplusplus } #endif\ " } # !$opt_dry_run pic_flag_for_symtable= case "$compile_command " in *" -static "*) ;; *) case $host in # compiling the symbol table file with pic_flag works around # a FreeBSD bug that causes programs to crash when -lm is # linked before any other PIC object. But we must not use # pic_flag when linking with -static. The problem exists in # FreeBSD 2.2.6 and is fixed in FreeBSD 3.1. *-*-freebsd2.*|*-*-freebsd3.0*|*-*-freebsdelf3.0*) pic_flag_for_symtable=" $pic_flag -DFREEBSD_WORKAROUND" ;; *-*-hpux*) pic_flag_for_symtable=" $pic_flag" ;; *) $my_pic_p && pic_flag_for_symtable=" $pic_flag" ;; esac ;; esac symtab_cflags= for arg in $LTCFLAGS; do case $arg in -pie | -fpie | -fPIE) ;; *) func_append symtab_cflags " $arg" ;; esac done # Now compile the dynamic symbol file. func_show_eval '(cd $output_objdir && $LTCC$symtab_cflags -c$no_builtin_flag$pic_flag_for_symtable "$my_dlsyms")' 'exit $?' # Clean up the generated files. func_show_eval '$RM "$output_objdir/$my_dlsyms" "$nlist" "${nlist}S" "${nlist}T" "${nlist}I"' # Transform the symbol file into the correct name. symfileobj=$output_objdir/${my_outputname}S.$objext case $host in *cygwin* | *mingw* | *cegcc* ) if test -f "$output_objdir/$my_outputname.def"; then compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$output_objdir/$my_outputname.def $symfileobj%"` else compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"` fi ;; *) compile_command=`$ECHO "$compile_command" | $SED "s%@SYMFILE@%$symfileobj%"` finalize_command=`$ECHO "$finalize_command" | $SED "s%@SYMFILE@%$symfileobj%"` ;; esac ;; *) func_fatal_error "unknown suffix for '$my_dlsyms'" ;; esac else # We keep going just in case the user didn't refer to # lt_preloaded_symbols. The linker will fail if global_symbol_pipe # really was required. # Nullify the symbol file. compile_command=`$ECHO "$compile_command" | $SED "s% @SYMFILE@%%"` finalize_command=`$ECHO "$finalize_command" | $SED "s% @SYMFILE@%%"` fi } # func_cygming_gnu_implib_p ARG # This predicate returns with zero status (TRUE) if # ARG is a GNU/binutils-style import library. Returns # with nonzero status (FALSE) otherwise. func_cygming_gnu_implib_p () { $debug_cmd func_to_tool_file "$1" func_convert_file_msys_to_w32 func_cygming_gnu_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $EGREP ' (_head_[A-Za-z0-9_]+_[ad]l*|[A-Za-z0-9_]+_[ad]l*_iname)$'` test -n "$func_cygming_gnu_implib_tmp" } # func_cygming_ms_implib_p ARG # This predicate returns with zero status (TRUE) if # ARG is an MS-style import library. Returns # with nonzero status (FALSE) otherwise. func_cygming_ms_implib_p () { $debug_cmd func_to_tool_file "$1" func_convert_file_msys_to_w32 func_cygming_ms_implib_tmp=`$NM "$func_to_tool_file_result" | eval "$global_symbol_pipe" | $GREP '_NULL_IMPORT_DESCRIPTOR'` test -n "$func_cygming_ms_implib_tmp" } # func_win32_libid arg # return the library type of file 'arg' # # Need a lot of goo to handle *both* DLLs and import libs # Has to be a shell function in order to 'eat' the argument # that is supplied when $file_magic_command is called. # Despite the name, also deal with 64 bit binaries. func_win32_libid () { $debug_cmd win32_libid_type=unknown win32_fileres=`file -L $1 2>/dev/null` case $win32_fileres in *ar\ archive\ import\ library*) # definitely import win32_libid_type="x86 archive import" ;; *ar\ archive*) # could be an import, or static # Keep the egrep pattern in sync with the one in _LT_CHECK_MAGIC_METHOD. if eval $OBJDUMP -f $1 | $SED -e '10q' 2>/dev/null | $EGREP 'file format (pei*-i386(.*architecture: i386)?|pe-arm-wince|pe-x86-64)' >/dev/null; then case $nm_interface in "MS dumpbin") if func_cygming_ms_implib_p "$1" || func_cygming_gnu_implib_p "$1" then win32_nmres=import else win32_nmres= fi ;; *) func_to_tool_file "$1" func_convert_file_msys_to_w32 win32_nmres=`eval $NM -f posix -A \"$func_to_tool_file_result\" | $SED -n -e ' 1,100{ / I /{ s|.*|import| p q } }'` ;; esac case $win32_nmres in import*) win32_libid_type="x86 archive import";; *) win32_libid_type="x86 archive static";; esac fi ;; *DLL*) win32_libid_type="x86 DLL" ;; *executable*) # but shell scripts are "executable" too... case $win32_fileres in *MS\ Windows\ PE\ Intel*) win32_libid_type="x86 DLL" ;; esac ;; esac $ECHO "$win32_libid_type" } # func_cygming_dll_for_implib ARG # # Platform-specific function to extract the # name of the DLL associated with the specified # import library ARG. # Invoked by eval'ing the libtool variable # $sharedlib_from_linklib_cmd # Result is available in the variable # $sharedlib_from_linklib_result func_cygming_dll_for_implib () { $debug_cmd sharedlib_from_linklib_result=`$DLLTOOL --identify-strict --identify "$1"` } # func_cygming_dll_for_implib_fallback_core SECTION_NAME LIBNAMEs # # The is the core of a fallback implementation of a # platform-specific function to extract the name of the # DLL associated with the specified import library LIBNAME. # # SECTION_NAME is either .idata$6 or .idata$7, depending # on the platform and compiler that created the implib. # # Echos the name of the DLL associated with the # specified import library. func_cygming_dll_for_implib_fallback_core () { $debug_cmd match_literal=`$ECHO "$1" | $SED "$sed_make_literal_regex"` $OBJDUMP -s --section "$1" "$2" 2>/dev/null | $SED '/^Contents of section '"$match_literal"':/{ # Place marker at beginning of archive member dllname section s/.*/====MARK====/ p d } # These lines can sometimes be longer than 43 characters, but # are always uninteresting /:[ ]*file format pe[i]\{,1\}-/d /^In archive [^:]*:/d # Ensure marker is printed /^====MARK====/p # Remove all lines with less than 43 characters /^.\{43\}/!d # From remaining lines, remove first 43 characters s/^.\{43\}//' | $SED -n ' # Join marker and all lines until next marker into a single line /^====MARK====/ b para H $ b para b :para x s/\n//g # Remove the marker s/^====MARK====// # Remove trailing dots and whitespace s/[\. \t]*$// # Print /./p' | # we now have a list, one entry per line, of the stringified # contents of the appropriate section of all members of the # archive that possess that section. Heuristic: eliminate # all those that have a first or second character that is # a '.' (that is, objdump's representation of an unprintable # character.) This should work for all archives with less than # 0x302f exports -- but will fail for DLLs whose name actually # begins with a literal '.' or a single character followed by # a '.'. # # Of those that remain, print the first one. $SED -e '/^\./d;/^.\./d;q' } # func_cygming_dll_for_implib_fallback ARG # Platform-specific function to extract the # name of the DLL associated with the specified # import library ARG. # # This fallback implementation is for use when $DLLTOOL # does not support the --identify-strict option. # Invoked by eval'ing the libtool variable # $sharedlib_from_linklib_cmd # Result is available in the variable # $sharedlib_from_linklib_result func_cygming_dll_for_implib_fallback () { $debug_cmd if func_cygming_gnu_implib_p "$1"; then # binutils import library sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$7' "$1"` elif func_cygming_ms_implib_p "$1"; then # ms-generated import library sharedlib_from_linklib_result=`func_cygming_dll_for_implib_fallback_core '.idata$6' "$1"` else # unknown sharedlib_from_linklib_result= fi } # func_extract_an_archive dir oldlib func_extract_an_archive () { $debug_cmd f_ex_an_ar_dir=$1; shift f_ex_an_ar_oldlib=$1 if test yes = "$lock_old_archive_extraction"; then lockfile=$f_ex_an_ar_oldlib.lock until $opt_dry_run || ln "$progpath" "$lockfile" 2>/dev/null; do func_echo "Waiting for $lockfile to be removed" sleep 2 done fi func_show_eval "(cd \$f_ex_an_ar_dir && $AR x \"\$f_ex_an_ar_oldlib\")" \ 'stat=$?; rm -f "$lockfile"; exit $stat' if test yes = "$lock_old_archive_extraction"; then $opt_dry_run || rm -f "$lockfile" fi if ($AR t "$f_ex_an_ar_oldlib" | sort | sort -uc >/dev/null 2>&1); then : else func_fatal_error "object name conflicts in archive: $f_ex_an_ar_dir/$f_ex_an_ar_oldlib" fi } # func_extract_archives gentop oldlib ... func_extract_archives () { $debug_cmd my_gentop=$1; shift my_oldlibs=${1+"$@"} my_oldobjs= my_xlib= my_xabs= my_xdir= for my_xlib in $my_oldlibs; do # Extract the objects. case $my_xlib in [\\/]* | [A-Za-z]:[\\/]*) my_xabs=$my_xlib ;; *) my_xabs=`pwd`"/$my_xlib" ;; esac func_basename "$my_xlib" my_xlib=$func_basename_result my_xlib_u=$my_xlib while :; do case " $extracted_archives " in *" $my_xlib_u "*) func_arith $extracted_serial + 1 extracted_serial=$func_arith_result my_xlib_u=lt$extracted_serial-$my_xlib ;; *) break ;; esac done extracted_archives="$extracted_archives $my_xlib_u" my_xdir=$my_gentop/$my_xlib_u func_mkdir_p "$my_xdir" case $host in *-darwin*) func_verbose "Extracting $my_xabs" # Do not bother doing anything if just a dry run $opt_dry_run || { darwin_orig_dir=`pwd` cd $my_xdir || exit $? darwin_archive=$my_xabs darwin_curdir=`pwd` func_basename "$darwin_archive" darwin_base_archive=$func_basename_result darwin_arches=`$LIPO -info "$darwin_archive" 2>/dev/null | $GREP Architectures 2>/dev/null || true` if test -n "$darwin_arches"; then darwin_arches=`$ECHO "$darwin_arches" | $SED -e 's/.*are://'` darwin_arch= func_verbose "$darwin_base_archive has multiple architectures $darwin_arches" for darwin_arch in $darwin_arches; do func_mkdir_p "unfat-$$/$darwin_base_archive-$darwin_arch" $LIPO -thin $darwin_arch -output "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive" "$darwin_archive" cd "unfat-$$/$darwin_base_archive-$darwin_arch" func_extract_an_archive "`pwd`" "$darwin_base_archive" cd "$darwin_curdir" $RM "unfat-$$/$darwin_base_archive-$darwin_arch/$darwin_base_archive" done # $darwin_arches ## Okay now we've a bunch of thin objects, gotta fatten them up :) darwin_filelist=`find unfat-$$ -type f -name \*.o -print -o -name \*.lo -print | $SED -e "$sed_basename" | sort -u` darwin_file= darwin_files= for darwin_file in $darwin_filelist; do darwin_files=`find unfat-$$ -name $darwin_file -print | sort | $NL2SP` $LIPO -create -output "$darwin_file" $darwin_files done # $darwin_filelist $RM -rf unfat-$$ cd "$darwin_orig_dir" else cd $darwin_orig_dir func_extract_an_archive "$my_xdir" "$my_xabs" fi # $darwin_arches } # !$opt_dry_run ;; *) func_extract_an_archive "$my_xdir" "$my_xabs" ;; esac my_oldobjs="$my_oldobjs "`find $my_xdir -name \*.$objext -print -o -name \*.lo -print | sort | $NL2SP` done func_extract_archives_result=$my_oldobjs } # func_emit_wrapper [arg=no] # # Emit a libtool wrapper script on stdout. # Don't directly open a file because we may want to # incorporate the script contents within a cygwin/mingw # wrapper executable. Must ONLY be called from within # func_mode_link because it depends on a number of variables # set therein. # # ARG is the value that the WRAPPER_SCRIPT_BELONGS_IN_OBJDIR # variable will take. If 'yes', then the emitted script # will assume that the directory where it is stored is # the $objdir directory. This is a cygwin/mingw-specific # behavior. func_emit_wrapper () { func_emit_wrapper_arg1=${1-no} $ECHO "\ #! $SHELL # $output - temporary wrapper script for $objdir/$outputname # Generated by $PROGRAM (GNU $PACKAGE) $VERSION # # The $output program cannot be directly executed until all the libtool # libraries that it depends on are installed. # # This wrapper script should never be moved out of the build directory. # If it is, it will not operate correctly. # Sed substitution that helps us do robust quoting. It backslashifies # metacharacters that are still active within double-quoted strings. sed_quote_subst='$sed_quote_subst' # Be Bourne compatible if test -n \"\${ZSH_VERSION+set}\" && (emulate sh) >/dev/null 2>&1; then emulate sh NULLCMD=: # Zsh 3.x and 4.x performs word splitting on \${1+\"\$@\"}, which # is contrary to our usage. Disable this feature. alias -g '\${1+\"\$@\"}'='\"\$@\"' setopt NO_GLOB_SUBST else case \`(set -o) 2>/dev/null\` in *posix*) set -o posix;; esac fi BIN_SH=xpg4; export BIN_SH # for Tru64 DUALCASE=1; export DUALCASE # for MKS sh # The HP-UX ksh and POSIX shell print the target directory to stdout # if CDPATH is set. (unset CDPATH) >/dev/null 2>&1 && unset CDPATH relink_command=\"$relink_command\" # This environment variable determines our operation mode. if test \"\$libtool_install_magic\" = \"$magic\"; then # install mode needs the following variables: generated_by_libtool_version='$macro_version' notinst_deplibs='$notinst_deplibs' else # When we are sourced in execute mode, \$file and \$ECHO are already set. if test \"\$libtool_execute_magic\" != \"$magic\"; then file=\"\$0\"" func_quote_arg pretty "$ECHO" qECHO=$func_quote_arg_result $ECHO "\ # A function that is used when there is no print builtin or printf. func_fallback_echo () { eval 'cat <<_LTECHO_EOF \$1 _LTECHO_EOF' } ECHO=$qECHO fi # Very basic option parsing. These options are (a) specific to # the libtool wrapper, (b) are identical between the wrapper # /script/ and the wrapper /executable/ that is used only on # windows platforms, and (c) all begin with the string "--lt-" # (application programs are unlikely to have options that match # this pattern). # # There are only two supported options: --lt-debug and # --lt-dump-script. There is, deliberately, no --lt-help. # # The first argument to this parsing function should be the # script's $0 value, followed by "$@". lt_option_debug= func_parse_lt_options () { lt_script_arg0=\$0 shift for lt_opt do case \"\$lt_opt\" in --lt-debug) lt_option_debug=1 ;; --lt-dump-script) lt_dump_D=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%/[^/]*$%%'\` test \"X\$lt_dump_D\" = \"X\$lt_script_arg0\" && lt_dump_D=. lt_dump_F=\`\$ECHO \"X\$lt_script_arg0\" | $SED -e 's/^X//' -e 's%^.*/%%'\` cat \"\$lt_dump_D/\$lt_dump_F\" exit 0 ;; --lt-*) \$ECHO \"Unrecognized --lt- option: '\$lt_opt'\" 1>&2 exit 1 ;; esac done # Print the debug banner immediately: if test -n \"\$lt_option_debug\"; then echo \"$outputname:$output:\$LINENO: libtool wrapper (GNU $PACKAGE) $VERSION\" 1>&2 fi } # Used when --lt-debug. Prints its arguments to stdout # (redirection is the responsibility of the caller) func_lt_dump_args () { lt_dump_args_N=1; for lt_arg do \$ECHO \"$outputname:$output:\$LINENO: newargv[\$lt_dump_args_N]: \$lt_arg\" lt_dump_args_N=\`expr \$lt_dump_args_N + 1\` done } # Core function for launching the target application func_exec_program_core () { " case $host in # Backslashes separate directories on plain windows *-*-mingw | *-*-os2* | *-cegcc*) $ECHO "\ if test -n \"\$lt_option_debug\"; then \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir\\\\\$program\" 1>&2 func_lt_dump_args \${1+\"\$@\"} 1>&2 fi exec \"\$progdir\\\\\$program\" \${1+\"\$@\"} " ;; *) $ECHO "\ if test -n \"\$lt_option_debug\"; then \$ECHO \"$outputname:$output:\$LINENO: newargv[0]: \$progdir/\$program\" 1>&2 func_lt_dump_args \${1+\"\$@\"} 1>&2 fi exec \"\$progdir/\$program\" \${1+\"\$@\"} " ;; esac $ECHO "\ \$ECHO \"\$0: cannot exec \$program \$*\" 1>&2 exit 1 } # A function to encapsulate launching the target application # Strips options in the --lt-* namespace from \$@ and # launches target application with the remaining arguments. func_exec_program () { case \" \$* \" in *\\ --lt-*) for lt_wr_arg do case \$lt_wr_arg in --lt-*) ;; *) set x \"\$@\" \"\$lt_wr_arg\"; shift;; esac shift done ;; esac func_exec_program_core \${1+\"\$@\"} } # Parse options func_parse_lt_options \"\$0\" \${1+\"\$@\"} # Find the directory that this script lives in. thisdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*$%%'\` test \"x\$thisdir\" = \"x\$file\" && thisdir=. # Follow symbolic links until we get to the real thisdir. file=\`ls -ld \"\$file\" | $SED -n 's/.*-> //p'\` while test -n \"\$file\"; do destdir=\`\$ECHO \"\$file\" | $SED 's%/[^/]*\$%%'\` # If there was a directory component, then change thisdir. if test \"x\$destdir\" != \"x\$file\"; then case \"\$destdir\" in [\\\\/]* | [A-Za-z]:[\\\\/]*) thisdir=\"\$destdir\" ;; *) thisdir=\"\$thisdir/\$destdir\" ;; esac fi file=\`\$ECHO \"\$file\" | $SED 's%^.*/%%'\` file=\`ls -ld \"\$thisdir/\$file\" | $SED -n 's/.*-> //p'\` done # Usually 'no', except on cygwin/mingw when embedded into # the cwrapper. WRAPPER_SCRIPT_BELONGS_IN_OBJDIR=$func_emit_wrapper_arg1 if test \"\$WRAPPER_SCRIPT_BELONGS_IN_OBJDIR\" = \"yes\"; then # special case for '.' if test \"\$thisdir\" = \".\"; then thisdir=\`pwd\` fi # remove .libs from thisdir case \"\$thisdir\" in *[\\\\/]$objdir ) thisdir=\`\$ECHO \"\$thisdir\" | $SED 's%[\\\\/][^\\\\/]*$%%'\` ;; $objdir ) thisdir=. ;; esac fi # Try to get the absolute directory name. absdir=\`cd \"\$thisdir\" && pwd\` test -n \"\$absdir\" && thisdir=\"\$absdir\" " if test yes = "$fast_install"; then $ECHO "\ program=lt-'$outputname'$exeext progdir=\"\$thisdir/$objdir\" if test ! -f \"\$progdir/\$program\" || { file=\`ls -1dt \"\$progdir/\$program\" \"\$progdir/../\$program\" 2>/dev/null | $SED 1q\`; \\ test \"X\$file\" != \"X\$progdir/\$program\"; }; then file=\"\$\$-\$program\" if test ! -d \"\$progdir\"; then $MKDIR \"\$progdir\" else $RM \"\$progdir/\$file\" fi" $ECHO "\ # relink executable if necessary if test -n \"\$relink_command\"; then if relink_command_output=\`eval \$relink_command 2>&1\`; then : else \$ECHO \"\$relink_command_output\" >&2 $RM \"\$progdir/\$file\" exit 1 fi fi $MV \"\$progdir/\$file\" \"\$progdir/\$program\" 2>/dev/null || { $RM \"\$progdir/\$program\"; $MV \"\$progdir/\$file\" \"\$progdir/\$program\"; } $RM \"\$progdir/\$file\" fi" else $ECHO "\ program='$outputname' progdir=\"\$thisdir/$objdir\" " fi $ECHO "\ if test -f \"\$progdir/\$program\"; then" # fixup the dll searchpath if we need to. # # Fix the DLL searchpath if we need to. Do this before prepending # to shlibpath, because on Windows, both are PATH and uninstalled # libraries must come first. if test -n "$dllsearchpath"; then $ECHO "\ # Add the dll search path components to the executable PATH PATH=$dllsearchpath:\$PATH " fi # Export our shlibpath_var if we have one. if test yes = "$shlibpath_overrides_runpath" && test -n "$shlibpath_var" && test -n "$temp_rpath"; then $ECHO "\ # Add our own library path to $shlibpath_var $shlibpath_var=\"$temp_rpath\$$shlibpath_var\" # Some systems cannot cope with colon-terminated $shlibpath_var # The second colon is a workaround for a bug in BeOS R4 sed $shlibpath_var=\`\$ECHO \"\$$shlibpath_var\" | $SED 's/::*\$//'\` export $shlibpath_var " fi $ECHO "\ if test \"\$libtool_execute_magic\" != \"$magic\"; then # Run the actual program with our arguments. func_exec_program \${1+\"\$@\"} fi else # The program doesn't exist. \$ECHO \"\$0: error: '\$progdir/\$program' does not exist\" 1>&2 \$ECHO \"This script is just a wrapper for \$program.\" 1>&2 \$ECHO \"See the $PACKAGE documentation for more information.\" 1>&2 exit 1 fi fi\ " } # func_emit_cwrapperexe_src # emit the source code for a wrapper executable on stdout # Must ONLY be called from within func_mode_link because # it depends on a number of variable set therein. func_emit_cwrapperexe_src () { cat < #include #ifdef _MSC_VER # include # include # include #else # include # include # ifdef __CYGWIN__ # include # endif #endif #include #include #include #include #include #include #include #include #define STREQ(s1, s2) (strcmp ((s1), (s2)) == 0) /* declarations of non-ANSI functions */ #if defined __MINGW32__ # ifdef __STRICT_ANSI__ int _putenv (const char *); # endif #elif defined __CYGWIN__ # ifdef __STRICT_ANSI__ char *realpath (const char *, char *); int putenv (char *); int setenv (const char *, const char *, int); # endif /* #elif defined other_platform || defined ... */ #endif /* portability defines, excluding path handling macros */ #if defined _MSC_VER # define setmode _setmode # define stat _stat # define chmod _chmod # define getcwd _getcwd # define putenv _putenv # define S_IXUSR _S_IEXEC #elif defined __MINGW32__ # define setmode _setmode # define stat _stat # define chmod _chmod # define getcwd _getcwd # define putenv _putenv #elif defined __CYGWIN__ # define HAVE_SETENV # define FOPEN_WB "wb" /* #elif defined other platforms ... */ #endif #if defined PATH_MAX # define LT_PATHMAX PATH_MAX #elif defined MAXPATHLEN # define LT_PATHMAX MAXPATHLEN #else # define LT_PATHMAX 1024 #endif #ifndef S_IXOTH # define S_IXOTH 0 #endif #ifndef S_IXGRP # define S_IXGRP 0 #endif /* path handling portability macros */ #ifndef DIR_SEPARATOR # define DIR_SEPARATOR '/' # define PATH_SEPARATOR ':' #endif #if defined _WIN32 || defined __MSDOS__ || defined __DJGPP__ || \ defined __OS2__ # define HAVE_DOS_BASED_FILE_SYSTEM # define FOPEN_WB "wb" # ifndef DIR_SEPARATOR_2 # define DIR_SEPARATOR_2 '\\' # endif # ifndef PATH_SEPARATOR_2 # define PATH_SEPARATOR_2 ';' # endif #endif #ifndef DIR_SEPARATOR_2 # define IS_DIR_SEPARATOR(ch) ((ch) == DIR_SEPARATOR) #else /* DIR_SEPARATOR_2 */ # define IS_DIR_SEPARATOR(ch) \ (((ch) == DIR_SEPARATOR) || ((ch) == DIR_SEPARATOR_2)) #endif /* DIR_SEPARATOR_2 */ #ifndef PATH_SEPARATOR_2 # define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR) #else /* PATH_SEPARATOR_2 */ # define IS_PATH_SEPARATOR(ch) ((ch) == PATH_SEPARATOR_2) #endif /* PATH_SEPARATOR_2 */ #ifndef FOPEN_WB # define FOPEN_WB "w" #endif #ifndef _O_BINARY # define _O_BINARY 0 #endif #define XMALLOC(type, num) ((type *) xmalloc ((num) * sizeof(type))) #define XFREE(stale) do { \ if (stale) { free (stale); stale = 0; } \ } while (0) #if defined LT_DEBUGWRAPPER static int lt_debug = 1; #else static int lt_debug = 0; #endif const char *program_name = "libtool-wrapper"; /* in case xstrdup fails */ void *xmalloc (size_t num); char *xstrdup (const char *string); const char *base_name (const char *name); char *find_executable (const char *wrapper); char *chase_symlinks (const char *pathspec); int make_executable (const char *path); int check_executable (const char *path); char *strendzap (char *str, const char *pat); void lt_debugprintf (const char *file, int line, const char *fmt, ...); void lt_fatal (const char *file, int line, const char *message, ...); static const char *nonnull (const char *s); static const char *nonempty (const char *s); void lt_setenv (const char *name, const char *value); char *lt_extend_str (const char *orig_value, const char *add, int to_end); void lt_update_exe_path (const char *name, const char *value); void lt_update_lib_path (const char *name, const char *value); char **prepare_spawn (char **argv); void lt_dump_script (FILE *f); EOF cat <= 0) && (st.st_mode & (S_IXUSR | S_IXGRP | S_IXOTH))) return 1; else return 0; } int make_executable (const char *path) { int rval = 0; struct stat st; lt_debugprintf (__FILE__, __LINE__, "(make_executable): %s\n", nonempty (path)); if ((!path) || (!*path)) return 0; if (stat (path, &st) >= 0) { rval = chmod (path, st.st_mode | S_IXOTH | S_IXGRP | S_IXUSR); } return rval; } /* Searches for the full path of the wrapper. Returns newly allocated full path name if found, NULL otherwise Does not chase symlinks, even on platforms that support them. */ char * find_executable (const char *wrapper) { int has_slash = 0; const char *p; const char *p_next; /* static buffer for getcwd */ char tmp[LT_PATHMAX + 1]; size_t tmp_len; char *concat_name; lt_debugprintf (__FILE__, __LINE__, "(find_executable): %s\n", nonempty (wrapper)); if ((wrapper == NULL) || (*wrapper == '\0')) return NULL; /* Absolute path? */ #if defined HAVE_DOS_BASED_FILE_SYSTEM if (isalpha ((unsigned char) wrapper[0]) && wrapper[1] == ':') { concat_name = xstrdup (wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } else { #endif if (IS_DIR_SEPARATOR (wrapper[0])) { concat_name = xstrdup (wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } #if defined HAVE_DOS_BASED_FILE_SYSTEM } #endif for (p = wrapper; *p; p++) if (*p == '/') { has_slash = 1; break; } if (!has_slash) { /* no slashes; search PATH */ const char *path = getenv ("PATH"); if (path != NULL) { for (p = path; *p; p = p_next) { const char *q; size_t p_len; for (q = p; *q; q++) if (IS_PATH_SEPARATOR (*q)) break; p_len = (size_t) (q - p); p_next = (*q == '\0' ? q : q + 1); if (p_len == 0) { /* empty path: current directory */ if (getcwd (tmp, LT_PATHMAX) == NULL) lt_fatal (__FILE__, __LINE__, "getcwd failed: %s", nonnull (strerror (errno))); tmp_len = strlen (tmp); concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, tmp, tmp_len); concat_name[tmp_len] = '/'; strcpy (concat_name + tmp_len + 1, wrapper); } else { concat_name = XMALLOC (char, p_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, p, p_len); concat_name[p_len] = '/'; strcpy (concat_name + p_len + 1, wrapper); } if (check_executable (concat_name)) return concat_name; XFREE (concat_name); } } /* not found in PATH; assume curdir */ } /* Relative path | not found in path: prepend cwd */ if (getcwd (tmp, LT_PATHMAX) == NULL) lt_fatal (__FILE__, __LINE__, "getcwd failed: %s", nonnull (strerror (errno))); tmp_len = strlen (tmp); concat_name = XMALLOC (char, tmp_len + 1 + strlen (wrapper) + 1); memcpy (concat_name, tmp, tmp_len); concat_name[tmp_len] = '/'; strcpy (concat_name + tmp_len + 1, wrapper); if (check_executable (concat_name)) return concat_name; XFREE (concat_name); return NULL; } char * chase_symlinks (const char *pathspec) { #ifndef S_ISLNK return xstrdup (pathspec); #else char buf[LT_PATHMAX]; struct stat s; char *tmp_pathspec = xstrdup (pathspec); char *p; int has_symlinks = 0; while (strlen (tmp_pathspec) && !has_symlinks) { lt_debugprintf (__FILE__, __LINE__, "checking path component for symlinks: %s\n", tmp_pathspec); if (lstat (tmp_pathspec, &s) == 0) { if (S_ISLNK (s.st_mode) != 0) { has_symlinks = 1; break; } /* search backwards for last DIR_SEPARATOR */ p = tmp_pathspec + strlen (tmp_pathspec) - 1; while ((p > tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) p--; if ((p == tmp_pathspec) && (!IS_DIR_SEPARATOR (*p))) { /* no more DIR_SEPARATORS left */ break; } *p = '\0'; } else { lt_fatal (__FILE__, __LINE__, "error accessing file \"%s\": %s", tmp_pathspec, nonnull (strerror (errno))); } } XFREE (tmp_pathspec); if (!has_symlinks) { return xstrdup (pathspec); } tmp_pathspec = realpath (pathspec, buf); if (tmp_pathspec == 0) { lt_fatal (__FILE__, __LINE__, "could not follow symlinks for %s", pathspec); } return xstrdup (tmp_pathspec); #endif } char * strendzap (char *str, const char *pat) { size_t len, patlen; assert (str != NULL); assert (pat != NULL); len = strlen (str); patlen = strlen (pat); if (patlen <= len) { str += len - patlen; if (STREQ (str, pat)) *str = '\0'; } return str; } void lt_debugprintf (const char *file, int line, const char *fmt, ...) { va_list args; if (lt_debug) { (void) fprintf (stderr, "%s:%s:%d: ", program_name, file, line); va_start (args, fmt); (void) vfprintf (stderr, fmt, args); va_end (args); } } static void lt_error_core (int exit_status, const char *file, int line, const char *mode, const char *message, va_list ap) { fprintf (stderr, "%s:%s:%d: %s: ", program_name, file, line, mode); vfprintf (stderr, message, ap); fprintf (stderr, ".\n"); if (exit_status >= 0) exit (exit_status); } void lt_fatal (const char *file, int line, const char *message, ...) { va_list ap; va_start (ap, message); lt_error_core (EXIT_FAILURE, file, line, "FATAL", message, ap); va_end (ap); } static const char * nonnull (const char *s) { return s ? s : "(null)"; } static const char * nonempty (const char *s) { return (s && !*s) ? "(empty)" : nonnull (s); } void lt_setenv (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_setenv) setting '%s' to '%s'\n", nonnull (name), nonnull (value)); { #ifdef HAVE_SETENV /* always make a copy, for consistency with !HAVE_SETENV */ char *str = xstrdup (value); setenv (name, str, 1); #else size_t len = strlen (name) + 1 + strlen (value) + 1; char *str = XMALLOC (char, len); sprintf (str, "%s=%s", name, value); if (putenv (str) != EXIT_SUCCESS) { XFREE (str); } #endif } } char * lt_extend_str (const char *orig_value, const char *add, int to_end) { char *new_value; if (orig_value && *orig_value) { size_t orig_value_len = strlen (orig_value); size_t add_len = strlen (add); new_value = XMALLOC (char, add_len + orig_value_len + 1); if (to_end) { strcpy (new_value, orig_value); strcpy (new_value + orig_value_len, add); } else { strcpy (new_value, add); strcpy (new_value + add_len, orig_value); } } else { new_value = xstrdup (add); } return new_value; } void lt_update_exe_path (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_update_exe_path) modifying '%s' by prepending '%s'\n", nonnull (name), nonnull (value)); if (name && *name && value && *value) { char *new_value = lt_extend_str (getenv (name), value, 0); /* some systems can't cope with a ':'-terminated path #' */ size_t len = strlen (new_value); while ((len > 0) && IS_PATH_SEPARATOR (new_value[len-1])) { new_value[--len] = '\0'; } lt_setenv (name, new_value); XFREE (new_value); } } void lt_update_lib_path (const char *name, const char *value) { lt_debugprintf (__FILE__, __LINE__, "(lt_update_lib_path) modifying '%s' by prepending '%s'\n", nonnull (name), nonnull (value)); if (name && *name && value && *value) { char *new_value = lt_extend_str (getenv (name), value, 0); lt_setenv (name, new_value); XFREE (new_value); } } EOF case $host_os in mingw*) cat <<"EOF" /* Prepares an argument vector before calling spawn(). Note that spawn() does not by itself call the command interpreter (getenv ("COMSPEC") != NULL ? getenv ("COMSPEC") : ({ OSVERSIONINFO v; v.dwOSVersionInfoSize = sizeof(OSVERSIONINFO); GetVersionEx(&v); v.dwPlatformId == VER_PLATFORM_WIN32_NT; }) ? "cmd.exe" : "command.com"). Instead it simply concatenates the arguments, separated by ' ', and calls CreateProcess(). We must quote the arguments since Win32 CreateProcess() interprets characters like ' ', '\t', '\\', '"' (but not '<' and '>') in a special way: - Space and tab are interpreted as delimiters. They are not treated as delimiters if they are surrounded by double quotes: "...". - Unescaped double quotes are removed from the input. Their only effect is that within double quotes, space and tab are treated like normal characters. - Backslashes not followed by double quotes are not special. - But 2*n+1 backslashes followed by a double quote become n backslashes followed by a double quote (n >= 0): \" -> " \\\" -> \" \\\\\" -> \\" */ #define SHELL_SPECIAL_CHARS "\"\\ \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037" #define SHELL_SPACE_CHARS " \001\002\003\004\005\006\007\010\011\012\013\014\015\016\017\020\021\022\023\024\025\026\027\030\031\032\033\034\035\036\037" char ** prepare_spawn (char **argv) { size_t argc; char **new_argv; size_t i; /* Count number of arguments. */ for (argc = 0; argv[argc] != NULL; argc++) ; /* Allocate new argument vector. */ new_argv = XMALLOC (char *, argc + 1); /* Put quoted arguments into the new argument vector. */ for (i = 0; i < argc; i++) { const char *string = argv[i]; if (string[0] == '\0') new_argv[i] = xstrdup ("\"\""); else if (strpbrk (string, SHELL_SPECIAL_CHARS) != NULL) { int quote_around = (strpbrk (string, SHELL_SPACE_CHARS) != NULL); size_t length; unsigned int backslashes; const char *s; char *quoted_string; char *p; length = 0; backslashes = 0; if (quote_around) length++; for (s = string; *s != '\0'; s++) { char c = *s; if (c == '"') length += backslashes + 1; length++; if (c == '\\') backslashes++; else backslashes = 0; } if (quote_around) length += backslashes + 1; quoted_string = XMALLOC (char, length + 1); p = quoted_string; backslashes = 0; if (quote_around) *p++ = '"'; for (s = string; *s != '\0'; s++) { char c = *s; if (c == '"') { unsigned int j; for (j = backslashes + 1; j > 0; j--) *p++ = '\\'; } *p++ = c; if (c == '\\') backslashes++; else backslashes = 0; } if (quote_around) { unsigned int j; for (j = backslashes; j > 0; j--) *p++ = '\\'; *p++ = '"'; } *p = '\0'; new_argv[i] = quoted_string; } else new_argv[i] = (char *) string; } new_argv[argc] = NULL; return new_argv; } EOF ;; esac cat <<"EOF" void lt_dump_script (FILE* f) { EOF func_emit_wrapper yes | $SED -n -e ' s/^\(.\{79\}\)\(..*\)/\1\ \2/ h s/\([\\"]\)/\\\1/g s/$/\\n/ s/\([^\n]*\).*/ fputs ("\1", f);/p g D' cat <<"EOF" } EOF } # end: func_emit_cwrapperexe_src # func_win32_import_lib_p ARG # True if ARG is an import lib, as indicated by $file_magic_cmd func_win32_import_lib_p () { $debug_cmd case `eval $file_magic_cmd \"\$1\" 2>/dev/null | $SED -e 10q` in *import*) : ;; *) false ;; esac } # func_suncc_cstd_abi # !!ONLY CALL THIS FOR SUN CC AFTER $compile_command IS FULLY EXPANDED!! # Several compiler flags select an ABI that is incompatible with the # Cstd library. Avoid specifying it if any are in CXXFLAGS. func_suncc_cstd_abi () { $debug_cmd case " $compile_command " in *" -compat=g "*|*\ -std=c++[0-9][0-9]\ *|*" -library=stdcxx4 "*|*" -library=stlport4 "*) suncc_use_cstd_abi=no ;; *) suncc_use_cstd_abi=yes ;; esac } # func_mode_link arg... func_mode_link () { $debug_cmd case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) # It is impossible to link a dll without this setting, and # we shouldn't force the makefile maintainer to figure out # what system we are compiling for in order to pass an extra # flag for every libtool invocation. # allow_undefined=no # FIXME: Unfortunately, there are problems with the above when trying # to make a dll that has undefined symbols, in which case not # even a static library is built. For now, we need to specify # -no-undefined on the libtool link line when we can be certain # that all symbols are satisfied, otherwise we get a static library. allow_undefined=yes ;; *) allow_undefined=yes ;; esac libtool_args=$nonopt base_compile="$nonopt $@" compile_command=$nonopt finalize_command=$nonopt compile_rpath= finalize_rpath= compile_shlibpath= finalize_shlibpath= convenience= old_convenience= deplibs= old_deplibs= compiler_flags= linker_flags= dllsearchpath= lib_search_path=`pwd` inst_prefix_dir= new_inherited_linker_flags= avoid_version=no bindir= dlfiles= dlprefiles= dlself=no export_dynamic=no export_symbols= export_symbols_regex= generated= libobjs= ltlibs= module=no no_install=no objs= os2dllname= non_pic_objects= precious_files_regex= prefer_static_libs=no preload=false prev= prevarg= release= rpath= xrpath= perm_rpath= temp_rpath= thread_safe=no vinfo= vinfo_number=no weak_libs= single_module=$wl-single_module func_infer_tag $base_compile # We need to know -static, to get the right output filenames. for arg do case $arg in -shared) test yes != "$build_libtool_libs" \ && func_fatal_configuration "cannot build a shared library" build_old_libs=no break ;; -all-static | -static | -static-libtool-libs) case $arg in -all-static) if test yes = "$build_libtool_libs" && test -z "$link_static_flag"; then func_warning "complete static linking is impossible in this configuration" fi if test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=yes ;; -static) if test -z "$pic_flag" && test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=built ;; -static-libtool-libs) if test -z "$pic_flag" && test -n "$link_static_flag"; then dlopen_self=$dlopen_self_static fi prefer_static_libs=yes ;; esac build_libtool_libs=no build_old_libs=yes break ;; esac done # See if our shared archives depend on static archives. test -n "$old_archive_from_new_cmds" && build_old_libs=yes # Go through the arguments, transforming them on the way. while test "$#" -gt 0; do arg=$1 shift func_quote_arg pretty,unquoted "$arg" qarg=$func_quote_arg_unquoted_result func_append libtool_args " $func_quote_arg_result" # If the previous option needs an argument, assign it. if test -n "$prev"; then case $prev in output) func_append compile_command " @OUTPUT@" func_append finalize_command " @OUTPUT@" ;; esac case $prev in bindir) bindir=$arg prev= continue ;; dlfiles|dlprefiles) $preload || { # Add the symbol object into the linking commands. func_append compile_command " @SYMFILE@" func_append finalize_command " @SYMFILE@" preload=: } case $arg in *.la | *.lo) ;; # We handle these cases below. force) if test no = "$dlself"; then dlself=needless export_dynamic=yes fi prev= continue ;; self) if test dlprefiles = "$prev"; then dlself=yes elif test dlfiles = "$prev" && test yes != "$dlopen_self"; then dlself=yes else dlself=needless export_dynamic=yes fi prev= continue ;; *) if test dlfiles = "$prev"; then func_append dlfiles " $arg" else func_append dlprefiles " $arg" fi prev= continue ;; esac ;; expsyms) export_symbols=$arg test -f "$arg" \ || func_fatal_error "symbol file '$arg' does not exist" prev= continue ;; expsyms_regex) export_symbols_regex=$arg prev= continue ;; framework) case $host in *-*-darwin*) case "$deplibs " in *" $qarg.ltframework "*) ;; *) func_append deplibs " $qarg.ltframework" # this is fixed later ;; esac ;; esac prev= continue ;; inst_prefix) inst_prefix_dir=$arg prev= continue ;; mllvm) # Clang does not use LLVM to link, so we can simply discard any # '-mllvm $arg' options when doing the link step. prev= continue ;; objectlist) if test -f "$arg"; then save_arg=$arg moreargs= for fil in `cat "$save_arg"` do # func_append moreargs " $fil" arg=$fil # A libtool-controlled object. # Check to see that this really is a libtool object. if func_lalib_unsafe_p "$arg"; then pic_object= non_pic_object= # Read the .lo file func_source "$arg" if test -z "$pic_object" || test -z "$non_pic_object" || test none = "$pic_object" && test none = "$non_pic_object"; then func_fatal_error "cannot find name of object for '$arg'" fi # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result if test none != "$pic_object"; then # Prepend the subdirectory the object is found in. pic_object=$xdir$pic_object if test dlfiles = "$prev"; then if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then func_append dlfiles " $pic_object" prev= continue else # If libtool objects are unsupported, then we need to preload. prev=dlprefiles fi fi # CHECK ME: I think I busted this. -Ossama if test dlprefiles = "$prev"; then # Preload the old-style object. func_append dlprefiles " $pic_object" prev= fi # A PIC object. func_append libobjs " $pic_object" arg=$pic_object fi # Non-PIC object. if test none != "$non_pic_object"; then # Prepend the subdirectory the object is found in. non_pic_object=$xdir$non_pic_object # A standard non-PIC object func_append non_pic_objects " $non_pic_object" if test -z "$pic_object" || test none = "$pic_object"; then arg=$non_pic_object fi else # If the PIC object exists, use it instead. # $xdir was prepended to $pic_object above. non_pic_object=$pic_object func_append non_pic_objects " $non_pic_object" fi else # Only an error if not doing a dry-run. if $opt_dry_run; then # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result func_lo2o "$arg" pic_object=$xdir$objdir/$func_lo2o_result non_pic_object=$xdir$func_lo2o_result func_append libobjs " $pic_object" func_append non_pic_objects " $non_pic_object" else func_fatal_error "'$arg' is not a valid libtool object" fi fi done else func_fatal_error "link input file '$arg' does not exist" fi arg=$save_arg prev= continue ;; os2dllname) os2dllname=$arg prev= continue ;; precious_regex) precious_files_regex=$arg prev= continue ;; release) release=-$arg prev= continue ;; rpath | xrpath) # We need an absolute path. case $arg in [\\/]* | [A-Za-z]:[\\/]*) ;; *) func_fatal_error "only absolute run-paths are allowed" ;; esac if test rpath = "$prev"; then case "$rpath " in *" $arg "*) ;; *) func_append rpath " $arg" ;; esac else case "$xrpath " in *" $arg "*) ;; *) func_append xrpath " $arg" ;; esac fi prev= continue ;; shrext) shrext_cmds=$arg prev= continue ;; weak) func_append weak_libs " $arg" prev= continue ;; xassembler) func_append compiler_flags " -Xassembler $qarg" prev= func_append compile_command " -Xassembler $qarg" func_append finalize_command " -Xassembler $qarg" continue ;; xcclinker) func_append linker_flags " $qarg" func_append compiler_flags " $qarg" prev= func_append compile_command " $qarg" func_append finalize_command " $qarg" continue ;; xcompiler) func_append compiler_flags " $qarg" prev= func_append compile_command " $qarg" func_append finalize_command " $qarg" continue ;; xlinker) func_append linker_flags " $qarg" func_append compiler_flags " $wl$qarg" prev= func_append compile_command " $wl$qarg" func_append finalize_command " $wl$qarg" continue ;; *) eval "$prev=\"\$arg\"" prev= continue ;; esac fi # test -n "$prev" prevarg=$arg case $arg in -all-static) if test -n "$link_static_flag"; then # See comment for -static flag below, for more details. func_append compile_command " $link_static_flag" func_append finalize_command " $link_static_flag" fi continue ;; -allow-undefined) # FIXME: remove this flag sometime in the future. func_fatal_error "'-allow-undefined' must not be used because it is the default" ;; -avoid-version) avoid_version=yes continue ;; -bindir) prev=bindir continue ;; -dlopen) prev=dlfiles continue ;; -dlpreopen) prev=dlprefiles continue ;; -export-dynamic) export_dynamic=yes continue ;; -export-symbols | -export-symbols-regex) if test -n "$export_symbols" || test -n "$export_symbols_regex"; then func_fatal_error "more than one -exported-symbols argument is not allowed" fi if test X-export-symbols = "X$arg"; then prev=expsyms else prev=expsyms_regex fi continue ;; -framework) prev=framework continue ;; -inst-prefix-dir) prev=inst_prefix continue ;; # The native IRIX linker understands -LANG:*, -LIST:* and -LNO:* # so, if we see these flags be careful not to treat them like -L -L[A-Z][A-Z]*:*) case $with_gcc/$host in no/*-*-irix* | /*-*-irix*) func_append compile_command " $arg" func_append finalize_command " $arg" ;; esac continue ;; -L*) func_stripname "-L" '' "$arg" if test -z "$func_stripname_result"; then if test "$#" -gt 0; then func_fatal_error "require no space between '-L' and '$1'" else func_fatal_error "need path for '-L' option" fi fi func_resolve_sysroot "$func_stripname_result" dir=$func_resolve_sysroot_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) ;; *) absdir=`cd "$dir" && pwd` test -z "$absdir" && \ func_fatal_error "cannot determine absolute directory name of '$dir'" dir=$absdir ;; esac case "$deplibs " in *" -L$dir "* | *" $arg "*) # Will only happen for absolute or sysroot arguments ;; *) # Preserve sysroot, but never include relative directories case $dir in [\\/]* | [A-Za-z]:[\\/]* | =*) func_append deplibs " $arg" ;; *) func_append deplibs " -L$dir" ;; esac func_append lib_search_path " $dir" ;; esac case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) testbindir=`$ECHO "$dir" | $SED 's*/lib$*/bin*'` case :$dllsearchpath: in *":$dir:"*) ;; ::) dllsearchpath=$dir;; *) func_append dllsearchpath ":$dir";; esac case :$dllsearchpath: in *":$testbindir:"*) ;; ::) dllsearchpath=$testbindir;; *) func_append dllsearchpath ":$testbindir";; esac ;; esac continue ;; -l*) if test X-lc = "X$arg" || test X-lm = "X$arg"; then case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-beos* | *-cegcc* | *-*-haiku*) # These systems don't actually have a C or math library (as such) continue ;; *-*-os2*) # These systems don't actually have a C library (as such) test X-lc = "X$arg" && continue ;; *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig* | *-*-midnightbsd*) # Do not include libc due to us having libc/libc_r. test X-lc = "X$arg" && continue ;; *-*-rhapsody* | *-*-darwin1.[012]) # Rhapsody C and math libraries are in the System framework func_append deplibs " System.ltframework" continue ;; *-*-sco3.2v5* | *-*-sco5v6*) # Causes problems with __ctype test X-lc = "X$arg" && continue ;; *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) # Compiler inserts libc in the correct place for threads to work test X-lc = "X$arg" && continue ;; esac elif test X-lc_r = "X$arg"; then case $host in *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-bitrig* | *-*-midnightbsd*) # Do not include libc_r directly, use -pthread flag. continue ;; esac fi func_append deplibs " $arg" continue ;; -mllvm) prev=mllvm continue ;; -module) module=yes continue ;; # Tru64 UNIX uses -model [arg] to determine the layout of C++ # classes, name mangling, and exception handling. # Darwin uses the -arch flag to determine output architecture. -model|-arch|-isysroot|--sysroot) func_append compiler_flags " $arg" func_append compile_command " $arg" func_append finalize_command " $arg" prev=xcompiler continue ;; # Solaris ld rejects as of 11.4. Refer to Oracle bug 22985199. -pthread) case $host in *solaris2*) ;; *) case "$new_inherited_linker_flags " in *" $arg "*) ;; * ) func_append new_inherited_linker_flags " $arg" ;; esac ;; esac continue ;; -mt|-mthreads|-kthread|-Kthread|-pthreads|--thread-safe \ |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*) func_append compiler_flags " $arg" func_append compile_command " $arg" func_append finalize_command " $arg" case "$new_inherited_linker_flags " in *" $arg "*) ;; * ) func_append new_inherited_linker_flags " $arg" ;; esac continue ;; -multi_module) single_module=$wl-multi_module continue ;; -no-fast-install) fast_install=no continue ;; -no-install) case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-darwin* | *-cegcc*) # The PATH hackery in wrapper scripts is required on Windows # and Darwin in order for the loader to find any dlls it needs. func_warning "'-no-install' is ignored for $host" func_warning "assuming '-no-fast-install' instead" fast_install=no ;; *) no_install=yes ;; esac continue ;; -no-undefined) allow_undefined=no continue ;; -objectlist) prev=objectlist continue ;; -os2dllname) prev=os2dllname continue ;; -o) prev=output ;; -precious-files-regex) prev=precious_regex continue ;; -release) prev=release continue ;; -rpath) prev=rpath continue ;; -R) prev=xrpath continue ;; -R*) func_stripname '-R' '' "$arg" dir=$func_stripname_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) ;; =*) func_stripname '=' '' "$dir" dir=$lt_sysroot$func_stripname_result ;; *) func_fatal_error "only absolute run-paths are allowed" ;; esac case "$xrpath " in *" $dir "*) ;; *) func_append xrpath " $dir" ;; esac continue ;; -shared) # The effects of -shared are defined in a previous loop. continue ;; -shrext) prev=shrext continue ;; -static | -static-libtool-libs) # The effects of -static are defined in a previous loop. # We used to do the same as -all-static on platforms that # didn't have a PIC flag, but the assumption that the effects # would be equivalent was wrong. It would break on at least # Digital Unix and AIX. continue ;; -thread-safe) thread_safe=yes continue ;; -version-info) prev=vinfo continue ;; -version-number) prev=vinfo vinfo_number=yes continue ;; -weak) prev=weak continue ;; -Wc,*) func_stripname '-Wc,' '' "$arg" args=$func_stripname_result arg= save_ifs=$IFS; IFS=, for flag in $args; do IFS=$save_ifs func_quote_arg pretty "$flag" func_append arg " $func_quote_arg_result" func_append compiler_flags " $func_quote_arg_result" done IFS=$save_ifs func_stripname ' ' '' "$arg" arg=$func_stripname_result ;; -Wl,*) func_stripname '-Wl,' '' "$arg" args=$func_stripname_result arg= save_ifs=$IFS; IFS=, for flag in $args; do IFS=$save_ifs func_quote_arg pretty "$flag" func_append arg " $wl$func_quote_arg_result" func_append compiler_flags " $wl$func_quote_arg_result" func_append linker_flags " $func_quote_arg_result" done IFS=$save_ifs func_stripname ' ' '' "$arg" arg=$func_stripname_result ;; -Xassembler) prev=xassembler continue ;; -Xcompiler) prev=xcompiler continue ;; -Xlinker) prev=xlinker continue ;; -XCClinker) prev=xcclinker continue ;; # -msg_* for osf cc -msg_*) func_quote_arg pretty "$arg" arg=$func_quote_arg_result ;; # Flags to be passed through unchanged, with rationale: # -64, -mips[0-9] enable 64-bit mode for the SGI compiler # -r[0-9][0-9]* specify processor for the SGI compiler # -xarch=*, -xtarget=* enable 64-bit mode for the Sun compiler # +DA*, +DD* enable 64-bit mode for the HP compiler # -q* compiler args for the IBM compiler # -m*, -t[45]*, -txscale* architecture-specific flags for GCC # -F/path path to uninstalled frameworks, gcc on darwin # -p, -pg, --coverage, -fprofile-* profiling flags for GCC # -fstack-protector* stack protector flags for GCC # @file GCC response files # -tp=* Portland pgcc target processor selection # --sysroot=* for sysroot support # -O*, -g*, -flto*, -fwhopr*, -fuse-linker-plugin GCC link-time optimization # -specs=* GCC specs files # -stdlib=* select c++ std lib with clang # -fsanitize=* Clang/GCC memory and address sanitizer # -fuse-ld=* Linker select flags for GCC # -Wa,* Pass flags directly to the assembler -64|-mips[0-9]|-r[0-9][0-9]*|-xarch=*|-xtarget=*|+DA*|+DD*|-q*|-m*| \ -t[45]*|-txscale*|-p|-pg|--coverage|-fprofile-*|-F*|@*|-tp=*|--sysroot=*| \ -O*|-g*|-flto*|-fwhopr*|-fuse-linker-plugin|-fstack-protector*|-stdlib=*| \ -specs=*|-fsanitize=*|-fuse-ld=*|-Wa,*) func_quote_arg pretty "$arg" arg=$func_quote_arg_result func_append compile_command " $arg" func_append finalize_command " $arg" func_append compiler_flags " $arg" continue ;; -Z*) if test os2 = "`expr $host : '.*\(os2\)'`"; then # OS/2 uses -Zxxx to specify OS/2-specific options compiler_flags="$compiler_flags $arg" func_append compile_command " $arg" func_append finalize_command " $arg" case $arg in -Zlinker | -Zstack) prev=xcompiler ;; esac continue else # Otherwise treat like 'Some other compiler flag' below func_quote_arg pretty "$arg" arg=$func_quote_arg_result fi ;; # Some other compiler flag. -* | +*) func_quote_arg pretty "$arg" arg=$func_quote_arg_result ;; *.$objext) # A standard object. func_append objs " $arg" ;; *.lo) # A libtool-controlled object. # Check to see that this really is a libtool object. if func_lalib_unsafe_p "$arg"; then pic_object= non_pic_object= # Read the .lo file func_source "$arg" if test -z "$pic_object" || test -z "$non_pic_object" || test none = "$pic_object" && test none = "$non_pic_object"; then func_fatal_error "cannot find name of object for '$arg'" fi # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result test none = "$pic_object" || { # Prepend the subdirectory the object is found in. pic_object=$xdir$pic_object if test dlfiles = "$prev"; then if test yes = "$build_libtool_libs" && test yes = "$dlopen_support"; then func_append dlfiles " $pic_object" prev= continue else # If libtool objects are unsupported, then we need to preload. prev=dlprefiles fi fi # CHECK ME: I think I busted this. -Ossama if test dlprefiles = "$prev"; then # Preload the old-style object. func_append dlprefiles " $pic_object" prev= fi # A PIC object. func_append libobjs " $pic_object" arg=$pic_object } # Non-PIC object. if test none != "$non_pic_object"; then # Prepend the subdirectory the object is found in. non_pic_object=$xdir$non_pic_object # A standard non-PIC object func_append non_pic_objects " $non_pic_object" if test -z "$pic_object" || test none = "$pic_object"; then arg=$non_pic_object fi else # If the PIC object exists, use it instead. # $xdir was prepended to $pic_object above. non_pic_object=$pic_object func_append non_pic_objects " $non_pic_object" fi else # Only an error if not doing a dry-run. if $opt_dry_run; then # Extract subdirectory from the argument. func_dirname "$arg" "/" "" xdir=$func_dirname_result func_lo2o "$arg" pic_object=$xdir$objdir/$func_lo2o_result non_pic_object=$xdir$func_lo2o_result func_append libobjs " $pic_object" func_append non_pic_objects " $non_pic_object" else func_fatal_error "'$arg' is not a valid libtool object" fi fi ;; *.$libext) # An archive. func_append deplibs " $arg" func_append old_deplibs " $arg" continue ;; *.la) # A libtool-controlled library. func_resolve_sysroot "$arg" if test dlfiles = "$prev"; then # This library was specified with -dlopen. func_append dlfiles " $func_resolve_sysroot_result" prev= elif test dlprefiles = "$prev"; then # The library was specified with -dlpreopen. func_append dlprefiles " $func_resolve_sysroot_result" prev= else func_append deplibs " $func_resolve_sysroot_result" fi continue ;; # Some other compiler argument. *) # Unknown arguments in both finalize_command and compile_command need # to be aesthetically quoted because they are evaled later. func_quote_arg pretty "$arg" arg=$func_quote_arg_result ;; esac # arg # Now actually substitute the argument into the commands. if test -n "$arg"; then func_append compile_command " $arg" func_append finalize_command " $arg" fi done # argument parsing loop test -n "$prev" && \ func_fatal_help "the '$prevarg' option requires an argument" if test yes = "$export_dynamic" && test -n "$export_dynamic_flag_spec"; then eval arg=\"$export_dynamic_flag_spec\" func_append compile_command " $arg" func_append finalize_command " $arg" fi oldlibs= # calculate the name of the file, without its directory func_basename "$output" outputname=$func_basename_result libobjs_save=$libobjs if test -n "$shlibpath_var"; then # get the directories listed in $shlibpath_var eval shlib_search_path=\`\$ECHO \"\$$shlibpath_var\" \| \$SED \'s/:/ /g\'\` else shlib_search_path= fi eval sys_lib_search_path=\"$sys_lib_search_path_spec\" eval sys_lib_dlsearch_path=\"$sys_lib_dlsearch_path_spec\" # Definition is injected by LT_CONFIG during libtool generation. func_munge_path_list sys_lib_dlsearch_path "$LT_SYS_LIBRARY_PATH" func_dirname "$output" "/" "" output_objdir=$func_dirname_result$objdir func_to_tool_file "$output_objdir/" tool_output_objdir=$func_to_tool_file_result # Create the object directory. func_mkdir_p "$output_objdir" # Determine the type of output case $output in "") func_fatal_help "you must specify an output file" ;; *.$libext) linkmode=oldlib ;; *.lo | *.$objext) linkmode=obj ;; *.la) linkmode=lib ;; *) linkmode=prog ;; # Anything else should be a program. esac specialdeplibs= libs= # Find all interdependent deplibs by searching for libraries # that are linked more than once (e.g. -la -lb -la) for deplib in $deplibs; do if $opt_preserve_dup_deps; then case "$libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append libs " $deplib" done if test lib = "$linkmode"; then libs="$predeps $libs $compiler_lib_search_path $postdeps" # Compute libraries that are listed more than once in $predeps # $postdeps and mark them as special (i.e., whose duplicates are # not to be eliminated). pre_post_deps= if $opt_duplicate_compiler_generated_deps; then for pre_post_dep in $predeps $postdeps; do case "$pre_post_deps " in *" $pre_post_dep "*) func_append specialdeplibs " $pre_post_deps" ;; esac func_append pre_post_deps " $pre_post_dep" done fi pre_post_deps= fi deplibs= newdependency_libs= newlib_search_path= need_relink=no # whether we're linking any uninstalled libtool libraries notinst_deplibs= # not-installed libtool libraries notinst_path= # paths that contain not-installed libtool libraries case $linkmode in lib) passes="conv dlpreopen link" for file in $dlfiles $dlprefiles; do case $file in *.la) ;; *) func_fatal_help "libraries can '-dlopen' only libtool libraries: $file" ;; esac done ;; prog) compile_deplibs= finalize_deplibs= alldeplibs=false newdlfiles= newdlprefiles= passes="conv scan dlopen dlpreopen link" ;; *) passes="conv" ;; esac for pass in $passes; do # The preopen pass in lib mode reverses $deplibs; put it back here # so that -L comes before libs that need it for instance... if test lib,link = "$linkmode,$pass"; then ## FIXME: Find the place where the list is rebuilt in the wrong ## order, and fix it there properly tmp_deplibs= for deplib in $deplibs; do tmp_deplibs="$deplib $tmp_deplibs" done deplibs=$tmp_deplibs fi if test lib,link = "$linkmode,$pass" || test prog,scan = "$linkmode,$pass"; then libs=$deplibs deplibs= fi if test prog = "$linkmode"; then case $pass in dlopen) libs=$dlfiles ;; dlpreopen) libs=$dlprefiles ;; link) libs="$deplibs %DEPLIBS% $dependency_libs" ;; esac fi if test lib,dlpreopen = "$linkmode,$pass"; then # Collect and forward deplibs of preopened libtool libs for lib in $dlprefiles; do # Ignore non-libtool-libs dependency_libs= func_resolve_sysroot "$lib" case $lib in *.la) func_source "$func_resolve_sysroot_result" ;; esac # Collect preopened libtool deplibs, except any this library # has declared as weak libs for deplib in $dependency_libs; do func_basename "$deplib" deplib_base=$func_basename_result case " $weak_libs " in *" $deplib_base "*) ;; *) func_append deplibs " $deplib" ;; esac done done libs=$dlprefiles fi if test dlopen = "$pass"; then # Collect dlpreopened libraries save_deplibs=$deplibs deplibs= fi for deplib in $libs; do lib= found=false case $deplib in -mt|-mthreads|-kthread|-Kthread|-pthread|-pthreads|--thread-safe \ |-threads|-fopenmp|-openmp|-mp|-xopenmp|-omp|-qsmp=*) if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else func_append compiler_flags " $deplib" if test lib = "$linkmode"; then case "$new_inherited_linker_flags " in *" $deplib "*) ;; * ) func_append new_inherited_linker_flags " $deplib" ;; esac fi fi continue ;; -l*) if test lib != "$linkmode" && test prog != "$linkmode"; then func_warning "'-l' is ignored for archives/objects" continue fi func_stripname '-l' '' "$deplib" name=$func_stripname_result if test lib = "$linkmode"; then searchdirs="$newlib_search_path $lib_search_path $compiler_lib_search_dirs $sys_lib_search_path $shlib_search_path" else searchdirs="$newlib_search_path $lib_search_path $sys_lib_search_path $shlib_search_path" fi for searchdir in $searchdirs; do for search_ext in .la $std_shrext .so .a; do # Search the libtool library lib=$searchdir/lib$name$search_ext if test -f "$lib"; then if test .la = "$search_ext"; then found=: else found=false fi break 2 fi done done if $found; then # deplib is a libtool library # If $allow_libtool_libs_with_static_runtimes && $deplib is a stdlib, # We need to do some special things here, and not later. if test yes = "$allow_libtool_libs_with_static_runtimes"; then case " $predeps $postdeps " in *" $deplib "*) if func_lalib_p "$lib"; then library_names= old_library= func_source "$lib" for l in $old_library $library_names; do ll=$l done if test "X$ll" = "X$old_library"; then # only static version available found=false func_dirname "$lib" "" "." ladir=$func_dirname_result lib=$ladir/$old_library if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs" fi continue fi fi ;; *) ;; esac fi else # deplib doesn't seem to be a libtool library if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" test lib = "$linkmode" && newdependency_libs="$deplib $newdependency_libs" fi continue fi ;; # -l *.ltframework) if test prog,link = "$linkmode,$pass"; then compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else deplibs="$deplib $deplibs" if test lib = "$linkmode"; then case "$new_inherited_linker_flags " in *" $deplib "*) ;; * ) func_append new_inherited_linker_flags " $deplib" ;; esac fi fi continue ;; -L*) case $linkmode in lib) deplibs="$deplib $deplibs" test conv = "$pass" && continue newdependency_libs="$deplib $newdependency_libs" func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; prog) if test conv = "$pass"; then deplibs="$deplib $deplibs" continue fi if test scan = "$pass"; then deplibs="$deplib $deplibs" else compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" fi func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; *) func_warning "'-L' is ignored for archives/objects" ;; esac # linkmode continue ;; # -L -R*) if test link = "$pass"; then func_stripname '-R' '' "$deplib" func_resolve_sysroot "$func_stripname_result" dir=$func_resolve_sysroot_result # Make sure the xrpath contains only unique directories. case "$xrpath " in *" $dir "*) ;; *) func_append xrpath " $dir" ;; esac fi deplibs="$deplib $deplibs" continue ;; *.la) func_resolve_sysroot "$deplib" lib=$func_resolve_sysroot_result ;; *.$libext) if test conv = "$pass"; then deplibs="$deplib $deplibs" continue fi case $linkmode in lib) # Linking convenience modules into shared libraries is allowed, # but linking other static libraries is non-portable. case " $dlpreconveniencelibs " in *" $deplib "*) ;; *) valid_a_lib=false case $deplibs_check_method in match_pattern*) set dummy $deplibs_check_method; shift match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` if eval "\$ECHO \"$deplib\"" 2>/dev/null | $SED 10q \ | $EGREP "$match_pattern_regex" > /dev/null; then valid_a_lib=: fi ;; pass_all) valid_a_lib=: ;; esac if $valid_a_lib; then echo $ECHO "*** Warning: Linking the shared library $output against the" $ECHO "*** static library $deplib is not portable!" deplibs="$deplib $deplibs" else echo $ECHO "*** Warning: Trying to link with static lib archive $deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because the file extensions .$libext of this argument makes me believe" echo "*** that it is just a static archive that I should not use here." fi ;; esac continue ;; prog) if test link != "$pass"; then deplibs="$deplib $deplibs" else compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" fi continue ;; esac # linkmode ;; # *.$libext *.lo | *.$objext) if test conv = "$pass"; then deplibs="$deplib $deplibs" elif test prog = "$linkmode"; then if test dlpreopen = "$pass" || test yes != "$dlopen_support" || test no = "$build_libtool_libs"; then # If there is no dlopen support or we're linking statically, # we need to preload. func_append newdlprefiles " $deplib" compile_deplibs="$deplib $compile_deplibs" finalize_deplibs="$deplib $finalize_deplibs" else func_append newdlfiles " $deplib" fi fi continue ;; %DEPLIBS%) alldeplibs=: continue ;; esac # case $deplib $found || test -f "$lib" \ || func_fatal_error "cannot find the library '$lib' or unhandled argument '$deplib'" # Check to see that this really is a libtool archive. func_lalib_unsafe_p "$lib" \ || func_fatal_error "'$lib' is not a valid libtool archive" func_dirname "$lib" "" "." ladir=$func_dirname_result dlname= dlopen= dlpreopen= libdir= library_names= old_library= inherited_linker_flags= # If the library was installed with an old release of libtool, # it will not redefine variables installed, or shouldnotlink installed=yes shouldnotlink=no avoidtemprpath= # Read the .la file func_source "$lib" # Convert "-framework foo" to "foo.ltframework" if test -n "$inherited_linker_flags"; then tmp_inherited_linker_flags=`$ECHO "$inherited_linker_flags" | $SED 's/-framework \([^ $]*\)/\1.ltframework/g'` for tmp_inherited_linker_flag in $tmp_inherited_linker_flags; do case " $new_inherited_linker_flags " in *" $tmp_inherited_linker_flag "*) ;; *) func_append new_inherited_linker_flags " $tmp_inherited_linker_flag";; esac done fi dependency_libs=`$ECHO " $dependency_libs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` if test lib,link = "$linkmode,$pass" || test prog,scan = "$linkmode,$pass" || { test prog != "$linkmode" && test lib != "$linkmode"; }; then test -n "$dlopen" && func_append dlfiles " $dlopen" test -n "$dlpreopen" && func_append dlprefiles " $dlpreopen" fi if test conv = "$pass"; then # Only check for convenience libraries deplibs="$lib $deplibs" if test -z "$libdir"; then if test -z "$old_library"; then func_fatal_error "cannot find name of link library for '$lib'" fi # It is a libtool convenience library, so add in its objects. func_append convenience " $ladir/$objdir/$old_library" func_append old_convenience " $ladir/$objdir/$old_library" elif test prog != "$linkmode" && test lib != "$linkmode"; then func_fatal_error "'$lib' is not a convenience library" fi tmp_libs= for deplib in $dependency_libs; do deplibs="$deplib $deplibs" if $opt_preserve_dup_deps; then case "$tmp_libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append tmp_libs " $deplib" done continue fi # $pass = conv # Get the name of the library we link against. linklib= if test -n "$old_library" && { test yes = "$prefer_static_libs" || test built,no = "$prefer_static_libs,$installed"; }; then linklib=$old_library else for l in $old_library $library_names; do linklib=$l done fi if test -z "$linklib"; then func_fatal_error "cannot find name of link library for '$lib'" fi # This library was specified with -dlopen. if test dlopen = "$pass"; then test -z "$libdir" \ && func_fatal_error "cannot -dlopen a convenience library: '$lib'" if test -z "$dlname" || test yes != "$dlopen_support" || test no = "$build_libtool_libs" then # If there is no dlname, no dlopen support or we're linking # statically, we need to preload. We also need to preload any # dependent libraries so libltdl's deplib preloader doesn't # bomb out in the load deplibs phase. func_append dlprefiles " $lib $dependency_libs" else func_append newdlfiles " $lib" fi continue fi # $pass = dlopen # We need an absolute path. case $ladir in [\\/]* | [A-Za-z]:[\\/]*) abs_ladir=$ladir ;; *) abs_ladir=`cd "$ladir" && pwd` if test -z "$abs_ladir"; then func_warning "cannot determine absolute directory name of '$ladir'" func_warning "passing it literally to the linker, although it might fail" abs_ladir=$ladir fi ;; esac func_basename "$lib" laname=$func_basename_result # Find the relevant object directory and library name. if test yes = "$installed"; then if test ! -f "$lt_sysroot$libdir/$linklib" && test -f "$abs_ladir/$linklib"; then func_warning "library '$lib' was moved." dir=$ladir absdir=$abs_ladir libdir=$abs_ladir else dir=$lt_sysroot$libdir absdir=$lt_sysroot$libdir fi test yes = "$hardcode_automatic" && avoidtemprpath=yes else if test ! -f "$ladir/$objdir/$linklib" && test -f "$abs_ladir/$linklib"; then dir=$ladir absdir=$abs_ladir # Remove this search path later func_append notinst_path " $abs_ladir" else dir=$ladir/$objdir absdir=$abs_ladir/$objdir # Remove this search path later func_append notinst_path " $abs_ladir" fi fi # $installed = yes func_stripname 'lib' '.la' "$laname" name=$func_stripname_result # This library was specified with -dlpreopen. if test dlpreopen = "$pass"; then if test -z "$libdir" && test prog = "$linkmode"; then func_fatal_error "only libraries may -dlpreopen a convenience library: '$lib'" fi case $host in # special handling for platforms with PE-DLLs. *cygwin* | *mingw* | *cegcc* ) # Linker will automatically link against shared library if both # static and shared are present. Therefore, ensure we extract # symbols from the import library if a shared library is present # (otherwise, the dlopen module name will be incorrect). We do # this by putting the import library name into $newdlprefiles. # We recover the dlopen module name by 'saving' the la file # name in a special purpose variable, and (later) extracting the # dlname from the la file. if test -n "$dlname"; then func_tr_sh "$dir/$linklib" eval "libfile_$func_tr_sh_result=\$abs_ladir/\$laname" func_append newdlprefiles " $dir/$linklib" else func_append newdlprefiles " $dir/$old_library" # Keep a list of preopened convenience libraries to check # that they are being used correctly in the link pass. test -z "$libdir" && \ func_append dlpreconveniencelibs " $dir/$old_library" fi ;; * ) # Prefer using a static library (so that no silly _DYNAMIC symbols # are required to link). if test -n "$old_library"; then func_append newdlprefiles " $dir/$old_library" # Keep a list of preopened convenience libraries to check # that they are being used correctly in the link pass. test -z "$libdir" && \ func_append dlpreconveniencelibs " $dir/$old_library" # Otherwise, use the dlname, so that lt_dlopen finds it. elif test -n "$dlname"; then func_append newdlprefiles " $dir/$dlname" else func_append newdlprefiles " $dir/$linklib" fi ;; esac fi # $pass = dlpreopen if test -z "$libdir"; then # Link the convenience library if test lib = "$linkmode"; then deplibs="$dir/$old_library $deplibs" elif test prog,link = "$linkmode,$pass"; then compile_deplibs="$dir/$old_library $compile_deplibs" finalize_deplibs="$dir/$old_library $finalize_deplibs" else deplibs="$lib $deplibs" # used for prog,scan pass fi continue fi if test prog = "$linkmode" && test link != "$pass"; then func_append newlib_search_path " $ladir" deplibs="$lib $deplibs" linkalldeplibs=false if test no != "$link_all_deplibs" || test -z "$library_names" || test no = "$build_libtool_libs"; then linkalldeplibs=: fi tmp_libs= for deplib in $dependency_libs; do case $deplib in -L*) func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result" func_append newlib_search_path " $func_resolve_sysroot_result" ;; esac # Need to link against all dependency_libs? if $linkalldeplibs; then deplibs="$deplib $deplibs" else # Need to hardcode shared library paths # or/and link against static libraries newdependency_libs="$deplib $newdependency_libs" fi if $opt_preserve_dup_deps; then case "$tmp_libs " in *" $deplib "*) func_append specialdeplibs " $deplib" ;; esac fi func_append tmp_libs " $deplib" done # for deplib continue fi # $linkmode = prog... if test prog,link = "$linkmode,$pass"; then if test -n "$library_names" && { { test no = "$prefer_static_libs" || test built,yes = "$prefer_static_libs,$installed"; } || test -z "$old_library"; }; then # We need to hardcode the library path if test -n "$shlibpath_var" && test -z "$avoidtemprpath"; then # Make sure the rpath contains only unique directories. case $temp_rpath: in *"$absdir:"*) ;; *) func_append temp_rpath "$absdir:" ;; esac fi # Hardcode the library path. # Skip directories that are in the system default run-time # search path. case " $sys_lib_dlsearch_path " in *" $absdir "*) ;; *) case "$compile_rpath " in *" $absdir "*) ;; *) func_append compile_rpath " $absdir" ;; esac ;; esac case " $sys_lib_dlsearch_path " in *" $libdir "*) ;; *) case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac ;; esac fi # $linkmode,$pass = prog,link... if $alldeplibs && { test pass_all = "$deplibs_check_method" || { test yes = "$build_libtool_libs" && test -n "$library_names"; }; }; then # We only need to search for static libraries continue fi fi link_static=no # Whether the deplib will be linked statically use_static_libs=$prefer_static_libs if test built = "$use_static_libs" && test yes = "$installed"; then use_static_libs=no fi if test -n "$library_names" && { test no = "$use_static_libs" || test -z "$old_library"; }; then case $host in *cygwin* | *mingw* | *cegcc* | *os2*) # No point in relinking DLLs because paths are not encoded func_append notinst_deplibs " $lib" need_relink=no ;; *) if test no = "$installed"; then func_append notinst_deplibs " $lib" need_relink=yes fi ;; esac # This is a shared library # Warn about portability, can't link against -module's on some # systems (darwin). Don't bleat about dlopened modules though! dlopenmodule= for dlpremoduletest in $dlprefiles; do if test "X$dlpremoduletest" = "X$lib"; then dlopenmodule=$dlpremoduletest break fi done if test -z "$dlopenmodule" && test yes = "$shouldnotlink" && test link = "$pass"; then echo if test prog = "$linkmode"; then $ECHO "*** Warning: Linking the executable $output against the loadable module" else $ECHO "*** Warning: Linking the shared library $output against the loadable module" fi $ECHO "*** $linklib is not portable!" fi if test lib = "$linkmode" && test yes = "$hardcode_into_libs"; then # Hardcode the library path. # Skip directories that are in the system default run-time # search path. case " $sys_lib_dlsearch_path " in *" $absdir "*) ;; *) case "$compile_rpath " in *" $absdir "*) ;; *) func_append compile_rpath " $absdir" ;; esac ;; esac case " $sys_lib_dlsearch_path " in *" $libdir "*) ;; *) case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac ;; esac fi if test -n "$old_archive_from_expsyms_cmds"; then # figure out the soname set dummy $library_names shift realname=$1 shift libname=`eval "\\$ECHO \"$libname_spec\""` # use dlname if we got it. it's perfectly good, no? if test -n "$dlname"; then soname=$dlname elif test -n "$soname_spec"; then # bleh windows case $host in *cygwin* | mingw* | *cegcc* | *os2*) func_arith $current - $age major=$func_arith_result versuffix=-$major ;; esac eval soname=\"$soname_spec\" else soname=$realname fi # Make a new name for the extract_expsyms_cmds to use soroot=$soname func_basename "$soroot" soname=$func_basename_result func_stripname 'lib' '.dll' "$soname" newlib=libimp-$func_stripname_result.a # If the library has no export list, then create one now if test -f "$output_objdir/$soname-def"; then : else func_verbose "extracting exported symbol list from '$soname'" func_execute_cmds "$extract_expsyms_cmds" 'exit $?' fi # Create $newlib if test -f "$output_objdir/$newlib"; then :; else func_verbose "generating import library for '$soname'" func_execute_cmds "$old_archive_from_expsyms_cmds" 'exit $?' fi # make sure the library variables are pointing to the new library dir=$output_objdir linklib=$newlib fi # test -n "$old_archive_from_expsyms_cmds" if test prog = "$linkmode" || test relink != "$opt_mode"; then add_shlibpath= add_dir= add= lib_linked=yes case $hardcode_action in immediate | unsupported) if test no = "$hardcode_direct"; then add=$dir/$linklib case $host in *-*-sco3.2v5.0.[024]*) add_dir=-L$dir ;; *-*-sysv4*uw2*) add_dir=-L$dir ;; *-*-sysv5OpenUNIX* | *-*-sysv5UnixWare7.[01].[10]* | \ *-*-unixware7*) add_dir=-L$dir ;; *-*-darwin* ) # if the lib is a (non-dlopened) module then we cannot # link against it, someone is ignoring the earlier warnings if /usr/bin/file -L $add 2> /dev/null | $GREP ": [^:]* bundle" >/dev/null; then if test "X$dlopenmodule" != "X$lib"; then $ECHO "*** Warning: lib $linklib is a module, not a shared library" if test -z "$old_library"; then echo echo "*** And there doesn't seem to be a static archive available" echo "*** The link will probably fail, sorry" else add=$dir/$old_library fi elif test -n "$old_library"; then add=$dir/$old_library fi fi esac elif test no = "$hardcode_minus_L"; then case $host in *-*-sunos*) add_shlibpath=$dir ;; esac add_dir=-L$dir add=-l$name elif test no = "$hardcode_shlibpath_var"; then add_shlibpath=$dir add=-l$name else lib_linked=no fi ;; relink) if test yes = "$hardcode_direct" && test no = "$hardcode_direct_absolute"; then add=$dir/$linklib elif test yes = "$hardcode_minus_L"; then add_dir=-L$absdir # Try looking first in the location we're being installed to. if test -n "$inst_prefix_dir"; then case $libdir in [\\/]*) func_append add_dir " -L$inst_prefix_dir$libdir" ;; esac fi add=-l$name elif test yes = "$hardcode_shlibpath_var"; then add_shlibpath=$dir add=-l$name else lib_linked=no fi ;; *) lib_linked=no ;; esac if test yes != "$lib_linked"; then func_fatal_configuration "unsupported hardcode properties" fi if test -n "$add_shlibpath"; then case :$compile_shlibpath: in *":$add_shlibpath:"*) ;; *) func_append compile_shlibpath "$add_shlibpath:" ;; esac fi if test prog = "$linkmode"; then test -n "$add_dir" && compile_deplibs="$add_dir $compile_deplibs" test -n "$add" && compile_deplibs="$add $compile_deplibs" else test -n "$add_dir" && deplibs="$add_dir $deplibs" test -n "$add" && deplibs="$add $deplibs" if test yes != "$hardcode_direct" && test yes != "$hardcode_minus_L" && test yes = "$hardcode_shlibpath_var"; then case :$finalize_shlibpath: in *":$libdir:"*) ;; *) func_append finalize_shlibpath "$libdir:" ;; esac fi fi fi if test prog = "$linkmode" || test relink = "$opt_mode"; then add_shlibpath= add_dir= add= # Finalize command for both is simple: just hardcode it. if test yes = "$hardcode_direct" && test no = "$hardcode_direct_absolute"; then add=$libdir/$linklib elif test yes = "$hardcode_minus_L"; then add_dir=-L$libdir add=-l$name elif test yes = "$hardcode_shlibpath_var"; then case :$finalize_shlibpath: in *":$libdir:"*) ;; *) func_append finalize_shlibpath "$libdir:" ;; esac add=-l$name elif test yes = "$hardcode_automatic"; then if test -n "$inst_prefix_dir" && test -f "$inst_prefix_dir$libdir/$linklib"; then add=$inst_prefix_dir$libdir/$linklib else add=$libdir/$linklib fi else # We cannot seem to hardcode it, guess we'll fake it. add_dir=-L$libdir # Try looking first in the location we're being installed to. if test -n "$inst_prefix_dir"; then case $libdir in [\\/]*) func_append add_dir " -L$inst_prefix_dir$libdir" ;; esac fi add=-l$name fi if test prog = "$linkmode"; then test -n "$add_dir" && finalize_deplibs="$add_dir $finalize_deplibs" test -n "$add" && finalize_deplibs="$add $finalize_deplibs" else test -n "$add_dir" && deplibs="$add_dir $deplibs" test -n "$add" && deplibs="$add $deplibs" fi fi elif test prog = "$linkmode"; then # Here we assume that one of hardcode_direct or hardcode_minus_L # is not unsupported. This is valid on all known static and # shared platforms. if test unsupported != "$hardcode_direct"; then test -n "$old_library" && linklib=$old_library compile_deplibs="$dir/$linklib $compile_deplibs" finalize_deplibs="$dir/$linklib $finalize_deplibs" else compile_deplibs="-l$name -L$dir $compile_deplibs" finalize_deplibs="-l$name -L$dir $finalize_deplibs" fi elif test yes = "$build_libtool_libs"; then # Not a shared library if test pass_all != "$deplibs_check_method"; then # We're trying link a shared library against a static one # but the system doesn't support it. # Just print a warning and add the library to dependency_libs so # that the program can be linked against the static library. echo $ECHO "*** Warning: This system cannot link to static lib archive $lib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have." if test yes = "$module"; then echo "*** But as you try to build a module library, libtool will still create " echo "*** a static module, that should work as long as the dlopening application" echo "*** is linked with the -dlopen flag to resolve symbols at runtime." if test -z "$global_symbol_pipe"; then echo echo "*** However, this would only work if libtool was able to extract symbol" echo "*** lists from a program, using 'nm' or equivalent, but libtool could" echo "*** not find such a program. So, this module is probably useless." echo "*** 'nm' from GNU binutils and a full rebuild may help." fi if test no = "$build_old_libs"; then build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi fi else deplibs="$dir/$old_library $deplibs" link_static=yes fi fi # link shared/static library? if test lib = "$linkmode"; then if test -n "$dependency_libs" && { test yes != "$hardcode_into_libs" || test yes = "$build_old_libs" || test yes = "$link_static"; }; then # Extract -R from dependency_libs temp_deplibs= for libdir in $dependency_libs; do case $libdir in -R*) func_stripname '-R' '' "$libdir" temp_xrpath=$func_stripname_result case " $xrpath " in *" $temp_xrpath "*) ;; *) func_append xrpath " $temp_xrpath";; esac;; *) func_append temp_deplibs " $libdir";; esac done dependency_libs=$temp_deplibs fi func_append newlib_search_path " $absdir" # Link against this library test no = "$link_static" && newdependency_libs="$abs_ladir/$laname $newdependency_libs" # ... and its dependency_libs tmp_libs= for deplib in $dependency_libs; do newdependency_libs="$deplib $newdependency_libs" case $deplib in -L*) func_stripname '-L' '' "$deplib" func_resolve_sysroot "$func_stripname_result";; *) func_resolve_sysroot "$deplib" ;; esac if $opt_preserve_dup_deps; then case "$tmp_libs " in *" $func_resolve_sysroot_result "*) func_append specialdeplibs " $func_resolve_sysroot_result" ;; esac fi func_append tmp_libs " $func_resolve_sysroot_result" done if test no != "$link_all_deplibs"; then # Add the search paths of all dependency libraries for deplib in $dependency_libs; do path= case $deplib in -L*) path=$deplib ;; *.la) func_resolve_sysroot "$deplib" deplib=$func_resolve_sysroot_result func_dirname "$deplib" "" "." dir=$func_dirname_result # We need an absolute path. case $dir in [\\/]* | [A-Za-z]:[\\/]*) absdir=$dir ;; *) absdir=`cd "$dir" && pwd` if test -z "$absdir"; then func_warning "cannot determine absolute directory name of '$dir'" absdir=$dir fi ;; esac if $GREP "^installed=no" $deplib > /dev/null; then case $host in *-*-darwin*) depdepl= eval deplibrary_names=`$SED -n -e 's/^library_names=\(.*\)$/\1/p' $deplib` if test -n "$deplibrary_names"; then for tmp in $deplibrary_names; do depdepl=$tmp done if test -f "$absdir/$objdir/$depdepl"; then depdepl=$absdir/$objdir/$depdepl darwin_install_name=`$OTOOL -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` if test -z "$darwin_install_name"; then darwin_install_name=`$OTOOL64 -L $depdepl | awk '{if (NR == 2) {print $1;exit}}'` fi func_append compiler_flags " $wl-dylib_file $wl$darwin_install_name:$depdepl" func_append linker_flags " -dylib_file $darwin_install_name:$depdepl" path= fi fi ;; *) path=-L$absdir/$objdir ;; esac else eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $deplib` test -z "$libdir" && \ func_fatal_error "'$deplib' is not a valid libtool archive" test "$absdir" != "$libdir" && \ func_warning "'$deplib' seems to be moved" path=-L$absdir fi ;; esac case " $deplibs " in *" $path "*) ;; *) deplibs="$path $deplibs" ;; esac done fi # link_all_deplibs != no fi # linkmode = lib done # for deplib in $libs if test link = "$pass"; then if test prog = "$linkmode"; then compile_deplibs="$new_inherited_linker_flags $compile_deplibs" finalize_deplibs="$new_inherited_linker_flags $finalize_deplibs" else compiler_flags="$compiler_flags "`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` fi fi dependency_libs=$newdependency_libs if test dlpreopen = "$pass"; then # Link the dlpreopened libraries before other libraries for deplib in $save_deplibs; do deplibs="$deplib $deplibs" done fi if test dlopen != "$pass"; then test conv = "$pass" || { # Make sure lib_search_path contains only unique directories. lib_search_path= for dir in $newlib_search_path; do case "$lib_search_path " in *" $dir "*) ;; *) func_append lib_search_path " $dir" ;; esac done newlib_search_path= } if test prog,link = "$linkmode,$pass"; then vars="compile_deplibs finalize_deplibs" else vars=deplibs fi for var in $vars dependency_libs; do # Add libraries to $var in reverse order eval tmp_libs=\"\$$var\" new_libs= for deplib in $tmp_libs; do # FIXME: Pedantically, this is the right thing to do, so # that some nasty dependency loop isn't accidentally # broken: #new_libs="$deplib $new_libs" # Pragmatically, this seems to cause very few problems in # practice: case $deplib in -L*) new_libs="$deplib $new_libs" ;; -R*) ;; *) # And here is the reason: when a library appears more # than once as an explicit dependence of a library, or # is implicitly linked in more than once by the # compiler, it is considered special, and multiple # occurrences thereof are not removed. Compare this # with having the same library being listed as a # dependency of multiple other libraries: in this case, # we know (pedantically, we assume) the library does not # need to be listed more than once, so we keep only the # last copy. This is not always right, but it is rare # enough that we require users that really mean to play # such unportable linking tricks to link the library # using -Wl,-lname, so that libtool does not consider it # for duplicate removal. case " $specialdeplibs " in *" $deplib "*) new_libs="$deplib $new_libs" ;; *) case " $new_libs " in *" $deplib "*) ;; *) new_libs="$deplib $new_libs" ;; esac ;; esac ;; esac done tmp_libs= for deplib in $new_libs; do case $deplib in -L*) case " $tmp_libs " in *" $deplib "*) ;; *) func_append tmp_libs " $deplib" ;; esac ;; *) func_append tmp_libs " $deplib" ;; esac done eval $var=\"$tmp_libs\" done # for var fi # Add Sun CC postdeps if required: test CXX = "$tagname" && { case $host_os in linux*) case `$CC -V 2>&1 | $SED 5q` in *Sun\ C*) # Sun C++ 5.9 func_suncc_cstd_abi if test no != "$suncc_use_cstd_abi"; then func_append postdeps ' -library=Cstd -library=Crun' fi ;; esac ;; solaris*) func_cc_basename "$CC" case $func_cc_basename_result in CC* | sunCC*) func_suncc_cstd_abi if test no != "$suncc_use_cstd_abi"; then func_append postdeps ' -library=Cstd -library=Crun' fi ;; esac ;; esac } # Last step: remove runtime libs from dependency_libs # (they stay in deplibs) tmp_libs= for i in $dependency_libs; do case " $predeps $postdeps $compiler_lib_search_path " in *" $i "*) i= ;; esac if test -n "$i"; then func_append tmp_libs " $i" fi done dependency_libs=$tmp_libs done # for pass if test prog = "$linkmode"; then dlfiles=$newdlfiles fi if test prog = "$linkmode" || test lib = "$linkmode"; then dlprefiles=$newdlprefiles fi case $linkmode in oldlib) if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then func_warning "'-dlopen' is ignored for archives" fi case " $deplibs" in *\ -l* | *\ -L*) func_warning "'-l' and '-L' are ignored for archives" ;; esac test -n "$rpath" && \ func_warning "'-rpath' is ignored for archives" test -n "$xrpath" && \ func_warning "'-R' is ignored for archives" test -n "$vinfo" && \ func_warning "'-version-info/-version-number' is ignored for archives" test -n "$release" && \ func_warning "'-release' is ignored for archives" test -n "$export_symbols$export_symbols_regex" && \ func_warning "'-export-symbols' is ignored for archives" # Now set the variables for building old libraries. build_libtool_libs=no oldlibs=$output func_append objs "$old_deplibs" ;; lib) # Make sure we only generate libraries of the form 'libNAME.la'. case $outputname in lib*) func_stripname 'lib' '.la' "$outputname" name=$func_stripname_result eval shared_ext=\"$shrext_cmds\" eval libname=\"$libname_spec\" ;; *) test no = "$module" \ && func_fatal_help "libtool library '$output' must begin with 'lib'" if test no != "$need_lib_prefix"; then # Add the "lib" prefix for modules if required func_stripname '' '.la' "$outputname" name=$func_stripname_result eval shared_ext=\"$shrext_cmds\" eval libname=\"$libname_spec\" else func_stripname '' '.la' "$outputname" libname=$func_stripname_result fi ;; esac if test -n "$objs"; then if test pass_all != "$deplibs_check_method"; then func_fatal_error "cannot build libtool library '$output' from non-libtool objects on this host:$objs" else echo $ECHO "*** Warning: Linking the shared library $output against the non-libtool" $ECHO "*** objects $objs is not portable!" func_append libobjs " $objs" fi fi test no = "$dlself" \ || func_warning "'-dlopen self' is ignored for libtool libraries" set dummy $rpath shift test 1 -lt "$#" \ && func_warning "ignoring multiple '-rpath's for a libtool library" install_libdir=$1 oldlibs= if test -z "$rpath"; then if test yes = "$build_libtool_libs"; then # Building a libtool convenience library. # Some compilers have problems with a '.al' extension so # convenience libraries should have the same extension an # archive normally would. oldlibs="$output_objdir/$libname.$libext $oldlibs" build_libtool_libs=convenience build_old_libs=yes fi test -n "$vinfo" && \ func_warning "'-version-info/-version-number' is ignored for convenience libraries" test -n "$release" && \ func_warning "'-release' is ignored for convenience libraries" else # Parse the version information argument. save_ifs=$IFS; IFS=: set dummy $vinfo 0 0 0 shift IFS=$save_ifs test -n "$7" && \ func_fatal_help "too many parameters to '-version-info'" # convert absolute version numbers to libtool ages # this retains compatibility with .la files and attempts # to make the code below a bit more comprehensible case $vinfo_number in yes) number_major=$1 number_minor=$2 number_revision=$3 # # There are really only two kinds -- those that # use the current revision as the major version # and those that subtract age and use age as # a minor version. But, then there is irix # that has an extra 1 added just for fun # case $version_type in # correct linux to gnu/linux during the next big refactor darwin|freebsd-elf|linux|midnightbsd-elf|osf|windows|none) func_arith $number_major + $number_minor current=$func_arith_result age=$number_minor revision=$number_revision ;; freebsd-aout|qnx|sunos) current=$number_major revision=$number_minor age=0 ;; irix|nonstopux) func_arith $number_major + $number_minor current=$func_arith_result age=$number_minor revision=$number_minor lt_irix_increment=no ;; esac ;; no) current=$1 revision=$2 age=$3 ;; esac # Check that each of the things are valid numbers. case $current in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "CURRENT '$current' must be a nonnegative integer" func_fatal_error "'$vinfo' is not valid version information" ;; esac case $revision in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "REVISION '$revision' must be a nonnegative integer" func_fatal_error "'$vinfo' is not valid version information" ;; esac case $age in 0|[1-9]|[1-9][0-9]|[1-9][0-9][0-9]|[1-9][0-9][0-9][0-9]|[1-9][0-9][0-9][0-9][0-9]) ;; *) func_error "AGE '$age' must be a nonnegative integer" func_fatal_error "'$vinfo' is not valid version information" ;; esac if test "$age" -gt "$current"; then func_error "AGE '$age' is greater than the current interface number '$current'" func_fatal_error "'$vinfo' is not valid version information" fi # Calculate the version variables. major= versuffix= verstring= case $version_type in none) ;; darwin) # Like Linux, but with the current version available in # verstring for coding it into the library header func_arith $current - $age major=.$func_arith_result versuffix=$major.$age.$revision # Darwin ld doesn't like 0 for these options... func_arith $current + 1 minor_current=$func_arith_result xlcverstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision" verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" # On Darwin other compilers case $CC in nagfor*) verstring="$wl-compatibility_version $wl$minor_current $wl-current_version $wl$minor_current.$revision" ;; *) verstring="-compatibility_version $minor_current -current_version $minor_current.$revision" ;; esac ;; freebsd-aout) major=.$current versuffix=.$current.$revision ;; freebsd-elf | midnightbsd-elf) func_arith $current - $age major=.$func_arith_result versuffix=$major.$age.$revision ;; irix | nonstopux) if test no = "$lt_irix_increment"; then func_arith $current - $age else func_arith $current - $age + 1 fi major=$func_arith_result case $version_type in nonstopux) verstring_prefix=nonstopux ;; *) verstring_prefix=sgi ;; esac verstring=$verstring_prefix$major.$revision # Add in all the interfaces that we are compatible with. loop=$revision while test 0 -ne "$loop"; do func_arith $revision - $loop iface=$func_arith_result func_arith $loop - 1 loop=$func_arith_result verstring=$verstring_prefix$major.$iface:$verstring done # Before this point, $major must not contain '.'. major=.$major versuffix=$major.$revision ;; linux) # correct to gnu/linux during the next big refactor func_arith $current - $age major=.$func_arith_result versuffix=$major.$age.$revision ;; osf) func_arith $current - $age major=.$func_arith_result versuffix=.$current.$age.$revision verstring=$current.$age.$revision # Add in all the interfaces that we are compatible with. loop=$age while test 0 -ne "$loop"; do func_arith $current - $loop iface=$func_arith_result func_arith $loop - 1 loop=$func_arith_result verstring=$verstring:$iface.0 done # Make executables depend on our current version. func_append verstring ":$current.0" ;; qnx) major=.$current versuffix=.$current ;; sco) major=.$current versuffix=.$current ;; sunos) major=.$current versuffix=.$current.$revision ;; windows) # Use '-' rather than '.', since we only want one # extension on DOS 8.3 file systems. func_arith $current - $age major=$func_arith_result versuffix=-$major ;; *) func_fatal_configuration "unknown library version type '$version_type'" ;; esac # Clear the version info if we defaulted, and they specified a release. if test -z "$vinfo" && test -n "$release"; then major= case $version_type in darwin) # we can't check for "0.0" in archive_cmds due to quoting # problems, so we reset it completely verstring= ;; *) verstring=0.0 ;; esac if test no = "$need_version"; then versuffix= else versuffix=.0.0 fi fi # Remove version info from name if versioning should be avoided if test yes,no = "$avoid_version,$need_version"; then major= versuffix= verstring= fi # Check to see if the archive will have undefined symbols. if test yes = "$allow_undefined"; then if test unsupported = "$allow_undefined_flag"; then if test yes = "$build_old_libs"; then func_warning "undefined symbols not allowed in $host shared libraries; building static only" build_libtool_libs=no else func_fatal_error "can't build $host shared library unless -no-undefined is specified" fi fi else # Don't allow undefined symbols. allow_undefined_flag=$no_undefined_flag fi fi func_generate_dlsyms "$libname" "$libname" : func_append libobjs " $symfileobj" test " " = "$libobjs" && libobjs= if test relink != "$opt_mode"; then # Remove our outputs, but don't remove object files since they # may have been created when compiling PIC objects. removelist= tempremovelist=`$ECHO "$output_objdir/*"` for p in $tempremovelist; do case $p in *.$objext | *.gcno) ;; $output_objdir/$outputname | $output_objdir/$libname.* | $output_objdir/$libname$release.*) if test -n "$precious_files_regex"; then if $ECHO "$p" | $EGREP -e "$precious_files_regex" >/dev/null 2>&1 then continue fi fi func_append removelist " $p" ;; *) ;; esac done test -n "$removelist" && \ func_show_eval "${RM}r \$removelist" fi # Now set the variables for building old libraries. if test yes = "$build_old_libs" && test convenience != "$build_libtool_libs"; then func_append oldlibs " $output_objdir/$libname.$libext" # Transform .lo files to .o files. oldobjs="$objs "`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; $lo2o" | $NL2SP` fi # Eliminate all temporary directories. #for path in $notinst_path; do # lib_search_path=`$ECHO "$lib_search_path " | $SED "s% $path % %g"` # deplibs=`$ECHO "$deplibs " | $SED "s% -L$path % %g"` # dependency_libs=`$ECHO "$dependency_libs " | $SED "s% -L$path % %g"` #done if test -n "$xrpath"; then # If the user specified any rpath flags, then add them. temp_xrpath= for libdir in $xrpath; do func_replace_sysroot "$libdir" func_append temp_xrpath " -R$func_replace_sysroot_result" case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac done if test yes != "$hardcode_into_libs" || test yes = "$build_old_libs"; then dependency_libs="$temp_xrpath $dependency_libs" fi fi # Make sure dlfiles contains only unique files that won't be dlpreopened old_dlfiles=$dlfiles dlfiles= for lib in $old_dlfiles; do case " $dlprefiles $dlfiles " in *" $lib "*) ;; *) func_append dlfiles " $lib" ;; esac done # Make sure dlprefiles contains only unique files old_dlprefiles=$dlprefiles dlprefiles= for lib in $old_dlprefiles; do case "$dlprefiles " in *" $lib "*) ;; *) func_append dlprefiles " $lib" ;; esac done if test yes = "$build_libtool_libs"; then if test -n "$rpath"; then case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-*-beos* | *-cegcc* | *-*-haiku*) # these systems don't actually have a c library (as such)! ;; *-*-rhapsody* | *-*-darwin1.[012]) # Rhapsody C library is in the System framework func_append deplibs " System.ltframework" ;; *-*-netbsd*) # Don't link with libc until the a.out ld.so is fixed. ;; *-*-openbsd* | *-*-freebsd* | *-*-dragonfly* | *-*-midnightbsd*) # Do not include libc due to us having libc/libc_r. ;; *-*-sco3.2v5* | *-*-sco5v6*) # Causes problems with __ctype ;; *-*-sysv4.2uw2* | *-*-sysv5* | *-*-unixware* | *-*-OpenUNIX*) # Compiler inserts libc in the correct place for threads to work ;; *) # Add libc to deplibs on all other systems if necessary. if test yes = "$build_libtool_need_lc"; then func_append deplibs " -lc" fi ;; esac fi # Transform deplibs into only deplibs that can be linked in shared. name_save=$name libname_save=$libname release_save=$release versuffix_save=$versuffix major_save=$major # I'm not sure if I'm treating the release correctly. I think # release should show up in the -l (ie -lgmp5) so we don't want to # add it in twice. Is that correct? release= versuffix= major= newdeplibs= droppeddeps=no case $deplibs_check_method in pass_all) # Don't check for shared/static. Everything works. # This might be a little naive. We might want to check # whether the library exists or not. But this is on # osf3 & osf4 and I'm not really sure... Just # implementing what was already the behavior. newdeplibs=$deplibs ;; test_compile) # This code stresses the "libraries are programs" paradigm to its # limits. Maybe even breaks it. We compile a program, linking it # against the deplibs as a proxy for the library. Then we can check # whether they linked in statically or dynamically with ldd. $opt_dry_run || $RM conftest.c cat > conftest.c </dev/null` $nocaseglob else potential_libs=`ls $i/$libnameglob[.-]* 2>/dev/null` fi for potent_lib in $potential_libs; do # Follow soft links. if ls -lLd "$potent_lib" 2>/dev/null | $GREP " -> " >/dev/null; then continue fi # The statement above tries to avoid entering an # endless loop below, in case of cyclic links. # We might still enter an endless loop, since a link # loop can be closed while we follow links, # but so what? potlib=$potent_lib while test -h "$potlib" 2>/dev/null; do potliblink=`ls -ld $potlib | $SED 's/.* -> //'` case $potliblink in [\\/]* | [A-Za-z]:[\\/]*) potlib=$potliblink;; *) potlib=`$ECHO "$potlib" | $SED 's|[^/]*$||'`"$potliblink";; esac done if eval $file_magic_cmd \"\$potlib\" 2>/dev/null | $SED -e 10q | $EGREP "$file_magic_regex" > /dev/null; then func_append newdeplibs " $a_deplib" a_deplib= break 2 fi done done fi if test -n "$a_deplib"; then droppeddeps=yes echo $ECHO "*** Warning: linker path does not have real file for library $a_deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because I did check the linker path looking for a file starting" if test -z "$potlib"; then $ECHO "*** with $libname but no candidates were found. (...for file magic test)" else $ECHO "*** with $libname and none of the candidates passed a file format test" $ECHO "*** using a file magic. Last file checked: $potlib" fi fi ;; *) # Add a -L argument. func_append newdeplibs " $a_deplib" ;; esac done # Gone through all deplibs. ;; match_pattern*) set dummy $deplibs_check_method; shift match_pattern_regex=`expr "$deplibs_check_method" : "$1 \(.*\)"` for a_deplib in $deplibs; do case $a_deplib in -l*) func_stripname -l '' "$a_deplib" name=$func_stripname_result if test yes = "$allow_libtool_libs_with_static_runtimes"; then case " $predeps $postdeps " in *" $a_deplib "*) func_append newdeplibs " $a_deplib" a_deplib= ;; esac fi if test -n "$a_deplib"; then libname=`eval "\\$ECHO \"$libname_spec\""` for i in $lib_search_path $sys_lib_search_path $shlib_search_path; do potential_libs=`ls $i/$libname[.-]* 2>/dev/null` for potent_lib in $potential_libs; do potlib=$potent_lib # see symlink-check above in file_magic test if eval "\$ECHO \"$potent_lib\"" 2>/dev/null | $SED 10q | \ $EGREP "$match_pattern_regex" > /dev/null; then func_append newdeplibs " $a_deplib" a_deplib= break 2 fi done done fi if test -n "$a_deplib"; then droppeddeps=yes echo $ECHO "*** Warning: linker path does not have real file for library $a_deplib." echo "*** I have the capability to make that library automatically link in when" echo "*** you link to this library. But I can only do this if you have a" echo "*** shared version of the library, which you do not appear to have" echo "*** because I did check the linker path looking for a file starting" if test -z "$potlib"; then $ECHO "*** with $libname but no candidates were found. (...for regex pattern test)" else $ECHO "*** with $libname and none of the candidates passed a file format test" $ECHO "*** using a regex pattern. Last file checked: $potlib" fi fi ;; *) # Add a -L argument. func_append newdeplibs " $a_deplib" ;; esac done # Gone through all deplibs. ;; none | unknown | *) newdeplibs= tmp_deplibs=`$ECHO " $deplibs" | $SED 's/ -lc$//; s/ -[LR][^ ]*//g'` if test yes = "$allow_libtool_libs_with_static_runtimes"; then for i in $predeps $postdeps; do # can't use Xsed below, because $i might contain '/' tmp_deplibs=`$ECHO " $tmp_deplibs" | $SED "s|$i||"` done fi case $tmp_deplibs in *[!\ \ ]*) echo if test none = "$deplibs_check_method"; then echo "*** Warning: inter-library dependencies are not supported in this platform." else echo "*** Warning: inter-library dependencies are not known to be supported." fi echo "*** All declared inter-library dependencies are being dropped." droppeddeps=yes ;; esac ;; esac versuffix=$versuffix_save major=$major_save release=$release_save libname=$libname_save name=$name_save case $host in *-*-rhapsody* | *-*-darwin1.[012]) # On Rhapsody replace the C library with the System framework newdeplibs=`$ECHO " $newdeplibs" | $SED 's/ -lc / System.ltframework /'` ;; esac if test yes = "$droppeddeps"; then if test yes = "$module"; then echo echo "*** Warning: libtool could not satisfy all declared inter-library" $ECHO "*** dependencies of module $libname. Therefore, libtool will create" echo "*** a static module, that should work as long as the dlopening" echo "*** application is linked with the -dlopen flag." if test -z "$global_symbol_pipe"; then echo echo "*** However, this would only work if libtool was able to extract symbol" echo "*** lists from a program, using 'nm' or equivalent, but libtool could" echo "*** not find such a program. So, this module is probably useless." echo "*** 'nm' from GNU binutils and a full rebuild may help." fi if test no = "$build_old_libs"; then oldlibs=$output_objdir/$libname.$libext build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi else echo "*** The inter-library dependencies that have been dropped here will be" echo "*** automatically added whenever a program is linked with this library" echo "*** or is declared to -dlopen it." if test no = "$allow_undefined"; then echo echo "*** Since this library must not contain undefined symbols," echo "*** because either the platform does not support them or" echo "*** it was explicitly requested with -no-undefined," echo "*** libtool will only create a static version of it." if test no = "$build_old_libs"; then oldlibs=$output_objdir/$libname.$libext build_libtool_libs=module build_old_libs=yes else build_libtool_libs=no fi fi fi fi # Done checking deplibs! deplibs=$newdeplibs fi # Time to change all our "foo.ltframework" stuff back to "-framework foo" case $host in *-*-darwin*) newdeplibs=`$ECHO " $newdeplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` new_inherited_linker_flags=`$ECHO " $new_inherited_linker_flags" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` deplibs=`$ECHO " $deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` ;; esac # move library search paths that coincide with paths to not yet # installed libraries to the beginning of the library search list new_libs= for path in $notinst_path; do case " $new_libs " in *" -L$path/$objdir "*) ;; *) case " $deplibs " in *" -L$path/$objdir "*) func_append new_libs " -L$path/$objdir" ;; esac ;; esac done for deplib in $deplibs; do case $deplib in -L*) case " $new_libs " in *" $deplib "*) ;; *) func_append new_libs " $deplib" ;; esac ;; *) func_append new_libs " $deplib" ;; esac done deplibs=$new_libs # All the library-specific variables (install_libdir is set above). library_names= old_library= dlname= # Test again, we may have decided not to build it any more if test yes = "$build_libtool_libs"; then # Remove $wl instances when linking with ld. # FIXME: should test the right _cmds variable. case $archive_cmds in *\$LD\ *) wl= ;; esac if test yes = "$hardcode_into_libs"; then # Hardcode the library paths hardcode_libdirs= dep_rpath= rpath=$finalize_rpath test relink = "$opt_mode" || rpath=$compile_rpath$rpath for libdir in $rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then func_replace_sysroot "$libdir" libdir=$func_replace_sysroot_result if test -z "$hardcode_libdirs"; then hardcode_libdirs=$libdir else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append dep_rpath " $flag" fi elif test -n "$runpath_var"; then case "$perm_rpath " in *" $libdir "*) ;; *) func_append perm_rpath " $libdir" ;; esac fi done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir=$hardcode_libdirs eval "dep_rpath=\"$hardcode_libdir_flag_spec\"" fi if test -n "$runpath_var" && test -n "$perm_rpath"; then # We should set the runpath_var. rpath= for dir in $perm_rpath; do func_append rpath "$dir:" done eval "$runpath_var='$rpath\$$runpath_var'; export $runpath_var" fi test -n "$dep_rpath" && deplibs="$dep_rpath $deplibs" fi shlibpath=$finalize_shlibpath test relink = "$opt_mode" || shlibpath=$compile_shlibpath$shlibpath if test -n "$shlibpath"; then eval "$shlibpath_var='$shlibpath\$$shlibpath_var'; export $shlibpath_var" fi # Get the real and link names of the library. eval shared_ext=\"$shrext_cmds\" eval library_names=\"$library_names_spec\" set dummy $library_names shift realname=$1 shift if test -n "$soname_spec"; then eval soname=\"$soname_spec\" else soname=$realname fi if test -z "$dlname"; then dlname=$soname fi lib=$output_objdir/$realname linknames= for link do func_append linknames " $link" done # Use standard objects if they are pic test -z "$pic_flag" && libobjs=`$ECHO "$libobjs" | $SP2NL | $SED "$lo2o" | $NL2SP` test "X$libobjs" = "X " && libobjs= delfiles= if test -n "$export_symbols" && test -n "$include_expsyms"; then $opt_dry_run || cp "$export_symbols" "$output_objdir/$libname.uexp" export_symbols=$output_objdir/$libname.uexp func_append delfiles " $export_symbols" fi orig_export_symbols= case $host_os in cygwin* | mingw* | cegcc*) if test -n "$export_symbols" && test -z "$export_symbols_regex"; then # exporting using user supplied symfile func_dll_def_p "$export_symbols" || { # and it's NOT already a .def file. Must figure out # which of the given symbols are data symbols and tag # them as such. So, trigger use of export_symbols_cmds. # export_symbols gets reassigned inside the "prepare # the list of exported symbols" if statement, so the # include_expsyms logic still works. orig_export_symbols=$export_symbols export_symbols= always_export_symbols=yes } fi ;; esac # Prepare the list of exported symbols if test -z "$export_symbols"; then if test yes = "$always_export_symbols" || test -n "$export_symbols_regex"; then func_verbose "generating symbol list for '$libname.la'" export_symbols=$output_objdir/$libname.exp $opt_dry_run || $RM $export_symbols cmds=$export_symbols_cmds save_ifs=$IFS; IFS='~' for cmd1 in $cmds; do IFS=$save_ifs # Take the normal branch if the nm_file_list_spec branch # doesn't work or if tool conversion is not needed. case $nm_file_list_spec~$to_tool_file_cmd in *~func_convert_file_noop | *~func_convert_file_msys_to_w32 | ~*) try_normal_branch=yes eval cmd=\"$cmd1\" func_len " $cmd" len=$func_len_result ;; *) try_normal_branch=no ;; esac if test yes = "$try_normal_branch" \ && { test "$len" -lt "$max_cmd_len" \ || test "$max_cmd_len" -le -1; } then func_show_eval "$cmd" 'exit $?' skipped_export=false elif test -n "$nm_file_list_spec"; then func_basename "$output" output_la=$func_basename_result save_libobjs=$libobjs save_output=$output output=$output_objdir/$output_la.nm func_to_tool_file "$output" libobjs=$nm_file_list_spec$func_to_tool_file_result func_append delfiles " $output" func_verbose "creating $NM input file list: $output" for obj in $save_libobjs; do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" done > "$output" eval cmd=\"$cmd1\" func_show_eval "$cmd" 'exit $?' output=$save_output libobjs=$save_libobjs skipped_export=false else # The command line is too long to execute in one step. func_verbose "using reloadable object file for export list..." skipped_export=: # Break out early, otherwise skipped_export may be # set to false by a later but shorter cmd. break fi done IFS=$save_ifs if test -n "$export_symbols_regex" && test : != "$skipped_export"; then func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' func_show_eval '$MV "${export_symbols}T" "$export_symbols"' fi fi fi if test -n "$export_symbols" && test -n "$include_expsyms"; then tmp_export_symbols=$export_symbols test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"' fi if test : != "$skipped_export" && test -n "$orig_export_symbols"; then # The given exports_symbols file has to be filtered, so filter it. func_verbose "filter symbol list for '$libname.la' to tag DATA exports" # FIXME: $output_objdir/$libname.filter potentially contains lots of # 's' commands, which not all seds can handle. GNU sed should be fine # though. Also, the filter scales superlinearly with the number of # global variables. join(1) would be nice here, but unfortunately # isn't a blessed tool. $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter func_append delfiles " $export_symbols $output_objdir/$libname.filter" export_symbols=$output_objdir/$libname.def $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols fi tmp_deplibs= for test_deplib in $deplibs; do case " $convenience " in *" $test_deplib "*) ;; *) func_append tmp_deplibs " $test_deplib" ;; esac done deplibs=$tmp_deplibs if test -n "$convenience"; then if test -n "$whole_archive_flag_spec" && test yes = "$compiler_needs_object" && test -z "$libobjs"; then # extract the archives, so we have objects to list. # TODO: could optimize this to just extract one archive. whole_archive_flag_spec= fi if test -n "$whole_archive_flag_spec"; then save_libobjs=$libobjs eval libobjs=\"\$libobjs $whole_archive_flag_spec\" test "X$libobjs" = "X " && libobjs= else gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $convenience func_append libobjs " $func_extract_archives_result" test "X$libobjs" = "X " && libobjs= fi fi if test yes = "$thread_safe" && test -n "$thread_safe_flag_spec"; then eval flag=\"$thread_safe_flag_spec\" func_append linker_flags " $flag" fi # Make a backup of the uninstalled library when relinking if test relink = "$opt_mode"; then $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}U && $MV $realname ${realname}U)' || exit $? fi # Do each of the archive commands. if test yes = "$module" && test -n "$module_cmds"; then if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then eval test_cmds=\"$module_expsym_cmds\" cmds=$module_expsym_cmds else eval test_cmds=\"$module_cmds\" cmds=$module_cmds fi else if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then eval test_cmds=\"$archive_expsym_cmds\" cmds=$archive_expsym_cmds else eval test_cmds=\"$archive_cmds\" cmds=$archive_cmds fi fi if test : != "$skipped_export" && func_len " $test_cmds" && len=$func_len_result && test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then : else # The command line is too long to link in one step, link piecewise # or, if using GNU ld and skipped_export is not :, use a linker # script. # Save the value of $output and $libobjs because we want to # use them later. If we have whole_archive_flag_spec, we # want to use save_libobjs as it was before # whole_archive_flag_spec was expanded, because we can't # assume the linker understands whole_archive_flag_spec. # This may have to be revisited, in case too many # convenience libraries get linked in and end up exceeding # the spec. if test -z "$convenience" || test -z "$whole_archive_flag_spec"; then save_libobjs=$libobjs fi save_output=$output func_basename "$output" output_la=$func_basename_result # Clear the reloadable object creation command queue and # initialize k to one. test_cmds= concat_cmds= objlist= last_robj= k=1 if test -n "$save_libobjs" && test : != "$skipped_export" && test yes = "$with_gnu_ld"; then output=$output_objdir/$output_la.lnkscript func_verbose "creating GNU ld script: $output" echo 'INPUT (' > $output for obj in $save_libobjs do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" >> $output done echo ')' >> $output func_append delfiles " $output" func_to_tool_file "$output" output=$func_to_tool_file_result elif test -n "$save_libobjs" && test : != "$skipped_export" && test -n "$file_list_spec"; then output=$output_objdir/$output_la.lnk func_verbose "creating linker input file list: $output" : > $output set x $save_libobjs shift firstobj= if test yes = "$compiler_needs_object"; then firstobj="$1 " shift fi for obj do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" >> $output done func_append delfiles " $output" func_to_tool_file "$output" output=$firstobj\"$file_list_spec$func_to_tool_file_result\" else if test -n "$save_libobjs"; then func_verbose "creating reloadable object files..." output=$output_objdir/$output_la-$k.$objext eval test_cmds=\"$reload_cmds\" func_len " $test_cmds" len0=$func_len_result len=$len0 # Loop over the list of objects to be linked. for obj in $save_libobjs do func_len " $obj" func_arith $len + $func_len_result len=$func_arith_result if test -z "$objlist" || test "$len" -lt "$max_cmd_len"; then func_append objlist " $obj" else # The command $test_cmds is almost too long, add a # command to the queue. if test 1 -eq "$k"; then # The first file doesn't have a previous command to add. reload_objs=$objlist eval concat_cmds=\"$reload_cmds\" else # All subsequent reloadable object files will link in # the last one created. reload_objs="$objlist $last_robj" eval concat_cmds=\"\$concat_cmds~$reload_cmds~\$RM $last_robj\" fi last_robj=$output_objdir/$output_la-$k.$objext func_arith $k + 1 k=$func_arith_result output=$output_objdir/$output_la-$k.$objext objlist=" $obj" func_len " $last_robj" func_arith $len0 + $func_len_result len=$func_arith_result fi done # Handle the remaining objects by creating one last # reloadable object file. All subsequent reloadable object # files will link in the last one created. test -z "$concat_cmds" || concat_cmds=$concat_cmds~ reload_objs="$objlist $last_robj" eval concat_cmds=\"\$concat_cmds$reload_cmds\" if test -n "$last_robj"; then eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\" fi func_append delfiles " $output" else output= fi ${skipped_export-false} && { func_verbose "generating symbol list for '$libname.la'" export_symbols=$output_objdir/$libname.exp $opt_dry_run || $RM $export_symbols libobjs=$output # Append the command to create the export file. test -z "$concat_cmds" || concat_cmds=$concat_cmds~ eval concat_cmds=\"\$concat_cmds$export_symbols_cmds\" if test -n "$last_robj"; then eval concat_cmds=\"\$concat_cmds~\$RM $last_robj\" fi } test -n "$save_libobjs" && func_verbose "creating a temporary reloadable object file: $output" # Loop through the commands generated above and execute them. save_ifs=$IFS; IFS='~' for cmd in $concat_cmds; do IFS=$save_ifs $opt_quiet || { func_quote_arg expand,pretty "$cmd" eval "func_echo $func_quote_arg_result" } $opt_dry_run || eval "$cmd" || { lt_exit=$? # Restore the uninstalled library and exit if test relink = "$opt_mode"; then ( cd "$output_objdir" && \ $RM "${realname}T" && \ $MV "${realname}U" "$realname" ) fi exit $lt_exit } done IFS=$save_ifs if test -n "$export_symbols_regex" && ${skipped_export-false}; then func_show_eval '$EGREP -e "$export_symbols_regex" "$export_symbols" > "${export_symbols}T"' func_show_eval '$MV "${export_symbols}T" "$export_symbols"' fi fi ${skipped_export-false} && { if test -n "$export_symbols" && test -n "$include_expsyms"; then tmp_export_symbols=$export_symbols test -n "$orig_export_symbols" && tmp_export_symbols=$orig_export_symbols $opt_dry_run || eval '$ECHO "$include_expsyms" | $SP2NL >> "$tmp_export_symbols"' fi if test -n "$orig_export_symbols"; then # The given exports_symbols file has to be filtered, so filter it. func_verbose "filter symbol list for '$libname.la' to tag DATA exports" # FIXME: $output_objdir/$libname.filter potentially contains lots of # 's' commands, which not all seds can handle. GNU sed should be fine # though. Also, the filter scales superlinearly with the number of # global variables. join(1) would be nice here, but unfortunately # isn't a blessed tool. $opt_dry_run || $SED -e '/[ ,]DATA/!d;s,\(.*\)\([ \,].*\),s|^\1$|\1\2|,' < $export_symbols > $output_objdir/$libname.filter func_append delfiles " $export_symbols $output_objdir/$libname.filter" export_symbols=$output_objdir/$libname.def $opt_dry_run || $SED -f $output_objdir/$libname.filter < $orig_export_symbols > $export_symbols fi } libobjs=$output # Restore the value of output. output=$save_output if test -n "$convenience" && test -n "$whole_archive_flag_spec"; then eval libobjs=\"\$libobjs $whole_archive_flag_spec\" test "X$libobjs" = "X " && libobjs= fi # Expand the library linking commands again to reset the # value of $libobjs for piecewise linking. # Do each of the archive commands. if test yes = "$module" && test -n "$module_cmds"; then if test -n "$export_symbols" && test -n "$module_expsym_cmds"; then cmds=$module_expsym_cmds else cmds=$module_cmds fi else if test -n "$export_symbols" && test -n "$archive_expsym_cmds"; then cmds=$archive_expsym_cmds else cmds=$archive_cmds fi fi fi if test -n "$delfiles"; then # Append the command to remove temporary files to $cmds. eval cmds=\"\$cmds~\$RM $delfiles\" fi # Add any objects from preloaded convenience libraries if test -n "$dlprefiles"; then gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $dlprefiles func_append libobjs " $func_extract_archives_result" test "X$libobjs" = "X " && libobjs= fi save_ifs=$IFS; IFS='~' for cmd in $cmds; do IFS=$sp$nl eval cmd=\"$cmd\" IFS=$save_ifs $opt_quiet || { func_quote_arg expand,pretty "$cmd" eval "func_echo $func_quote_arg_result" } $opt_dry_run || eval "$cmd" || { lt_exit=$? # Restore the uninstalled library and exit if test relink = "$opt_mode"; then ( cd "$output_objdir" && \ $RM "${realname}T" && \ $MV "${realname}U" "$realname" ) fi exit $lt_exit } done IFS=$save_ifs # Restore the uninstalled library and exit if test relink = "$opt_mode"; then $opt_dry_run || eval '(cd $output_objdir && $RM ${realname}T && $MV $realname ${realname}T && $MV ${realname}U $realname)' || exit $? if test -n "$convenience"; then if test -z "$whole_archive_flag_spec"; then func_show_eval '${RM}r "$gentop"' fi fi exit $EXIT_SUCCESS fi # Create links to the real library. for linkname in $linknames; do if test "$realname" != "$linkname"; then func_show_eval '(cd "$output_objdir" && $RM "$linkname" && $LN_S "$realname" "$linkname")' 'exit $?' fi done # If -module or -export-dynamic was specified, set the dlname. if test yes = "$module" || test yes = "$export_dynamic"; then # On all known operating systems, these are identical. dlname=$soname fi fi ;; obj) if test -n "$dlfiles$dlprefiles" || test no != "$dlself"; then func_warning "'-dlopen' is ignored for objects" fi case " $deplibs" in *\ -l* | *\ -L*) func_warning "'-l' and '-L' are ignored for objects" ;; esac test -n "$rpath" && \ func_warning "'-rpath' is ignored for objects" test -n "$xrpath" && \ func_warning "'-R' is ignored for objects" test -n "$vinfo" && \ func_warning "'-version-info' is ignored for objects" test -n "$release" && \ func_warning "'-release' is ignored for objects" case $output in *.lo) test -n "$objs$old_deplibs" && \ func_fatal_error "cannot build library object '$output' from non-libtool objects" libobj=$output func_lo2o "$libobj" obj=$func_lo2o_result ;; *) libobj= obj=$output ;; esac # Delete the old objects. $opt_dry_run || $RM $obj $libobj # Objects from convenience libraries. This assumes # single-version convenience libraries. Whenever we create # different ones for PIC/non-PIC, this we'll have to duplicate # the extraction. reload_conv_objs= gentop= # if reload_cmds runs $LD directly, get rid of -Wl from # whole_archive_flag_spec and hope we can get by with turning comma # into space. case $reload_cmds in *\$LD[\ \$]*) wl= ;; esac if test -n "$convenience"; then if test -n "$whole_archive_flag_spec"; then eval tmp_whole_archive_flags=\"$whole_archive_flag_spec\" test -n "$wl" || tmp_whole_archive_flags=`$ECHO "$tmp_whole_archive_flags" | $SED 's|,| |g'` reload_conv_objs=$reload_objs\ $tmp_whole_archive_flags else gentop=$output_objdir/${obj}x func_append generated " $gentop" func_extract_archives $gentop $convenience reload_conv_objs="$reload_objs $func_extract_archives_result" fi fi # If we're not building shared, we need to use non_pic_objs test yes = "$build_libtool_libs" || libobjs=$non_pic_objects # Create the old-style object. reload_objs=$objs$old_deplibs' '`$ECHO "$libobjs" | $SP2NL | $SED "/\.$libext$/d; /\.lib$/d; $lo2o" | $NL2SP`' '$reload_conv_objs output=$obj func_execute_cmds "$reload_cmds" 'exit $?' # Exit if we aren't doing a library object file. if test -z "$libobj"; then if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi exit $EXIT_SUCCESS fi test yes = "$build_libtool_libs" || { if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi # Create an invalid libtool object if no PIC, so that we don't # accidentally link it into a program. # $show "echo timestamp > $libobj" # $opt_dry_run || eval "echo timestamp > $libobj" || exit $? exit $EXIT_SUCCESS } if test -n "$pic_flag" || test default != "$pic_mode"; then # Only do commands if we really have different PIC objects. reload_objs="$libobjs $reload_conv_objs" output=$libobj func_execute_cmds "$reload_cmds" 'exit $?' fi if test -n "$gentop"; then func_show_eval '${RM}r "$gentop"' fi exit $EXIT_SUCCESS ;; prog) case $host in *cygwin*) func_stripname '' '.exe' "$output" output=$func_stripname_result.exe;; esac test -n "$vinfo" && \ func_warning "'-version-info' is ignored for programs" test -n "$release" && \ func_warning "'-release' is ignored for programs" $preload \ && test unknown,unknown,unknown = "$dlopen_support,$dlopen_self,$dlopen_self_static" \ && func_warning "'LT_INIT([dlopen])' not used. Assuming no dlopen support." case $host in *-*-rhapsody* | *-*-darwin1.[012]) # On Rhapsody replace the C library is the System framework compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's/ -lc / System.ltframework /'` finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's/ -lc / System.ltframework /'` ;; esac case $host in *-*-darwin*) # Don't allow lazy linking, it breaks C++ global constructors # But is supposedly fixed on 10.4 or later (yay!). if test CXX = "$tagname"; then case ${MACOSX_DEPLOYMENT_TARGET-10.0} in 10.[0123]) func_append compile_command " $wl-bind_at_load" func_append finalize_command " $wl-bind_at_load" ;; esac fi # Time to change all our "foo.ltframework" stuff back to "-framework foo" compile_deplibs=`$ECHO " $compile_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` finalize_deplibs=`$ECHO " $finalize_deplibs" | $SED 's% \([^ $]*\).ltframework% -framework \1%g'` ;; esac # move library search paths that coincide with paths to not yet # installed libraries to the beginning of the library search list new_libs= for path in $notinst_path; do case " $new_libs " in *" -L$path/$objdir "*) ;; *) case " $compile_deplibs " in *" -L$path/$objdir "*) func_append new_libs " -L$path/$objdir" ;; esac ;; esac done for deplib in $compile_deplibs; do case $deplib in -L*) case " $new_libs " in *" $deplib "*) ;; *) func_append new_libs " $deplib" ;; esac ;; *) func_append new_libs " $deplib" ;; esac done compile_deplibs=$new_libs func_append compile_command " $compile_deplibs" func_append finalize_command " $finalize_deplibs" if test -n "$rpath$xrpath"; then # If the user specified any rpath flags, then add them. for libdir in $rpath $xrpath; do # This is the magic to use -rpath. case "$finalize_rpath " in *" $libdir "*) ;; *) func_append finalize_rpath " $libdir" ;; esac done fi # Now hardcode the library paths rpath= hardcode_libdirs= for libdir in $compile_rpath $finalize_rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then if test -z "$hardcode_libdirs"; then hardcode_libdirs=$libdir else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append rpath " $flag" fi elif test -n "$runpath_var"; then case "$perm_rpath " in *" $libdir "*) ;; *) func_append perm_rpath " $libdir" ;; esac fi case $host in *-*-cygwin* | *-*-mingw* | *-*-pw32* | *-*-os2* | *-cegcc*) testbindir=`$ECHO "$libdir" | $SED -e 's*/lib$*/bin*'` case :$dllsearchpath: in *":$libdir:"*) ;; ::) dllsearchpath=$libdir;; *) func_append dllsearchpath ":$libdir";; esac case :$dllsearchpath: in *":$testbindir:"*) ;; ::) dllsearchpath=$testbindir;; *) func_append dllsearchpath ":$testbindir";; esac ;; esac done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir=$hardcode_libdirs eval rpath=\" $hardcode_libdir_flag_spec\" fi compile_rpath=$rpath rpath= hardcode_libdirs= for libdir in $finalize_rpath; do if test -n "$hardcode_libdir_flag_spec"; then if test -n "$hardcode_libdir_separator"; then if test -z "$hardcode_libdirs"; then hardcode_libdirs=$libdir else # Just accumulate the unique libdirs. case $hardcode_libdir_separator$hardcode_libdirs$hardcode_libdir_separator in *"$hardcode_libdir_separator$libdir$hardcode_libdir_separator"*) ;; *) func_append hardcode_libdirs "$hardcode_libdir_separator$libdir" ;; esac fi else eval flag=\"$hardcode_libdir_flag_spec\" func_append rpath " $flag" fi elif test -n "$runpath_var"; then case "$finalize_perm_rpath " in *" $libdir "*) ;; *) func_append finalize_perm_rpath " $libdir" ;; esac fi done # Substitute the hardcoded libdirs into the rpath. if test -n "$hardcode_libdir_separator" && test -n "$hardcode_libdirs"; then libdir=$hardcode_libdirs eval rpath=\" $hardcode_libdir_flag_spec\" fi finalize_rpath=$rpath if test -n "$libobjs" && test yes = "$build_old_libs"; then # Transform all the library objects into standard objects. compile_command=`$ECHO "$compile_command" | $SP2NL | $SED "$lo2o" | $NL2SP` finalize_command=`$ECHO "$finalize_command" | $SP2NL | $SED "$lo2o" | $NL2SP` fi func_generate_dlsyms "$outputname" "@PROGRAM@" false # template prelinking step if test -n "$prelink_cmds"; then func_execute_cmds "$prelink_cmds" 'exit $?' fi wrappers_required=: case $host in *cegcc* | *mingw32ce*) # Disable wrappers for cegcc and mingw32ce hosts, we are cross compiling anyway. wrappers_required=false ;; *cygwin* | *mingw* ) test yes = "$build_libtool_libs" || wrappers_required=false ;; *) if test no = "$need_relink" || test yes != "$build_libtool_libs"; then wrappers_required=false fi ;; esac $wrappers_required || { # Replace the output file specification. compile_command=`$ECHO "$compile_command" | $SED 's%@OUTPUT@%'"$output"'%g'` link_command=$compile_command$compile_rpath # We have no uninstalled library dependencies, so finalize right now. exit_status=0 func_show_eval "$link_command" 'exit_status=$?' if test -n "$postlink_cmds"; then func_to_tool_file "$output" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi # Delete the generated files. if test -f "$output_objdir/${outputname}S.$objext"; then func_show_eval '$RM "$output_objdir/${outputname}S.$objext"' fi exit $exit_status } if test -n "$compile_shlibpath$finalize_shlibpath"; then compile_command="$shlibpath_var=\"$compile_shlibpath$finalize_shlibpath\$$shlibpath_var\" $compile_command" fi if test -n "$finalize_shlibpath"; then finalize_command="$shlibpath_var=\"$finalize_shlibpath\$$shlibpath_var\" $finalize_command" fi compile_var= finalize_var= if test -n "$runpath_var"; then if test -n "$perm_rpath"; then # We should set the runpath_var. rpath= for dir in $perm_rpath; do func_append rpath "$dir:" done compile_var="$runpath_var=\"$rpath\$$runpath_var\" " fi if test -n "$finalize_perm_rpath"; then # We should set the runpath_var. rpath= for dir in $finalize_perm_rpath; do func_append rpath "$dir:" done finalize_var="$runpath_var=\"$rpath\$$runpath_var\" " fi fi if test yes = "$no_install"; then # We don't need to create a wrapper script. link_command=$compile_var$compile_command$compile_rpath # Replace the output file specification. link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output"'%g'` # Delete the old output file. $opt_dry_run || $RM $output # Link the executable and exit func_show_eval "$link_command" 'exit $?' if test -n "$postlink_cmds"; then func_to_tool_file "$output" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi exit $EXIT_SUCCESS fi case $hardcode_action,$fast_install in relink,*) # Fast installation is not supported link_command=$compile_var$compile_command$compile_rpath relink_command=$finalize_var$finalize_command$finalize_rpath func_warning "this platform does not like uninstalled shared libraries" func_warning "'$output' will be relinked during installation" ;; *,yes) link_command=$finalize_var$compile_command$finalize_rpath relink_command=`$ECHO "$compile_var$compile_command$compile_rpath" | $SED 's%@OUTPUT@%\$progdir/\$file%g'` ;; *,no) link_command=$compile_var$compile_command$compile_rpath relink_command=$finalize_var$finalize_command$finalize_rpath ;; *,needless) link_command=$finalize_var$compile_command$finalize_rpath relink_command= ;; esac # Replace the output file specification. link_command=`$ECHO "$link_command" | $SED 's%@OUTPUT@%'"$output_objdir/$outputname"'%g'` # Delete the old output files. $opt_dry_run || $RM $output $output_objdir/$outputname $output_objdir/lt-$outputname func_show_eval "$link_command" 'exit $?' if test -n "$postlink_cmds"; then func_to_tool_file "$output_objdir/$outputname" postlink_cmds=`func_echo_all "$postlink_cmds" | $SED -e 's%@OUTPUT@%'"$output_objdir/$outputname"'%g' -e 's%@TOOL_OUTPUT@%'"$func_to_tool_file_result"'%g'` func_execute_cmds "$postlink_cmds" 'exit $?' fi # Now create the wrapper script. func_verbose "creating $output" # Quote the relink command for shipping. if test -n "$relink_command"; then # Preserve any variables that may affect compiler behavior for var in $variables_saved_for_relink; do if eval test -z \"\${$var+set}\"; then relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" elif eval var_value=\$$var; test -z "$var_value"; then relink_command="$var=; export $var; $relink_command" else func_quote_arg pretty "$var_value" relink_command="$var=$func_quote_arg_result; export $var; $relink_command" fi done func_quote eval cd "`pwd`" func_quote_arg pretty,unquoted "($func_quote_result; $relink_command)" relink_command=$func_quote_arg_unquoted_result fi # Only actually do things if not in dry run mode. $opt_dry_run || { # win32 will think the script is a binary if it has # a .exe suffix, so we strip it off here. case $output in *.exe) func_stripname '' '.exe' "$output" output=$func_stripname_result ;; esac # test for cygwin because mv fails w/o .exe extensions case $host in *cygwin*) exeext=.exe func_stripname '' '.exe' "$outputname" outputname=$func_stripname_result ;; *) exeext= ;; esac case $host in *cygwin* | *mingw* ) func_dirname_and_basename "$output" "" "." output_name=$func_basename_result output_path=$func_dirname_result cwrappersource=$output_path/$objdir/lt-$output_name.c cwrapper=$output_path/$output_name.exe $RM $cwrappersource $cwrapper trap "$RM $cwrappersource $cwrapper; exit $EXIT_FAILURE" 1 2 15 func_emit_cwrapperexe_src > $cwrappersource # The wrapper executable is built using the $host compiler, # because it contains $host paths and files. If cross- # compiling, it, like the target executable, must be # executed on the $host or under an emulation environment. $opt_dry_run || { $LTCC $LTCFLAGS -o $cwrapper $cwrappersource $STRIP $cwrapper } # Now, create the wrapper script for func_source use: func_ltwrapper_scriptname $cwrapper $RM $func_ltwrapper_scriptname_result trap "$RM $func_ltwrapper_scriptname_result; exit $EXIT_FAILURE" 1 2 15 $opt_dry_run || { # note: this script will not be executed, so do not chmod. if test "x$build" = "x$host"; then $cwrapper --lt-dump-script > $func_ltwrapper_scriptname_result else func_emit_wrapper no > $func_ltwrapper_scriptname_result fi } ;; * ) $RM $output trap "$RM $output; exit $EXIT_FAILURE" 1 2 15 func_emit_wrapper no > $output chmod +x $output ;; esac } exit $EXIT_SUCCESS ;; esac # See if we need to build an old-fashioned archive. for oldlib in $oldlibs; do case $build_libtool_libs in convenience) oldobjs="$libobjs_save $symfileobj" addlibs=$convenience build_libtool_libs=no ;; module) oldobjs=$libobjs_save addlibs=$old_convenience build_libtool_libs=no ;; *) oldobjs="$old_deplibs $non_pic_objects" $preload && test -f "$symfileobj" \ && func_append oldobjs " $symfileobj" addlibs=$old_convenience ;; esac if test -n "$addlibs"; then gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $addlibs func_append oldobjs " $func_extract_archives_result" fi # Do each command in the archive commands. if test -n "$old_archive_from_new_cmds" && test yes = "$build_libtool_libs"; then cmds=$old_archive_from_new_cmds else # Add any objects from preloaded convenience libraries if test -n "$dlprefiles"; then gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_extract_archives $gentop $dlprefiles func_append oldobjs " $func_extract_archives_result" fi # POSIX demands no paths to be encoded in archives. We have # to avoid creating archives with duplicate basenames if we # might have to extract them afterwards, e.g., when creating a # static archive out of a convenience library, or when linking # the entirety of a libtool archive into another (currently # not supported by libtool). if (for obj in $oldobjs do func_basename "$obj" $ECHO "$func_basename_result" done | sort | sort -uc >/dev/null 2>&1); then : else echo "copying selected object files to avoid basename conflicts..." gentop=$output_objdir/${outputname}x func_append generated " $gentop" func_mkdir_p "$gentop" save_oldobjs=$oldobjs oldobjs= counter=1 for obj in $save_oldobjs do func_basename "$obj" objbase=$func_basename_result case " $oldobjs " in " ") oldobjs=$obj ;; *[\ /]"$objbase "*) while :; do # Make sure we don't pick an alternate name that also # overlaps. newobj=lt$counter-$objbase func_arith $counter + 1 counter=$func_arith_result case " $oldobjs " in *[\ /]"$newobj "*) ;; *) if test ! -f "$gentop/$newobj"; then break; fi ;; esac done func_show_eval "ln $obj $gentop/$newobj || cp $obj $gentop/$newobj" func_append oldobjs " $gentop/$newobj" ;; *) func_append oldobjs " $obj" ;; esac done fi func_to_tool_file "$oldlib" func_convert_file_msys_to_w32 tool_oldlib=$func_to_tool_file_result eval cmds=\"$old_archive_cmds\" func_len " $cmds" len=$func_len_result if test "$len" -lt "$max_cmd_len" || test "$max_cmd_len" -le -1; then cmds=$old_archive_cmds elif test -n "$archiver_list_spec"; then func_verbose "using command file archive linking..." for obj in $oldobjs do func_to_tool_file "$obj" $ECHO "$func_to_tool_file_result" done > $output_objdir/$libname.libcmd func_to_tool_file "$output_objdir/$libname.libcmd" oldobjs=" $archiver_list_spec$func_to_tool_file_result" cmds=$old_archive_cmds else # the command line is too long to link in one step, link in parts func_verbose "using piecewise archive linking..." save_RANLIB=$RANLIB RANLIB=: objlist= concat_cmds= save_oldobjs=$oldobjs oldobjs= # Is there a better way of finding the last object in the list? for obj in $save_oldobjs do last_oldobj=$obj done eval test_cmds=\"$old_archive_cmds\" func_len " $test_cmds" len0=$func_len_result len=$len0 for obj in $save_oldobjs do func_len " $obj" func_arith $len + $func_len_result len=$func_arith_result func_append objlist " $obj" if test "$len" -lt "$max_cmd_len"; then : else # the above command should be used before it gets too long oldobjs=$objlist if test "$obj" = "$last_oldobj"; then RANLIB=$save_RANLIB fi test -z "$concat_cmds" || concat_cmds=$concat_cmds~ eval concat_cmds=\"\$concat_cmds$old_archive_cmds\" objlist= len=$len0 fi done RANLIB=$save_RANLIB oldobjs=$objlist if test -z "$oldobjs"; then eval cmds=\"\$concat_cmds\" else eval cmds=\"\$concat_cmds~\$old_archive_cmds\" fi fi fi func_execute_cmds "$cmds" 'exit $?' done test -n "$generated" && \ func_show_eval "${RM}r$generated" # Now create the libtool archive. case $output in *.la) old_library= test yes = "$build_old_libs" && old_library=$libname.$libext func_verbose "creating $output" # Preserve any variables that may affect compiler behavior for var in $variables_saved_for_relink; do if eval test -z \"\${$var+set}\"; then relink_command="{ test -z \"\${$var+set}\" || $lt_unset $var || { $var=; export $var; }; }; $relink_command" elif eval var_value=\$$var; test -z "$var_value"; then relink_command="$var=; export $var; $relink_command" else func_quote_arg pretty,unquoted "$var_value" relink_command="$var=$func_quote_arg_unquoted_result; export $var; $relink_command" fi done # Quote the link command for shipping. func_quote eval cd "`pwd`" relink_command="($func_quote_result; $SHELL \"$progpath\" $preserve_args --mode=relink $libtool_args @inst_prefix_dir@)" func_quote_arg pretty,unquoted "$relink_command" relink_command=$func_quote_arg_unquoted_result if test yes = "$hardcode_automatic"; then relink_command= fi # Only create the output if not a dry run. $opt_dry_run || { for installed in no yes; do if test yes = "$installed"; then if test -z "$install_libdir"; then break fi output=$output_objdir/${outputname}i # Replace all uninstalled libtool libraries with the installed ones newdependency_libs= for deplib in $dependency_libs; do case $deplib in *.la) func_basename "$deplib" name=$func_basename_result func_resolve_sysroot "$deplib" eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $func_resolve_sysroot_result` test -z "$libdir" && \ func_fatal_error "'$deplib' is not a valid libtool archive" func_append newdependency_libs " ${lt_sysroot:+=}$libdir/$name" ;; -L*) func_stripname -L '' "$deplib" func_replace_sysroot "$func_stripname_result" func_append newdependency_libs " -L$func_replace_sysroot_result" ;; -R*) func_stripname -R '' "$deplib" func_replace_sysroot "$func_stripname_result" func_append newdependency_libs " -R$func_replace_sysroot_result" ;; *) func_append newdependency_libs " $deplib" ;; esac done dependency_libs=$newdependency_libs newdlfiles= for lib in $dlfiles; do case $lib in *.la) func_basename "$lib" name=$func_basename_result eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib` test -z "$libdir" && \ func_fatal_error "'$lib' is not a valid libtool archive" func_append newdlfiles " ${lt_sysroot:+=}$libdir/$name" ;; *) func_append newdlfiles " $lib" ;; esac done dlfiles=$newdlfiles newdlprefiles= for lib in $dlprefiles; do case $lib in *.la) # Only pass preopened files to the pseudo-archive (for # eventual linking with the app. that links it) if we # didn't already link the preopened objects directly into # the library: func_basename "$lib" name=$func_basename_result eval libdir=`$SED -n -e 's/^libdir=\(.*\)$/\1/p' $lib` test -z "$libdir" && \ func_fatal_error "'$lib' is not a valid libtool archive" func_append newdlprefiles " ${lt_sysroot:+=}$libdir/$name" ;; esac done dlprefiles=$newdlprefiles else newdlfiles= for lib in $dlfiles; do case $lib in [\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;; *) abs=`pwd`"/$lib" ;; esac func_append newdlfiles " $abs" done dlfiles=$newdlfiles newdlprefiles= for lib in $dlprefiles; do case $lib in [\\/]* | [A-Za-z]:[\\/]*) abs=$lib ;; *) abs=`pwd`"/$lib" ;; esac func_append newdlprefiles " $abs" done dlprefiles=$newdlprefiles fi $RM $output # place dlname in correct position for cygwin # In fact, it would be nice if we could use this code for all target # systems that can't hard-code library paths into their executables # and that have no shared library path variable independent of PATH, # but it turns out we can't easily determine that from inspecting # libtool variables, so we have to hard-code the OSs to which it # applies here; at the moment, that means platforms that use the PE # object format with DLL files. See the long comment at the top of # tests/bindir.at for full details. tdlname=$dlname case $host,$output,$installed,$module,$dlname in *cygwin*,*lai,yes,no,*.dll | *mingw*,*lai,yes,no,*.dll | *cegcc*,*lai,yes,no,*.dll) # If a -bindir argument was supplied, place the dll there. if test -n "$bindir"; then func_relative_path "$install_libdir" "$bindir" tdlname=$func_relative_path_result/$dlname else # Otherwise fall back on heuristic. tdlname=../bin/$dlname fi ;; esac $ECHO > $output "\ # $outputname - a libtool library file # Generated by $PROGRAM (GNU $PACKAGE) $VERSION # # Please DO NOT delete this file! # It is necessary for linking the library. # The name that we can dlopen(3). dlname='$tdlname' # Names of this library. library_names='$library_names' # The name of the static archive. old_library='$old_library' # Linker flags that cannot go in dependency_libs. inherited_linker_flags='$new_inherited_linker_flags' # Libraries that this one depends upon. dependency_libs='$dependency_libs' # Names of additional weak libraries provided by this library weak_library_names='$weak_libs' # Version information for $libname. current=$current age=$age revision=$revision # Is this an already installed library? installed=$installed # Should we warn about portability when linking against -modules? shouldnotlink=$module # Files to dlopen/dlpreopen dlopen='$dlfiles' dlpreopen='$dlprefiles' # Directory that this library needs to be installed in: libdir='$install_libdir'" if test no,yes = "$installed,$need_relink"; then $ECHO >> $output "\ relink_command=\"$relink_command\"" fi done } # Do a symbolic link so that the libtool archive can be found in # LD_LIBRARY_PATH before the program is installed. func_show_eval '( cd "$output_objdir" && $RM "$outputname" && $LN_S "../$outputname" "$outputname" )' 'exit $?' ;; esac exit $EXIT_SUCCESS } if test link = "$opt_mode" || test relink = "$opt_mode"; then func_mode_link ${1+"$@"} fi # func_mode_uninstall arg... func_mode_uninstall () { $debug_cmd RM=$nonopt files= rmforce=false exit_status=0 # This variable tells wrapper scripts just to set variables rather # than running their programs. libtool_install_magic=$magic for arg do case $arg in -f) func_append RM " $arg"; rmforce=: ;; -*) func_append RM " $arg" ;; *) func_append files " $arg" ;; esac done test -z "$RM" && \ func_fatal_help "you must specify an RM program" rmdirs= for file in $files; do func_dirname "$file" "" "." dir=$func_dirname_result if test . = "$dir"; then odir=$objdir else odir=$dir/$objdir fi func_basename "$file" name=$func_basename_result test uninstall = "$opt_mode" && odir=$dir # Remember odir for removal later, being careful to avoid duplicates if test clean = "$opt_mode"; then case " $rmdirs " in *" $odir "*) ;; *) func_append rmdirs " $odir" ;; esac fi # Don't error if the file doesn't exist and rm -f was used. if { test -L "$file"; } >/dev/null 2>&1 || { test -h "$file"; } >/dev/null 2>&1 || test -f "$file"; then : elif test -d "$file"; then exit_status=1 continue elif $rmforce; then continue fi rmfiles=$file case $name in *.la) # Possibly a libtool archive, so verify it. if func_lalib_p "$file"; then func_source $dir/$name # Delete the libtool libraries and symlinks. for n in $library_names; do func_append rmfiles " $odir/$n" done test -n "$old_library" && func_append rmfiles " $odir/$old_library" case $opt_mode in clean) case " $library_names " in *" $dlname "*) ;; *) test -n "$dlname" && func_append rmfiles " $odir/$dlname" ;; esac test -n "$libdir" && func_append rmfiles " $odir/$name $odir/${name}i" ;; uninstall) if test -n "$library_names"; then # Do each command in the postuninstall commands. func_execute_cmds "$postuninstall_cmds" '$rmforce || exit_status=1' fi if test -n "$old_library"; then # Do each command in the old_postuninstall commands. func_execute_cmds "$old_postuninstall_cmds" '$rmforce || exit_status=1' fi # FIXME: should reinstall the best remaining shared library. ;; esac fi ;; *.lo) # Possibly a libtool object, so verify it. if func_lalib_p "$file"; then # Read the .lo file func_source $dir/$name # Add PIC object to the list of files to remove. if test -n "$pic_object" && test none != "$pic_object"; then func_append rmfiles " $dir/$pic_object" fi # Add non-PIC object to the list of files to remove. if test -n "$non_pic_object" && test none != "$non_pic_object"; then func_append rmfiles " $dir/$non_pic_object" fi fi ;; *) if test clean = "$opt_mode"; then noexename=$name case $file in *.exe) func_stripname '' '.exe' "$file" file=$func_stripname_result func_stripname '' '.exe' "$name" noexename=$func_stripname_result # $file with .exe has already been added to rmfiles, # add $file without .exe func_append rmfiles " $file" ;; esac # Do a test to see if this is a libtool program. if func_ltwrapper_p "$file"; then if func_ltwrapper_executable_p "$file"; then func_ltwrapper_scriptname "$file" relink_command= func_source $func_ltwrapper_scriptname_result func_append rmfiles " $func_ltwrapper_scriptname_result" else relink_command= func_source $dir/$noexename fi # note $name still contains .exe if it was in $file originally # as does the version of $file that was added into $rmfiles func_append rmfiles " $odir/$name $odir/${name}S.$objext" if test yes = "$fast_install" && test -n "$relink_command"; then func_append rmfiles " $odir/lt-$name" fi if test "X$noexename" != "X$name"; then func_append rmfiles " $odir/lt-$noexename.c" fi fi fi ;; esac func_show_eval "$RM $rmfiles" 'exit_status=1' done # Try to remove the $objdir's in the directories where we deleted files for dir in $rmdirs; do if test -d "$dir"; then func_show_eval "rmdir $dir >/dev/null 2>&1" fi done exit $exit_status } if test uninstall = "$opt_mode" || test clean = "$opt_mode"; then func_mode_uninstall ${1+"$@"} fi test -z "$opt_mode" && { help=$generic_help func_fatal_help "you must specify a MODE" } test -z "$exec_cmd" && \ func_fatal_help "invalid operation mode '$opt_mode'" if test -n "$exec_cmd"; then eval exec "$exec_cmd" exit $EXIT_FAILURE fi exit $exit_status # The TAGs below are defined such that we never get into a situation # where we disable both kinds of libraries. Given conflicting # choices, we go for a static library, that is the most portable, # since we can't tell whether shared libraries were disabled because # the user asked for that or because the platform doesn't support # them. This is particularly important on AIX, because we don't # support having both static and shared libraries enabled at the same # time on that platform, so we default to a shared-only configuration. # If a disable-shared tag is given, we'll fallback to a static-only # configuration. But we'll never go from static-only to shared-only. # ### BEGIN LIBTOOL TAG CONFIG: disable-shared build_libtool_libs=no build_old_libs=yes # ### END LIBTOOL TAG CONFIG: disable-shared # ### BEGIN LIBTOOL TAG CONFIG: disable-static build_old_libs=`case $build_libtool_libs in yes) echo no;; *) echo yes;; esac` # ### END LIBTOOL TAG CONFIG: disable-static # Local Variables: # mode:shell-script # sh-indentation:2 # End: libcaes-20240413/po/0000755000175000017500000000000014606477654014654 5ustar00lordyestalordyestalibcaes-20240413/po/remove-potcdate.sin0000644000175000017500000000132014533041422020434 0ustar00lordyestalordyesta# Sed script that removes the POT-Creation-Date line in the header entry # from a POT file. # # Copyright (C) 2002 Free Software Foundation, Inc. # Copying and distribution of this file, with or without modification, # are permitted in any medium without royalty provided the copyright # notice and this notice are preserved. This file is offered as-is, # without any warranty. # # The distinction between the first and the following occurrences of the # pattern is achieved by looking at the hold space. /^"POT-Creation-Date: .*"$/{ x # Test if the hold space is empty. s/P/P/ ta # Yes it was empty. First occurrence. Remove the line. g d bb :a # The hold space was nonempty. Following occurrences. Do nothing. x :b } libcaes-20240413/po/POTFILES.in0000644000175000017500000000007314533041422016404 0ustar00lordyestalordyesta# List of source files which contain translatable strings. libcaes-20240413/po/Makefile.in.in0000644000175000017500000004616314533041422017313 0ustar00lordyestalordyesta# Makefile for PO directory in any package using GNU gettext. # Copyright (C) 1995-2000 Ulrich Drepper # Copyright (C) 2000-2020 Free Software Foundation, Inc. # # Copying and distribution of this file, with or without modification, # are permitted in any medium without royalty provided the copyright # notice and this notice are preserved. This file is offered as-is, # without any warranty. # # Origin: gettext-0.21 GETTEXT_MACRO_VERSION = 0.20 PACKAGE = @PACKAGE@ VERSION = @VERSION@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ SED = @SED@ SHELL = /bin/sh @SET_MAKE@ srcdir = @srcdir@ top_srcdir = @top_srcdir@ VPATH = @srcdir@ prefix = @prefix@ exec_prefix = @exec_prefix@ datarootdir = @datarootdir@ datadir = @datadir@ localedir = @localedir@ gettextsrcdir = $(datadir)/gettext/po INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ # We use $(mkdir_p). # In automake <= 1.9.x, $(mkdir_p) is defined either as "mkdir -p --" or as # "$(mkinstalldirs)" or as "$(install_sh) -d". For these automake versions, # @install_sh@ does not start with $(SHELL), so we add it. # In automake >= 1.10, @mkdir_p@ is derived from ${MKDIR_P}, which is defined # either as "/path/to/mkdir -p" or ".../install-sh -c -d". For these automake # versions, $(mkinstalldirs) and $(install_sh) are unused. mkinstalldirs = $(SHELL) @install_sh@ -d install_sh = $(SHELL) @install_sh@ MKDIR_P = @MKDIR_P@ mkdir_p = @mkdir_p@ # When building gettext-tools, we prefer to use the built programs # rather than installed programs. However, we can't do that when we # are cross compiling. CROSS_COMPILING = @CROSS_COMPILING@ GMSGFMT_ = @GMSGFMT@ GMSGFMT_no = @GMSGFMT@ GMSGFMT_yes = @GMSGFMT_015@ GMSGFMT = $(GMSGFMT_$(USE_MSGCTXT)) XGETTEXT_ = @XGETTEXT@ XGETTEXT_no = @XGETTEXT@ XGETTEXT_yes = @XGETTEXT_015@ XGETTEXT = $(XGETTEXT_$(USE_MSGCTXT)) MSGMERGE = @MSGMERGE@ MSGMERGE_UPDATE = @MSGMERGE@ --update MSGMERGE_FOR_MSGFMT_OPTION = @MSGMERGE_FOR_MSGFMT_OPTION@ MSGINIT = msginit MSGCONV = msgconv MSGFILTER = msgfilter POFILES = @POFILES@ GMOFILES = @GMOFILES@ UPDATEPOFILES = @UPDATEPOFILES@ DUMMYPOFILES = @DUMMYPOFILES@ DISTFILES.common = Makefile.in.in remove-potcdate.sin \ $(DISTFILES.common.extra1) $(DISTFILES.common.extra2) $(DISTFILES.common.extra3) DISTFILES = $(DISTFILES.common) Makevars POTFILES.in \ $(POFILES) $(GMOFILES) \ $(DISTFILES.extra1) $(DISTFILES.extra2) $(DISTFILES.extra3) POTFILES = \ CATALOGS = @CATALOGS@ POFILESDEPS_ = $(srcdir)/$(DOMAIN).pot POFILESDEPS_yes = $(POFILESDEPS_) POFILESDEPS_no = POFILESDEPS = $(POFILESDEPS_$(PO_DEPENDS_ON_POT)) DISTFILESDEPS_ = update-po DISTFILESDEPS_yes = $(DISTFILESDEPS_) DISTFILESDEPS_no = DISTFILESDEPS = $(DISTFILESDEPS_$(DIST_DEPENDS_ON_UPDATE_PO)) # Makevars gets inserted here. (Don't remove this line!) all: all-@USE_NLS@ .SUFFIXES: .SUFFIXES: .po .gmo .sed .sin .nop .po-create .po-update # The .pot file, stamp-po, .po files, and .gmo files appear in release tarballs. # The GNU Coding Standards say in # : # "GNU distributions usually contain some files which are not source files # ... . Since these files normally appear in the source directory, they # should always appear in the source directory, not in the build directory. # So Makefile rules to update them should put the updated files in the # source directory." # Therefore we put these files in the source directory, not the build directory. # During .po -> .gmo conversion, take into account the most recent changes to # the .pot file. This eliminates the need to update the .po files when the # .pot file has changed, which would be troublesome if the .po files are put # under version control. $(GMOFILES): $(srcdir)/$(DOMAIN).pot .po.gmo: @lang=`echo $* | sed -e 's,.*/,,'`; \ test "$(srcdir)" = . && cdcmd="" || cdcmd="cd $(srcdir) && "; \ echo "$${cdcmd}rm -f $${lang}.gmo && $(MSGMERGE) $(MSGMERGE_FOR_MSGFMT_OPTION) -o $${lang}.1po $${lang}.po $(DOMAIN).pot && $(GMSGFMT) -c --statistics --verbose -o $${lang}.gmo $${lang}.1po && rm -f $${lang}.1po"; \ cd $(srcdir) && \ rm -f $${lang}.gmo && \ $(MSGMERGE) $(MSGMERGE_FOR_MSGFMT_OPTION) -o $${lang}.1po $${lang}.po $(DOMAIN).pot && \ $(GMSGFMT) -c --statistics --verbose -o t-$${lang}.gmo $${lang}.1po && \ mv t-$${lang}.gmo $${lang}.gmo && \ rm -f $${lang}.1po .sin.sed: sed -e '/^#/d' $< > t-$@ mv t-$@ $@ all-yes: $(srcdir)/stamp-po all-no: # Ensure that the gettext macros and this Makefile.in.in are in sync. CHECK_MACRO_VERSION = \ test "$(GETTEXT_MACRO_VERSION)" = "@GETTEXT_MACRO_VERSION@" \ || { echo "*** error: gettext infrastructure mismatch: using a Makefile.in.in from gettext version $(GETTEXT_MACRO_VERSION) but the autoconf macros are from gettext version @GETTEXT_MACRO_VERSION@" 1>&2; \ exit 1; \ } # $(srcdir)/$(DOMAIN).pot is only created when needed. When xgettext finds no # internationalized messages, no $(srcdir)/$(DOMAIN).pot is created (because # we don't want to bother translators with empty POT files). We assume that # LINGUAS is empty in this case, i.e. $(POFILES) and $(GMOFILES) are empty. # In this case, $(srcdir)/stamp-po is a nop (i.e. a phony target). # $(srcdir)/stamp-po is a timestamp denoting the last time at which the CATALOGS # have been loosely updated. Its purpose is that when a developer or translator # checks out the package from a version control system, and the $(DOMAIN).pot # file is not under version control, "make" will update the $(DOMAIN).pot and # the $(CATALOGS), but subsequent invocations of "make" will do nothing. This # timestamp would not be necessary if updating the $(CATALOGS) would always # touch them; however, the rule for $(POFILES) has been designed to not touch # files that don't need to be changed. $(srcdir)/stamp-po: $(srcdir)/$(DOMAIN).pot @$(CHECK_MACRO_VERSION) test ! -f $(srcdir)/$(DOMAIN).pot || \ test -z "$(GMOFILES)" || $(MAKE) $(GMOFILES) @test ! -f $(srcdir)/$(DOMAIN).pot || { \ echo "touch $(srcdir)/stamp-po" && \ echo timestamp > $(srcdir)/stamp-poT && \ mv $(srcdir)/stamp-poT $(srcdir)/stamp-po; \ } # Note: Target 'all' must not depend on target '$(DOMAIN).pot-update', # otherwise packages like GCC can not be built if only parts of the source # have been downloaded. # This target rebuilds $(DOMAIN).pot; it is an expensive operation. # Note that $(DOMAIN).pot is not touched if it doesn't need to be changed. # The determination of whether the package xyz is a GNU one is based on the # heuristic whether some file in the top level directory mentions "GNU xyz". # If GNU 'find' is available, we avoid grepping through monster files. $(DOMAIN).pot-update: $(POTFILES) $(srcdir)/POTFILES.in remove-potcdate.sed package_gnu="$(PACKAGE_GNU)"; \ test -n "$$package_gnu" || { \ if { if (LC_ALL=C find --version) 2>/dev/null | grep GNU >/dev/null; then \ LC_ALL=C find -L $(top_srcdir) -maxdepth 1 -type f -size -10000000c -exec grep -i 'GNU @PACKAGE@' /dev/null '{}' ';' 2>/dev/null; \ else \ LC_ALL=C grep -i 'GNU @PACKAGE@' $(top_srcdir)/* 2>/dev/null; \ fi; \ } | grep -v 'libtool:' >/dev/null; then \ package_gnu=yes; \ else \ package_gnu=no; \ fi; \ }; \ if test "$$package_gnu" = "yes"; then \ package_prefix='GNU '; \ else \ package_prefix=''; \ fi; \ if test -n '$(MSGID_BUGS_ADDRESS)' || test '$(PACKAGE_BUGREPORT)' = '@'PACKAGE_BUGREPORT'@'; then \ msgid_bugs_address='$(MSGID_BUGS_ADDRESS)'; \ else \ msgid_bugs_address='$(PACKAGE_BUGREPORT)'; \ fi; \ case `$(XGETTEXT) --version | sed 1q | sed -e 's,^[^0-9]*,,'` in \ '' | 0.[0-9] | 0.[0-9].* | 0.1[0-5] | 0.1[0-5].* | 0.16 | 0.16.[0-1]*) \ $(XGETTEXT) --default-domain=$(DOMAIN) --directory=$(top_srcdir) \ --add-comments=TRANSLATORS: \ --files-from=$(srcdir)/POTFILES.in \ --copyright-holder='$(COPYRIGHT_HOLDER)' \ --msgid-bugs-address="$$msgid_bugs_address" \ $(XGETTEXT_OPTIONS) @XGETTEXT_EXTRA_OPTIONS@ \ ;; \ *) \ $(XGETTEXT) --default-domain=$(DOMAIN) --directory=$(top_srcdir) \ --add-comments=TRANSLATORS: \ --files-from=$(srcdir)/POTFILES.in \ --copyright-holder='$(COPYRIGHT_HOLDER)' \ --package-name="$${package_prefix}@PACKAGE@" \ --package-version='@VERSION@' \ --msgid-bugs-address="$$msgid_bugs_address" \ $(XGETTEXT_OPTIONS) @XGETTEXT_EXTRA_OPTIONS@ \ ;; \ esac test ! -f $(DOMAIN).po || { \ if test -f $(srcdir)/$(DOMAIN).pot-header; then \ sed -e '1,/^#$$/d' < $(DOMAIN).po > $(DOMAIN).1po && \ cat $(srcdir)/$(DOMAIN).pot-header $(DOMAIN).1po > $(DOMAIN).po && \ rm -f $(DOMAIN).1po \ || exit 1; \ fi; \ if test -f $(srcdir)/$(DOMAIN).pot; then \ sed -f remove-potcdate.sed < $(srcdir)/$(DOMAIN).pot > $(DOMAIN).1po && \ sed -f remove-potcdate.sed < $(DOMAIN).po > $(DOMAIN).2po && \ if cmp $(DOMAIN).1po $(DOMAIN).2po >/dev/null 2>&1; then \ rm -f $(DOMAIN).1po $(DOMAIN).2po $(DOMAIN).po; \ else \ rm -f $(DOMAIN).1po $(DOMAIN).2po $(srcdir)/$(DOMAIN).pot && \ mv $(DOMAIN).po $(srcdir)/$(DOMAIN).pot; \ fi; \ else \ mv $(DOMAIN).po $(srcdir)/$(DOMAIN).pot; \ fi; \ } # This rule has no dependencies: we don't need to update $(DOMAIN).pot at # every "make" invocation, only create it when it is missing. # Only "make $(DOMAIN).pot-update" or "make dist" will force an update. $(srcdir)/$(DOMAIN).pot: $(MAKE) $(DOMAIN).pot-update # This target rebuilds a PO file if $(DOMAIN).pot has changed. # Note that a PO file is not touched if it doesn't need to be changed. $(POFILES): $(POFILESDEPS) @test -f $(srcdir)/$(DOMAIN).pot || $(MAKE) $(srcdir)/$(DOMAIN).pot @lang=`echo $@ | sed -e 's,.*/,,' -e 's/\.po$$//'`; \ if test -f "$(srcdir)/$${lang}.po"; then \ test "$(srcdir)" = . && cdcmd="" || cdcmd="cd $(srcdir) && "; \ echo "$${cdcmd}$(MSGMERGE_UPDATE) $(MSGMERGE_OPTIONS) --lang=$${lang} --previous $${lang}.po $(DOMAIN).pot"; \ cd $(srcdir) \ && { case `$(MSGMERGE_UPDATE) --version | sed 1q | sed -e 's,^[^0-9]*,,'` in \ '' | 0.[0-9] | 0.[0-9].* | 0.1[0-5] | 0.1[0-5].*) \ $(MSGMERGE_UPDATE) $(MSGMERGE_OPTIONS) $${lang}.po $(DOMAIN).pot;; \ 0.1[6-7] | 0.1[6-7].*) \ $(MSGMERGE_UPDATE) $(MSGMERGE_OPTIONS) --previous $${lang}.po $(DOMAIN).pot;; \ *) \ $(MSGMERGE_UPDATE) $(MSGMERGE_OPTIONS) --lang=$${lang} --previous $${lang}.po $(DOMAIN).pot;; \ esac; \ }; \ else \ $(MAKE) $${lang}.po-create; \ fi install: install-exec install-data install-exec: install-data: install-data-@USE_NLS@ if test "$(PACKAGE)" = "gettext-tools"; then \ $(mkdir_p) $(DESTDIR)$(gettextsrcdir); \ for file in $(DISTFILES.common) Makevars.template; do \ $(INSTALL_DATA) $(srcdir)/$$file \ $(DESTDIR)$(gettextsrcdir)/$$file; \ done; \ for file in Makevars; do \ rm -f $(DESTDIR)$(gettextsrcdir)/$$file; \ done; \ else \ : ; \ fi install-data-no: all install-data-yes: all @catalogs='$(CATALOGS)'; \ for cat in $$catalogs; do \ cat=`basename $$cat`; \ lang=`echo $$cat | sed -e 's/\.gmo$$//'`; \ dir=$(localedir)/$$lang/LC_MESSAGES; \ $(mkdir_p) $(DESTDIR)$$dir; \ if test -r $$cat; then realcat=$$cat; else realcat=$(srcdir)/$$cat; fi; \ $(INSTALL_DATA) $$realcat $(DESTDIR)$$dir/$(DOMAIN).mo; \ echo "installing $$realcat as $(DESTDIR)$$dir/$(DOMAIN).mo"; \ for lc in '' $(EXTRA_LOCALE_CATEGORIES); do \ if test -n "$$lc"; then \ if (cd $(DESTDIR)$(localedir)/$$lang && LC_ALL=C ls -l -d $$lc 2>/dev/null) | grep ' -> ' >/dev/null; then \ link=`cd $(DESTDIR)$(localedir)/$$lang && LC_ALL=C ls -l -d $$lc | sed -e 's/^.* -> //'`; \ mv $(DESTDIR)$(localedir)/$$lang/$$lc $(DESTDIR)$(localedir)/$$lang/$$lc.old; \ mkdir $(DESTDIR)$(localedir)/$$lang/$$lc; \ (cd $(DESTDIR)$(localedir)/$$lang/$$lc.old && \ for file in *; do \ if test -f $$file; then \ ln -s ../$$link/$$file $(DESTDIR)$(localedir)/$$lang/$$lc/$$file; \ fi; \ done); \ rm -f $(DESTDIR)$(localedir)/$$lang/$$lc.old; \ else \ if test -d $(DESTDIR)$(localedir)/$$lang/$$lc; then \ :; \ else \ rm -f $(DESTDIR)$(localedir)/$$lang/$$lc; \ mkdir $(DESTDIR)$(localedir)/$$lang/$$lc; \ fi; \ fi; \ rm -f $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo; \ ln -s ../LC_MESSAGES/$(DOMAIN).mo $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo 2>/dev/null || \ ln $(DESTDIR)$(localedir)/$$lang/LC_MESSAGES/$(DOMAIN).mo $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo 2>/dev/null || \ cp -p $(DESTDIR)$(localedir)/$$lang/LC_MESSAGES/$(DOMAIN).mo $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo; \ echo "installing $$realcat link as $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo"; \ fi; \ done; \ done install-strip: install installdirs: installdirs-exec installdirs-data installdirs-exec: installdirs-data: installdirs-data-@USE_NLS@ if test "$(PACKAGE)" = "gettext-tools"; then \ $(mkdir_p) $(DESTDIR)$(gettextsrcdir); \ else \ : ; \ fi installdirs-data-no: installdirs-data-yes: @catalogs='$(CATALOGS)'; \ for cat in $$catalogs; do \ cat=`basename $$cat`; \ lang=`echo $$cat | sed -e 's/\.gmo$$//'`; \ dir=$(localedir)/$$lang/LC_MESSAGES; \ $(mkdir_p) $(DESTDIR)$$dir; \ for lc in '' $(EXTRA_LOCALE_CATEGORIES); do \ if test -n "$$lc"; then \ if (cd $(DESTDIR)$(localedir)/$$lang && LC_ALL=C ls -l -d $$lc 2>/dev/null) | grep ' -> ' >/dev/null; then \ link=`cd $(DESTDIR)$(localedir)/$$lang && LC_ALL=C ls -l -d $$lc | sed -e 's/^.* -> //'`; \ mv $(DESTDIR)$(localedir)/$$lang/$$lc $(DESTDIR)$(localedir)/$$lang/$$lc.old; \ mkdir $(DESTDIR)$(localedir)/$$lang/$$lc; \ (cd $(DESTDIR)$(localedir)/$$lang/$$lc.old && \ for file in *; do \ if test -f $$file; then \ ln -s ../$$link/$$file $(DESTDIR)$(localedir)/$$lang/$$lc/$$file; \ fi; \ done); \ rm -f $(DESTDIR)$(localedir)/$$lang/$$lc.old; \ else \ if test -d $(DESTDIR)$(localedir)/$$lang/$$lc; then \ :; \ else \ rm -f $(DESTDIR)$(localedir)/$$lang/$$lc; \ mkdir $(DESTDIR)$(localedir)/$$lang/$$lc; \ fi; \ fi; \ fi; \ done; \ done # Define this as empty until I found a useful application. installcheck: uninstall: uninstall-exec uninstall-data uninstall-exec: uninstall-data: uninstall-data-@USE_NLS@ if test "$(PACKAGE)" = "gettext-tools"; then \ for file in $(DISTFILES.common) Makevars.template; do \ rm -f $(DESTDIR)$(gettextsrcdir)/$$file; \ done; \ else \ : ; \ fi uninstall-data-no: uninstall-data-yes: catalogs='$(CATALOGS)'; \ for cat in $$catalogs; do \ cat=`basename $$cat`; \ lang=`echo $$cat | sed -e 's/\.gmo$$//'`; \ for lc in LC_MESSAGES $(EXTRA_LOCALE_CATEGORIES); do \ rm -f $(DESTDIR)$(localedir)/$$lang/$$lc/$(DOMAIN).mo; \ done; \ done check: all info dvi ps pdf html tags TAGS ctags CTAGS ID: install-dvi install-ps install-pdf install-html: mostlyclean: rm -f remove-potcdate.sed rm -f $(srcdir)/stamp-poT rm -f core core.* $(DOMAIN).po $(DOMAIN).1po $(DOMAIN).2po *.new.po rm -fr *.o clean: mostlyclean distclean: clean rm -f Makefile Makefile.in POTFILES maintainer-clean: distclean @echo "This command is intended for maintainers to use;" @echo "it deletes files that may require special tools to rebuild." rm -f $(srcdir)/$(DOMAIN).pot $(srcdir)/stamp-po $(GMOFILES) distdir = $(top_builddir)/$(PACKAGE)-$(VERSION)/$(subdir) dist distdir: test -z "$(DISTFILESDEPS)" || $(MAKE) $(DISTFILESDEPS) @$(MAKE) dist2 # This is a separate target because 'update-po' must be executed before. dist2: $(srcdir)/stamp-po $(DISTFILES) @dists="$(DISTFILES)"; \ if test "$(PACKAGE)" = "gettext-tools"; then \ dists="$$dists Makevars.template"; \ fi; \ if test -f $(srcdir)/$(DOMAIN).pot; then \ dists="$$dists $(DOMAIN).pot stamp-po"; \ else \ case $(XGETTEXT) in \ :) echo "Warning: Creating a tarball without '$(DOMAIN).pot', because a suitable 'xgettext' program was not found in PATH." 1>&2;; \ *) echo "Warning: Creating a tarball without '$(DOMAIN).pot', because 'xgettext' found no strings to extract. Check the contents of the POTFILES.in file and the XGETTEXT_OPTIONS in the Makevars file." 1>&2;; \ esac; \ fi; \ if test -f $(srcdir)/ChangeLog; then \ dists="$$dists ChangeLog"; \ fi; \ for i in 0 1 2 3 4 5 6 7 8 9; do \ if test -f $(srcdir)/ChangeLog.$$i; then \ dists="$$dists ChangeLog.$$i"; \ fi; \ done; \ if test -f $(srcdir)/LINGUAS; then dists="$$dists LINGUAS"; fi; \ for file in $$dists; do \ if test -f $$file; then \ cp -p $$file $(distdir) || exit 1; \ else \ cp -p $(srcdir)/$$file $(distdir) || exit 1; \ fi; \ done update-po: Makefile $(MAKE) $(DOMAIN).pot-update test -z "$(UPDATEPOFILES)" || $(MAKE) $(UPDATEPOFILES) $(MAKE) update-gmo # General rule for creating PO files. .nop.po-create: @lang=`echo $@ | sed -e 's/\.po-create$$//'`; \ echo "File $$lang.po does not exist. If you are a translator, you can create it through 'msginit'." 1>&2; \ exit 1 # General rule for updating PO files. .nop.po-update: @lang=`echo $@ | sed -e 's/\.po-update$$//'`; \ if test "$(PACKAGE)" = "gettext-tools" && test "$(CROSS_COMPILING)" != "yes"; then PATH=`pwd`/../src:$$PATH; fi; \ tmpdir=`pwd`; \ echo "$$lang:"; \ test "$(srcdir)" = . && cdcmd="" || cdcmd="cd $(srcdir) && "; \ echo "$${cdcmd}$(MSGMERGE) $(MSGMERGE_OPTIONS) --lang=$$lang --previous $$lang.po $(DOMAIN).pot -o $$lang.new.po"; \ cd $(srcdir); \ if { case `$(MSGMERGE) --version | sed 1q | sed -e 's,^[^0-9]*,,'` in \ '' | 0.[0-9] | 0.[0-9].* | 0.1[0-5] | 0.1[0-5].*) \ $(MSGMERGE) $(MSGMERGE_OPTIONS) -o $$tmpdir/$$lang.new.po $$lang.po $(DOMAIN).pot;; \ 0.1[6-7] | 0.1[6-7].*) \ $(MSGMERGE) $(MSGMERGE_OPTIONS) --previous -o $$tmpdir/$$lang.new.po $$lang.po $(DOMAIN).pot;; \ *) \ $(MSGMERGE) $(MSGMERGE_OPTIONS) --lang=$$lang --previous -o $$tmpdir/$$lang.new.po $$lang.po $(DOMAIN).pot;; \ esac; \ }; then \ if cmp $$lang.po $$tmpdir/$$lang.new.po >/dev/null 2>&1; then \ rm -f $$tmpdir/$$lang.new.po; \ else \ if mv -f $$tmpdir/$$lang.new.po $$lang.po; then \ :; \ else \ echo "msgmerge for $$lang.po failed: cannot move $$tmpdir/$$lang.new.po to $$lang.po" 1>&2; \ exit 1; \ fi; \ fi; \ else \ echo "msgmerge for $$lang.po failed!" 1>&2; \ rm -f $$tmpdir/$$lang.new.po; \ fi $(DUMMYPOFILES): update-gmo: Makefile $(GMOFILES) @: # Recreate Makefile by invoking config.status. Explicitly invoke the shell, # because execution permission bits may not work on the current file system. # Use @SHELL@, which is the shell determined by autoconf for the use by its # scripts, not $(SHELL) which is hardwired to /bin/sh and may be deficient. Makefile: Makefile.in.in Makevars $(top_builddir)/config.status @POMAKEFILEDEPS@ cd $(top_builddir) \ && @SHELL@ ./config.status $(subdir)/$@.in po-directories force: # Tell versions [3.59,3.63) of GNU make not to export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: libcaes-20240413/po/quot.sed0000644000175000017500000000023114533041422016310 0ustar00lordyestalordyestas/"\([^"]*\)"/“\1”/g s/`\([^`']*\)'/‘\1’/g s/ '\([^`']*\)' / ‘\1’ /g s/ '\([^`']*\)'$/ ‘\1’/g s/^'\([^`']*\)' /‘\1’ /g s/“”/""/g libcaes-20240413/po/en@quot.header0000644000175000017500000000226414533041422017420 0ustar00lordyestalordyesta# All this catalog "translates" are quotation characters. # The msgids must be ASCII and therefore cannot contain real quotation # characters, only substitutes like grave accent (0x60), apostrophe (0x27) # and double quote (0x22). These substitutes look strange; see # https://www.cl.cam.ac.uk/~mgk25/ucs/quotes.html # # This catalog translates grave accent (0x60) and apostrophe (0x27) to # left single quotation mark (U+2018) and right single quotation mark (U+2019). # It also translates pairs of apostrophe (0x27) to # left single quotation mark (U+2018) and right single quotation mark (U+2019) # and pairs of quotation mark (0x22) to # left double quotation mark (U+201C) and right double quotation mark (U+201D). # # When output to an UTF-8 terminal, the quotation characters appear perfectly. # When output to an ISO-8859-1 terminal, the single quotation marks are # transliterated to apostrophes (by iconv in glibc 2.2 or newer) or to # grave/acute accent (by libiconv), and the double quotation marks are # transliterated to 0x22. # When output to an ASCII terminal, the single quotation marks are # transliterated to apostrophes, and the double quotation marks are # transliterated to 0x22. # libcaes-20240413/po/en@boldquot.header0000644000175000017500000000247214533041422020262 0ustar00lordyestalordyesta# All this catalog "translates" are quotation characters. # The msgids must be ASCII and therefore cannot contain real quotation # characters, only substitutes like grave accent (0x60), apostrophe (0x27) # and double quote (0x22). These substitutes look strange; see # https://www.cl.cam.ac.uk/~mgk25/ucs/quotes.html # # This catalog translates grave accent (0x60) and apostrophe (0x27) to # left single quotation mark (U+2018) and right single quotation mark (U+2019). # It also translates pairs of apostrophe (0x27) to # left single quotation mark (U+2018) and right single quotation mark (U+2019) # and pairs of quotation mark (0x22) to # left double quotation mark (U+201C) and right double quotation mark (U+201D). # # When output to an UTF-8 terminal, the quotation characters appear perfectly. # When output to an ISO-8859-1 terminal, the single quotation marks are # transliterated to apostrophes (by iconv in glibc 2.2 or newer) or to # grave/acute accent (by libiconv), and the double quotation marks are # transliterated to 0x22. # When output to an ASCII terminal, the single quotation marks are # transliterated to apostrophes, and the double quotation marks are # transliterated to 0x22. # # This catalog furthermore displays the text between the quotation marks in # bold face, assuming the VT100/XTerm escape sequences. # libcaes-20240413/po/boldquot.sed0000644000175000017500000000033114533041422017152 0ustar00lordyestalordyestas/"\([^"]*\)"/“\1”/g s/`\([^`']*\)'/‘\1’/g s/ '\([^`']*\)' / ‘\1’ /g s/ '\([^`']*\)'$/ ‘\1’/g s/^'\([^`']*\)' /‘\1’ /g s/“”/""/g s/“/“/g s/”/”/g s/‘/‘/g s/’/’/g libcaes-20240413/po/insert-header.sin0000644000175000017500000000161214533041422020074 0ustar00lordyestalordyesta# Sed script that inserts the file called HEADER before the header entry. # # Copyright (C) 2001 Free Software Foundation, Inc. # Written by Bruno Haible , 2001. # This file is free software; the Free Software Foundation gives # unlimited permission to use, copy, distribute, and modify it. # # At each occurrence of a line starting with "msgid ", we execute the following # commands. At the first occurrence, insert the file. At the following # occurrences, do nothing. The distinction between the first and the following # occurrences is achieved by looking at the hold space. /^msgid /{ x # Test if the hold space is empty. s/m/m/ ta # Yes it was empty. First occurrence. Read the file. r HEADER # Output the file's contents by reading the next line. But don't lose the # current line while doing this. g N bb :a # The hold space was nonempty. Following occurrences. Do nothing. x :b } libcaes-20240413/po/ChangeLog0000644000175000017500000000006214533041422016377 0ustar00lordyestalordyesta2016-11-06 gettextize libcaes-20240413/po/Makevars0000644000175000017500000000347514606477645016361 0ustar00lordyestalordyesta# Makefile variables for PO directory in any package using GNU gettext. # Usually the message domain is the same as the package name. DOMAIN = libcaes # These two variables depend on the location of this directory. subdir = po top_builddir = .. # These options get passed to xgettext. XGETTEXT_OPTIONS = --keyword=_ --keyword=N_ # This is the copyright holder that gets inserted into the header of the # $(DOMAIN).pot file. Set this to the copyright holder of the surrounding # package. (Note that the msgstr strings, extracted from the package's # sources, belong to the copyright holder of the package.) Translators are # expected to transfer the copyright for their translations to this person # or entity, or to disclaim their copyright. The empty string stands for # the public domain; in this case the translators are expected to disclaim # their copyright. COPYRIGHT_HOLDER = Joachim Metz # This is the email address or URL to which the translators shall report # bugs in the untranslated strings: # - Strings which are not entire sentences, see the maintainer guidelines # in the GNU gettext documentation, section 'Preparing Strings'. # - Strings which use unclear terms or require additional context to be # understood. # - Strings which make invalid assumptions about notation of date, time or # money. # - Pluralisation problems. # - Incorrect English spelling. # - Incorrect formatting. # It can be your email address, or a mailing list address where translators # can write to without being subscribed, or the URL of a web page through # which the translators can contact you. MSGID_BUGS_ADDRESS = joachim.metz@gmail.com # This is the list of locale categories, beyond LC_MESSAGES, for which the # message catalogs shall be used. It is usually empty. EXTRA_LOCALE_CATEGORIES = # Additional make targets. sources splint: libcaes-20240413/po/Makevars.in0000644000175000017500000000347414533041422016740 0ustar00lordyestalordyesta# Makefile variables for PO directory in any package using GNU gettext. # Usually the message domain is the same as the package name. DOMAIN = @PACKAGE@ # These two variables depend on the location of this directory. subdir = po top_builddir = .. # These options get passed to xgettext. XGETTEXT_OPTIONS = --keyword=_ --keyword=N_ # This is the copyright holder that gets inserted into the header of the # $(DOMAIN).pot file. Set this to the copyright holder of the surrounding # package. (Note that the msgstr strings, extracted from the package's # sources, belong to the copyright holder of the package.) Translators are # expected to transfer the copyright for their translations to this person # or entity, or to disclaim their copyright. The empty string stands for # the public domain; in this case the translators are expected to disclaim # their copyright. COPYRIGHT_HOLDER = Joachim Metz # This is the email address or URL to which the translators shall report # bugs in the untranslated strings: # - Strings which are not entire sentences, see the maintainer guidelines # in the GNU gettext documentation, section 'Preparing Strings'. # - Strings which use unclear terms or require additional context to be # understood. # - Strings which make invalid assumptions about notation of date, time or # money. # - Pluralisation problems. # - Incorrect English spelling. # - Incorrect formatting. # It can be your email address, or a mailing list address where translators # can write to without being subscribed, or the URL of a web page through # which the translators can contact you. MSGID_BUGS_ADDRESS = @PACKAGE_BUGREPORT@ # This is the list of locale categories, beyond LC_MESSAGES, for which the # message catalogs shall be used. It is usually empty. EXTRA_LOCALE_CATEGORIES = # Additional make targets. sources splint: libcaes-20240413/po/Rules-quot0000644000175000017500000000453314533041422016637 0ustar00lordyestalordyesta# Special Makefile rules for English message catalogs with quotation marks. # # Copyright (C) 2001-2017 Free Software Foundation, Inc. # This file, Rules-quot, and its auxiliary files (listed under # DISTFILES.common.extra1) are free software; the Free Software Foundation # gives unlimited permission to use, copy, distribute, and modify them. DISTFILES.common.extra1 = quot.sed boldquot.sed en@quot.header en@boldquot.header insert-header.sin Rules-quot .SUFFIXES: .insert-header .po-update-en en@quot.po-create: $(MAKE) en@quot.po-update en@boldquot.po-create: $(MAKE) en@boldquot.po-update en@quot.po-update: en@quot.po-update-en en@boldquot.po-update: en@boldquot.po-update-en .insert-header.po-update-en: @lang=`echo $@ | sed -e 's/\.po-update-en$$//'`; \ if test "$(PACKAGE)" = "gettext-tools" && test "$(CROSS_COMPILING)" != "yes"; then PATH=`pwd`/../src:$$PATH; GETTEXTLIBDIR=`cd $(top_srcdir)/src && pwd`; export GETTEXTLIBDIR; fi; \ tmpdir=`pwd`; \ echo "$$lang:"; \ ll=`echo $$lang | sed -e 's/@.*//'`; \ LC_ALL=C; export LC_ALL; \ cd $(srcdir); \ if $(MSGINIT) $(MSGINIT_OPTIONS) -i $(DOMAIN).pot --no-translator -l $$lang -o - 2>/dev/null \ | $(SED) -f $$tmpdir/$$lang.insert-header | $(MSGCONV) -t UTF-8 | \ { case `$(MSGFILTER) --version | sed 1q | sed -e 's,^[^0-9]*,,'` in \ '' | 0.[0-9] | 0.[0-9].* | 0.1[0-8] | 0.1[0-8].*) \ $(MSGFILTER) $(SED) -f `echo $$lang | sed -e 's/.*@//'`.sed \ ;; \ *) \ $(MSGFILTER) `echo $$lang | sed -e 's/.*@//'` \ ;; \ esac } 2>/dev/null > $$tmpdir/$$lang.new.po \ ; then \ if cmp $$lang.po $$tmpdir/$$lang.new.po >/dev/null 2>&1; then \ rm -f $$tmpdir/$$lang.new.po; \ else \ if mv -f $$tmpdir/$$lang.new.po $$lang.po; then \ :; \ else \ echo "creation of $$lang.po failed: cannot move $$tmpdir/$$lang.new.po to $$lang.po" 1>&2; \ exit 1; \ fi; \ fi; \ else \ echo "creation of $$lang.po failed!" 1>&2; \ rm -f $$tmpdir/$$lang.new.po; \ fi en@quot.insert-header: insert-header.sin sed -e '/^#/d' -e 's/HEADER/en@quot.header/g' $(srcdir)/insert-header.sin > en@quot.insert-header en@boldquot.insert-header: insert-header.sin sed -e '/^#/d' -e 's/HEADER/en@boldquot.header/g' $(srcdir)/insert-header.sin > en@boldquot.insert-header mostlyclean: mostlyclean-quot mostlyclean-quot: rm -f *.insert-header libcaes-20240413/Makefile.in0000644000175000017500000010123214606477627016302 0ustar00lordyestalordyesta# Makefile.in generated by automake 1.16.5 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2021 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = . ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/common.m4 \ $(top_srcdir)/m4/gettext.m4 $(top_srcdir)/m4/host-cpu-c-abi.m4 \ $(top_srcdir)/m4/iconv.m4 $(top_srcdir)/m4/intlmacosx.m4 \ $(top_srcdir)/m4/lib-ld.m4 $(top_srcdir)/m4/lib-link.m4 \ $(top_srcdir)/m4/lib-prefix.m4 $(top_srcdir)/m4/libcerror.m4 \ $(top_srcdir)/m4/libcrypto.m4 $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/nls.m4 $(top_srcdir)/m4/po.m4 \ $(top_srcdir)/m4/progtest.m4 $(top_srcdir)/m4/python.m4 \ $(top_srcdir)/m4/tests.m4 $(top_srcdir)/m4/types.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(top_srcdir)/configure \ $(am__configure_deps) $(am__DIST_COMMON) am__CONFIG_DISTCLEAN_FILES = config.status config.cache config.log \ configure.lineno config.status.lineno mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/common/config.h CONFIG_CLEAN_FILES = include/libcaes/definitions.h \ include/libcaes/features.h include/libcaes/types.h \ dpkg/changelog libcaes.pc libcaes.spec setup.cfg CONFIG_CLEAN_VPATH_FILES = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = SOURCES = DIST_SOURCES = RECURSIVE_TARGETS = all-recursive check-recursive cscopelist-recursive \ ctags-recursive dvi-recursive html-recursive info-recursive \ install-data-recursive install-dvi-recursive \ install-exec-recursive install-html-recursive \ install-info-recursive install-pdf-recursive \ install-ps-recursive install-recursive installcheck-recursive \ installdirs-recursive pdf-recursive ps-recursive \ tags-recursive uninstall-recursive am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__vpath_adj_setup = srcdirstrip=`echo "$(srcdir)" | sed 's|.|.|g'`; am__vpath_adj = case $$p in \ $(srcdir)/*) f=`echo "$$p" | sed "s|^$$srcdirstrip/||"`;; \ *) f=$$p;; \ esac; am__strip_dir = f=`echo $$p | sed -e 's|^.*/||'`; am__install_max = 40 am__nobase_strip_setup = \ srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*|]/\\\\&/g'` am__nobase_strip = \ for p in $$list; do echo "$$p"; done | sed -e "s|$$srcdirstrip/||" am__nobase_list = $(am__nobase_strip_setup); \ for p in $$list; do echo "$$p $$p"; done | \ sed "s| $$srcdirstrip/| |;"' / .*\//!s/ .*/ ./; s,\( .*\)/[^/]*$$,\1,' | \ $(AWK) 'BEGIN { files["."] = "" } { files[$$2] = files[$$2] " " $$1; \ if (++n[$$2] == $(am__install_max)) \ { print $$2, files[$$2]; n[$$2] = 0; files[$$2] = "" } } \ END { for (dir in files) print dir, files[dir] }' am__base_list = \ sed '$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;$$!N;s/\n/ /g' | \ sed '$$!N;$$!N;$$!N;$$!N;s/\n/ /g' am__uninstall_files_from_dir = { \ test -z "$$files" \ || { test ! -d "$$dir" && test ! -f "$$dir" && test ! -r "$$dir"; } \ || { echo " ( cd '$$dir' && rm -f" $$files ")"; \ $(am__cd) "$$dir" && rm -f $$files; }; \ } am__installdirs = "$(DESTDIR)$(pkgconfigdir)" DATA = $(pkgconfig_DATA) RECURSIVE_CLEAN_TARGETS = mostlyclean-recursive clean-recursive \ distclean-recursive maintainer-clean-recursive am__recursive_targets = \ $(RECURSIVE_TARGETS) \ $(RECURSIVE_CLEAN_TARGETS) \ $(am__extra_recursive_targets) AM_RECURSIVE_TARGETS = $(am__recursive_targets:-recursive=) TAGS CTAGS \ cscope distdir distdir-am dist dist-all distcheck am__extra_recursive_targets = sources-recursive splint-recursive am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` DIST_SUBDIRS = $(SUBDIRS) am__DIST_COMMON = $(srcdir)/Makefile.in $(srcdir)/libcaes.pc.in \ $(srcdir)/libcaes.spec.in $(srcdir)/setup.cfg.in \ $(top_srcdir)/dpkg/changelog.in \ $(top_srcdir)/include/libcaes/definitions.h.in \ $(top_srcdir)/include/libcaes/features.h.in \ $(top_srcdir)/include/libcaes/types.h.in ABOUT-NLS AUTHORS \ COPYING COPYING.LESSER ChangeLog INSTALL NEWS README compile \ config.guess config.rpath config.sub install-sh ltmain.sh \ missing DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) distdir = $(PACKAGE)-$(VERSION) top_distdir = $(distdir) am__remove_distdir = \ if test -d "$(distdir)"; then \ find "$(distdir)" -type d ! -perm -200 -exec chmod u+w {} ';' \ && rm -rf "$(distdir)" \ || { sleep 5 && rm -rf "$(distdir)"; }; \ else :; fi am__post_remove_distdir = $(am__remove_distdir) am__relativize = \ dir0=`pwd`; \ sed_first='s,^\([^/]*\)/.*$$,\1,'; \ sed_rest='s,^[^/]*/*,,'; \ sed_last='s,^.*/\([^/]*\)$$,\1,'; \ sed_butlast='s,/*[^/]*$$,,'; \ while test -n "$$dir1"; do \ first=`echo "$$dir1" | sed -e "$$sed_first"`; \ if test "$$first" != "."; then \ if test "$$first" = ".."; then \ dir2=`echo "$$dir0" | sed -e "$$sed_last"`/"$$dir2"; \ dir0=`echo "$$dir0" | sed -e "$$sed_butlast"`; \ else \ first2=`echo "$$dir2" | sed -e "$$sed_first"`; \ if test "$$first2" = "$$first"; then \ dir2=`echo "$$dir2" | sed -e "$$sed_rest"`; \ else \ dir2="../$$dir2"; \ fi; \ dir0="$$dir0"/"$$first"; \ fi; \ fi; \ dir1=`echo "$$dir1" | sed -e "$$sed_rest"`; \ done; \ reldir="$$dir2" DIST_ARCHIVES = $(distdir).tar.gz GZIP_ENV = --best DIST_TARGETS = dist-gzip # Exists only to be overridden by the user if desired. AM_DISTCHECK_DVI_TARGET = dvi distuninstallcheck_listfiles = find . -type f -print am__distuninstallcheck_listfiles = $(distuninstallcheck_listfiles) \ | sed 's|^\./|$(prefix)/|' | grep -v '$(infodir)/dir$$' distcleancheck_listfiles = find . -type f -print ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CSCOPE = @CSCOPE@ CTAGS = @CTAGS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DPKG_DATE = @DPKG_DATE@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ ETAGS = @ETAGS@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ FILECMD = @FILECMD@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GREP = @GREP@ HAVE_DLLMAIN = @HAVE_DLLMAIN@ HAVE_INTTYPES_H = @HAVE_INTTYPES_H@ HAVE_LIBCERROR = @HAVE_LIBCERROR@ HAVE_LOCAL_LIBCERROR = @HAVE_LOCAL_LIBCERROR@ HAVE_OFF64_T = @HAVE_OFF64_T@ HAVE_OPENSSL_EVP_H = @HAVE_OPENSSL_EVP_H@ HAVE_SIZE32_T = @HAVE_SIZE32_T@ HAVE_SIZE64_T = @HAVE_SIZE64_T@ HAVE_SSIZE32_T = @HAVE_SSIZE32_T@ HAVE_SSIZE64_T = @HAVE_SSIZE64_T@ HAVE_STDINT_H = @HAVE_STDINT_H@ HAVE_SYS_TYPES_H = @HAVE_SYS_TYPES_H@ HAVE_WCHAR_H = @HAVE_WCHAR_H@ HAVE_WIDE_CHARACTER_TYPE = @HAVE_WIDE_CHARACTER_TYPE@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBCAES_DLL_EXPORT = @LIBCAES_DLL_EXPORT@ LIBCAES_DLL_IMPORT = @LIBCAES_DLL_IMPORT@ LIBCERROR_CPPFLAGS = @LIBCERROR_CPPFLAGS@ LIBCERROR_LIBADD = @LIBCERROR_LIBADD@ LIBCRYPTO_CPPFLAGS = @LIBCRYPTO_CPPFLAGS@ LIBCRYPTO_LIBADD = @LIBCRYPTO_LIBADD@ LIBDL_LIBADD = @LIBDL_LIBADD@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIB_FUZZING_ENGINE = @LIB_FUZZING_ENGINE@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGMERGE = @MSGMERGE@ MSGMERGE_FOR_MSGFMT_OPTION = @MSGMERGE_FOR_MSGFMT_OPTION@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ PKGCONFIG = @PKGCONFIG@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ PYTHON = @PYTHON@ PYTHON_CONFIG = @PYTHON_CONFIG@ PYTHON_CPPFLAGS = @PYTHON_CPPFLAGS@ PYTHON_EXEC_PREFIX = @PYTHON_EXEC_PREFIX@ PYTHON_LDFLAGS = @PYTHON_LDFLAGS@ PYTHON_LIBRARY_DIR = @PYTHON_LIBRARY_DIR@ PYTHON_PACKAGE_DIR = @PYTHON_PACKAGE_DIR@ PYTHON_PLATFORM = @PYTHON_PLATFORM@ PYTHON_PREFIX = @PYTHON_PREFIX@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ SPEC_DATE = @SPEC_DATE@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ ax_libcerror_pc_libs_private = @ax_libcerror_pc_libs_private@ ax_libcerror_spec_build_requires = @ax_libcerror_spec_build_requires@ ax_libcerror_spec_requires = @ax_libcerror_spec_requires@ ax_libcrypto_pc_libs_private = @ax_libcrypto_pc_libs_private@ ax_libcrypto_spec_build_requires = @ax_libcrypto_spec_build_requires@ ax_libcrypto_spec_requires = @ax_libcrypto_spec_requires@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libcaes_spec_requires = @libcaes_spec_requires@ libcerror_CFLAGS = @libcerror_CFLAGS@ libcerror_LIBS = @libcerror_LIBS@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ openssl_CFLAGS = @openssl_CFLAGS@ openssl_LIBS = @openssl_LIBS@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ pyexecdir = @pyexecdir@ pythondir = @pythondir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ ACLOCAL_AMFLAGS = -I m4 SUBDIRS = \ include \ common \ libcerror \ libcaes \ pycaes \ po \ manuals \ tests \ ossfuzz \ msvscpp DPKG_FILES = \ dpkg/changelog \ dpkg/changelog.in \ dpkg/compat \ dpkg/control \ dpkg/copyright \ dpkg/rules \ dpkg/libcaes.install \ dpkg/libcaes-dev.install \ dpkg/libcaes-python3.install \ dpkg/source/format GETTEXT_FILES = \ config.rpath \ po/Makevars.in PKGCONFIG_FILES = \ libcaes.pc.in SETUP_PY_FILES = \ pyproject.toml \ setup.cfg \ setup.cfg.in \ setup.py SPEC_FILES = \ libcaes.spec \ libcaes.spec.in EXTRA_DIST = \ $(DPKG_FILES) \ $(GETTEXT_FILES) \ $(PKGCONFIG_FILES) \ $(SETUP_PY_FILES) \ $(SPEC_FILES) DISTCLEANFILES = \ config.status \ config.cache \ config.log \ libcaes.pc \ libcaes.spec \ Makefile \ Makefile.in \ po/Makevars pkgconfigdir = $(libdir)/pkgconfig pkgconfig_DATA = \ libcaes.pc all: all-recursive .SUFFIXES: am--refresh: Makefile @: $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ echo ' cd $(srcdir) && $(AUTOMAKE) --gnu'; \ $(am__cd) $(srcdir) && $(AUTOMAKE) --gnu \ && exit 0; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ echo ' $(SHELL) ./config.status'; \ $(SHELL) ./config.status;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) $(SHELL) ./config.status --recheck $(top_srcdir)/configure: $(am__configure_deps) $(am__cd) $(srcdir) && $(AUTOCONF) $(ACLOCAL_M4): $(am__aclocal_m4_deps) $(am__cd) $(srcdir) && $(ACLOCAL) $(ACLOCAL_AMFLAGS) $(am__aclocal_m4_deps): include/libcaes/definitions.h: $(top_builddir)/config.status $(top_srcdir)/include/libcaes/definitions.h.in cd $(top_builddir) && $(SHELL) ./config.status $@ include/libcaes/features.h: $(top_builddir)/config.status $(top_srcdir)/include/libcaes/features.h.in cd $(top_builddir) && $(SHELL) ./config.status $@ include/libcaes/types.h: $(top_builddir)/config.status $(top_srcdir)/include/libcaes/types.h.in cd $(top_builddir) && $(SHELL) ./config.status $@ dpkg/changelog: $(top_builddir)/config.status $(top_srcdir)/dpkg/changelog.in cd $(top_builddir) && $(SHELL) ./config.status $@ libcaes.pc: $(top_builddir)/config.status $(srcdir)/libcaes.pc.in cd $(top_builddir) && $(SHELL) ./config.status $@ libcaes.spec: $(top_builddir)/config.status $(srcdir)/libcaes.spec.in cd $(top_builddir) && $(SHELL) ./config.status $@ setup.cfg: $(top_builddir)/config.status $(srcdir)/setup.cfg.in cd $(top_builddir) && $(SHELL) ./config.status $@ mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs distclean-libtool: -rm -f libtool config.lt install-pkgconfigDATA: $(pkgconfig_DATA) @$(NORMAL_INSTALL) @list='$(pkgconfig_DATA)'; test -n "$(pkgconfigdir)" || list=; \ if test -n "$$list"; then \ echo " $(MKDIR_P) '$(DESTDIR)$(pkgconfigdir)'"; \ $(MKDIR_P) "$(DESTDIR)$(pkgconfigdir)" || exit 1; \ fi; \ for p in $$list; do \ if test -f "$$p"; then d=; else d="$(srcdir)/"; fi; \ echo "$$d$$p"; \ done | $(am__base_list) | \ while read files; do \ echo " $(INSTALL_DATA) $$files '$(DESTDIR)$(pkgconfigdir)'"; \ $(INSTALL_DATA) $$files "$(DESTDIR)$(pkgconfigdir)" || exit $$?; \ done uninstall-pkgconfigDATA: @$(NORMAL_UNINSTALL) @list='$(pkgconfig_DATA)'; test -n "$(pkgconfigdir)" || list=; \ files=`for p in $$list; do echo $$p; done | sed -e 's|^.*/||'`; \ dir='$(DESTDIR)$(pkgconfigdir)'; $(am__uninstall_files_from_dir) # This directory's subdirectories are mostly independent; you can cd # into them and run 'make' without going through this Makefile. # To change the values of 'make' variables: instead of editing Makefiles, # (1) if the variable is set in 'config.status', edit 'config.status' # (which will cause the Makefiles to be regenerated when you run 'make'); # (2) otherwise, pass the desired values on the 'make' command line. $(am__recursive_targets): @fail=; \ if $(am__make_keepgoing); then \ failcom='fail=yes'; \ else \ failcom='exit 1'; \ fi; \ dot_seen=no; \ target=`echo $@ | sed s/-recursive//`; \ case "$@" in \ distclean-* | maintainer-clean-*) list='$(DIST_SUBDIRS)' ;; \ *) list='$(SUBDIRS)' ;; \ esac; \ for subdir in $$list; do \ echo "Making $$target in $$subdir"; \ if test "$$subdir" = "."; then \ dot_seen=yes; \ local_target="$$target-am"; \ else \ local_target="$$target"; \ fi; \ ($(am__cd) $$subdir && $(MAKE) $(AM_MAKEFLAGS) $$local_target) \ || eval $$failcom; \ done; \ if test "$$dot_seen" = "no"; then \ $(MAKE) $(AM_MAKEFLAGS) "$$target-am" || exit 1; \ fi; test -z "$$fail" sources-local: splint-local: ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-recursive TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ if ($(ETAGS) --etags-include --version) >/dev/null 2>&1; then \ include_option=--etags-include; \ empty_fix=.; \ else \ include_option=--include; \ empty_fix=; \ fi; \ list='$(SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ test ! -f $$subdir/TAGS || \ set "$$@" "$$include_option=$$here/$$subdir/TAGS"; \ fi; \ done; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-recursive CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscope: cscope.files test ! -s cscope.files \ || $(CSCOPE) -b -q $(AM_CSCOPEFLAGS) $(CSCOPEFLAGS) -i cscope.files $(CSCOPE_ARGS) clean-cscope: -rm -f cscope.files cscope.files: clean-cscope cscopelist cscopelist: cscopelist-recursive cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags -rm -f cscope.out cscope.in.out cscope.po.out cscope.files distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(DISTFILES) $(am__remove_distdir) test -d "$(distdir)" || mkdir "$(distdir)" @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done @list='$(DIST_SUBDIRS)'; for subdir in $$list; do \ if test "$$subdir" = .; then :; else \ $(am__make_dryrun) \ || test -d "$(distdir)/$$subdir" \ || $(MKDIR_P) "$(distdir)/$$subdir" \ || exit 1; \ dir1=$$subdir; dir2="$(distdir)/$$subdir"; \ $(am__relativize); \ new_distdir=$$reldir; \ dir1=$$subdir; dir2="$(top_distdir)"; \ $(am__relativize); \ new_top_distdir=$$reldir; \ echo " (cd $$subdir && $(MAKE) $(AM_MAKEFLAGS) top_distdir="$$new_top_distdir" distdir="$$new_distdir" \\"; \ echo " am__remove_distdir=: am__skip_length_check=: am__skip_mode_fix=: distdir)"; \ ($(am__cd) $$subdir && \ $(MAKE) $(AM_MAKEFLAGS) \ top_distdir="$$new_top_distdir" \ distdir="$$new_distdir" \ am__remove_distdir=: \ am__skip_length_check=: \ am__skip_mode_fix=: \ distdir) \ || exit 1; \ fi; \ done -test -n "$(am__skip_mode_fix)" \ || find "$(distdir)" -type d ! -perm -755 \ -exec chmod u+rwx,go+rx {} \; -o \ ! -type d ! -perm -444 -links 1 -exec chmod a+r {} \; -o \ ! -type d ! -perm -400 -exec chmod a+r {} \; -o \ ! -type d ! -perm -444 -exec $(install_sh) -c -m a+r {} {} \; \ || chmod -R a+r "$(distdir)" dist-gzip: distdir tardir=$(distdir) && $(am__tar) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).tar.gz $(am__post_remove_distdir) dist-bzip2: distdir tardir=$(distdir) && $(am__tar) | BZIP2=$${BZIP2--9} bzip2 -c >$(distdir).tar.bz2 $(am__post_remove_distdir) dist-lzip: distdir tardir=$(distdir) && $(am__tar) | lzip -c $${LZIP_OPT--9} >$(distdir).tar.lz $(am__post_remove_distdir) dist-xz: distdir tardir=$(distdir) && $(am__tar) | XZ_OPT=$${XZ_OPT--e} xz -c >$(distdir).tar.xz $(am__post_remove_distdir) dist-zstd: distdir tardir=$(distdir) && $(am__tar) | zstd -c $${ZSTD_CLEVEL-$${ZSTD_OPT--19}} >$(distdir).tar.zst $(am__post_remove_distdir) dist-tarZ: distdir @echo WARNING: "Support for distribution archives compressed with" \ "legacy program 'compress' is deprecated." >&2 @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 tardir=$(distdir) && $(am__tar) | compress -c >$(distdir).tar.Z $(am__post_remove_distdir) dist-shar: distdir @echo WARNING: "Support for shar distribution archives is" \ "deprecated." >&2 @echo WARNING: "It will be removed altogether in Automake 2.0" >&2 shar $(distdir) | eval GZIP= gzip $(GZIP_ENV) -c >$(distdir).shar.gz $(am__post_remove_distdir) dist-zip: distdir -rm -f $(distdir).zip zip -rq $(distdir).zip $(distdir) $(am__post_remove_distdir) dist dist-all: $(MAKE) $(AM_MAKEFLAGS) $(DIST_TARGETS) am__post_remove_distdir='@:' $(am__post_remove_distdir) # This target untars the dist file and tries a VPATH configuration. Then # it guarantees that the distribution is self-contained by making another # tarfile. distcheck: dist case '$(DIST_ARCHIVES)' in \ *.tar.gz*) \ eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).tar.gz | $(am__untar) ;;\ *.tar.bz2*) \ bzip2 -dc $(distdir).tar.bz2 | $(am__untar) ;;\ *.tar.lz*) \ lzip -dc $(distdir).tar.lz | $(am__untar) ;;\ *.tar.xz*) \ xz -dc $(distdir).tar.xz | $(am__untar) ;;\ *.tar.Z*) \ uncompress -c $(distdir).tar.Z | $(am__untar) ;;\ *.shar.gz*) \ eval GZIP= gzip $(GZIP_ENV) -dc $(distdir).shar.gz | unshar ;;\ *.zip*) \ unzip $(distdir).zip ;;\ *.tar.zst*) \ zstd -dc $(distdir).tar.zst | $(am__untar) ;;\ esac chmod -R a-w $(distdir) chmod u+w $(distdir) mkdir $(distdir)/_build $(distdir)/_build/sub $(distdir)/_inst chmod a-w $(distdir) test -d $(distdir)/_build || exit 0; \ dc_install_base=`$(am__cd) $(distdir)/_inst && pwd | sed -e 's,^[^:\\/]:[\\/],/,'` \ && dc_destdir="$${TMPDIR-/tmp}/am-dc-$$$$/" \ && am__cwd=`pwd` \ && $(am__cd) $(distdir)/_build/sub \ && ../../configure \ $(AM_DISTCHECK_CONFIGURE_FLAGS) \ $(DISTCHECK_CONFIGURE_FLAGS) \ --srcdir=../.. --prefix="$$dc_install_base" \ && $(MAKE) $(AM_MAKEFLAGS) \ && $(MAKE) $(AM_MAKEFLAGS) $(AM_DISTCHECK_DVI_TARGET) \ && $(MAKE) $(AM_MAKEFLAGS) check \ && $(MAKE) $(AM_MAKEFLAGS) install \ && $(MAKE) $(AM_MAKEFLAGS) installcheck \ && $(MAKE) $(AM_MAKEFLAGS) uninstall \ && $(MAKE) $(AM_MAKEFLAGS) distuninstallcheck_dir="$$dc_install_base" \ distuninstallcheck \ && chmod -R a-w "$$dc_install_base" \ && ({ \ (cd ../.. && umask 077 && mkdir "$$dc_destdir") \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" install \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" uninstall \ && $(MAKE) $(AM_MAKEFLAGS) DESTDIR="$$dc_destdir" \ distuninstallcheck_dir="$$dc_destdir" distuninstallcheck; \ } || { rm -rf "$$dc_destdir"; exit 1; }) \ && rm -rf "$$dc_destdir" \ && $(MAKE) $(AM_MAKEFLAGS) dist \ && rm -rf $(DIST_ARCHIVES) \ && $(MAKE) $(AM_MAKEFLAGS) distcleancheck \ && cd "$$am__cwd" \ || exit 1 $(am__post_remove_distdir) @(echo "$(distdir) archives ready for distribution: "; \ list='$(DIST_ARCHIVES)'; for i in $$list; do echo $$i; done) | \ sed -e 1h -e 1s/./=/g -e 1p -e 1x -e '$$p' -e '$$x' distuninstallcheck: @test -n '$(distuninstallcheck_dir)' || { \ echo 'ERROR: trying to run $@ with an empty' \ '$$(distuninstallcheck_dir)' >&2; \ exit 1; \ }; \ $(am__cd) '$(distuninstallcheck_dir)' || { \ echo 'ERROR: cannot chdir into $(distuninstallcheck_dir)' >&2; \ exit 1; \ }; \ test `$(am__distuninstallcheck_listfiles) | wc -l` -eq 0 \ || { echo "ERROR: files left after uninstall:" ; \ if test -n "$(DESTDIR)"; then \ echo " (check DESTDIR support)"; \ fi ; \ $(distuninstallcheck_listfiles) ; \ exit 1; } >&2 distcleancheck: distclean @if test '$(srcdir)' = . ; then \ echo "ERROR: distcleancheck can only run from a VPATH build" ; \ exit 1 ; \ fi @test `$(distcleancheck_listfiles) | wc -l` -eq 0 \ || { echo "ERROR: files left in build directory after distclean:" ; \ $(distcleancheck_listfiles) ; \ exit 1; } >&2 check-am: all-am check: check-recursive all-am: Makefile $(DATA) installdirs: installdirs-recursive installdirs-am: for dir in "$(DESTDIR)$(pkgconfigdir)"; do \ test -z "$$dir" || $(MKDIR_P) "$$dir"; \ done install: install-recursive install-exec: install-exec-recursive install-data: install-data-recursive uninstall: uninstall-recursive install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-recursive install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) -test -z "$(DISTCLEANFILES)" || rm -f $(DISTCLEANFILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-recursive clean-am: clean-generic clean-libtool mostlyclean-am distclean: distclean-recursive -rm -f $(am__CONFIG_DISTCLEAN_FILES) -rm -f Makefile distclean-am: clean-am distclean-generic distclean-libtool \ distclean-tags dvi: dvi-recursive dvi-am: html: html-recursive html-am: info: info-recursive info-am: install-data-am: install-pkgconfigDATA install-dvi: install-dvi-recursive install-dvi-am: install-exec-am: install-html: install-html-recursive install-html-am: install-info: install-info-recursive install-info-am: install-man: install-pdf: install-pdf-recursive install-pdf-am: install-ps: install-ps-recursive install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-recursive -rm -f $(am__CONFIG_DISTCLEAN_FILES) -rm -rf $(top_srcdir)/autom4te.cache -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-recursive mostlyclean-am: mostlyclean-generic mostlyclean-libtool pdf: pdf-recursive pdf-am: ps: ps-recursive ps-am: sources: sources-recursive sources-am: sources-local splint: splint-recursive splint-am: splint-local uninstall-am: uninstall-pkgconfigDATA .MAKE: $(am__recursive_targets) install-am install-strip .PHONY: $(am__recursive_targets) CTAGS GTAGS TAGS all all-am \ am--refresh check check-am clean clean-cscope clean-generic \ clean-libtool cscope cscopelist-am ctags ctags-am dist \ dist-all dist-bzip2 dist-gzip dist-lzip dist-shar dist-tarZ \ dist-xz dist-zip dist-zstd distcheck distclean \ distclean-generic distclean-libtool distclean-tags \ distcleancheck distdir distuninstallcheck dvi dvi-am html \ html-am info info-am install install-am install-data \ install-data-am install-dvi install-dvi-am install-exec \ install-exec-am install-html install-html-am install-info \ install-info-am install-man install-pdf install-pdf-am \ install-pkgconfigDATA install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs installdirs-am \ maintainer-clean maintainer-clean-generic mostlyclean \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ sources-am sources-local splint-am splint-local tags tags-am \ uninstall uninstall-am uninstall-pkgconfigDATA .PRECIOUS: Makefile libtool: @LIBTOOL_DEPS@ cd $(srcdir) && $(SHELL) ./config.status --recheck lib: library library: (cd $(srcdir)/common && $(MAKE) $(AM_MAKEFLAGS)) (cd $(srcdir)/libcerror && $(MAKE) $(AM_MAKEFLAGS)) (cd $(srcdir)/libcaes && $(MAKE) $(AM_MAKEFLAGS)) (cd $(srcdir)/po && $(MAKE) $(AM_MAKEFLAGS)) # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: libcaes-20240413/libcerror/0000755000175000017500000000000014606477653016220 5ustar00lordyestalordyestalibcaes-20240413/libcerror/libcerror_system.c0000644000175000017500000003607414606477617021765 0ustar00lordyestalordyesta/* * System functions * * Copyright (C) 2008-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include #include #include #include #if defined( HAVE_STDLIB_H ) || defined( WINAPI ) #include #endif #if defined( HAVE_STRING_H ) || defined( WINAPI ) #include #endif #if defined( HAVE_STDARG_H ) || defined( WINAPI ) #include #elif defined( HAVE_VARARGS_H ) #include #else #error Missing headers stdarg.h and varargs.h #endif #include "libcerror_definitions.h" #include "libcerror_error.h" #include "libcerror_system.h" #include "libcerror_types.h" #if defined( WINAPI ) /* The make language identifier macro for the WINAPI FormatMessage function */ #if !defined( MAKELANGID ) #define MAKELANGID( primary_language_identifier, sub_language_identifier ) \ ( ( ( (WORD) ( sub_language_identifier ) ) << 10 ) | (WORD) ( primary_language_identifier ) ) #endif #if !defined( LANG_NEUTRAL ) #define LANG_NEUTRAL 0 #endif #if !defined( SUBLANG_DEFAULT ) #define SUBLANG_DEFAULT 1 #endif #endif /* defined( WINAPI ) */ #if defined( WINAPI ) && ( WINVER <= 0x0500 ) /* Cross Windows safe version of FormatMessageA * Returns the number of printed characters without the end-of-string character or 0 on error */ DWORD libcerror_FormatMessageA( DWORD flags, LPCVOID source, DWORD message_identifier, DWORD language_identifier, LPCSTR string, DWORD string_size, va_list *argument_list ) { FARPROC function = NULL; HMODULE library_handle = NULL; DWORD print_count = 0; if( string == NULL ) { return( 0 ); } library_handle = LoadLibrary( _SYSTEM_STRING( "kernel32.dll" ) ); if( library_handle == NULL ) { return( 0 ); } function = GetProcAddress( library_handle, (LPCSTR) "FormatMessageA" ); if( function != NULL ) { print_count = function( flags, source, message_identifier, language_identifier, string, string_size, argument_list ); } /* This call should be after using the function * in most cases kernel32.dll will still be available after free */ if( FreeLibrary( library_handle ) != TRUE ) { print_count = 0; } return( print_count ); } /* Cross Windows safe version of FormatMessageW * Returns the number of printed characters without the end-of-string character or 0 on error */ DWORD libcerror_FormatMessageW( DWORD flags, LPCVOID source, DWORD message_identifier, DWORD language_identifier, LPWSTR string, DWORD string_size, va_list *argument_list ) { FARPROC function = NULL; HMODULE library_handle = NULL; DWORD print_count = 0; if( string == NULL ) { return( 0 ); } library_handle = LoadLibrary( _SYSTEM_STRING( "kernel32.dll" ) ); if( library_handle == NULL ) { return( 0 ); } function = GetProcAddress( library_handle, (LPCSTR) "FormatMessageW" ); if( function != NULL ) { print_count = function( flags, source, message_identifier, language_identifier, string, string_size, argument_list ); } /* This call should be after using the function * in most cases kernel32.dll will still be available after free */ if( FreeLibrary( library_handle ) != TRUE ) { print_count = 0; } return( print_count ); } #endif /* defined( WINAPI ) && ( WINVER <= 0x0500 ) */ #if defined( WINAPI ) #if ( WINVER <= 0x0500 ) #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) #define libcerror_system_FormatMessage libcerror_FormatMessageW #else #define libcerror_system_FormatMessage libcerror_FormatMessageA #endif #else #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) #define libcerror_system_FormatMessage FormatMessageW #else #define libcerror_system_FormatMessage FormatMessageA #endif #endif /* ( WINVER <= 0x0500 ) */ /* Retrieves a descriptive string of the error number * This function uses the WINAPI functions for Windows XP or later * Returns the string_length if successful or -1 on error */ int libcerror_system_copy_string_from_error_number( system_character_t *string, size_t string_size, uint32_t error_number ) { DWORD print_count = 0; if( string == NULL ) { return( -1 ); } if( string_size > (size_t) INT_MAX ) { return( -1 ); } print_count = libcerror_system_FormatMessage( FORMAT_MESSAGE_FROM_SYSTEM | FORMAT_MESSAGE_IGNORE_INSERTS, NULL, (DWORD) error_number, MAKELANGID( LANG_NEUTRAL, SUBLANG_DEFAULT ), string, (DWORD) string_size, NULL ); if( print_count == 0 ) { return( -1 ); } return( (int) print_count ); } #elif defined( HAVE_STRERROR_R ) #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) #error Missing wide character strerror_r function #endif /* Retrieves a descriptive string of the error number * This function uses the POSIX strerror_r function or equivalent * Returns the string_length if successful or -1 on error */ int libcerror_system_copy_string_from_error_number( system_character_t *string, size_t string_size, uint32_t error_number ) { size_t string_length = 0; if( string == NULL ) { return( -1 ); } if( string_size > (size_t) INT_MAX ) { return( -1 ); } #if defined( STRERROR_R_CHAR_P ) if( strerror_r( (int) error_number, string, string_size ) == NULL ) #else if( strerror_r( (int) error_number, string, string_size ) != 0 ) #endif { return( -1 ); } string[ string_size - 1 ] = (system_character_t) 0; string_length = system_string_length( string ); return( (int) string_length ); } #elif defined( HAVE_STRERROR ) #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) #error Missing wide character strerror function #endif /* Retrieves a descriptive string of the error number * This function uses the POSIX strerror function or equivalent * Returns the string_length if successful or -1 on error */ int libcerror_system_copy_string_from_error_number( system_character_t *string, size_t string_size, uint32_t error_number ) { #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) const wchar_t *static_error_string = NULL; #else const char *static_error_string = NULL; #endif size_t static_error_string_length = 0; if( string == NULL ) { return( -1 ); } if( string_size > (size_t) INT_MAX ) { return( -1 ); } #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) static_error_string = _wcserror( (int) error_number ); #else static_error_string = strerror( (int) error_number ); #endif if( static_error_string == NULL ) { return( -1 ); } static_error_string_length = system_string_length( static_error_string ); if( system_string_copy( string, static_error_string, static_error_string_length ) == NULL ) { return( -1 ); } string[ static_error_string_length ] = 0; return( (int) static_error_string_length ); } #else #error Missing error to string system function #endif #if defined( HAVE_STDARG_H ) || defined( WINAPI ) #define VARARGS( function, error, error_domain, error_code, system_error_code, type, argument ) \ function( error, error_domain, error_code, system_error_code, type argument, ... ) #define VASTART( argument_list, type, name ) \ va_start( argument_list, name ) #define VAEND( argument_list ) \ va_end( argument_list ) #elif defined( HAVE_VARARGS_H ) #define VARARGS( function, error, error_domain, error_code, system_error_code, type, argument ) \ function( error, error_domain, error_code, system_error_code, va_alist ) va_dcl #define VASTART( argument_list, type, name ) \ { type name; va_start( argument_list ); name = va_arg( argument_list, type ) #define VAEND( argument_list ) \ va_end( argument_list ); } #endif /* Sets an error and adds a system specific error string if possible * Creates the error if necessary * The error domain and code are set only the first time and the error message is appended for back tracing */ void VARARGS( libcerror_system_set_error, libcerror_error_t **error, int error_domain, int error_code, uint32_t system_error_code, const char *, format_string ) { va_list argument_list; libcerror_internal_error_t *internal_error = NULL; system_character_t *error_string = NULL; system_character_t *system_format_string = NULL; void *reallocation = NULL; size_t error_string_size = 0; size_t format_string_length = 0; size_t message_size = 0; size_t next_message_size = LIBCERROR_MESSAGE_INCREMENT_SIZE; size_t string_index = 0; int message_index = 0; int print_count = 0; if( error == NULL ) { return; } if( format_string == NULL ) { return; } format_string_length = narrow_string_length( format_string ); #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) libcerror_error_get_system_format_string( format_string, format_string_length, &system_format_string ); if( system_format_string == NULL ) { return; } #else system_format_string = (system_character_t *) format_string; #endif if( *error == NULL ) { if( libcerror_error_initialize( error, error_domain, error_code ) != 1 ) { goto on_error; } } internal_error = (libcerror_internal_error_t *) *error; if( libcerror_error_resize( internal_error ) != 1 ) { goto on_error; } if( format_string_length > next_message_size ) { next_message_size = ( ( format_string_length / LIBCERROR_MESSAGE_INCREMENT_SIZE ) + 1 ) * LIBCERROR_MESSAGE_INCREMENT_SIZE; } do { if( next_message_size >= LIBCERROR_MESSAGE_MAXIMUM_SIZE ) { next_message_size = LIBCERROR_MESSAGE_MAXIMUM_SIZE; } reallocation = memory_reallocate( error_string, sizeof( system_character_t ) * next_message_size ); if( reallocation == NULL ) { memory_free( error_string ); goto on_error; } error_string = (system_character_t *) reallocation; message_size = next_message_size; /* argument_list cannot be reused in successive calls to vsnprintf */ VASTART( argument_list, const char *, format_string ); print_count = system_string_vsnprintf( error_string, message_size, system_format_string, argument_list ); VAEND( argument_list ); if( print_count <= -1 ) { next_message_size += LIBCERROR_MESSAGE_INCREMENT_SIZE; } else if( ( (size_t) print_count >= message_size ) || ( error_string[ print_count ] != (system_character_t) 0 ) ) { next_message_size = (size_t) ( print_count + 1 ); print_count = -1; } else { error_string_size = (size_t) print_count + 1; } if( message_size >= LIBCERROR_MESSAGE_MAXIMUM_SIZE ) { break; } } while( print_count <= -1 ); if( message_size >= LIBCERROR_MESSAGE_MAXIMUM_SIZE ) { error_string[ LIBCERROR_MESSAGE_MAXIMUM_SIZE - 4 ] = (system_character_t) '.'; error_string[ LIBCERROR_MESSAGE_MAXIMUM_SIZE - 3 ] = (system_character_t) '.'; error_string[ LIBCERROR_MESSAGE_MAXIMUM_SIZE - 2 ] = (system_character_t) '.'; error_string[ LIBCERROR_MESSAGE_MAXIMUM_SIZE - 1 ] = 0; error_string_size = (size_t) LIBCERROR_MESSAGE_MAXIMUM_SIZE; } message_index = internal_error->number_of_messages - 1; internal_error->messages[ message_index ] = error_string; internal_error->sizes[ message_index ] = error_string_size; #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) memory_free( system_format_string ); system_format_string = NULL; #endif message_size = internal_error->sizes[ message_index ]; if( message_size < LIBCERROR_MESSAGE_MAXIMUM_SIZE ) { /* TODO move to separate helper function */ string_index = internal_error->sizes[ message_index ] - 1; if( ( internal_error->messages[ message_index ] != NULL ) && ( ( internal_error->messages[ message_index ] )[ string_index - 1 ] == (system_character_t) '.' ) ) { string_index -= 1; } reallocation = memory_reallocate( internal_error->messages[ message_index ], sizeof( system_character_t ) * ( message_size + 13 + 512 ) ); if( reallocation == NULL ) { memory_free( internal_error->messages[ message_index ] ); internal_error->messages[ message_index ] = NULL; goto on_error; } internal_error->messages[ message_index ] = (system_character_t *) reallocation; if( system_string_copy( &( ( internal_error->messages[ message_index ] )[ string_index ] ), _SYSTEM_STRING( " with error: " ), 13 ) == NULL ) { memory_free( internal_error->messages[ message_index ] ); internal_error->messages[ message_index ] = NULL; goto on_error; } internal_error->sizes[ message_index ] += 13; string_index += 13; print_count = libcerror_system_copy_string_from_error_number( &( ( internal_error->messages[ message_index ] )[ string_index ] ), 512, system_error_code ); if( print_count == -1 ) { goto on_error; } internal_error->sizes[ message_index ] += print_count; } if( internal_error->sizes[ message_index ] >= LIBCERROR_MESSAGE_MAXIMUM_SIZE ) { internal_error->messages[ message_index ][ LIBCERROR_MESSAGE_MAXIMUM_SIZE - 4 ] = (system_character_t) '.'; internal_error->messages[ message_index ][ LIBCERROR_MESSAGE_MAXIMUM_SIZE - 3 ] = (system_character_t) '.'; internal_error->messages[ message_index ][ LIBCERROR_MESSAGE_MAXIMUM_SIZE - 2 ] = (system_character_t) '.'; internal_error->messages[ message_index ][ LIBCERROR_MESSAGE_MAXIMUM_SIZE - 1 ] = 0; internal_error->sizes[ message_index ] = (size_t) LIBCERROR_MESSAGE_MAXIMUM_SIZE; } return; on_error: #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) if( system_format_string != NULL ) { memory_free( system_format_string ); } #endif return; } #undef VARARGS #undef VASTART #undef VAEND libcaes-20240413/libcerror/libcerror_error.c0000644000175000017500000004572014606477617021570 0ustar00lordyestalordyesta/* * Error functions * * Copyright (C) 2008-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include #include #include #include #if defined( HAVE_STDARG_H ) || defined( WINAPI ) #include #elif defined( HAVE_VARARGS_H ) #include #else #error Missing headers stdarg.h and varargs.h #endif #include #include "libcerror_definitions.h" #include "libcerror_error.h" #include "libcerror_types.h" /* Creates an error * Returns 1 if successful or -1 on error */ int libcerror_error_initialize( libcerror_error_t **error, int error_domain, int error_code ) { libcerror_internal_error_t *internal_error = NULL; if( error == NULL ) { return( -1 ); } if( *error != NULL ) { return( -1 ); } internal_error = memory_allocate_structure( libcerror_internal_error_t ); if( internal_error == NULL ) { return( -1 ); } internal_error->domain = error_domain; internal_error->code = error_code; internal_error->number_of_messages = 0; internal_error->messages = NULL; internal_error->sizes = NULL; *error = (libcerror_error_t *) internal_error; return( 1 ); } /* Free an error and its elements */ void libcerror_error_free( libcerror_error_t **error ) { libcerror_internal_error_t *internal_error = NULL; int message_index = 0; if( error == NULL ) { return; } if( *error != NULL ) { internal_error = (libcerror_internal_error_t *) *error; if( internal_error->messages != NULL ) { for( message_index = 0; message_index < internal_error->number_of_messages; message_index++ ) { if( internal_error->messages[ message_index ] != NULL ) { memory_free( internal_error->messages[ message_index ] ); } } memory_free( internal_error->messages ); } if( internal_error->sizes != NULL ) { memory_free( internal_error->sizes ); } memory_free( *error ); *error = NULL; } } /* Resizes an error * Returns 1 if successful or -1 on error */ int libcerror_error_resize( libcerror_internal_error_t *internal_error ) { void *reallocation = NULL; int message_index = 0; int number_of_messages = 0; if( internal_error == NULL ) { return( -1 ); } message_index = internal_error->number_of_messages; number_of_messages = internal_error->number_of_messages + 1; reallocation = memory_reallocate( internal_error->messages, sizeof( system_character_t * ) * number_of_messages ); if( reallocation == NULL ) { return( -1 ); } internal_error->messages = (system_character_t **) reallocation; internal_error->messages[ message_index ] = NULL; reallocation = memory_reallocate( internal_error->sizes, sizeof( size_t ) * number_of_messages ); if( reallocation == NULL ) { return( -1 ); } internal_error->sizes = (size_t *) reallocation; internal_error->sizes[ message_index ] = 0; internal_error->number_of_messages += 1; return( 1 ); } #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) /* Retrieves the format string as a system string */ void libcerror_error_get_system_format_string( const char *format_string, size_t format_string_length, system_character_t **system_format_string ) { void *reallocation = NULL; size_t next_format_string_length = 0; int print_count = 0; #if defined( __BORLANDC__ ) || defined( _MSC_VER ) size_t string_index = 0; #endif if( format_string == NULL ) { return; } if( format_string_length > (size_t) SSIZE_MAX ) { return; } if( system_format_string == NULL ) { return; } next_format_string_length = format_string_length + 1; do { if( next_format_string_length >= LIBCERROR_MESSAGE_MAXIMUM_SIZE ) { next_format_string_length = LIBCERROR_MESSAGE_MAXIMUM_SIZE; } reallocation = memory_reallocate( *system_format_string, sizeof( system_character_t ) * next_format_string_length ); if( reallocation == NULL ) { memory_free( *system_format_string ); *system_format_string = NULL; return; } *system_format_string = (system_character_t *) reallocation; format_string_length = next_format_string_length; #if defined( __BORLANDC__ ) || defined( _MSC_VER ) print_count = wide_string_snwprintf( *system_format_string, format_string_length, L"%S", format_string ); #else print_count = wide_string_snwprintf( *system_format_string, format_string_length, L"%s", format_string ); #endif if( print_count <= -1 ) { next_format_string_length += LIBCERROR_MESSAGE_INCREMENT_SIZE; } else if( ( (size_t) print_count > format_string_length ) || ( ( *system_format_string )[ print_count ] != 0 ) ) { next_format_string_length = (size_t) print_count; print_count = -1; } if( next_format_string_length >= LIBCERROR_MESSAGE_MAXIMUM_SIZE ) { /* TODO handle similar to error string */ memory_free( *system_format_string ); *system_format_string = NULL; return; } } while( print_count <= -1 ); #if defined( __BORLANDC__ ) || defined( _MSC_VER ) /* Rewrite %s to %S */ string_index = 0; while( string_index < format_string_length ) { if( ( *system_format_string )[ string_index ] == 0 ) { break; } else if( ( *system_format_string )[ string_index ] == (system_character_t) '%' ) { string_index++; if( ( *system_format_string )[ string_index ] == (system_character_t) 's' ) { ( *system_format_string )[ string_index ] = (system_character_t) 'S'; } } string_index++; } #endif /* defined( __BORLANDC__ ) || defined( _MSC_VER ) */ } #endif /* defined( HAVE_WIDE_SYSTEM_CHARACTER ) */ #if defined( HAVE_STDARG_H ) || defined( WINAPI ) #define VARARGS( function, error, error_domain, error_code, type, argument ) \ function( error, error_domain, error_code, type argument, ... ) #define VASTART( argument_list, type, name ) \ va_start( argument_list, name ) #define VAEND( argument_list ) \ va_end( argument_list ) #elif defined( HAVE_VARARGS_H ) #define VARARGS( function, error, error_domain, error_code, type, argument ) \ function( error, error_domain, error_code, va_alist ) va_dcl #define VASTART( argument_list, type, name ) \ { type name; va_start( argument_list ); name = va_arg( argument_list, type ) #define VAEND( argument_list ) \ va_end( argument_list ); } #endif /* defined( HAVE_STDARG_H ) || defined( WINAPI ) */ /* Sets an error * Creates the error if necessary * The error domain and code are set only the first time and the error message is appended for back tracing */ void VARARGS( libcerror_error_set, libcerror_error_t **error, int error_domain, int error_code, const char *, format_string ) { va_list argument_list; libcerror_internal_error_t *internal_error = NULL; system_character_t *error_string = NULL; system_character_t *system_format_string = NULL; void *reallocation = NULL; size_t error_string_size = 0; size_t format_string_length = 0; size_t message_size = 0; size_t next_message_size = LIBCERROR_MESSAGE_INCREMENT_SIZE; int message_index = 0; int print_count = 0; if( error == NULL ) { return; } if( format_string == NULL ) { return; } format_string_length = narrow_string_length( format_string ); #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) libcerror_error_get_system_format_string( format_string, format_string_length, &system_format_string ); if( system_format_string == NULL ) { return; } #else system_format_string = (system_character_t *) format_string; #endif if( *error == NULL ) { if( libcerror_error_initialize( error, error_domain, error_code ) != 1 ) { goto on_error; } } internal_error = (libcerror_internal_error_t *) *error; if( libcerror_error_resize( internal_error ) != 1 ) { goto on_error; } if( format_string_length > next_message_size ) { next_message_size = ( ( format_string_length / LIBCERROR_MESSAGE_INCREMENT_SIZE ) + 1 ) * LIBCERROR_MESSAGE_INCREMENT_SIZE; } do { if( next_message_size >= LIBCERROR_MESSAGE_MAXIMUM_SIZE ) { next_message_size = LIBCERROR_MESSAGE_MAXIMUM_SIZE; } reallocation = memory_reallocate( error_string, sizeof( system_character_t ) * next_message_size ); if( reallocation == NULL ) { memory_free( error_string ); goto on_error; } error_string = (system_character_t *) reallocation; message_size = next_message_size; /* argument_list cannot be reused in successive calls to vsnprintf */ VASTART( argument_list, const char *, format_string ); print_count = system_string_vsnprintf( error_string, message_size, system_format_string, argument_list ); VAEND( argument_list ); if( print_count <= -1 ) { next_message_size += LIBCERROR_MESSAGE_INCREMENT_SIZE; } else if( ( (size_t) print_count >= message_size ) || ( error_string[ print_count ] != (system_character_t) 0 ) ) { next_message_size = (size_t) ( print_count + 1 ); print_count = -1; } else { error_string_size = (size_t) print_count + 1; } if( message_size >= LIBCERROR_MESSAGE_MAXIMUM_SIZE ) { break; } } while( print_count <= -1 ); if( message_size >= LIBCERROR_MESSAGE_MAXIMUM_SIZE ) { error_string[ LIBCERROR_MESSAGE_MAXIMUM_SIZE - 4 ] = (system_character_t) '.'; error_string[ LIBCERROR_MESSAGE_MAXIMUM_SIZE - 3 ] = (system_character_t) '.'; error_string[ LIBCERROR_MESSAGE_MAXIMUM_SIZE - 2 ] = (system_character_t) '.'; error_string[ LIBCERROR_MESSAGE_MAXIMUM_SIZE - 1 ] = 0; error_string_size = (size_t) LIBCERROR_MESSAGE_MAXIMUM_SIZE; } message_index = internal_error->number_of_messages - 1; internal_error->messages[ message_index ] = error_string; internal_error->sizes[ message_index ] = error_string_size; #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) memory_free( system_format_string ); system_format_string = NULL; #endif return; on_error: #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) if( system_format_string != NULL ) { memory_free( system_format_string ); } #endif return; } #undef VARARGS #undef VASTART #undef VAEND /* Determines if an error equals a certain error code of a domain * Returns 1 if error matches or 0 if not */ int libcerror_error_matches( libcerror_error_t *error, int error_domain, int error_code ) { if( error == NULL ) { return( 0 ); } if( ( ( (libcerror_internal_error_t *) error )->domain == error_domain ) && ( ( (libcerror_internal_error_t *) error )->code == error_code ) ) { return( 1 ); } return( 0 ); } /* Prints a descriptive string of the error to the stream * Returns the number of printed characters if successful or -1 on error */ int libcerror_error_fprint( libcerror_error_t *error, FILE *stream ) { libcerror_internal_error_t *internal_error = NULL; system_character_t *error_string = NULL; int message_index = 0; int print_count = 0; #if defined( WINAPI ) const char *format_string = "%" PRIs_SYSTEM "\r\n"; #else const char *format_string = "%" PRIs_SYSTEM "\n"; #endif if( error == NULL ) { return( -1 ); } internal_error = (libcerror_internal_error_t *) error; if( internal_error->messages == NULL ) { return( -1 ); } if( stream == NULL ) { return( -1 ); } message_index = internal_error->number_of_messages - 1; error_string = internal_error->messages[ message_index ]; if( error_string != NULL ) { print_count = fprintf( stream, format_string, error_string ); if( print_count <= -1 ) { return( -1 ); } } return( print_count ); } /* Prints a descriptive string of the error to the string * The end-of-string character is not included in the return value * Returns the number of printed characters if successful or -1 on error */ int libcerror_error_sprint( libcerror_error_t *error, char *string, size_t size ) { libcerror_internal_error_t *internal_error = NULL; system_character_t *error_string = NULL; size_t message_index = 0; size_t print_count = 0; #if !defined( HAVE_WIDE_SYSTEM_CHARACTER ) size_t error_string_size = 0; #endif if( error == NULL ) { return( -1 ); } internal_error = (libcerror_internal_error_t *) error; if( internal_error->messages == NULL ) { return( -1 ); } if( internal_error->sizes == NULL ) { return( -1 ); } if( string == NULL ) { return( -1 ); } #if INT_MAX < SSIZE_MAX if( size > (size_t) INT_MAX ) #else if( size > (size_t) SSIZE_MAX ) #endif { return( -1 ); } message_index = internal_error->number_of_messages - 1; error_string = internal_error->messages[ message_index ]; if( error_string != NULL ) { #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) #if defined( _MSC_VER ) if( wcstombs_s( &print_count, string, size, error_string, _TRUNCATE ) != 0 ) { return( -1 ); } #else print_count = wcstombs( string, error_string, size ); if( print_count == (size_t) -1 ) { return( -1 ); } #endif /* defined( _MSC_VER ) */ if( print_count >= size ) { return( -1 ); } #else error_string_size = internal_error->sizes[ message_index ]; if( size < ( error_string_size + 1 ) ) { return( -1 ); } if( narrow_string_copy( string, error_string, error_string_size ) == NULL ) { return( -1 ); } print_count = error_string_size; #endif /* defined( HAVE_WIDE_SYSTEM_CHARACTER ) */ } if( print_count > (size_t) INT_MAX ) { return( -1 ); } return( (int) print_count ); } /* Prints a backtrace of the error to the stream * Returns the number of printed characters if successful or -1 on error */ int libcerror_error_backtrace_fprint( libcerror_error_t *error, FILE *stream ) { libcerror_internal_error_t *internal_error = NULL; system_character_t *error_string = NULL; int message_index = 0; int print_count = 0; int total_print_count = 0; #if defined( WINAPI ) const char *format_string = "%" PRIs_SYSTEM "\r\n"; #else const char *format_string = "%" PRIs_SYSTEM "\n"; #endif if( error == NULL ) { return( -1 ); } internal_error = (libcerror_internal_error_t *) error; if( internal_error->messages == NULL ) { return( -1 ); } if( stream == NULL ) { return( -1 ); } for( message_index = 0; message_index < internal_error->number_of_messages; message_index++ ) { error_string = internal_error->messages[ message_index ]; if( error_string != NULL ) { print_count = fprintf( stream, format_string, error_string ); if( print_count <= -1 ) { return( -1 ); } total_print_count += print_count; } } return( total_print_count ); } /* Prints a backtrace of the error to the string * The end-of-string character is not included in the return value * Returns the number of printed characters if successful or -1 on error */ int libcerror_error_backtrace_sprint( libcerror_error_t *error, char *string, size_t size ) { libcerror_internal_error_t *internal_error = NULL; system_character_t *error_string = NULL; size_t string_index = 0; int message_index = 0; #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) size_t print_count = 0; #else size_t error_string_size = 0; #endif if( error == NULL ) { return( -1 ); } internal_error = (libcerror_internal_error_t *) error; if( internal_error->messages == NULL ) { return( -1 ); } if( internal_error->sizes == NULL ) { return( -1 ); } if( string == NULL ) { return( -1 ); } #if INT_MAX < SSIZE_MAX if( size > (size_t) INT_MAX ) #else if( size > (size_t) SSIZE_MAX ) #endif { return( -1 ); } for( message_index = 0; message_index < internal_error->number_of_messages; message_index++ ) { error_string = internal_error->messages[ message_index ]; if( error_string != NULL ) { if( string_index > 0 ) { #if defined( WINAPI ) if( ( string_index + 2 ) >= size ) { return( -1 ); } string[ string_index++ ] = (system_character_t) '\r'; #else if( ( string_index + 1 ) >= size ) { return( -1 ); } #endif /* defined( WINAPI ) */ string[ string_index++ ] = (system_character_t) '\n'; string[ string_index ] = (system_character_t) 0; } #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) #if defined( _MSC_VER ) if( wcstombs_s( &print_count, &( string[ string_index ] ), size - string_index, error_string, _TRUNCATE ) != 0 ) { return( -1 ); } #else print_count = wcstombs( &( string[ string_index ] ), error_string, size - string_index ); if( print_count == (size_t) -1 ) { return( -1 ); } #endif /*defined( _MSC_VER ) */ string_index += print_count; if( string_index >= size ) { return( -1 ); } if( string[ string_index - 1 ] == 0 ) { string_index--; } #else error_string_size = internal_error->sizes[ message_index ]; if( size < ( string_index + error_string_size + 1 ) ) { return( -1 ); } if( narrow_string_copy( &( string[ string_index ] ), error_string, error_string_size ) == NULL ) { return( -1 ); } string_index += error_string_size - 1; #endif /* defined( HAVE_WIDE_SYSTEM_CHARACTER ) */ } } string_index++; if( string_index > (size_t) INT_MAX ) { return( -1 ); } return( (int) string_index ); } libcaes-20240413/libcerror/libcerror_extern.h0000644000175000017500000000257214606477617021747 0ustar00lordyestalordyesta/* * The internal extern definition * * Copyright (C) 2008-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCERROR_INTERNAL_EXTERN_H ) #define _LIBCERROR_INTERNAL_EXTERN_H #include /* Define HAVE_LOCAL_LIBCERROR for local use of libcerror */ #if !defined( HAVE_LOCAL_LIBCERROR ) #include #if defined( __CYGWIN__ ) || defined( __MINGW32__ ) #define LIBCERROR_EXTERN_VARIABLE extern #else #define LIBCERROR_EXTERN_VARIABLE LIBCERROR_EXTERN #endif #else #define LIBCERROR_EXTERN /* extern */ #define LIBCERROR_EXTERN_VARIABLE extern #endif /* !defined( HAVE_LOCAL_LIBCERROR ) */ #endif /* !defined( _LIBCERROR_INTERNAL_EXTERN_H ) */ libcaes-20240413/libcerror/Makefile.am0000644000175000017500000000122714606477617020256 0ustar00lordyestalordyestaif HAVE_LOCAL_LIBCERROR AM_CPPFLAGS = \ -I../include -I$(top_srcdir)/include \ -I../common -I$(top_srcdir)/common noinst_LTLIBRARIES = libcerror.la libcerror_la_SOURCES = \ libcerror_definitions.h \ libcerror_extern.h \ libcerror_error.c libcerror_error.h \ libcerror_support.c libcerror_support.h \ libcerror_system.c libcerror_system.h \ libcerror_types.h \ libcerror_unused.h endif DISTCLEANFILES = \ libcerror_definitions.h \ Makefile \ Makefile.in sources-local: $(BUILT_SOURCES) splint-local: @echo "Running splint on libcerror ..." -splint -preproc -redef $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(libcerror_la_SOURCES) libcaes-20240413/libcerror/libcerror_types.h0000644000175000017500000000276214606477617021607 0ustar00lordyestalordyesta/* * The internal type definitions * * Copyright (C) 2008-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCERROR_INTERNAL_TYPES_H ) #define _LIBCERROR_INTERNAL_TYPES_H #include #include /* Define HAVE_LOCAL_LIBCERROR for local use of libcerror * The definitions in are copied here * for local use of libcerror */ #if defined( HAVE_LOCAL_LIBCERROR ) /* The following type definitions hide internal data structures */ typedef intptr_t libcerror_error_t; /* Currently not supported #if defined( HAVE_DEBUG_OUTPUT ) && !defined( WINAPI ) typedef struct libcerror_error {} libcerror_error_t; #else typedef intptr_t libcerror_error_t; #endif */ #endif /* defined( HAVE_LOCAL_LIBCERROR ) */ #endif /* !defined( _LIBCERROR_INTERNAL_TYPES_H ) */ libcaes-20240413/libcerror/libcerror_support.h0000644000175000017500000000232614606477617022153 0ustar00lordyestalordyesta/* * Support functions * * Copyright (C) 2008-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCERROR_SUPPORT_H ) #define _LIBCERROR_SUPPORT_H #include #include #include "libcerror_extern.h" #if defined( __cplusplus ) extern "C" { #endif #if !defined( HAVE_LOCAL_LIBCERROR ) LIBCERROR_EXTERN \ const char *libcerror_get_version( void ); #endif /* !defined( HAVE_LOCAL_LIBCERROR ) */ #if defined( __cplusplus ) } #endif #endif /* !defined( _LIBCERROR_SUPPORT_H ) */ libcaes-20240413/libcerror/libcerror_error.h0000644000175000017500000000550014606477617021565 0ustar00lordyestalordyesta/* * Error functions * * Copyright (C) 2008-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCERROR_INTERNAL_ERROR_H ) #define _LIBCERROR_INTERNAL_ERROR_H #include #include #include #include "libcerror_extern.h" #include "libcerror_types.h" #if defined( __cplusplus ) extern "C" { #endif typedef struct libcerror_internal_error libcerror_internal_error_t; struct libcerror_internal_error { /* The error domain */ int domain; /* The error code */ int code; /* The number of messages */ int number_of_messages; /* A dynamic array containing the message strings */ system_character_t **messages; /* A dynamic array containing the message string sizes * without the end-of-string character */ size_t *sizes; }; int libcerror_error_initialize( libcerror_error_t **error, int error_domain, int error_code ); LIBCERROR_EXTERN \ void libcerror_error_free( libcerror_error_t **error ); int libcerror_error_resize( libcerror_internal_error_t *internal_error ); #if defined( HAVE_WIDE_SYSTEM_CHARACTER ) void libcerror_error_get_system_format_string( const char *format_string, size_t format_string_length, system_character_t **system_format_string ); #endif /* defined( HAVE_WIDE_SYSTEM_CHARACTER ) */ LIBCERROR_EXTERN \ void libcerror_error_set( libcerror_error_t **error, int error_domain, int error_code, const char *format_string, ... ); LIBCERROR_EXTERN \ int libcerror_error_matches( libcerror_error_t *error, int error_domain, int error_code ); LIBCERROR_EXTERN \ int libcerror_error_fprint( libcerror_error_t *error, FILE *stream ); LIBCERROR_EXTERN \ int libcerror_error_sprint( libcerror_error_t *error, char *string, size_t size ); LIBCERROR_EXTERN \ int libcerror_error_backtrace_fprint( libcerror_error_t *error, FILE *stream ); LIBCERROR_EXTERN \ int libcerror_error_backtrace_sprint( libcerror_error_t *error, char *string, size_t size ); #if defined( __cplusplus ) } #endif #endif /* !defined( _LIBCERROR_INTERNAL_ERROR_H ) */ libcaes-20240413/libcerror/libcerror_system.h0000644000175000017500000000375214606477617021767 0ustar00lordyestalordyesta/* * System functions * * Copyright (C) 2008-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCERROR_SYSTEM_H ) #define _LIBCERROR_SYSTEM_H #include #include #include #include "libcerror_extern.h" #include "libcerror_types.h" #if defined( __cplusplus ) extern "C" { #endif #if defined( WINAPI ) && ( WINVER <= 0x0500 ) DWORD libcerror_FormatMessageA( DWORD flags, LPCVOID source, DWORD message_identifier, DWORD language_identifier, LPCSTR string, DWORD string_size, va_list *argument_list ); DWORD libcerror_FormatMessageW( DWORD flags, LPCVOID source, DWORD message_identifier, DWORD language_identifier, LPWSTR string, DWORD string_size, va_list *argument_list ); #endif /* defined( WINAPI ) && ( WINVER <= 0x0500 ) */ int libcerror_system_copy_string_from_error_number( system_character_t *string, size_t string_size, uint32_t error_number ); LIBCERROR_EXTERN \ void libcerror_system_set_error( libcerror_error_t **error, int error_domain, int error_code, uint32_t system_error_code, const char *format_string, ... ); #if defined( __cplusplus ) } #endif #endif /* !defined( _LIBCERROR_SYSTEM_H ) */ libcaes-20240413/libcerror/libcerror_definitions.h0000644000175000017500000001671514606477617022761 0ustar00lordyestalordyesta/* * The internal definitions * * Copyright (C) 2008-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( LIBCERROR_INTERNAL_DEFINITIONS_H ) #define LIBCERROR_INTERNAL_DEFINITIONS_H #include #include /* Define HAVE_LOCAL_LIBCERROR for local use of libcerror */ #if !defined( HAVE_LOCAL_LIBCERROR ) #include /* The definitions in are copied here * for local use of libcerror */ #else #define LIBCERROR_VERSION 20240413 /* The libcerror version string */ #define LIBCERROR_VERSION_STRING "20240413" /* The error domains */ enum LIBCERROR_ERROR_DOMAINS { LIBCERROR_ERROR_DOMAIN_ARGUMENTS = (int) 'a', LIBCERROR_ERROR_DOMAIN_CONVERSION = (int) 'c', LIBCERROR_ERROR_DOMAIN_COMPRESSION = (int) 'C', LIBCERROR_ERROR_DOMAIN_ENCRYPTION = (int) 'E', LIBCERROR_ERROR_DOMAIN_IO = (int) 'I', LIBCERROR_ERROR_DOMAIN_INPUT = (int) 'i', LIBCERROR_ERROR_DOMAIN_MEMORY = (int) 'm', LIBCERROR_ERROR_DOMAIN_OUTPUT = (int) 'o', LIBCERROR_ERROR_DOMAIN_RUNTIME = (int) 'r', }; /* The argument error codes * to signify errors regarding arguments passed to a function */ enum LIBCERROR_ARGUMENT_ERROR { LIBCERROR_ARGUMENT_ERROR_GENERIC = 0, /* The argument contains an invalid value */ LIBCERROR_ARGUMENT_ERROR_INVALID_VALUE = 1, /* The argument contains a value less than zero */ LIBCERROR_ARGUMENT_ERROR_VALUE_LESS_THAN_ZERO = 2, /* The argument contains a value zero or less */ LIBCERROR_ARGUMENT_ERROR_VALUE_ZERO_OR_LESS = 3, /* The argument contains a value that exceeds the maximum * for the specific type */ LIBCERROR_ARGUMENT_ERROR_VALUE_EXCEEDS_MAXIMUM = 4, /* The argument contains a value that is too small */ LIBCERROR_ARGUMENT_ERROR_VALUE_TOO_SMALL = 5, /* The argument contains a value that is too large */ LIBCERROR_ARGUMENT_ERROR_VALUE_TOO_LARGE = 6, /* The argument contains a value that is out of bound */ LIBCERROR_ARGUMENT_ERROR_VALUE_OUT_OF_BOUNDS = 7, /* The argument contains a value that is not supported */ LIBCERROR_ARGUMENT_ERROR_UNSUPPORTED_VALUE = 8, /* The argument contains a value that conficts with another argument */ LIBCERROR_ARGUMENT_ERROR_CONFLICTING_VALUE = 9 }; /* The conversion error codes * to signify errors regarding conversions */ enum LIBCERROR_CONVERSION_ERROR { LIBCERROR_CONVERSION_ERROR_GENERIC = 0, /* The conversion failed on the input */ LIBCERROR_CONVERSION_ERROR_INPUT_FAILED = 1, /* The conversion failed on the output */ LIBCERROR_CONVERSION_ERROR_OUTPUT_FAILED = 2 }; /* The compression error codes * to signify errors regarding compression */ enum LIBCERROR_COMPRESSION_ERROR { LIBCERROR_COMPRESSION_ERROR_GENERIC = 0, /* The compression failed */ LIBCERROR_COMPRESSION_ERROR_COMPRESS_FAILED = 1, /* The decompression failed */ LIBCERROR_COMPRESSION_ERROR_DECOMPRESS_FAILED = 2 }; /* The encryption error codes * to signify errors regarding encryption */ enum LIBCERROR_ENCRYPTION_ERROR { LIBCERROR_ENCRYPTION_ERROR_GENERIC = 0, /* The encryption failed */ LIBCERROR_ENCRYPTION_ERROR_ENCRYPT_FAILED = 1, /* The decryption failed */ LIBCERROR_ENCRYPTION_ERROR_DECRYPT_FAILED = 2 }; /* The input/output error codes * to signify errors regarding input/output */ enum LIBCERROR_IO_ERROR { LIBCERROR_IO_ERROR_GENERIC = 0, /* The open failed */ LIBCERROR_IO_ERROR_OPEN_FAILED = 1, /* The close failed */ LIBCERROR_IO_ERROR_CLOSE_FAILED = 2, /* The seek failed */ LIBCERROR_IO_ERROR_SEEK_FAILED = 3, /* The read failed */ LIBCERROR_IO_ERROR_READ_FAILED = 4, /* The write failed */ LIBCERROR_IO_ERROR_WRITE_FAILED = 5, /* Access denied */ LIBCERROR_IO_ERROR_ACCESS_DENIED = 6, /* The resource is invalid i.e. a missing file */ LIBCERROR_IO_ERROR_INVALID_RESOURCE = 7, /* The ioctl failed */ LIBCERROR_IO_ERROR_IOCTL_FAILED = 8, /* The unlink failed */ LIBCERROR_IO_ERROR_UNLINK_FAILED = 9 }; /* The input error codes * to signify errors regarding handing input data */ enum LIBCERROR_INPUT_ERROR { LIBCERROR_INPUT_ERROR_GENERIC = 0, /* The input contains invalid data */ LIBCERROR_INPUT_ERROR_INVALID_DATA = 1, /* The input contains an unsupported signature */ LIBCERROR_INPUT_ERROR_SIGNATURE_MISMATCH = 2, /* A checksum in the input did not match */ LIBCERROR_INPUT_ERROR_CHECKSUM_MISMATCH = 3, /* A value in the input did not match a previously * read value or calculated value */ LIBCERROR_INPUT_ERROR_VALUE_MISMATCH = 4 }; /* The memory error codes * to signify errors regarding memory */ enum LIBCERROR_MEMORY_ERROR { LIBCERROR_MEMORY_ERROR_GENERIC = 0, /* There is insufficient memory available */ LIBCERROR_MEMORY_ERROR_INSUFFICIENT = 1, /* The memory failed to be copied */ LIBCERROR_MEMORY_ERROR_COPY_FAILED = 2, /* The memory failed to be set */ LIBCERROR_MEMORY_ERROR_SET_FAILED = 3 }; /* The output error codes */ enum LIBCERROR_OUTPUT_ERROR { LIBCERROR_OUTPUT_ERROR_GENERIC = 0, /* There is insuficient space to write the output */ LIBCERROR_OUTPUT_ERROR_INSUFFICIENT_SPACE = 1 }; /* The runtime error codes * to signify errors regarding runtime processing */ enum LIBCERROR_RUNTIME_ERROR { LIBCERROR_RUNTIME_ERROR_GENERIC = 0, /* The value is missing */ LIBCERROR_RUNTIME_ERROR_VALUE_MISSING = 1, /* The value was already set */ LIBCERROR_RUNTIME_ERROR_VALUE_ALREADY_SET = 2, /* The creation and/or initialization of an internal structure failed */ LIBCERROR_RUNTIME_ERROR_INITIALIZE_FAILED = 3, /* The resize of an internal structure failed */ LIBCERROR_RUNTIME_ERROR_RESIZE_FAILED = 4, /* The free and/or finalization of an internal structure failed */ LIBCERROR_RUNTIME_ERROR_FINALIZE_FAILED = 5, /* The value could not be determined */ LIBCERROR_RUNTIME_ERROR_GET_FAILED = 6, /* The value could not be set */ LIBCERROR_RUNTIME_ERROR_SET_FAILED = 7, /* The value could not be appended/prepended */ LIBCERROR_RUNTIME_ERROR_APPEND_FAILED = 8, /* The value could not be copied */ LIBCERROR_RUNTIME_ERROR_COPY_FAILED = 9, /* The value could not be removed */ LIBCERROR_RUNTIME_ERROR_REMOVE_FAILED = 10, /* The value could not be printed */ LIBCERROR_RUNTIME_ERROR_PRINT_FAILED = 11, /* The value was out of bounds */ LIBCERROR_RUNTIME_ERROR_VALUE_OUT_OF_BOUNDS = 12, /* The value exceeds the maximum for its specific type */ LIBCERROR_RUNTIME_ERROR_VALUE_EXCEEDS_MAXIMUM = 13, /* The value is unsupported */ LIBCERROR_RUNTIME_ERROR_UNSUPPORTED_VALUE = 14, /* An aborted was requested */ LIBCERROR_RUNTIME_ERROR_ABORT_REQUESTED = 15 }; #endif /* !defined( HAVE_LOCAL_LIBCERROR ) */ #define LIBCERROR_MESSAGE_INCREMENT_SIZE 64 #define LIBCERROR_MESSAGE_MAXIMUM_SIZE 4096 #endif /* !defined( LIBCERROR_INTERNAL_DEFINITIONS_H ) */ libcaes-20240413/libcerror/libcerror_support.c0000644000175000017500000000220614606477617022143 0ustar00lordyestalordyesta/* * Support functions * * Copyright (C) 2008-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #include #include #include "libcerror_definitions.h" #include "libcerror_support.h" #if !defined( HAVE_LOCAL_LIBCERROR ) /* Returns the library version as a string */ const char *libcerror_get_version( void ) { return( (const char *) LIBCERROR_VERSION_STRING ); } #endif /* !defined( HAVE_LOCAL_LIBCERROR ) */ libcaes-20240413/libcerror/libcerror_unused.h0000644000175000017500000000261014606477617021736 0ustar00lordyestalordyesta/* * Definitions to silence compiler warnings about unused function attributes/parameters. * * Copyright (C) 2008-2024, Joachim Metz * * Refer to AUTHORS for acknowledgements. * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU Lesser General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program 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 Lesser General Public License * along with this program. If not, see . */ #if !defined( _LIBCERROR_UNUSED_H ) #define _LIBCERROR_UNUSED_H #include #if !defined( LIBCERROR_ATTRIBUTE_UNUSED ) #if defined( __GNUC__ ) && __GNUC__ >= 3 #define LIBCERROR_ATTRIBUTE_UNUSED __attribute__ ((__unused__)) #else #define LIBCERROR_ATTRIBUTE_UNUSED #endif #endif #if defined( _MSC_VER ) #define LIBCERROR_UNREFERENCED_PARAMETER( parameter ) \ UNREFERENCED_PARAMETER( parameter ); #else #define LIBCERROR_UNREFERENCED_PARAMETER( parameter ) \ /* parameter */ #endif #endif /* !defined( _LIBCERROR_UNUSED_H ) */ libcaes-20240413/libcerror/Makefile.in0000644000175000017500000005471114606477627020276 0ustar00lordyestalordyesta# Makefile.in generated by automake 1.16.5 from Makefile.am. # @configure_input@ # Copyright (C) 1994-2021 Free Software Foundation, Inc. # This Makefile.in is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. @SET_MAKE@ VPATH = @srcdir@ am__is_gnu_make = { \ if test -z '$(MAKELEVEL)'; then \ false; \ elif test -n '$(MAKE_HOST)'; then \ true; \ elif test -n '$(MAKE_VERSION)' && test -n '$(CURDIR)'; then \ true; \ else \ false; \ fi; \ } am__make_running_with_option = \ case $${target_option-} in \ ?) ;; \ *) echo "am__make_running_with_option: internal error: invalid" \ "target option '$${target_option-}' specified" >&2; \ exit 1;; \ esac; \ has_opt=no; \ sane_makeflags=$$MAKEFLAGS; \ if $(am__is_gnu_make); then \ sane_makeflags=$$MFLAGS; \ else \ case $$MAKEFLAGS in \ *\\[\ \ ]*) \ bs=\\; \ sane_makeflags=`printf '%s\n' "$$MAKEFLAGS" \ | sed "s/$$bs$$bs[$$bs $$bs ]*//g"`;; \ esac; \ fi; \ skip_next=no; \ strip_trailopt () \ { \ flg=`printf '%s\n' "$$flg" | sed "s/$$1.*$$//"`; \ }; \ for flg in $$sane_makeflags; do \ test $$skip_next = yes && { skip_next=no; continue; }; \ case $$flg in \ *=*|--*) continue;; \ -*I) strip_trailopt 'I'; skip_next=yes;; \ -*I?*) strip_trailopt 'I';; \ -*O) strip_trailopt 'O'; skip_next=yes;; \ -*O?*) strip_trailopt 'O';; \ -*l) strip_trailopt 'l'; skip_next=yes;; \ -*l?*) strip_trailopt 'l';; \ -[dEDm]) skip_next=yes;; \ -[JT]) skip_next=yes;; \ esac; \ case $$flg in \ *$$target_option*) has_opt=yes; break;; \ esac; \ done; \ test $$has_opt = yes am__make_dryrun = (target_option=n; $(am__make_running_with_option)) am__make_keepgoing = (target_option=k; $(am__make_running_with_option)) pkgdatadir = $(datadir)/@PACKAGE@ pkgincludedir = $(includedir)/@PACKAGE@ pkglibdir = $(libdir)/@PACKAGE@ pkglibexecdir = $(libexecdir)/@PACKAGE@ am__cd = CDPATH="$${ZSH_VERSION+.}$(PATH_SEPARATOR)" && cd install_sh_DATA = $(install_sh) -c -m 644 install_sh_PROGRAM = $(install_sh) -c install_sh_SCRIPT = $(install_sh) -c INSTALL_HEADER = $(INSTALL_DATA) transform = $(program_transform_name) NORMAL_INSTALL = : PRE_INSTALL = : POST_INSTALL = : NORMAL_UNINSTALL = : PRE_UNINSTALL = : POST_UNINSTALL = : build_triplet = @build@ host_triplet = @host@ subdir = libcerror ACLOCAL_M4 = $(top_srcdir)/aclocal.m4 am__aclocal_m4_deps = $(top_srcdir)/m4/common.m4 \ $(top_srcdir)/m4/gettext.m4 $(top_srcdir)/m4/host-cpu-c-abi.m4 \ $(top_srcdir)/m4/iconv.m4 $(top_srcdir)/m4/intlmacosx.m4 \ $(top_srcdir)/m4/lib-ld.m4 $(top_srcdir)/m4/lib-link.m4 \ $(top_srcdir)/m4/lib-prefix.m4 $(top_srcdir)/m4/libcerror.m4 \ $(top_srcdir)/m4/libcrypto.m4 $(top_srcdir)/m4/libtool.m4 \ $(top_srcdir)/m4/ltoptions.m4 $(top_srcdir)/m4/ltsugar.m4 \ $(top_srcdir)/m4/ltversion.m4 $(top_srcdir)/m4/lt~obsolete.m4 \ $(top_srcdir)/m4/nls.m4 $(top_srcdir)/m4/po.m4 \ $(top_srcdir)/m4/progtest.m4 $(top_srcdir)/m4/python.m4 \ $(top_srcdir)/m4/tests.m4 $(top_srcdir)/m4/types.m4 \ $(top_srcdir)/acinclude.m4 $(top_srcdir)/configure.ac am__configure_deps = $(am__aclocal_m4_deps) $(CONFIGURE_DEPENDENCIES) \ $(ACLOCAL_M4) DIST_COMMON = $(srcdir)/Makefile.am $(am__DIST_COMMON) mkinstalldirs = $(install_sh) -d CONFIG_HEADER = $(top_builddir)/common/config.h CONFIG_CLEAN_FILES = CONFIG_CLEAN_VPATH_FILES = LTLIBRARIES = $(noinst_LTLIBRARIES) libcerror_la_LIBADD = am__libcerror_la_SOURCES_DIST = libcerror_definitions.h \ libcerror_extern.h libcerror_error.c libcerror_error.h \ libcerror_support.c libcerror_support.h libcerror_system.c \ libcerror_system.h libcerror_types.h libcerror_unused.h @HAVE_LOCAL_LIBCERROR_TRUE@am_libcerror_la_OBJECTS = \ @HAVE_LOCAL_LIBCERROR_TRUE@ libcerror_error.lo \ @HAVE_LOCAL_LIBCERROR_TRUE@ libcerror_support.lo \ @HAVE_LOCAL_LIBCERROR_TRUE@ libcerror_system.lo libcerror_la_OBJECTS = $(am_libcerror_la_OBJECTS) AM_V_lt = $(am__v_lt_@AM_V@) am__v_lt_ = $(am__v_lt_@AM_DEFAULT_V@) am__v_lt_0 = --silent am__v_lt_1 = @HAVE_LOCAL_LIBCERROR_TRUE@am_libcerror_la_rpath = AM_V_P = $(am__v_P_@AM_V@) am__v_P_ = $(am__v_P_@AM_DEFAULT_V@) am__v_P_0 = false am__v_P_1 = : AM_V_GEN = $(am__v_GEN_@AM_V@) am__v_GEN_ = $(am__v_GEN_@AM_DEFAULT_V@) am__v_GEN_0 = @echo " GEN " $@; am__v_GEN_1 = AM_V_at = $(am__v_at_@AM_V@) am__v_at_ = $(am__v_at_@AM_DEFAULT_V@) am__v_at_0 = @ am__v_at_1 = DEFAULT_INCLUDES = -I.@am__isrc@ -I$(top_builddir)/common depcomp = $(SHELL) $(top_srcdir)/depcomp am__maybe_remake_depfiles = depfiles am__depfiles_remade = ./$(DEPDIR)/libcerror_error.Plo \ ./$(DEPDIR)/libcerror_support.Plo \ ./$(DEPDIR)/libcerror_system.Plo am__mv = mv -f COMPILE = $(CC) $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) \ $(CPPFLAGS) $(AM_CFLAGS) $(CFLAGS) LTCOMPILE = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=compile $(CC) $(DEFS) \ $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(CPPFLAGS) \ $(AM_CFLAGS) $(CFLAGS) AM_V_CC = $(am__v_CC_@AM_V@) am__v_CC_ = $(am__v_CC_@AM_DEFAULT_V@) am__v_CC_0 = @echo " CC " $@; am__v_CC_1 = CCLD = $(CC) LINK = $(LIBTOOL) $(AM_V_lt) --tag=CC $(AM_LIBTOOLFLAGS) \ $(LIBTOOLFLAGS) --mode=link $(CCLD) $(AM_CFLAGS) $(CFLAGS) \ $(AM_LDFLAGS) $(LDFLAGS) -o $@ AM_V_CCLD = $(am__v_CCLD_@AM_V@) am__v_CCLD_ = $(am__v_CCLD_@AM_DEFAULT_V@) am__v_CCLD_0 = @echo " CCLD " $@; am__v_CCLD_1 = SOURCES = $(libcerror_la_SOURCES) DIST_SOURCES = $(am__libcerror_la_SOURCES_DIST) am__can_run_installinfo = \ case $$AM_UPDATE_INFO_DIR in \ n|no|NO) false;; \ *) (install-info --version) >/dev/null 2>&1;; \ esac am__extra_recursive_targets = sources-recursive splint-recursive am__tagged_files = $(HEADERS) $(SOURCES) $(TAGS_FILES) $(LISP) # Read a list of newline-separated strings from the standard input, # and print each of them once, without duplicates. Input order is # *not* preserved. am__uniquify_input = $(AWK) '\ BEGIN { nonempty = 0; } \ { items[$$0] = 1; nonempty = 1; } \ END { if (nonempty) { for (i in items) print i; }; } \ ' # Make sure the list of sources is unique. This is necessary because, # e.g., the same source file might be shared among _SOURCES variables # for different programs/libraries. am__define_uniq_tagged_files = \ list='$(am__tagged_files)'; \ unique=`for i in $$list; do \ if test -f "$$i"; then echo $$i; else echo $(srcdir)/$$i; fi; \ done | $(am__uniquify_input)` am__DIST_COMMON = $(srcdir)/Makefile.in $(top_srcdir)/depcomp DISTFILES = $(DIST_COMMON) $(DIST_SOURCES) $(TEXINFOS) $(EXTRA_DIST) ACLOCAL = @ACLOCAL@ AMTAR = @AMTAR@ AM_DEFAULT_VERBOSITY = @AM_DEFAULT_VERBOSITY@ AR = @AR@ AS = @AS@ AUTOCONF = @AUTOCONF@ AUTOHEADER = @AUTOHEADER@ AUTOMAKE = @AUTOMAKE@ AWK = @AWK@ CC = @CC@ CCDEPMODE = @CCDEPMODE@ CFLAGS = @CFLAGS@ CPP = @CPP@ CPPFLAGS = @CPPFLAGS@ CSCOPE = @CSCOPE@ CTAGS = @CTAGS@ CXX = @CXX@ CXXCPP = @CXXCPP@ CXXDEPMODE = @CXXDEPMODE@ CXXFLAGS = @CXXFLAGS@ CYGPATH_W = @CYGPATH_W@ DEFS = @DEFS@ DEPDIR = @DEPDIR@ DLLTOOL = @DLLTOOL@ DPKG_DATE = @DPKG_DATE@ DSYMUTIL = @DSYMUTIL@ DUMPBIN = @DUMPBIN@ ECHO_C = @ECHO_C@ ECHO_N = @ECHO_N@ ECHO_T = @ECHO_T@ EGREP = @EGREP@ ETAGS = @ETAGS@ EXEEXT = @EXEEXT@ FGREP = @FGREP@ FILECMD = @FILECMD@ GETTEXT_MACRO_VERSION = @GETTEXT_MACRO_VERSION@ GMSGFMT = @GMSGFMT@ GMSGFMT_015 = @GMSGFMT_015@ GREP = @GREP@ HAVE_DLLMAIN = @HAVE_DLLMAIN@ HAVE_INTTYPES_H = @HAVE_INTTYPES_H@ HAVE_LIBCERROR = @HAVE_LIBCERROR@ HAVE_LOCAL_LIBCERROR = @HAVE_LOCAL_LIBCERROR@ HAVE_OFF64_T = @HAVE_OFF64_T@ HAVE_OPENSSL_EVP_H = @HAVE_OPENSSL_EVP_H@ HAVE_SIZE32_T = @HAVE_SIZE32_T@ HAVE_SIZE64_T = @HAVE_SIZE64_T@ HAVE_SSIZE32_T = @HAVE_SSIZE32_T@ HAVE_SSIZE64_T = @HAVE_SSIZE64_T@ HAVE_STDINT_H = @HAVE_STDINT_H@ HAVE_SYS_TYPES_H = @HAVE_SYS_TYPES_H@ HAVE_WCHAR_H = @HAVE_WCHAR_H@ HAVE_WIDE_CHARACTER_TYPE = @HAVE_WIDE_CHARACTER_TYPE@ INSTALL = @INSTALL@ INSTALL_DATA = @INSTALL_DATA@ INSTALL_PROGRAM = @INSTALL_PROGRAM@ INSTALL_SCRIPT = @INSTALL_SCRIPT@ INSTALL_STRIP_PROGRAM = @INSTALL_STRIP_PROGRAM@ INTLLIBS = @INTLLIBS@ INTL_MACOSX_LIBS = @INTL_MACOSX_LIBS@ LD = @LD@ LDFLAGS = @LDFLAGS@ LIBCAES_DLL_EXPORT = @LIBCAES_DLL_EXPORT@ LIBCAES_DLL_IMPORT = @LIBCAES_DLL_IMPORT@ LIBCERROR_CPPFLAGS = @LIBCERROR_CPPFLAGS@ LIBCERROR_LIBADD = @LIBCERROR_LIBADD@ LIBCRYPTO_CPPFLAGS = @LIBCRYPTO_CPPFLAGS@ LIBCRYPTO_LIBADD = @LIBCRYPTO_LIBADD@ LIBDL_LIBADD = @LIBDL_LIBADD@ LIBICONV = @LIBICONV@ LIBINTL = @LIBINTL@ LIBOBJS = @LIBOBJS@ LIBS = @LIBS@ LIBTOOL = @LIBTOOL@ LIBTOOL_DEPS = @LIBTOOL_DEPS@ LIB_FUZZING_ENGINE = @LIB_FUZZING_ENGINE@ LIPO = @LIPO@ LN_S = @LN_S@ LTLIBICONV = @LTLIBICONV@ LTLIBINTL = @LTLIBINTL@ LTLIBOBJS = @LTLIBOBJS@ LT_SYS_LIBRARY_PATH = @LT_SYS_LIBRARY_PATH@ MAKEINFO = @MAKEINFO@ MANIFEST_TOOL = @MANIFEST_TOOL@ MKDIR_P = @MKDIR_P@ MSGFMT = @MSGFMT@ MSGMERGE = @MSGMERGE@ MSGMERGE_FOR_MSGFMT_OPTION = @MSGMERGE_FOR_MSGFMT_OPTION@ NM = @NM@ NMEDIT = @NMEDIT@ OBJDUMP = @OBJDUMP@ OBJEXT = @OBJEXT@ OTOOL = @OTOOL@ OTOOL64 = @OTOOL64@ PACKAGE = @PACKAGE@ PACKAGE_BUGREPORT = @PACKAGE_BUGREPORT@ PACKAGE_NAME = @PACKAGE_NAME@ PACKAGE_STRING = @PACKAGE_STRING@ PACKAGE_TARNAME = @PACKAGE_TARNAME@ PACKAGE_URL = @PACKAGE_URL@ PACKAGE_VERSION = @PACKAGE_VERSION@ PATH_SEPARATOR = @PATH_SEPARATOR@ PKGCONFIG = @PKGCONFIG@ PKG_CONFIG = @PKG_CONFIG@ PKG_CONFIG_LIBDIR = @PKG_CONFIG_LIBDIR@ PKG_CONFIG_PATH = @PKG_CONFIG_PATH@ POSUB = @POSUB@ PYTHON = @PYTHON@ PYTHON_CONFIG = @PYTHON_CONFIG@ PYTHON_CPPFLAGS = @PYTHON_CPPFLAGS@ PYTHON_EXEC_PREFIX = @PYTHON_EXEC_PREFIX@ PYTHON_LDFLAGS = @PYTHON_LDFLAGS@ PYTHON_LIBRARY_DIR = @PYTHON_LIBRARY_DIR@ PYTHON_PACKAGE_DIR = @PYTHON_PACKAGE_DIR@ PYTHON_PLATFORM = @PYTHON_PLATFORM@ PYTHON_PREFIX = @PYTHON_PREFIX@ RANLIB = @RANLIB@ SED = @SED@ SET_MAKE = @SET_MAKE@ SHELL = @SHELL@ SPEC_DATE = @SPEC_DATE@ STRIP = @STRIP@ USE_NLS = @USE_NLS@ VERSION = @VERSION@ XGETTEXT = @XGETTEXT@ XGETTEXT_015 = @XGETTEXT_015@ XGETTEXT_EXTRA_OPTIONS = @XGETTEXT_EXTRA_OPTIONS@ abs_builddir = @abs_builddir@ abs_srcdir = @abs_srcdir@ abs_top_builddir = @abs_top_builddir@ abs_top_srcdir = @abs_top_srcdir@ ac_ct_AR = @ac_ct_AR@ ac_ct_CC = @ac_ct_CC@ ac_ct_CXX = @ac_ct_CXX@ ac_ct_DUMPBIN = @ac_ct_DUMPBIN@ am__include = @am__include@ am__leading_dot = @am__leading_dot@ am__quote = @am__quote@ am__tar = @am__tar@ am__untar = @am__untar@ ax_libcerror_pc_libs_private = @ax_libcerror_pc_libs_private@ ax_libcerror_spec_build_requires = @ax_libcerror_spec_build_requires@ ax_libcerror_spec_requires = @ax_libcerror_spec_requires@ ax_libcrypto_pc_libs_private = @ax_libcrypto_pc_libs_private@ ax_libcrypto_spec_build_requires = @ax_libcrypto_spec_build_requires@ ax_libcrypto_spec_requires = @ax_libcrypto_spec_requires@ bindir = @bindir@ build = @build@ build_alias = @build_alias@ build_cpu = @build_cpu@ build_os = @build_os@ build_vendor = @build_vendor@ builddir = @builddir@ datadir = @datadir@ datarootdir = @datarootdir@ docdir = @docdir@ dvidir = @dvidir@ exec_prefix = @exec_prefix@ host = @host@ host_alias = @host_alias@ host_cpu = @host_cpu@ host_os = @host_os@ host_vendor = @host_vendor@ htmldir = @htmldir@ includedir = @includedir@ infodir = @infodir@ install_sh = @install_sh@ libcaes_spec_requires = @libcaes_spec_requires@ libcerror_CFLAGS = @libcerror_CFLAGS@ libcerror_LIBS = @libcerror_LIBS@ libdir = @libdir@ libexecdir = @libexecdir@ localedir = @localedir@ localstatedir = @localstatedir@ mandir = @mandir@ mkdir_p = @mkdir_p@ oldincludedir = @oldincludedir@ openssl_CFLAGS = @openssl_CFLAGS@ openssl_LIBS = @openssl_LIBS@ pdfdir = @pdfdir@ prefix = @prefix@ program_transform_name = @program_transform_name@ psdir = @psdir@ pyexecdir = @pyexecdir@ pythondir = @pythondir@ runstatedir = @runstatedir@ sbindir = @sbindir@ sharedstatedir = @sharedstatedir@ srcdir = @srcdir@ sysconfdir = @sysconfdir@ target_alias = @target_alias@ top_build_prefix = @top_build_prefix@ top_builddir = @top_builddir@ top_srcdir = @top_srcdir@ @HAVE_LOCAL_LIBCERROR_TRUE@AM_CPPFLAGS = \ @HAVE_LOCAL_LIBCERROR_TRUE@ -I../include -I$(top_srcdir)/include \ @HAVE_LOCAL_LIBCERROR_TRUE@ -I../common -I$(top_srcdir)/common @HAVE_LOCAL_LIBCERROR_TRUE@noinst_LTLIBRARIES = libcerror.la @HAVE_LOCAL_LIBCERROR_TRUE@libcerror_la_SOURCES = \ @HAVE_LOCAL_LIBCERROR_TRUE@ libcerror_definitions.h \ @HAVE_LOCAL_LIBCERROR_TRUE@ libcerror_extern.h \ @HAVE_LOCAL_LIBCERROR_TRUE@ libcerror_error.c libcerror_error.h \ @HAVE_LOCAL_LIBCERROR_TRUE@ libcerror_support.c libcerror_support.h \ @HAVE_LOCAL_LIBCERROR_TRUE@ libcerror_system.c libcerror_system.h \ @HAVE_LOCAL_LIBCERROR_TRUE@ libcerror_types.h \ @HAVE_LOCAL_LIBCERROR_TRUE@ libcerror_unused.h DISTCLEANFILES = \ libcerror_definitions.h \ Makefile \ Makefile.in all: all-am .SUFFIXES: .SUFFIXES: .c .lo .o .obj $(srcdir)/Makefile.in: $(srcdir)/Makefile.am $(am__configure_deps) @for dep in $?; do \ case '$(am__configure_deps)' in \ *$$dep*) \ ( cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh ) \ && { if test -f $@; then exit 0; else break; fi; }; \ exit 1;; \ esac; \ done; \ echo ' cd $(top_srcdir) && $(AUTOMAKE) --gnu libcerror/Makefile'; \ $(am__cd) $(top_srcdir) && \ $(AUTOMAKE) --gnu libcerror/Makefile Makefile: $(srcdir)/Makefile.in $(top_builddir)/config.status @case '$?' in \ *config.status*) \ cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh;; \ *) \ echo ' cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles)'; \ cd $(top_builddir) && $(SHELL) ./config.status $(subdir)/$@ $(am__maybe_remake_depfiles);; \ esac; $(top_builddir)/config.status: $(top_srcdir)/configure $(CONFIG_STATUS_DEPENDENCIES) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(top_srcdir)/configure: $(am__configure_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(ACLOCAL_M4): $(am__aclocal_m4_deps) cd $(top_builddir) && $(MAKE) $(AM_MAKEFLAGS) am--refresh $(am__aclocal_m4_deps): clean-noinstLTLIBRARIES: -test -z "$(noinst_LTLIBRARIES)" || rm -f $(noinst_LTLIBRARIES) @list='$(noinst_LTLIBRARIES)'; \ locs=`for p in $$list; do echo $$p; done | \ sed 's|^[^/]*$$|.|; s|/[^/]*$$||; s|$$|/so_locations|' | \ sort -u`; \ test -z "$$locs" || { \ echo rm -f $${locs}; \ rm -f $${locs}; \ } libcerror.la: $(libcerror_la_OBJECTS) $(libcerror_la_DEPENDENCIES) $(EXTRA_libcerror_la_DEPENDENCIES) $(AM_V_CCLD)$(LINK) $(am_libcerror_la_rpath) $(libcerror_la_OBJECTS) $(libcerror_la_LIBADD) $(LIBS) mostlyclean-compile: -rm -f *.$(OBJEXT) distclean-compile: -rm -f *.tab.c @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libcerror_error.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libcerror_support.Plo@am__quote@ # am--include-marker @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/libcerror_system.Plo@am__quote@ # am--include-marker $(am__depfiles_remade): @$(MKDIR_P) $(@D) @echo '# dummy' >$@-t && $(am__mv) $@-t $@ am--depfiles: $(am__depfiles_remade) .c.o: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ $< .c.obj: @am__fastdepCC_TRUE@ $(AM_V_CC)$(COMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ `$(CYGPATH_W) '$<'` @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Po @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=no @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(COMPILE) -c -o $@ `$(CYGPATH_W) '$<'` .c.lo: @am__fastdepCC_TRUE@ $(AM_V_CC)$(LTCOMPILE) -MT $@ -MD -MP -MF $(DEPDIR)/$*.Tpo -c -o $@ $< @am__fastdepCC_TRUE@ $(AM_V_at)$(am__mv) $(DEPDIR)/$*.Tpo $(DEPDIR)/$*.Plo @AMDEP_TRUE@@am__fastdepCC_FALSE@ $(AM_V_CC)source='$<' object='$@' libtool=yes @AMDEPBACKSLASH@ @AMDEP_TRUE@@am__fastdepCC_FALSE@ DEPDIR=$(DEPDIR) $(CCDEPMODE) $(depcomp) @AMDEPBACKSLASH@ @am__fastdepCC_FALSE@ $(AM_V_CC@am__nodep@)$(LTCOMPILE) -c -o $@ $< mostlyclean-libtool: -rm -f *.lo clean-libtool: -rm -rf .libs _libs sources-local: splint-local: ID: $(am__tagged_files) $(am__define_uniq_tagged_files); mkid -fID $$unique tags: tags-am TAGS: tags tags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) set x; \ here=`pwd`; \ $(am__define_uniq_tagged_files); \ shift; \ if test -z "$(ETAGS_ARGS)$$*$$unique"; then :; else \ test -n "$$unique" || unique=$$empty_fix; \ if test $$# -gt 0; then \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ "$$@" $$unique; \ else \ $(ETAGS) $(ETAGSFLAGS) $(AM_ETAGSFLAGS) $(ETAGS_ARGS) \ $$unique; \ fi; \ fi ctags: ctags-am CTAGS: ctags ctags-am: $(TAGS_DEPENDENCIES) $(am__tagged_files) $(am__define_uniq_tagged_files); \ test -z "$(CTAGS_ARGS)$$unique" \ || $(CTAGS) $(CTAGSFLAGS) $(AM_CTAGSFLAGS) $(CTAGS_ARGS) \ $$unique GTAGS: here=`$(am__cd) $(top_builddir) && pwd` \ && $(am__cd) $(top_srcdir) \ && gtags -i $(GTAGS_ARGS) "$$here" cscopelist: cscopelist-am cscopelist-am: $(am__tagged_files) list='$(am__tagged_files)'; \ case "$(srcdir)" in \ [\\/]* | ?:[\\/]*) sdir="$(srcdir)" ;; \ *) sdir=$(subdir)/$(srcdir) ;; \ esac; \ for i in $$list; do \ if test -f "$$i"; then \ echo "$(subdir)/$$i"; \ else \ echo "$$sdir/$$i"; \ fi; \ done >> $(top_builddir)/cscope.files distclean-tags: -rm -f TAGS ID GTAGS GRTAGS GSYMS GPATH tags distdir: $(BUILT_SOURCES) $(MAKE) $(AM_MAKEFLAGS) distdir-am distdir-am: $(DISTFILES) @srcdirstrip=`echo "$(srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ topsrcdirstrip=`echo "$(top_srcdir)" | sed 's/[].[^$$\\*]/\\\\&/g'`; \ list='$(DISTFILES)'; \ dist_files=`for file in $$list; do echo $$file; done | \ sed -e "s|^$$srcdirstrip/||;t" \ -e "s|^$$topsrcdirstrip/|$(top_builddir)/|;t"`; \ case $$dist_files in \ */*) $(MKDIR_P) `echo "$$dist_files" | \ sed '/\//!d;s|^|$(distdir)/|;s,/[^/]*$$,,' | \ sort -u` ;; \ esac; \ for file in $$dist_files; do \ if test -f $$file || test -d $$file; then d=.; else d=$(srcdir); fi; \ if test -d $$d/$$file; then \ dir=`echo "/$$file" | sed -e 's,/[^/]*$$,,'`; \ if test -d "$(distdir)/$$file"; then \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ if test -d $(srcdir)/$$file && test $$d != $(srcdir); then \ cp -fpR $(srcdir)/$$file "$(distdir)$$dir" || exit 1; \ find "$(distdir)/$$file" -type d ! -perm -700 -exec chmod u+rwx {} \;; \ fi; \ cp -fpR $$d/$$file "$(distdir)$$dir" || exit 1; \ else \ test -f "$(distdir)/$$file" \ || cp -p $$d/$$file "$(distdir)/$$file" \ || exit 1; \ fi; \ done check-am: all-am check: check-am all-am: Makefile $(LTLIBRARIES) installdirs: install: install-am install-exec: install-exec-am install-data: install-data-am uninstall: uninstall-am install-am: all-am @$(MAKE) $(AM_MAKEFLAGS) install-exec-am install-data-am installcheck: installcheck-am install-strip: if test -z '$(STRIP)'; then \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ install; \ else \ $(MAKE) $(AM_MAKEFLAGS) INSTALL_PROGRAM="$(INSTALL_STRIP_PROGRAM)" \ install_sh_PROGRAM="$(INSTALL_STRIP_PROGRAM)" INSTALL_STRIP_FLAG=-s \ "INSTALL_PROGRAM_ENV=STRIPPROG='$(STRIP)'" install; \ fi mostlyclean-generic: clean-generic: distclean-generic: -test -z "$(CONFIG_CLEAN_FILES)" || rm -f $(CONFIG_CLEAN_FILES) -test . = "$(srcdir)" || test -z "$(CONFIG_CLEAN_VPATH_FILES)" || rm -f $(CONFIG_CLEAN_VPATH_FILES) -test -z "$(DISTCLEANFILES)" || rm -f $(DISTCLEANFILES) maintainer-clean-generic: @echo "This command is intended for maintainers to use" @echo "it deletes files that may require special tools to rebuild." clean: clean-am clean-am: clean-generic clean-libtool clean-noinstLTLIBRARIES \ mostlyclean-am distclean: distclean-am -rm -f ./$(DEPDIR)/libcerror_error.Plo -rm -f ./$(DEPDIR)/libcerror_support.Plo -rm -f ./$(DEPDIR)/libcerror_system.Plo -rm -f Makefile distclean-am: clean-am distclean-compile distclean-generic \ distclean-tags dvi: dvi-am dvi-am: html: html-am html-am: info: info-am info-am: install-data-am: install-dvi: install-dvi-am install-dvi-am: install-exec-am: install-html: install-html-am install-html-am: install-info: install-info-am install-info-am: install-man: install-pdf: install-pdf-am install-pdf-am: install-ps: install-ps-am install-ps-am: installcheck-am: maintainer-clean: maintainer-clean-am -rm -f ./$(DEPDIR)/libcerror_error.Plo -rm -f ./$(DEPDIR)/libcerror_support.Plo -rm -f ./$(DEPDIR)/libcerror_system.Plo -rm -f Makefile maintainer-clean-am: distclean-am maintainer-clean-generic mostlyclean: mostlyclean-am mostlyclean-am: mostlyclean-compile mostlyclean-generic \ mostlyclean-libtool pdf: pdf-am pdf-am: ps: ps-am ps-am: sources: sources-am sources-am: sources-local splint: splint-am splint-am: splint-local uninstall-am: .MAKE: install-am install-strip .PHONY: CTAGS GTAGS TAGS all all-am am--depfiles check check-am clean \ clean-generic clean-libtool clean-noinstLTLIBRARIES \ cscopelist-am ctags ctags-am distclean distclean-compile \ distclean-generic distclean-libtool distclean-tags distdir dvi \ dvi-am html html-am info info-am install install-am \ install-data install-data-am install-dvi install-dvi-am \ install-exec install-exec-am install-html install-html-am \ install-info install-info-am install-man install-pdf \ install-pdf-am install-ps install-ps-am install-strip \ installcheck installcheck-am installdirs maintainer-clean \ maintainer-clean-generic mostlyclean mostlyclean-compile \ mostlyclean-generic mostlyclean-libtool pdf pdf-am ps ps-am \ sources-am sources-local splint-am splint-local tags tags-am \ uninstall uninstall-am .PRECIOUS: Makefile sources-local: $(BUILT_SOURCES) splint-local: @echo "Running splint on libcerror ..." -splint -preproc -redef $(DEFS) $(DEFAULT_INCLUDES) $(INCLUDES) $(AM_CPPFLAGS) $(libcerror_la_SOURCES) # Tell versions [3.59,3.63) of GNU make to not export all variables. # Otherwise a system limit (for SysV at least) may be exceeded. .NOEXPORT: libcaes-20240413/libcaes.pc.in0000644000175000017500000000046014606473411016554 0ustar00lordyestalordyestaprefix=@prefix@ exec_prefix=@exec_prefix@ libdir=@libdir@ includedir=@includedir@ Name: libcaes Description: Library to support cross-platform AES encryption Version: @VERSION@ Libs: -L${libdir} -lcaes Libs.private: @ax_libcerror_pc_libs_private@ @ax_libcrypto_pc_libs_private@ Cflags: -I${includedir} libcaes-20240413/aclocal.m40000644000175000017500000015613514606477625016107 0ustar00lordyestalordyesta# generated automatically by aclocal 1.16.5 -*- Autoconf -*- # Copyright (C) 1996-2021 Free Software Foundation, Inc. # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This program is distributed in the hope that it will be useful, # but WITHOUT ANY WARRANTY, to the extent permitted by law; without # even the implied warranty of MERCHANTABILITY or FITNESS FOR A # PARTICULAR PURPOSE. m4_ifndef([AC_CONFIG_MACRO_DIRS], [m4_defun([_AM_CONFIG_MACRO_DIRS], [])m4_defun([AC_CONFIG_MACRO_DIRS], [_AM_CONFIG_MACRO_DIRS($@)])]) m4_ifndef([AC_AUTOCONF_VERSION], [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl m4_if(m4_defn([AC_AUTOCONF_VERSION]), [2.71],, [m4_warning([this file was generated for autoconf 2.71. You have another version of autoconf. It may work, but is not guaranteed to. If you have problems, you may need to regenerate the build system entirely. To do so, use the procedure documented by the package, typically 'autoreconf'.])]) # pkg.m4 - Macros to locate and use pkg-config. -*- Autoconf -*- # serial 12 (pkg-config-0.29.2) dnl Copyright © 2004 Scott James Remnant . dnl Copyright © 2012-2015 Dan Nicholson dnl dnl This program is free software; you can redistribute it and/or modify dnl it under the terms of the GNU General Public License as published by dnl the Free Software Foundation; either version 2 of the License, or dnl (at your option) any later version. dnl dnl This program is distributed in the hope that it will be useful, but dnl WITHOUT ANY WARRANTY; without even the implied warranty of dnl MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU dnl General Public License for more details. dnl dnl You should have received a copy of the GNU General Public License dnl along with this program; if not, write to the Free Software dnl Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA dnl 02111-1307, USA. dnl dnl As a special exception to the GNU General Public License, if you dnl distribute this file as part of a program that contains a dnl configuration script generated by Autoconf, you may include it under dnl the same distribution terms that you use for the rest of that dnl program. dnl PKG_PREREQ(MIN-VERSION) dnl ----------------------- dnl Since: 0.29 dnl dnl Verify that the version of the pkg-config macros are at least dnl MIN-VERSION. Unlike PKG_PROG_PKG_CONFIG, which checks the user's dnl installed version of pkg-config, this checks the developer's version dnl of pkg.m4 when generating configure. dnl dnl To ensure that this macro is defined, also add: dnl m4_ifndef([PKG_PREREQ], dnl [m4_fatal([must install pkg-config 0.29 or later before running autoconf/autogen])]) dnl dnl See the "Since" comment for each macro you use to see what version dnl of the macros you require. m4_defun([PKG_PREREQ], [m4_define([PKG_MACROS_VERSION], [0.29.2]) m4_if(m4_version_compare(PKG_MACROS_VERSION, [$1]), -1, [m4_fatal([pkg.m4 version $1 or higher is required but ]PKG_MACROS_VERSION[ found])]) ])dnl PKG_PREREQ dnl PKG_PROG_PKG_CONFIG([MIN-VERSION]) dnl ---------------------------------- dnl Since: 0.16 dnl dnl Search for the pkg-config tool and set the PKG_CONFIG variable to dnl first found in the path. Checks that the version of pkg-config found dnl is at least MIN-VERSION. If MIN-VERSION is not specified, 0.9.0 is dnl used since that's the first version where most current features of dnl pkg-config existed. AC_DEFUN([PKG_PROG_PKG_CONFIG], [m4_pattern_forbid([^_?PKG_[A-Z_]+$]) m4_pattern_allow([^PKG_CONFIG(_(PATH|LIBDIR|SYSROOT_DIR|ALLOW_SYSTEM_(CFLAGS|LIBS)))?$]) m4_pattern_allow([^PKG_CONFIG_(DISABLE_UNINSTALLED|TOP_BUILD_DIR|DEBUG_SPEW)$]) AC_ARG_VAR([PKG_CONFIG], [path to pkg-config utility]) AC_ARG_VAR([PKG_CONFIG_PATH], [directories to add to pkg-config's search path]) AC_ARG_VAR([PKG_CONFIG_LIBDIR], [path overriding pkg-config's built-in search path]) if test "x$ac_cv_env_PKG_CONFIG_set" != "xset"; then AC_PATH_TOOL([PKG_CONFIG], [pkg-config]) fi if test -n "$PKG_CONFIG"; then _pkg_min_version=m4_default([$1], [0.9.0]) AC_MSG_CHECKING([pkg-config is at least version $_pkg_min_version]) if $PKG_CONFIG --atleast-pkgconfig-version $_pkg_min_version; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) PKG_CONFIG="" fi fi[]dnl ])dnl PKG_PROG_PKG_CONFIG dnl PKG_CHECK_EXISTS(MODULES, [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND]) dnl ------------------------------------------------------------------- dnl Since: 0.18 dnl dnl Check to see whether a particular set of modules exists. Similar to dnl PKG_CHECK_MODULES(), but does not set variables or print errors. dnl dnl Please remember that m4 expands AC_REQUIRE([PKG_PROG_PKG_CONFIG]) dnl only at the first occurrence in configure.ac, so if the first place dnl it's called might be skipped (such as if it is within an "if", you dnl have to call PKG_CHECK_EXISTS manually AC_DEFUN([PKG_CHECK_EXISTS], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl if test -n "$PKG_CONFIG" && \ AC_RUN_LOG([$PKG_CONFIG --exists --print-errors "$1"]); then m4_default([$2], [:]) m4_ifvaln([$3], [else $3])dnl fi]) dnl _PKG_CONFIG([VARIABLE], [COMMAND], [MODULES]) dnl --------------------------------------------- dnl Internal wrapper calling pkg-config via PKG_CONFIG and setting dnl pkg_failed based on the result. m4_define([_PKG_CONFIG], [if test -n "$$1"; then pkg_cv_[]$1="$$1" elif test -n "$PKG_CONFIG"; then PKG_CHECK_EXISTS([$3], [pkg_cv_[]$1=`$PKG_CONFIG --[]$2 "$3" 2>/dev/null` test "x$?" != "x0" && pkg_failed=yes ], [pkg_failed=yes]) else pkg_failed=untried fi[]dnl ])dnl _PKG_CONFIG dnl _PKG_SHORT_ERRORS_SUPPORTED dnl --------------------------- dnl Internal check to see if pkg-config supports short errors. AC_DEFUN([_PKG_SHORT_ERRORS_SUPPORTED], [AC_REQUIRE([PKG_PROG_PKG_CONFIG]) if $PKG_CONFIG --atleast-pkgconfig-version 0.20; then _pkg_short_errors_supported=yes else _pkg_short_errors_supported=no fi[]dnl ])dnl _PKG_SHORT_ERRORS_SUPPORTED dnl PKG_CHECK_MODULES(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND], dnl [ACTION-IF-NOT-FOUND]) dnl -------------------------------------------------------------- dnl Since: 0.4.0 dnl dnl Note that if there is a possibility the first call to dnl PKG_CHECK_MODULES might not happen, you should be sure to include an dnl explicit call to PKG_PROG_PKG_CONFIG in your configure.ac AC_DEFUN([PKG_CHECK_MODULES], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl AC_ARG_VAR([$1][_CFLAGS], [C compiler flags for $1, overriding pkg-config])dnl AC_ARG_VAR([$1][_LIBS], [linker flags for $1, overriding pkg-config])dnl pkg_failed=no AC_MSG_CHECKING([for $2]) _PKG_CONFIG([$1][_CFLAGS], [cflags], [$2]) _PKG_CONFIG([$1][_LIBS], [libs], [$2]) m4_define([_PKG_TEXT], [Alternatively, you may set the environment variables $1[]_CFLAGS and $1[]_LIBS to avoid the need to call pkg-config. See the pkg-config man page for more details.]) if test $pkg_failed = yes; then AC_MSG_RESULT([no]) _PKG_SHORT_ERRORS_SUPPORTED if test $_pkg_short_errors_supported = yes; then $1[]_PKG_ERRORS=`$PKG_CONFIG --short-errors --print-errors --cflags --libs "$2" 2>&1` else $1[]_PKG_ERRORS=`$PKG_CONFIG --print-errors --cflags --libs "$2" 2>&1` fi # Put the nasty error message in config.log where it belongs echo "$$1[]_PKG_ERRORS" >&AS_MESSAGE_LOG_FD m4_default([$4], [AC_MSG_ERROR( [Package requirements ($2) were not met: $$1_PKG_ERRORS Consider adjusting the PKG_CONFIG_PATH environment variable if you installed software in a non-standard prefix. _PKG_TEXT])[]dnl ]) elif test $pkg_failed = untried; then AC_MSG_RESULT([no]) m4_default([$4], [AC_MSG_FAILURE( [The pkg-config script could not be found or is too old. Make sure it is in your PATH or set the PKG_CONFIG environment variable to the full path to pkg-config. _PKG_TEXT To get pkg-config, see .])[]dnl ]) else $1[]_CFLAGS=$pkg_cv_[]$1[]_CFLAGS $1[]_LIBS=$pkg_cv_[]$1[]_LIBS AC_MSG_RESULT([yes]) $3 fi[]dnl ])dnl PKG_CHECK_MODULES dnl PKG_CHECK_MODULES_STATIC(VARIABLE-PREFIX, MODULES, [ACTION-IF-FOUND], dnl [ACTION-IF-NOT-FOUND]) dnl --------------------------------------------------------------------- dnl Since: 0.29 dnl dnl Checks for existence of MODULES and gathers its build flags with dnl static libraries enabled. Sets VARIABLE-PREFIX_CFLAGS from --cflags dnl and VARIABLE-PREFIX_LIBS from --libs. dnl dnl Note that if there is a possibility the first call to dnl PKG_CHECK_MODULES_STATIC might not happen, you should be sure to dnl include an explicit call to PKG_PROG_PKG_CONFIG in your dnl configure.ac. AC_DEFUN([PKG_CHECK_MODULES_STATIC], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl _save_PKG_CONFIG=$PKG_CONFIG PKG_CONFIG="$PKG_CONFIG --static" PKG_CHECK_MODULES($@) PKG_CONFIG=$_save_PKG_CONFIG[]dnl ])dnl PKG_CHECK_MODULES_STATIC dnl PKG_INSTALLDIR([DIRECTORY]) dnl ------------------------- dnl Since: 0.27 dnl dnl Substitutes the variable pkgconfigdir as the location where a module dnl should install pkg-config .pc files. By default the directory is dnl $libdir/pkgconfig, but the default can be changed by passing dnl DIRECTORY. The user can override through the --with-pkgconfigdir dnl parameter. AC_DEFUN([PKG_INSTALLDIR], [m4_pushdef([pkg_default], [m4_default([$1], ['${libdir}/pkgconfig'])]) m4_pushdef([pkg_description], [pkg-config installation directory @<:@]pkg_default[@:>@]) AC_ARG_WITH([pkgconfigdir], [AS_HELP_STRING([--with-pkgconfigdir], pkg_description)],, [with_pkgconfigdir=]pkg_default) AC_SUBST([pkgconfigdir], [$with_pkgconfigdir]) m4_popdef([pkg_default]) m4_popdef([pkg_description]) ])dnl PKG_INSTALLDIR dnl PKG_NOARCH_INSTALLDIR([DIRECTORY]) dnl -------------------------------- dnl Since: 0.27 dnl dnl Substitutes the variable noarch_pkgconfigdir as the location where a dnl module should install arch-independent pkg-config .pc files. By dnl default the directory is $datadir/pkgconfig, but the default can be dnl changed by passing DIRECTORY. The user can override through the dnl --with-noarch-pkgconfigdir parameter. AC_DEFUN([PKG_NOARCH_INSTALLDIR], [m4_pushdef([pkg_default], [m4_default([$1], ['${datadir}/pkgconfig'])]) m4_pushdef([pkg_description], [pkg-config arch-independent installation directory @<:@]pkg_default[@:>@]) AC_ARG_WITH([noarch-pkgconfigdir], [AS_HELP_STRING([--with-noarch-pkgconfigdir], pkg_description)],, [with_noarch_pkgconfigdir=]pkg_default) AC_SUBST([noarch_pkgconfigdir], [$with_noarch_pkgconfigdir]) m4_popdef([pkg_default]) m4_popdef([pkg_description]) ])dnl PKG_NOARCH_INSTALLDIR dnl PKG_CHECK_VAR(VARIABLE, MODULE, CONFIG-VARIABLE, dnl [ACTION-IF-FOUND], [ACTION-IF-NOT-FOUND]) dnl ------------------------------------------- dnl Since: 0.28 dnl dnl Retrieves the value of the pkg-config variable for the given module. AC_DEFUN([PKG_CHECK_VAR], [AC_REQUIRE([PKG_PROG_PKG_CONFIG])dnl AC_ARG_VAR([$1], [value of $3 for $2, overriding pkg-config])dnl _PKG_CONFIG([$1], [variable="][$3]["], [$2]) AS_VAR_COPY([$1], [pkg_cv_][$1]) AS_VAR_IF([$1], [""], [$5], [$4])dnl ])dnl PKG_CHECK_VAR dnl PKG_WITH_MODULES(VARIABLE-PREFIX, MODULES, dnl [ACTION-IF-FOUND],[ACTION-IF-NOT-FOUND], dnl [DESCRIPTION], [DEFAULT]) dnl ------------------------------------------ dnl dnl Prepare a "--with-" configure option using the lowercase dnl [VARIABLE-PREFIX] name, merging the behaviour of AC_ARG_WITH and dnl PKG_CHECK_MODULES in a single macro. AC_DEFUN([PKG_WITH_MODULES], [ m4_pushdef([with_arg], m4_tolower([$1])) m4_pushdef([description], [m4_default([$5], [build with ]with_arg[ support])]) m4_pushdef([def_arg], [m4_default([$6], [auto])]) m4_pushdef([def_action_if_found], [AS_TR_SH([with_]with_arg)=yes]) m4_pushdef([def_action_if_not_found], [AS_TR_SH([with_]with_arg)=no]) m4_case(def_arg, [yes],[m4_pushdef([with_without], [--without-]with_arg)], [m4_pushdef([with_without],[--with-]with_arg)]) AC_ARG_WITH(with_arg, AS_HELP_STRING(with_without, description[ @<:@default=]def_arg[@:>@]),, [AS_TR_SH([with_]with_arg)=def_arg]) AS_CASE([$AS_TR_SH([with_]with_arg)], [yes],[PKG_CHECK_MODULES([$1],[$2],$3,$4)], [auto],[PKG_CHECK_MODULES([$1],[$2], [m4_n([def_action_if_found]) $3], [m4_n([def_action_if_not_found]) $4])]) m4_popdef([with_arg]) m4_popdef([description]) m4_popdef([def_arg]) ])dnl PKG_WITH_MODULES dnl PKG_HAVE_WITH_MODULES(VARIABLE-PREFIX, MODULES, dnl [DESCRIPTION], [DEFAULT]) dnl ----------------------------------------------- dnl dnl Convenience macro to trigger AM_CONDITIONAL after PKG_WITH_MODULES dnl check._[VARIABLE-PREFIX] is exported as make variable. AC_DEFUN([PKG_HAVE_WITH_MODULES], [ PKG_WITH_MODULES([$1],[$2],,,[$3],[$4]) AM_CONDITIONAL([HAVE_][$1], [test "$AS_TR_SH([with_]m4_tolower([$1]))" = "yes"]) ])dnl PKG_HAVE_WITH_MODULES dnl PKG_HAVE_DEFINE_WITH_MODULES(VARIABLE-PREFIX, MODULES, dnl [DESCRIPTION], [DEFAULT]) dnl ------------------------------------------------------ dnl dnl Convenience macro to run AM_CONDITIONAL and AC_DEFINE after dnl PKG_WITH_MODULES check. HAVE_[VARIABLE-PREFIX] is exported as make dnl and preprocessor variable. AC_DEFUN([PKG_HAVE_DEFINE_WITH_MODULES], [ PKG_HAVE_WITH_MODULES([$1],[$2],[$3],[$4]) AS_IF([test "$AS_TR_SH([with_]m4_tolower([$1]))" = "yes"], [AC_DEFINE([HAVE_][$1], 1, [Enable ]m4_tolower([$1])[ support])]) ])dnl PKG_HAVE_DEFINE_WITH_MODULES # Copyright (C) 2002-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_AUTOMAKE_VERSION(VERSION) # ---------------------------- # Automake X.Y traces this macro to ensure aclocal.m4 has been # generated from the m4 files accompanying Automake X.Y. # (This private macro should not be called outside this file.) AC_DEFUN([AM_AUTOMAKE_VERSION], [am__api_version='1.16' dnl Some users find AM_AUTOMAKE_VERSION and mistake it for a way to dnl require some minimum version. Point them to the right macro. m4_if([$1], [1.16.5], [], [AC_FATAL([Do not call $0, use AM_INIT_AUTOMAKE([$1]).])])dnl ]) # _AM_AUTOCONF_VERSION(VERSION) # ----------------------------- # aclocal traces this macro to find the Autoconf version. # This is a private macro too. Using m4_define simplifies # the logic in aclocal, which can simply ignore this definition. m4_define([_AM_AUTOCONF_VERSION], []) # AM_SET_CURRENT_AUTOMAKE_VERSION # ------------------------------- # Call AM_AUTOMAKE_VERSION and AM_AUTOMAKE_VERSION so they can be traced. # This function is AC_REQUIREd by AM_INIT_AUTOMAKE. AC_DEFUN([AM_SET_CURRENT_AUTOMAKE_VERSION], [AM_AUTOMAKE_VERSION([1.16.5])dnl m4_ifndef([AC_AUTOCONF_VERSION], [m4_copy([m4_PACKAGE_VERSION], [AC_AUTOCONF_VERSION])])dnl _AM_AUTOCONF_VERSION(m4_defn([AC_AUTOCONF_VERSION]))]) # AM_AUX_DIR_EXPAND -*- Autoconf -*- # Copyright (C) 2001-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # For projects using AC_CONFIG_AUX_DIR([foo]), Autoconf sets # $ac_aux_dir to '$srcdir/foo'. In other projects, it is set to # '$srcdir', '$srcdir/..', or '$srcdir/../..'. # # Of course, Automake must honor this variable whenever it calls a # tool from the auxiliary directory. The problem is that $srcdir (and # therefore $ac_aux_dir as well) can be either absolute or relative, # depending on how configure is run. This is pretty annoying, since # it makes $ac_aux_dir quite unusable in subdirectories: in the top # source directory, any form will work fine, but in subdirectories a # relative path needs to be adjusted first. # # $ac_aux_dir/missing # fails when called from a subdirectory if $ac_aux_dir is relative # $top_srcdir/$ac_aux_dir/missing # fails if $ac_aux_dir is absolute, # fails when called from a subdirectory in a VPATH build with # a relative $ac_aux_dir # # The reason of the latter failure is that $top_srcdir and $ac_aux_dir # are both prefixed by $srcdir. In an in-source build this is usually # harmless because $srcdir is '.', but things will broke when you # start a VPATH build or use an absolute $srcdir. # # So we could use something similar to $top_srcdir/$ac_aux_dir/missing, # iff we strip the leading $srcdir from $ac_aux_dir. That would be: # am_aux_dir='\$(top_srcdir)/'`expr "$ac_aux_dir" : "$srcdir//*\(.*\)"` # and then we would define $MISSING as # MISSING="\${SHELL} $am_aux_dir/missing" # This will work as long as MISSING is not called from configure, because # unfortunately $(top_srcdir) has no meaning in configure. # However there are other variables, like CC, which are often used in # configure, and could therefore not use this "fixed" $ac_aux_dir. # # Another solution, used here, is to always expand $ac_aux_dir to an # absolute PATH. The drawback is that using absolute paths prevent a # configured tree to be moved without reconfiguration. AC_DEFUN([AM_AUX_DIR_EXPAND], [AC_REQUIRE([AC_CONFIG_AUX_DIR_DEFAULT])dnl # Expand $ac_aux_dir to an absolute path. am_aux_dir=`cd "$ac_aux_dir" && pwd` ]) # AM_CONDITIONAL -*- Autoconf -*- # Copyright (C) 1997-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_CONDITIONAL(NAME, SHELL-CONDITION) # ------------------------------------- # Define a conditional. AC_DEFUN([AM_CONDITIONAL], [AC_PREREQ([2.52])dnl m4_if([$1], [TRUE], [AC_FATAL([$0: invalid condition: $1])], [$1], [FALSE], [AC_FATAL([$0: invalid condition: $1])])dnl AC_SUBST([$1_TRUE])dnl AC_SUBST([$1_FALSE])dnl _AM_SUBST_NOTMAKE([$1_TRUE])dnl _AM_SUBST_NOTMAKE([$1_FALSE])dnl m4_define([_AM_COND_VALUE_$1], [$2])dnl if $2; then $1_TRUE= $1_FALSE='#' else $1_TRUE='#' $1_FALSE= fi AC_CONFIG_COMMANDS_PRE( [if test -z "${$1_TRUE}" && test -z "${$1_FALSE}"; then AC_MSG_ERROR([[conditional "$1" was never defined. Usually this means the macro was only invoked conditionally.]]) fi])]) # Copyright (C) 1999-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # There are a few dirty hacks below to avoid letting 'AC_PROG_CC' be # written in clear, in which case automake, when reading aclocal.m4, # will think it sees a *use*, and therefore will trigger all it's # C support machinery. Also note that it means that autoscan, seeing # CC etc. in the Makefile, will ask for an AC_PROG_CC use... # _AM_DEPENDENCIES(NAME) # ---------------------- # See how the compiler implements dependency checking. # NAME is "CC", "CXX", "OBJC", "OBJCXX", "UPC", or "GJC". # We try a few techniques and use that to set a single cache variable. # # We don't AC_REQUIRE the corresponding AC_PROG_CC since the latter was # modified to invoke _AM_DEPENDENCIES(CC); we would have a circular # dependency, and given that the user is not expected to run this macro, # just rely on AC_PROG_CC. AC_DEFUN([_AM_DEPENDENCIES], [AC_REQUIRE([AM_SET_DEPDIR])dnl AC_REQUIRE([AM_OUTPUT_DEPENDENCY_COMMANDS])dnl AC_REQUIRE([AM_MAKE_INCLUDE])dnl AC_REQUIRE([AM_DEP_TRACK])dnl m4_if([$1], [CC], [depcc="$CC" am_compiler_list=], [$1], [CXX], [depcc="$CXX" am_compiler_list=], [$1], [OBJC], [depcc="$OBJC" am_compiler_list='gcc3 gcc'], [$1], [OBJCXX], [depcc="$OBJCXX" am_compiler_list='gcc3 gcc'], [$1], [UPC], [depcc="$UPC" am_compiler_list=], [$1], [GCJ], [depcc="$GCJ" am_compiler_list='gcc3 gcc'], [depcc="$$1" am_compiler_list=]) AC_CACHE_CHECK([dependency style of $depcc], [am_cv_$1_dependencies_compiler_type], [if test -z "$AMDEP_TRUE" && test -f "$am_depcomp"; then # We make a subdir and do the tests there. Otherwise we can end up # making bogus files that we don't know about and never remove. For # instance it was reported that on HP-UX the gcc test will end up # making a dummy file named 'D' -- because '-MD' means "put the output # in D". rm -rf conftest.dir mkdir conftest.dir # Copy depcomp to subdir because otherwise we won't find it if we're # using a relative directory. cp "$am_depcomp" conftest.dir cd conftest.dir # We will build objects and dependencies in a subdirectory because # it helps to detect inapplicable dependency modes. For instance # both Tru64's cc and ICC support -MD to output dependencies as a # side effect of compilation, but ICC will put the dependencies in # the current directory while Tru64 will put them in the object # directory. mkdir sub am_cv_$1_dependencies_compiler_type=none if test "$am_compiler_list" = ""; then am_compiler_list=`sed -n ['s/^#*\([a-zA-Z0-9]*\))$/\1/p'] < ./depcomp` fi am__universal=false m4_case([$1], [CC], [case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac], [CXX], [case " $depcc " in #( *\ -arch\ *\ -arch\ *) am__universal=true ;; esac]) for depmode in $am_compiler_list; do # Setup a source with many dependencies, because some compilers # like to wrap large dependency lists on column 80 (with \), and # we should not choose a depcomp mode which is confused by this. # # We need to recreate these files for each test, as the compiler may # overwrite some of them when testing with obscure command lines. # This happens at least with the AIX C compiler. : > sub/conftest.c for i in 1 2 3 4 5 6; do echo '#include "conftst'$i'.h"' >> sub/conftest.c # Using ": > sub/conftst$i.h" creates only sub/conftst1.h with # Solaris 10 /bin/sh. echo '/* dummy */' > sub/conftst$i.h done echo "${am__include} ${am__quote}sub/conftest.Po${am__quote}" > confmf # We check with '-c' and '-o' for the sake of the "dashmstdout" # mode. It turns out that the SunPro C++ compiler does not properly # handle '-M -o', and we need to detect this. Also, some Intel # versions had trouble with output in subdirs. am__obj=sub/conftest.${OBJEXT-o} am__minus_obj="-o $am__obj" case $depmode in gcc) # This depmode causes a compiler race in universal mode. test "$am__universal" = false || continue ;; nosideeffect) # After this tag, mechanisms are not by side-effect, so they'll # only be used when explicitly requested. if test "x$enable_dependency_tracking" = xyes; then continue else break fi ;; msvc7 | msvc7msys | msvisualcpp | msvcmsys) # This compiler won't grok '-c -o', but also, the minuso test has # not run yet. These depmodes are late enough in the game, and # so weak that their functioning should not be impacted. am__obj=conftest.${OBJEXT-o} am__minus_obj= ;; none) break ;; esac if depmode=$depmode \ source=sub/conftest.c object=$am__obj \ depfile=sub/conftest.Po tmpdepfile=sub/conftest.TPo \ $SHELL ./depcomp $depcc -c $am__minus_obj sub/conftest.c \ >/dev/null 2>conftest.err && grep sub/conftst1.h sub/conftest.Po > /dev/null 2>&1 && grep sub/conftst6.h sub/conftest.Po > /dev/null 2>&1 && grep $am__obj sub/conftest.Po > /dev/null 2>&1 && ${MAKE-make} -s -f confmf > /dev/null 2>&1; then # icc doesn't choke on unknown options, it will just issue warnings # or remarks (even with -Werror). So we grep stderr for any message # that says an option was ignored or not supported. # When given -MP, icc 7.0 and 7.1 complain thusly: # icc: Command line warning: ignoring option '-M'; no argument required # The diagnosis changed in icc 8.0: # icc: Command line remark: option '-MP' not supported if (grep 'ignoring option' conftest.err || grep 'not supported' conftest.err) >/dev/null 2>&1; then :; else am_cv_$1_dependencies_compiler_type=$depmode break fi fi done cd .. rm -rf conftest.dir else am_cv_$1_dependencies_compiler_type=none fi ]) AC_SUBST([$1DEPMODE], [depmode=$am_cv_$1_dependencies_compiler_type]) AM_CONDITIONAL([am__fastdep$1], [ test "x$enable_dependency_tracking" != xno \ && test "$am_cv_$1_dependencies_compiler_type" = gcc3]) ]) # AM_SET_DEPDIR # ------------- # Choose a directory name for dependency files. # This macro is AC_REQUIREd in _AM_DEPENDENCIES. AC_DEFUN([AM_SET_DEPDIR], [AC_REQUIRE([AM_SET_LEADING_DOT])dnl AC_SUBST([DEPDIR], ["${am__leading_dot}deps"])dnl ]) # AM_DEP_TRACK # ------------ AC_DEFUN([AM_DEP_TRACK], [AC_ARG_ENABLE([dependency-tracking], [dnl AS_HELP_STRING( [--enable-dependency-tracking], [do not reject slow dependency extractors]) AS_HELP_STRING( [--disable-dependency-tracking], [speeds up one-time build])]) if test "x$enable_dependency_tracking" != xno; then am_depcomp="$ac_aux_dir/depcomp" AMDEPBACKSLASH='\' am__nodep='_no' fi AM_CONDITIONAL([AMDEP], [test "x$enable_dependency_tracking" != xno]) AC_SUBST([AMDEPBACKSLASH])dnl _AM_SUBST_NOTMAKE([AMDEPBACKSLASH])dnl AC_SUBST([am__nodep])dnl _AM_SUBST_NOTMAKE([am__nodep])dnl ]) # Generate code to set up dependency tracking. -*- Autoconf -*- # Copyright (C) 1999-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_OUTPUT_DEPENDENCY_COMMANDS # ------------------------------ AC_DEFUN([_AM_OUTPUT_DEPENDENCY_COMMANDS], [{ # Older Autoconf quotes --file arguments for eval, but not when files # are listed without --file. Let's play safe and only enable the eval # if we detect the quoting. # TODO: see whether this extra hack can be removed once we start # requiring Autoconf 2.70 or later. AS_CASE([$CONFIG_FILES], [*\'*], [eval set x "$CONFIG_FILES"], [*], [set x $CONFIG_FILES]) shift # Used to flag and report bootstrapping failures. am_rc=0 for am_mf do # Strip MF so we end up with the name of the file. am_mf=`AS_ECHO(["$am_mf"]) | sed -e 's/:.*$//'` # Check whether this is an Automake generated Makefile which includes # dependency-tracking related rules and includes. # Grep'ing the whole file directly is not great: AIX grep has a line # limit of 2048, but all sed's we know have understand at least 4000. sed -n 's,^am--depfiles:.*,X,p' "$am_mf" | grep X >/dev/null 2>&1 \ || continue am_dirpart=`AS_DIRNAME(["$am_mf"])` am_filepart=`AS_BASENAME(["$am_mf"])` AM_RUN_LOG([cd "$am_dirpart" \ && sed -e '/# am--include-marker/d' "$am_filepart" \ | $MAKE -f - am--depfiles]) || am_rc=$? done if test $am_rc -ne 0; then AC_MSG_FAILURE([Something went wrong bootstrapping makefile fragments for automatic dependency tracking. If GNU make was not used, consider re-running the configure script with MAKE="gmake" (or whatever is necessary). You can also try re-running configure with the '--disable-dependency-tracking' option to at least be able to build the package (albeit without support for automatic dependency tracking).]) fi AS_UNSET([am_dirpart]) AS_UNSET([am_filepart]) AS_UNSET([am_mf]) AS_UNSET([am_rc]) rm -f conftest-deps.mk } ])# _AM_OUTPUT_DEPENDENCY_COMMANDS # AM_OUTPUT_DEPENDENCY_COMMANDS # ----------------------------- # This macro should only be invoked once -- use via AC_REQUIRE. # # This code is only required when automatic dependency tracking is enabled. # This creates each '.Po' and '.Plo' makefile fragment that we'll need in # order to bootstrap the dependency handling code. AC_DEFUN([AM_OUTPUT_DEPENDENCY_COMMANDS], [AC_CONFIG_COMMANDS([depfiles], [test x"$AMDEP_TRUE" != x"" || _AM_OUTPUT_DEPENDENCY_COMMANDS], [AMDEP_TRUE="$AMDEP_TRUE" MAKE="${MAKE-make}"])]) # AM_EXTRA_RECURSIVE_TARGETS -*- Autoconf -*- # Copyright (C) 2012-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_EXTRA_RECURSIVE_TARGETS # -------------------------- # Define the list of user recursive targets. This macro exists only to # be traced by Automake, which will ensure that a proper definition of # user-defined recursive targets (and associated rules) is propagated # into all the generated Makefiles. # TODO: We should really reject non-literal arguments here... AC_DEFUN([AM_EXTRA_RECURSIVE_TARGETS], []) # Do all the work for Automake. -*- Autoconf -*- # Copyright (C) 1996-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # This macro actually does too much. Some checks are only needed if # your package does certain things. But this isn't really a big deal. dnl Redefine AC_PROG_CC to automatically invoke _AM_PROG_CC_C_O. m4_define([AC_PROG_CC], m4_defn([AC_PROG_CC]) [_AM_PROG_CC_C_O ]) # AM_INIT_AUTOMAKE(PACKAGE, VERSION, [NO-DEFINE]) # AM_INIT_AUTOMAKE([OPTIONS]) # ----------------------------------------------- # The call with PACKAGE and VERSION arguments is the old style # call (pre autoconf-2.50), which is being phased out. PACKAGE # and VERSION should now be passed to AC_INIT and removed from # the call to AM_INIT_AUTOMAKE. # We support both call styles for the transition. After # the next Automake release, Autoconf can make the AC_INIT # arguments mandatory, and then we can depend on a new Autoconf # release and drop the old call support. AC_DEFUN([AM_INIT_AUTOMAKE], [AC_PREREQ([2.65])dnl m4_ifdef([_$0_ALREADY_INIT], [m4_fatal([$0 expanded multiple times ]m4_defn([_$0_ALREADY_INIT]))], [m4_define([_$0_ALREADY_INIT], m4_expansion_stack)])dnl dnl Autoconf wants to disallow AM_ names. We explicitly allow dnl the ones we care about. m4_pattern_allow([^AM_[A-Z]+FLAGS$])dnl AC_REQUIRE([AM_SET_CURRENT_AUTOMAKE_VERSION])dnl AC_REQUIRE([AC_PROG_INSTALL])dnl if test "`cd $srcdir && pwd`" != "`pwd`"; then # Use -I$(srcdir) only when $(srcdir) != ., so that make's output # is not polluted with repeated "-I." AC_SUBST([am__isrc], [' -I$(srcdir)'])_AM_SUBST_NOTMAKE([am__isrc])dnl # test to see if srcdir already configured if test -f $srcdir/config.status; then AC_MSG_ERROR([source directory already configured; run "make distclean" there first]) fi fi # test whether we have cygpath if test -z "$CYGPATH_W"; then if (cygpath --version) >/dev/null 2>/dev/null; then CYGPATH_W='cygpath -w' else CYGPATH_W=echo fi fi AC_SUBST([CYGPATH_W]) # Define the identity of the package. dnl Distinguish between old-style and new-style calls. m4_ifval([$2], [AC_DIAGNOSE([obsolete], [$0: two- and three-arguments forms are deprecated.]) m4_ifval([$3], [_AM_SET_OPTION([no-define])])dnl AC_SUBST([PACKAGE], [$1])dnl AC_SUBST([VERSION], [$2])], [_AM_SET_OPTIONS([$1])dnl dnl Diagnose old-style AC_INIT with new-style AM_AUTOMAKE_INIT. m4_if( m4_ifset([AC_PACKAGE_NAME], [ok]):m4_ifset([AC_PACKAGE_VERSION], [ok]), [ok:ok],, [m4_fatal([AC_INIT should be called with package and version arguments])])dnl AC_SUBST([PACKAGE], ['AC_PACKAGE_TARNAME'])dnl AC_SUBST([VERSION], ['AC_PACKAGE_VERSION'])])dnl _AM_IF_OPTION([no-define],, [AC_DEFINE_UNQUOTED([PACKAGE], ["$PACKAGE"], [Name of package]) AC_DEFINE_UNQUOTED([VERSION], ["$VERSION"], [Version number of package])])dnl # Some tools Automake needs. AC_REQUIRE([AM_SANITY_CHECK])dnl AC_REQUIRE([AC_ARG_PROGRAM])dnl AM_MISSING_PROG([ACLOCAL], [aclocal-${am__api_version}]) AM_MISSING_PROG([AUTOCONF], [autoconf]) AM_MISSING_PROG([AUTOMAKE], [automake-${am__api_version}]) AM_MISSING_PROG([AUTOHEADER], [autoheader]) AM_MISSING_PROG([MAKEINFO], [makeinfo]) AC_REQUIRE([AM_PROG_INSTALL_SH])dnl AC_REQUIRE([AM_PROG_INSTALL_STRIP])dnl AC_REQUIRE([AC_PROG_MKDIR_P])dnl # For better backward compatibility. To be removed once Automake 1.9.x # dies out for good. For more background, see: # # AC_SUBST([mkdir_p], ['$(MKDIR_P)']) # We need awk for the "check" target (and possibly the TAP driver). The # system "awk" is bad on some platforms. AC_REQUIRE([AC_PROG_AWK])dnl AC_REQUIRE([AC_PROG_MAKE_SET])dnl AC_REQUIRE([AM_SET_LEADING_DOT])dnl _AM_IF_OPTION([tar-ustar], [_AM_PROG_TAR([ustar])], [_AM_IF_OPTION([tar-pax], [_AM_PROG_TAR([pax])], [_AM_PROG_TAR([v7])])]) _AM_IF_OPTION([no-dependencies],, [AC_PROVIDE_IFELSE([AC_PROG_CC], [_AM_DEPENDENCIES([CC])], [m4_define([AC_PROG_CC], m4_defn([AC_PROG_CC])[_AM_DEPENDENCIES([CC])])])dnl AC_PROVIDE_IFELSE([AC_PROG_CXX], [_AM_DEPENDENCIES([CXX])], [m4_define([AC_PROG_CXX], m4_defn([AC_PROG_CXX])[_AM_DEPENDENCIES([CXX])])])dnl AC_PROVIDE_IFELSE([AC_PROG_OBJC], [_AM_DEPENDENCIES([OBJC])], [m4_define([AC_PROG_OBJC], m4_defn([AC_PROG_OBJC])[_AM_DEPENDENCIES([OBJC])])])dnl AC_PROVIDE_IFELSE([AC_PROG_OBJCXX], [_AM_DEPENDENCIES([OBJCXX])], [m4_define([AC_PROG_OBJCXX], m4_defn([AC_PROG_OBJCXX])[_AM_DEPENDENCIES([OBJCXX])])])dnl ]) # Variables for tags utilities; see am/tags.am if test -z "$CTAGS"; then CTAGS=ctags fi AC_SUBST([CTAGS]) if test -z "$ETAGS"; then ETAGS=etags fi AC_SUBST([ETAGS]) if test -z "$CSCOPE"; then CSCOPE=cscope fi AC_SUBST([CSCOPE]) AC_REQUIRE([AM_SILENT_RULES])dnl dnl The testsuite driver may need to know about EXEEXT, so add the dnl 'am__EXEEXT' conditional if _AM_COMPILER_EXEEXT was seen. This dnl macro is hooked onto _AC_COMPILER_EXEEXT early, see below. AC_CONFIG_COMMANDS_PRE(dnl [m4_provide_if([_AM_COMPILER_EXEEXT], [AM_CONDITIONAL([am__EXEEXT], [test -n "$EXEEXT"])])])dnl # POSIX will say in a future version that running "rm -f" with no argument # is OK; and we want to be able to make that assumption in our Makefile # recipes. So use an aggressive probe to check that the usage we want is # actually supported "in the wild" to an acceptable degree. # See automake bug#10828. # To make any issue more visible, cause the running configure to be aborted # by default if the 'rm' program in use doesn't match our expectations; the # user can still override this though. if rm -f && rm -fr && rm -rf; then : OK; else cat >&2 <<'END' Oops! Your 'rm' program seems unable to run without file operands specified on the command line, even when the '-f' option is present. This is contrary to the behaviour of most rm programs out there, and not conforming with the upcoming POSIX standard: Please tell bug-automake@gnu.org about your system, including the value of your $PATH and any error possibly output before this message. This can help us improve future automake versions. END if test x"$ACCEPT_INFERIOR_RM_PROGRAM" = x"yes"; then echo 'Configuration will proceed anyway, since you have set the' >&2 echo 'ACCEPT_INFERIOR_RM_PROGRAM variable to "yes"' >&2 echo >&2 else cat >&2 <<'END' Aborting the configuration process, to ensure you take notice of the issue. You can download and install GNU coreutils to get an 'rm' implementation that behaves properly: . If you want to complete the configuration process using your problematic 'rm' anyway, export the environment variable ACCEPT_INFERIOR_RM_PROGRAM to "yes", and re-run configure. END AC_MSG_ERROR([Your 'rm' program is bad, sorry.]) fi fi dnl The trailing newline in this macro's definition is deliberate, for dnl backward compatibility and to allow trailing 'dnl'-style comments dnl after the AM_INIT_AUTOMAKE invocation. See automake bug#16841. ]) dnl Hook into '_AC_COMPILER_EXEEXT' early to learn its expansion. Do not dnl add the conditional right here, as _AC_COMPILER_EXEEXT may be further dnl mangled by Autoconf and run in a shell conditional statement. m4_define([_AC_COMPILER_EXEEXT], m4_defn([_AC_COMPILER_EXEEXT])[m4_provide([_AM_COMPILER_EXEEXT])]) # When config.status generates a header, we must update the stamp-h file. # This file resides in the same directory as the config header # that is generated. The stamp files are numbered to have different names. # Autoconf calls _AC_AM_CONFIG_HEADER_HOOK (when defined) in the # loop where config.status creates the headers, so we can generate # our stamp files there. AC_DEFUN([_AC_AM_CONFIG_HEADER_HOOK], [# Compute $1's index in $config_headers. _am_arg=$1 _am_stamp_count=1 for _am_header in $config_headers :; do case $_am_header in $_am_arg | $_am_arg:* ) break ;; * ) _am_stamp_count=`expr $_am_stamp_count + 1` ;; esac done echo "timestamp for $_am_arg" >`AS_DIRNAME(["$_am_arg"])`/stamp-h[]$_am_stamp_count]) # Copyright (C) 2001-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_PROG_INSTALL_SH # ------------------ # Define $install_sh. AC_DEFUN([AM_PROG_INSTALL_SH], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl if test x"${install_sh+set}" != xset; then case $am_aux_dir in *\ * | *\ *) install_sh="\${SHELL} '$am_aux_dir/install-sh'" ;; *) install_sh="\${SHELL} $am_aux_dir/install-sh" esac fi AC_SUBST([install_sh])]) # Copyright (C) 2003-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # Check whether the underlying file-system supports filenames # with a leading dot. For instance MS-DOS doesn't. AC_DEFUN([AM_SET_LEADING_DOT], [rm -rf .tst 2>/dev/null mkdir .tst 2>/dev/null if test -d .tst; then am__leading_dot=. else am__leading_dot=_ fi rmdir .tst 2>/dev/null AC_SUBST([am__leading_dot])]) # Check to see how 'make' treats includes. -*- Autoconf -*- # Copyright (C) 2001-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_MAKE_INCLUDE() # ----------------- # Check whether make has an 'include' directive that can support all # the idioms we need for our automatic dependency tracking code. AC_DEFUN([AM_MAKE_INCLUDE], [AC_MSG_CHECKING([whether ${MAKE-make} supports the include directive]) cat > confinc.mk << 'END' am__doit: @echo this is the am__doit target >confinc.out .PHONY: am__doit END am__include="#" am__quote= # BSD make does it like this. echo '.include "confinc.mk" # ignored' > confmf.BSD # Other make implementations (GNU, Solaris 10, AIX) do it like this. echo 'include confinc.mk # ignored' > confmf.GNU _am_result=no for s in GNU BSD; do AM_RUN_LOG([${MAKE-make} -f confmf.$s && cat confinc.out]) AS_CASE([$?:`cat confinc.out 2>/dev/null`], ['0:this is the am__doit target'], [AS_CASE([$s], [BSD], [am__include='.include' am__quote='"'], [am__include='include' am__quote=''])]) if test "$am__include" != "#"; then _am_result="yes ($s style)" break fi done rm -f confinc.* confmf.* AC_MSG_RESULT([${_am_result}]) AC_SUBST([am__include])]) AC_SUBST([am__quote])]) # Fake the existence of programs that GNU maintainers use. -*- Autoconf -*- # Copyright (C) 1997-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_MISSING_PROG(NAME, PROGRAM) # ------------------------------ AC_DEFUN([AM_MISSING_PROG], [AC_REQUIRE([AM_MISSING_HAS_RUN]) $1=${$1-"${am_missing_run}$2"} AC_SUBST($1)]) # AM_MISSING_HAS_RUN # ------------------ # Define MISSING if not defined so far and test if it is modern enough. # If it is, set am_missing_run to use it, otherwise, to nothing. AC_DEFUN([AM_MISSING_HAS_RUN], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl AC_REQUIRE_AUX_FILE([missing])dnl if test x"${MISSING+set}" != xset; then MISSING="\${SHELL} '$am_aux_dir/missing'" fi # Use eval to expand $SHELL if eval "$MISSING --is-lightweight"; then am_missing_run="$MISSING " else am_missing_run= AC_MSG_WARN(['missing' script is too old or missing]) fi ]) # Helper functions for option handling. -*- Autoconf -*- # Copyright (C) 2001-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_MANGLE_OPTION(NAME) # ----------------------- AC_DEFUN([_AM_MANGLE_OPTION], [[_AM_OPTION_]m4_bpatsubst($1, [[^a-zA-Z0-9_]], [_])]) # _AM_SET_OPTION(NAME) # -------------------- # Set option NAME. Presently that only means defining a flag for this option. AC_DEFUN([_AM_SET_OPTION], [m4_define(_AM_MANGLE_OPTION([$1]), [1])]) # _AM_SET_OPTIONS(OPTIONS) # ------------------------ # OPTIONS is a space-separated list of Automake options. AC_DEFUN([_AM_SET_OPTIONS], [m4_foreach_w([_AM_Option], [$1], [_AM_SET_OPTION(_AM_Option)])]) # _AM_IF_OPTION(OPTION, IF-SET, [IF-NOT-SET]) # ------------------------------------------- # Execute IF-SET if OPTION is set, IF-NOT-SET otherwise. AC_DEFUN([_AM_IF_OPTION], [m4_ifset(_AM_MANGLE_OPTION([$1]), [$2], [$3])]) # Copyright (C) 1999-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_PROG_CC_C_O # --------------- # Like AC_PROG_CC_C_O, but changed for automake. We rewrite AC_PROG_CC # to automatically call this. AC_DEFUN([_AM_PROG_CC_C_O], [AC_REQUIRE([AM_AUX_DIR_EXPAND])dnl AC_REQUIRE_AUX_FILE([compile])dnl AC_LANG_PUSH([C])dnl AC_CACHE_CHECK( [whether $CC understands -c and -o together], [am_cv_prog_cc_c_o], [AC_LANG_CONFTEST([AC_LANG_PROGRAM([])]) # Make sure it works both with $CC and with simple cc. # Following AC_PROG_CC_C_O, we do the test twice because some # compilers refuse to overwrite an existing .o file with -o, # though they will create one. am_cv_prog_cc_c_o=yes for am_i in 1 2; do if AM_RUN_LOG([$CC -c conftest.$ac_ext -o conftest2.$ac_objext]) \ && test -f conftest2.$ac_objext; then : OK else am_cv_prog_cc_c_o=no break fi done rm -f core conftest* unset am_i]) if test "$am_cv_prog_cc_c_o" != yes; then # Losing compiler, so override with the script. # FIXME: It is wrong to rewrite CC. # But if we don't then we get into trouble of one sort or another. # A longer-term fix would be to have automake use am__CC in this case, # and then we could set am__CC="\$(top_srcdir)/compile \$(CC)" CC="$am_aux_dir/compile $CC" fi AC_LANG_POP([C])]) # For backward compatibility. AC_DEFUN_ONCE([AM_PROG_CC_C_O], [AC_REQUIRE([AC_PROG_CC])]) # Copyright (C) 2001-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_RUN_LOG(COMMAND) # ------------------- # Run COMMAND, save the exit status in ac_status, and log it. # (This has been adapted from Autoconf's _AC_RUN_LOG macro.) AC_DEFUN([AM_RUN_LOG], [{ echo "$as_me:$LINENO: $1" >&AS_MESSAGE_LOG_FD ($1) >&AS_MESSAGE_LOG_FD 2>&AS_MESSAGE_LOG_FD ac_status=$? echo "$as_me:$LINENO: \$? = $ac_status" >&AS_MESSAGE_LOG_FD (exit $ac_status); }]) # Check to make sure that the build environment is sane. -*- Autoconf -*- # Copyright (C) 1996-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_SANITY_CHECK # --------------- AC_DEFUN([AM_SANITY_CHECK], [AC_MSG_CHECKING([whether build environment is sane]) # Reject unsafe characters in $srcdir or the absolute working directory # name. Accept space and tab only in the latter. am_lf=' ' case `pwd` in *[[\\\"\#\$\&\'\`$am_lf]]*) AC_MSG_ERROR([unsafe absolute working directory name]);; esac case $srcdir in *[[\\\"\#\$\&\'\`$am_lf\ \ ]]*) AC_MSG_ERROR([unsafe srcdir value: '$srcdir']);; esac # Do 'set' in a subshell so we don't clobber the current shell's # arguments. Must try -L first in case configure is actually a # symlink; some systems play weird games with the mod time of symlinks # (eg FreeBSD returns the mod time of the symlink's containing # directory). if ( am_has_slept=no for am_try in 1 2; do echo "timestamp, slept: $am_has_slept" > conftest.file set X `ls -Lt "$srcdir/configure" conftest.file 2> /dev/null` if test "$[*]" = "X"; then # -L didn't work. set X `ls -t "$srcdir/configure" conftest.file` fi if test "$[*]" != "X $srcdir/configure conftest.file" \ && test "$[*]" != "X conftest.file $srcdir/configure"; then # If neither matched, then we have a broken ls. This can happen # if, for instance, CONFIG_SHELL is bash and it inherits a # broken ls alias from the environment. This has actually # happened. Such a system could not be considered "sane". AC_MSG_ERROR([ls -t appears to fail. Make sure there is not a broken alias in your environment]) fi if test "$[2]" = conftest.file || test $am_try -eq 2; then break fi # Just in case. sleep 1 am_has_slept=yes done test "$[2]" = conftest.file ) then # Ok. : else AC_MSG_ERROR([newly created file is older than distributed files! Check your system clock]) fi AC_MSG_RESULT([yes]) # If we didn't sleep, we still need to ensure time stamps of config.status and # generated files are strictly newer. am_sleep_pid= if grep 'slept: no' conftest.file >/dev/null 2>&1; then ( sleep 1 ) & am_sleep_pid=$! fi AC_CONFIG_COMMANDS_PRE( [AC_MSG_CHECKING([that generated files are newer than configure]) if test -n "$am_sleep_pid"; then # Hide warnings about reused PIDs. wait $am_sleep_pid 2>/dev/null fi AC_MSG_RESULT([done])]) rm -f conftest.file ]) # Copyright (C) 2009-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_SILENT_RULES([DEFAULT]) # -------------------------- # Enable less verbose build rules; with the default set to DEFAULT # ("yes" being less verbose, "no" or empty being verbose). AC_DEFUN([AM_SILENT_RULES], [AC_ARG_ENABLE([silent-rules], [dnl AS_HELP_STRING( [--enable-silent-rules], [less verbose build output (undo: "make V=1")]) AS_HELP_STRING( [--disable-silent-rules], [verbose build output (undo: "make V=0")])dnl ]) case $enable_silent_rules in @%:@ ((( yes) AM_DEFAULT_VERBOSITY=0;; no) AM_DEFAULT_VERBOSITY=1;; *) AM_DEFAULT_VERBOSITY=m4_if([$1], [yes], [0], [1]);; esac dnl dnl A few 'make' implementations (e.g., NonStop OS and NextStep) dnl do not support nested variable expansions. dnl See automake bug#9928 and bug#10237. am_make=${MAKE-make} AC_CACHE_CHECK([whether $am_make supports nested variables], [am_cv_make_support_nested_variables], [if AS_ECHO([['TRUE=$(BAR$(V)) BAR0=false BAR1=true V=1 am__doit: @$(TRUE) .PHONY: am__doit']]) | $am_make -f - >/dev/null 2>&1; then am_cv_make_support_nested_variables=yes else am_cv_make_support_nested_variables=no fi]) if test $am_cv_make_support_nested_variables = yes; then dnl Using '$V' instead of '$(V)' breaks IRIX make. AM_V='$(V)' AM_DEFAULT_V='$(AM_DEFAULT_VERBOSITY)' else AM_V=$AM_DEFAULT_VERBOSITY AM_DEFAULT_V=$AM_DEFAULT_VERBOSITY fi AC_SUBST([AM_V])dnl AM_SUBST_NOTMAKE([AM_V])dnl AC_SUBST([AM_DEFAULT_V])dnl AM_SUBST_NOTMAKE([AM_DEFAULT_V])dnl AC_SUBST([AM_DEFAULT_VERBOSITY])dnl AM_BACKSLASH='\' AC_SUBST([AM_BACKSLASH])dnl _AM_SUBST_NOTMAKE([AM_BACKSLASH])dnl ]) # Copyright (C) 2001-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # AM_PROG_INSTALL_STRIP # --------------------- # One issue with vendor 'install' (even GNU) is that you can't # specify the program used to strip binaries. This is especially # annoying in cross-compiling environments, where the build's strip # is unlikely to handle the host's binaries. # Fortunately install-sh will honor a STRIPPROG variable, so we # always use install-sh in "make install-strip", and initialize # STRIPPROG with the value of the STRIP variable (set by the user). AC_DEFUN([AM_PROG_INSTALL_STRIP], [AC_REQUIRE([AM_PROG_INSTALL_SH])dnl # Installed binaries are usually stripped using 'strip' when the user # run "make install-strip". However 'strip' might not be the right # tool to use in cross-compilation environments, therefore Automake # will honor the 'STRIP' environment variable to overrule this program. dnl Don't test for $cross_compiling = yes, because it might be 'maybe'. if test "$cross_compiling" != no; then AC_CHECK_TOOL([STRIP], [strip], :) fi INSTALL_STRIP_PROGRAM="\$(install_sh) -c -s" AC_SUBST([INSTALL_STRIP_PROGRAM])]) # Copyright (C) 2006-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_SUBST_NOTMAKE(VARIABLE) # --------------------------- # Prevent Automake from outputting VARIABLE = @VARIABLE@ in Makefile.in. # This macro is traced by Automake. AC_DEFUN([_AM_SUBST_NOTMAKE]) # AM_SUBST_NOTMAKE(VARIABLE) # -------------------------- # Public sister of _AM_SUBST_NOTMAKE. AC_DEFUN([AM_SUBST_NOTMAKE], [_AM_SUBST_NOTMAKE($@)]) # Check how to create a tarball. -*- Autoconf -*- # Copyright (C) 2004-2021 Free Software Foundation, Inc. # # This file is free software; the Free Software Foundation # gives unlimited permission to copy and/or distribute it, # with or without modifications, as long as this notice is preserved. # _AM_PROG_TAR(FORMAT) # -------------------- # Check how to create a tarball in format FORMAT. # FORMAT should be one of 'v7', 'ustar', or 'pax'. # # Substitute a variable $(am__tar) that is a command # writing to stdout a FORMAT-tarball containing the directory # $tardir. # tardir=directory && $(am__tar) > result.tar # # Substitute a variable $(am__untar) that extract such # a tarball read from stdin. # $(am__untar) < result.tar # AC_DEFUN([_AM_PROG_TAR], [# Always define AMTAR for backward compatibility. Yes, it's still used # in the wild :-( We should find a proper way to deprecate it ... AC_SUBST([AMTAR], ['$${TAR-tar}']) # We'll loop over all known methods to create a tar archive until one works. _am_tools='gnutar m4_if([$1], [ustar], [plaintar]) pax cpio none' m4_if([$1], [v7], [am__tar='$${TAR-tar} chof - "$$tardir"' am__untar='$${TAR-tar} xf -'], [m4_case([$1], [ustar], [# The POSIX 1988 'ustar' format is defined with fixed-size fields. # There is notably a 21 bits limit for the UID and the GID. In fact, # the 'pax' utility can hang on bigger UID/GID (see automake bug#8343 # and bug#13588). am_max_uid=2097151 # 2^21 - 1 am_max_gid=$am_max_uid # The $UID and $GID variables are not portable, so we need to resort # to the POSIX-mandated id(1) utility. Errors in the 'id' calls # below are definitely unexpected, so allow the users to see them # (that is, avoid stderr redirection). am_uid=`id -u || echo unknown` am_gid=`id -g || echo unknown` AC_MSG_CHECKING([whether UID '$am_uid' is supported by ustar format]) if test $am_uid -le $am_max_uid; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) _am_tools=none fi AC_MSG_CHECKING([whether GID '$am_gid' is supported by ustar format]) if test $am_gid -le $am_max_gid; then AC_MSG_RESULT([yes]) else AC_MSG_RESULT([no]) _am_tools=none fi], [pax], [], [m4_fatal([Unknown tar format])]) AC_MSG_CHECKING([how to create a $1 tar archive]) # Go ahead even if we have the value already cached. We do so because we # need to set the values for the 'am__tar' and 'am__untar' variables. _am_tools=${am_cv_prog_tar_$1-$_am_tools} for _am_tool in $_am_tools; do case $_am_tool in gnutar) for _am_tar in tar gnutar gtar; do AM_RUN_LOG([$_am_tar --version]) && break done am__tar="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$$tardir"' am__tar_="$_am_tar --format=m4_if([$1], [pax], [posix], [$1]) -chf - "'"$tardir"' am__untar="$_am_tar -xf -" ;; plaintar) # Must skip GNU tar: if it does not support --format= it doesn't create # ustar tarball either. (tar --version) >/dev/null 2>&1 && continue am__tar='tar chf - "$$tardir"' am__tar_='tar chf - "$tardir"' am__untar='tar xf -' ;; pax) am__tar='pax -L -x $1 -w "$$tardir"' am__tar_='pax -L -x $1 -w "$tardir"' am__untar='pax -r' ;; cpio) am__tar='find "$$tardir" -print | cpio -o -H $1 -L' am__tar_='find "$tardir" -print | cpio -o -H $1 -L' am__untar='cpio -i -H $1 -d' ;; none) am__tar=false am__tar_=false am__untar=false ;; esac # If the value was cached, stop now. We just wanted to have am__tar # and am__untar set. test -n "${am_cv_prog_tar_$1}" && break # tar/untar a dummy directory, and stop if the command works. rm -rf conftest.dir mkdir conftest.dir echo GrepMe > conftest.dir/file AM_RUN_LOG([tardir=conftest.dir && eval $am__tar_ >conftest.tar]) rm -rf conftest.dir if test -s conftest.tar; then AM_RUN_LOG([$am__untar /dev/null 2>&1 && break fi done rm -rf conftest.dir AC_CACHE_VAL([am_cv_prog_tar_$1], [am_cv_prog_tar_$1=$_am_tool]) AC_MSG_RESULT([$am_cv_prog_tar_$1])]) AC_SUBST([am__tar]) AC_SUBST([am__untar]) ]) # _AM_PROG_TAR m4_include([m4/common.m4]) m4_include([m4/gettext.m4]) m4_include([m4/host-cpu-c-abi.m4]) m4_include([m4/iconv.m4]) m4_include([m4/intlmacosx.m4]) m4_include([m4/lib-ld.m4]) m4_include([m4/lib-link.m4]) m4_include([m4/lib-prefix.m4]) m4_include([m4/libcerror.m4]) m4_include([m4/libcrypto.m4]) m4_include([m4/libtool.m4]) m4_include([m4/ltoptions.m4]) m4_include([m4/ltsugar.m4]) m4_include([m4/ltversion.m4]) m4_include([m4/lt~obsolete.m4]) m4_include([m4/nls.m4]) m4_include([m4/po.m4]) m4_include([m4/progtest.m4]) m4_include([m4/python.m4]) m4_include([m4/tests.m4]) m4_include([m4/types.m4]) m4_include([acinclude.m4]) libcaes-20240413/configure.ac0000644000175000017500000000712014606473411016507 0ustar00lordyestalordyestaAC_PREREQ([2.71]) AC_INIT( [libcaes], [20240413], [joachim.metz@gmail.com]) AC_CONFIG_SRCDIR( [include/libcaes.h.in]) AM_INIT_AUTOMAKE([gnu 1.6 tar-ustar]) AM_EXTRA_RECURSIVE_TARGETS([sources splint]) AC_CONFIG_MACRO_DIR([m4]) dnl Check for host type AC_CANONICAL_HOST dnl Check for libtool DLL support LT_INIT([win32-dll]) dnl Checks for programs AC_PROG_CC AC_PROG_GCC_TRADITIONAL AC_PROG_CXX AC_PROG_MAKE_SET AC_PROG_INSTALL dnl Check for libtool AC_SUBST(LIBTOOL_DEPS) dnl Check for pkg-config AC_PATH_PROG(PKGCONFIG,[pkg-config]) dnl Support of internationalization (i18n) AM_GNU_GETTEXT([external]) AM_GNU_GETTEXT_VERSION([0.21]) dnl Check for compiler language support AC_C_CONST AC_C_VOLATILE dnl Check for large file support AC_SYS_LARGEFILE dnl Check if shared library support should be disabled AX_COMMON_CHECK_DISABLE_SHARED_LIBS dnl Check if WINAPI support should be enabled AX_COMMON_CHECK_ENABLE_WINAPI dnl Check for type definitions AX_TYPES_CHECK_LOCAL dnl Check if common required headers and functions are available AX_COMMON_CHECK_LOCAL dnl Check if libcerror or required headers and functions are available AX_LIBCERROR_CHECK_ENABLE dnl Check if libcaes required headers and functions are available AX_LIBCAES_CHECK_LOCAL dnl Check if libcaes Python bindings (pycaes) required headers and functions are available AX_PYTHON_CHECK_ENABLE AS_IF( [test "x${ac_cv_enable_python}" != xno], [dnl Headers included in pycaes/pycaes_error.c AC_CHECK_HEADERS([stdarg.h varargs.h]) AS_IF( [test "x$ac_cv_header_stdarg_h" != xyes && test "x$ac_cv_header_varargs_h" != xyes], [AC_MSG_FAILURE( [Missing headers: stdarg.h and varargs.h], [1]) ]) ]) dnl Check if DLL support is needed AX_LIBCAES_CHECK_DLL_SUPPORT dnl Check if tests required headers and functions are available AX_TESTS_CHECK_LOCAL AX_TESTS_CHECK_OSSFUZZ dnl Set additional compiler flags CFLAGS="$CFLAGS -Wall"; dnl Check if requires and build requires should be set in spec file AS_IF( [test "x$ac_cv_libcerror" = xyes || test "x$ac_cv_libcrypto" != xno], [AC_SUBST( [libcaes_spec_requires], [Requires:]) ]) dnl Set the date for the dpkg files AC_SUBST( [DPKG_DATE], [`date -R 2> /dev/null`]) dnl Set the date for the spec file AC_SUBST( [SPEC_DATE], [`date +"%a %b %e %Y" 2> /dev/null`]) dnl Generate Makefiles AC_CONFIG_FILES([Makefile]) AC_CONFIG_FILES([include/Makefile]) AC_CONFIG_FILES([common/Makefile]) AC_CONFIG_FILES([libcerror/Makefile]) AC_CONFIG_FILES([libcaes/Makefile]) AC_CONFIG_FILES([pycaes/Makefile]) AC_CONFIG_FILES([po/Makefile.in]) AC_CONFIG_FILES([po/Makevars]) AC_CONFIG_FILES([manuals/Makefile]) AC_CONFIG_FILES([tests/Makefile]) AC_CONFIG_FILES([ossfuzz/Makefile]) AC_CONFIG_FILES([msvscpp/Makefile]) dnl Generate header files AC_CONFIG_FILES([include/libcaes.h]) AC_CONFIG_FILES([include/libcaes/definitions.h]) AC_CONFIG_FILES([include/libcaes/features.h]) AC_CONFIG_FILES([include/libcaes/types.h]) AC_CONFIG_FILES([libcaes/libcaes_definitions.h]) dnl Generate distribution specific files AC_CONFIG_FILES([common/types.h]) AC_CONFIG_FILES([dpkg/changelog]) AC_CONFIG_FILES([libcaes/libcaes.rc]) AC_CONFIG_FILES([libcaes.pc]) AC_CONFIG_FILES([libcaes.spec]) AC_CONFIG_FILES([setup.cfg]) dnl Generate a source configuration file AC_CONFIG_HEADERS([common/config.h]) AC_OUTPUT dnl Print a summary AC_MSG_NOTICE([ Building: libcerror support: $ac_cv_libcerror AES-CBC support: $ac_cv_libcaes_aes_cbc AES-ECB support: $ac_cv_libcaes_aes_ecb AES-XTS support: $ac_cv_libcaes_aes_xts Features: Python (pycaes) support: $ac_cv_enable_python ]);