2006-05-05 18:13:26 +00:00
|
|
|
|
Native Development Kit README
|
|
|
|
|
NDK 1.00
|
|
|
|
|
-----------------------------
|
|
|
|
|
|
2007-07-27 03:19:23 +00:00
|
|
|
|
0. PREAMBLE
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
|
|
|
|
0.1 COPYRIGHT
|
|
|
|
|
|
2012-02-28 17:57:16 +00:00
|
|
|
|
The NDK is Copyright <20> 2005-2012 Alex Ionescu.
|
|
|
|
|
It is actively maintained by Alex Ionescu, and open contributions are welcome.
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
|
|
|
|
0.2 CONTACT INFORMATION
|
|
|
|
|
|
2012-02-28 17:57:16 +00:00
|
|
|
|
The maintainer and author, Alex Ionescu, may be reached through the following means:
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
2012-02-28 17:57:16 +00:00
|
|
|
|
Email: aionescu@gmail.com
|
|
|
|
|
Mail: 512 Van Ness #302. San Francisco, CA
|
|
|
|
|
Phone: (424) 781-7156
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
|
|
|
|
1. LICENSE
|
|
|
|
|
|
|
|
|
|
1.1 OPEN SOURCE USAGE
|
|
|
|
|
|
2007-07-27 03:19:23 +00:00
|
|
|
|
Open Source Projects may choose to use the following licenses:
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
|
|
|
|
GNU GENERAL PUBLIC LICENSE Version 2, June 1991
|
|
|
|
|
|
|
|
|
|
OR
|
|
|
|
|
|
|
|
|
|
GNU LESSER GENERAL PUBLIC LICENSE Version 2.1, February 1999
|
|
|
|
|
|
2007-07-27 03:19:23 +00:00
|
|
|
|
OR
|
|
|
|
|
|
|
|
|
|
EITHER of the aforementioned licenses AND (at your option)
|
2012-02-28 17:57:16 +00:00
|
|
|
|
any later version of the above said licenses.
|
2007-07-27 03:19:23 +00:00
|
|
|
|
|
|
|
|
|
1.2 LICENSE LIMITATIONS
|
|
|
|
|
|
2006-05-05 18:13:26 +00:00
|
|
|
|
The choice is yours to make based on the license which is most compatible with your
|
|
|
|
|
software.
|
|
|
|
|
|
|
|
|
|
You MUST read GPL.TXT or LGPL.TXT after your decision. Violating your chosen license
|
|
|
|
|
voids your usage rights of the NDK and will lead to legal action on the part of the
|
2007-07-27 03:19:23 +00:00
|
|
|
|
author. Using this software with any later version of the GNU GPL or LGPL in no way
|
2013-01-13 15:02:38 +00:00
|
|
|
|
changes your obligations under the versions listed above. You MUST still release the
|
2007-07-27 03:19:23 +00:00
|
|
|
|
NDK and its changes under the terms of the original licenses (either GPLv2 or LGPLv2.1)
|
|
|
|
|
as listed above. This DOES NOT AFFECT the license of a software package released under
|
|
|
|
|
a later version and ONLY serves to clarify that using the NDK with a later version is
|
|
|
|
|
permitted provided the aforementioned terms are met.
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
|
|
|
|
If your Open Source product does not use a license which is compatible with the ones
|
|
|
|
|
listed above, please contact the author to reach a mutual agreement to find a better
|
|
|
|
|
solution for your product. Alternatively, you may choose to use the Proprietary Usage
|
2007-07-27 03:19:23 +00:00
|
|
|
|
license displayed below in section 1.3
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
|
|
|
|
If you are unsure of whether or not your product qualifies as an Open Source product,
|
|
|
|
|
please contact the Free Software Foundation, or visit their website at www.fsf.org.
|
|
|
|
|
|
2007-07-27 03:19:23 +00:00
|
|
|
|
1.3 PROPRIETARY USAGE
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
|
|
|
|
Because it may be undesirable or impossible to adapt this software to your commercial
|
|
|
|
|
and/or proprietary product(s) and/or service(s) using a (L)GPL license, proprietary
|
|
|
|
|
products are free to use the following license:
|
|
|
|
|
|
|
|
|
|
NDK LICENSE Version 1, November 2005
|
|
|
|
|
|
|
|
|
|
You MUST read NDK.TXT for the full text of this license. Violating your chosen license
|
|
|
|
|
voids your usage rights of the NDK, constitutes a copyright violation, and will lead to
|
|
|
|
|
legal action on the part of the author.
|
|
|
|
|
|
|
|
|
|
If you are unsure of have any questions about the NDK License, please contact the
|
|
|
|
|
author for further clarification.
|
|
|
|
|
|
|
|
|
|
2. ORIGINS OF NDK MATERIAL, AND ADDING YOUR OWN
|
|
|
|
|
|
|
|
|
|
2.1 CONTRIBUTIONS AND SOURCES
|
|
|
|
|
|
|
|
|
|
The NDK could not exist without the various contributions made by a variety of people
|
|
|
|
|
and sources. The following public sources of information were lawfully used:
|
|
|
|
|
|
|
|
|
|
- GNU NTIFS.H, Revision 43
|
|
|
|
|
- W32API, Version 2.5
|
2006-05-10 17:47:44 +00:00
|
|
|
|
- Microsoft Windows Driver Kit
|
2006-05-05 18:13:26 +00:00
|
|
|
|
- Microsoft Driver Development Kit 2003 SP1
|
|
|
|
|
- Microsoft Driver Development Kit 2000
|
|
|
|
|
- Microsoft Driver Development Kit NT 4
|
|
|
|
|
- Microsoft Driver Development Kit WinME
|
|
|
|
|
- Microsoft Installable File Systems Kit 2003 SP1
|
|
|
|
|
- Microsoft Windows Debugger (WinDBG) 6.5.0003.7
|
|
|
|
|
- Microsoft Public Symbolic Data
|
|
|
|
|
- Microsoft Public Windows Binaries (strings)
|
|
|
|
|
- OSR Technical Articles
|
|
|
|
|
- Undocumented windows 2000 Secrets, a Programmer's Cookbook
|
|
|
|
|
- Windows NT/2000 Native API Reference
|
|
|
|
|
- Windows NT File System Internals
|
|
|
|
|
- Windows Internals I - II
|
|
|
|
|
- Windows Internals 4th Edition
|
|
|
|
|
|
|
|
|
|
If the information contained in these sources was copyrighted, the information was not
|
|
|
|
|
copied, but simply used as a basis for developing a compatible and identical definition.
|
|
|
|
|
No information protected by a patent or NDA was used. All information was publically
|
|
|
|
|
located through the Internet or purchased or licensed for lawful use.
|
|
|
|
|
|
|
|
|
|
Additionally, the following people contributed to the NDK:
|
|
|
|
|
|
|
|
|
|
- Art Yerkes
|
|
|
|
|
- Eric Kohl
|
|
|
|
|
- Filip Navara
|
|
|
|
|
- Steven Edwards
|
2012-02-28 17:57:16 +00:00
|
|
|
|
- Matthieu Suiche
|
|
|
|
|
- Stefan Ginsberg
|
|
|
|
|
- Timo Kreuzer
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
|
|
|
|
2.2 BECOMING A CONTRIBUTOR
|
|
|
|
|
|
|
|
|
|
To contribute information to the NDK, simply contact the author with your new structure,
|
|
|
|
|
definition, enumeration, or prototype. Please make sure that your addition is:
|
|
|
|
|
|
|
|
|
|
1) Actually correct!
|
2012-02-28 17:57:16 +00:00
|
|
|
|
2) Present in Windows NT 5, 5.1, 5.2, 6.0, 6.1 and/or 6.2
|
2006-05-05 18:13:26 +00:00
|
|
|
|
3) Not already accessible through another public header in the DDK, IFS, WDK and/or PSDK.
|
|
|
|
|
4) From a publically verifiable source. The author needs to be able to search for your
|
|
|
|
|
addition in a public information location (book, Internet, etc) and locate this definition.
|
|
|
|
|
5) Not Reversed. Reversing a type is STRONGLY discouraged and a reversed type will more then likely
|
|
|
|
|
not be accepted, due to the fact that functionality and naming will be entirely guessed, and things
|
|
|
|
|
like unions are almost impossible to determine. It can also bring up possible legal ramifications
|
|
|
|
|
depending on your location. However, using a tool to dump the strings inside an executable
|
|
|
|
|
for the purpose of locating the actual name or definition of a structure (sometimes possible due
|
|
|
|
|
to ASSERTs or debugging strings) is considered 'fair use' and will be a likely candidate.
|
|
|
|
|
|
2012-02-28 18:38:28 +00:00
|
|
|
|
If your contribution satsfies these points, then please submit it to the author with the following
|
|
|
|
|
statement:
|
|
|
|
|
|
|
|
|
|
"
|
|
|
|
|
Copyright Grant.
|
|
|
|
|
I grant to you a perpetual (for the duration of the applicable copyright), worldwide, non-exclusive,
|
|
|
|
|
no-charge, royalty-free, copyright license, without any obligation for accounting to me, to reproduce,
|
|
|
|
|
prepare derivative works of, publicly display, publicly perform, sublicense, distribute, and implement
|
|
|
|
|
my Contribution to the full extent of my copyright interest in the Contribution.
|
|
|
|
|
"
|
|
|
|
|
|
|
|
|
|
If you wish to be credited for your contribution (which the author is more than happy to do!), you
|
|
|
|
|
should add:
|
|
|
|
|
|
|
|
|
|
"As a condition of the copyright grant, you must include an attribution in any derivative work you make
|
|
|
|
|
based on the Contribution. That attribution must include, at minimum, my name."
|
|
|
|
|
|
|
|
|
|
This will allow you to have your name in the readme.txt file (which you are now reading). If you wish to
|
|
|
|
|
remain anonymous, simply do not include this statement.
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
|
|
|
|
3. USAGE
|
|
|
|
|
|
|
|
|
|
3.1 ORGANIZATION
|
|
|
|
|
|
2013-01-13 15:02:38 +00:00
|
|
|
|
* The NDK is organized in a main folder (include/ndk) with arch-specific subfolders (ex: include/ndk/i386).
|
|
|
|
|
* The NDK is structured by NT Subsystem Component (ex: ex, ps, rtl, etc).
|
2006-05-05 18:13:26 +00:00
|
|
|
|
* The NDK can either be included on-demand (#include <ndk/xxxxx.h>) or globally (#include <ndk/ntndk.h>).
|
2013-01-13 15:02:38 +00:00
|
|
|
|
The former is recommended to reduce compile time.
|
2006-05-05 18:13:26 +00:00
|
|
|
|
* The NDK is structured by function and type. Every Subsystem Component has an associated "xxfuncs.h" and
|
2013-01-13 15:02:38 +00:00
|
|
|
|
"xxtypes.h" header, where "xx" is the Subsystem (ex: iofuncs.h, iotypes.h)
|
2006-05-05 18:13:26 +00:00
|
|
|
|
* The NDK has a special file called "umtypes.h" which exports to User-Mode or Native-Mode Applications the
|
|
|
|
|
basic NT types which are present in ntdef.h. This file cannot be included since it would conflict with
|
|
|
|
|
winnt.h and/or windef.h. Thus, umtypes.h provides the missing types. This file is automatically included
|
2013-01-13 15:02:38 +00:00
|
|
|
|
in a User-Mode NDK project.
|
2006-05-05 18:13:26 +00:00
|
|
|
|
* The NDK also includes a file called "umfuncs.h" which exports to User-Mode or Native-Mode Applications
|
2013-01-13 15:02:38 +00:00
|
|
|
|
undocumented functions which can only be accessed from ntdll.dll.
|
2006-05-05 18:13:26 +00:00
|
|
|
|
* The NDK has another special file called "ifssupp.h", which exports to Kernel-Mode drivers a few types which
|
|
|
|
|
are only documented in the IFS kit, and are part of some native definitions. It will be deprecated next year
|
2013-01-13 15:02:38 +00:00
|
|
|
|
with the release of the WDK.
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
2013-01-13 15:02:38 +00:00
|
|
|
|
3.2 USING IN YOUR PROJECT
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
2013-01-13 15:02:38 +00:00
|
|
|
|
* User Mode Application requiring Native Types:
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
|
|
|
|
#define WIN32_NO_STATUS /* Tell Windows headers you'll use ntstatus.s from NDK */
|
2006-05-10 17:47:44 +00:00
|
|
|
|
#include "windows.h" /* Declare Windows Headers like you normally would */
|
|
|
|
|
#include "ntndk.h" /* Declare the NDK Headers */
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
2013-01-13 15:02:38 +00:00
|
|
|
|
* Native Mode Application:
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
2006-05-10 17:47:44 +00:00
|
|
|
|
#include "windows.h" /* Declare Windows Headers for basic types. NEEDED UNTIL NDK 1.5 */
|
|
|
|
|
#include "ntndk.h" /* Declare the NDK Headers */
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
2013-01-13 15:02:38 +00:00
|
|
|
|
* Kernel Mode Driver:
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
2006-05-10 17:47:44 +00:00
|
|
|
|
#include "ntddk.h" /* Declare DDK Headers like you normally would */
|
|
|
|
|
#include "ntndk.h" /* Declare the NDK Headers */
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
|
|
|
|
* You may also include only the files you need (example for User-Mode application):
|
|
|
|
|
|
|
|
|
|
#define WIN32_NO_STATUS /* Tell Windows headers you'll use ntstatus.s from NDK */
|
2006-05-10 17:47:44 +00:00
|
|
|
|
#include "windows.h" /* Declare Windows Headers like you normally would */
|
|
|
|
|
#include "rtlfuncs.h" /* Declare the Rtl* Functions */
|
2006-05-05 18:13:26 +00:00
|
|
|
|
|
|
|
|
|
3.3 CAVEATS
|
|
|
|
|
|
|
|
|
|
* winternl.h: This header, part of the PSDK, was released by Microsoft as part of one of the governmen
|
2007-12-05 18:21:11 +00:00
|
|
|
|
lawsuits against it, and documents a certain (minimal) part of the Native API and/or types. Unfortunately,
|
2006-05-05 18:13:26 +00:00
|
|
|
|
Microsoft decided to hack the Native Types and to define them incorrectly, replacing real members by "reserved"
|
|
|
|
|
ones. As such, you 'cannot include winternl.h in any project that uses the NDK. Note however, that the NDK fully
|
|
|
|
|
replaces it and retains compatibility with any project that used it.
|
|
|
|
|
* Native programs: Native programs must include "windows.h" until the next release of the NDK (1.5). The upcoming
|
2006-05-10 17:47:44 +00:00
|
|
|
|
version will automatically detect the lack of missing types and include them. Note however that you will still
|
|
|
|
|
need to have the PSDK installed.
|