本文整理汇总了C++中ARGUMENT_PRESENT函数的典型用法代码示例。如果您正苦于以下问题:C++ ARGUMENT_PRESENT函数的具体用法?C++ ARGUMENT_PRESENT怎么用?C++ ARGUMENT_PRESENT使用的例子?那么, 这里精选的函数代码示例或许可以为您提供帮助。
在下文中一共展示了ARGUMENT_PRESENT函数的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: KeGetBugMessageText
BOOLEAN
KeGetBugMessageText(
IN ULONG MessageId,
IN PANSI_STRING ReturnedString OPTIONAL
)
{
ULONG i;
PUCHAR s;
PMESSAGE_RESOURCE_BLOCK MessageBlock;
PUCHAR Buffer;
BOOLEAN Result;
Result = FALSE;
try {
if (KiBugCodeMessages != NULL) {
MmMakeKernelResourceSectionWritable ();
MessageBlock = &KiBugCodeMessages->Blocks[0];
for (i = KiBugCodeMessages->NumberOfBlocks; i; i -= 1) {
if (MessageId >= MessageBlock->LowId &&
MessageId <= MessageBlock->HighId) {
s = (PCHAR)KiBugCodeMessages + MessageBlock->OffsetToEntries;
for (i = MessageId - MessageBlock->LowId; i; i -= 1) {
s += ((PMESSAGE_RESOURCE_ENTRY)s)->Length;
}
Buffer = ((PMESSAGE_RESOURCE_ENTRY)s)->Text;
i = strlen(Buffer) - 1;
while (i > 0 && (Buffer[i] == '\n' ||
Buffer[i] == '\r' ||
Buffer[i] == 0
)
) {
if (!ARGUMENT_PRESENT( ReturnedString )) {
Buffer[i] = 0;
}
i -= 1;
}
if (!ARGUMENT_PRESENT( ReturnedString )) {
InbvDisplayString(Buffer);
}
else {
ReturnedString->Buffer = Buffer;
ReturnedString->Length = (USHORT)(i+1);
ReturnedString->MaximumLength = (USHORT)(i+1);
}
Result = TRUE;
break;
}
MessageBlock += 1;
}
}
} except ( EXCEPTION_EXECUTE_HANDLER ) {
;
}
return Result;
}
示例2: NtQueryInformationPort
NTSTATUS
NTAPI
NtQueryInformationPort(
IN HANDLE PortHandle OPTIONAL,
IN PORT_INFORMATION_CLASS PortInformationClass,
OUT PVOID PortInformation,
IN ULONG Length,
OUT PULONG ReturnLength OPTIONAL
)
{
KPROCESSOR_MODE PreviousMode;
NTSTATUS Status;
PLPCP_PORT_OBJECT PortObject;
PAGED_CODE();
//
// Get previous processor mode and probe output argument if necessary.
//
PreviousMode = KeGetPreviousMode();
if (PreviousMode != KernelMode) {
try {
ProbeForWrite( PortInformation,
Length,
sizeof( ULONG )
);
if (ARGUMENT_PRESENT( ReturnLength )) {
ProbeForWriteUlong( ReturnLength );
}
}
except( EXCEPTION_EXECUTE_HANDLER ) {
return( GetExceptionCode() );
}
}
if (ARGUMENT_PRESENT( PortHandle )) {
Status = ObReferenceObjectByHandle( PortHandle,
GENERIC_READ,
LpcPortObjectType,
PreviousMode,
&PortObject,
NULL
);
if (!NT_SUCCESS( Status )) {
return( Status );
}
ObDereferenceObject( PortObject );
return STATUS_SUCCESS;
}
else {
return STATUS_INVALID_INFO_CLASS;
}
}
示例3: RtlInitUnicodeStringEx
NTSTATUS
RtlInitUnicodeStringEx (
OUT PUNICODE_STRING DestinationString,
IN PCWSTR SourceString OPTIONAL
)
{
SIZE_T Length;
DestinationString->Length = 0;
DestinationString->MaximumLength = 0;
DestinationString->Buffer = (PWSTR)SourceString;
if (ARGUMENT_PRESENT(SourceString)) {
Length = wcslen(SourceString);
// We are actually limited to 32765 characters since we want to store a meaningful
// MaximumLength also.
if (Length > (UNICODE_STRING_MAX_CHARS - 1)) {
return STATUS_NAME_TOO_LONG;
}
Length *= sizeof(WCHAR);
DestinationString->Length = (USHORT)Length;
DestinationString->MaximumLength = (USHORT)(Length + sizeof(WCHAR));
}
return STATUS_SUCCESS;
}
示例4: AddPartners
static
FORCEINLINE
BOOLEAN
AddPartners (
__inout PST_BARRIER Barrier,
__in USHORT Count,
__out_opt ULONGLONG *AddedPhase
)
{
PPHASE_STATE PhaseState;
ULONG State;
ULONG Partners;
ULONG Arrived;
PhaseState = Barrier->PhaseState;
do {
Partners = (State = PhaseState->State) >> PARTNERS_SHIFT;
Arrived = State & ARRIVED_MASK;
//
// Validate the argument.
//
if (Count == 0 || (Count + Partners) > MAX_PARTNERS) {
SetLastError(ERROR_INVALID_PARAMETER);
return FALSE;
}
//
// If the current phase was already reached, wait unconditionally
// until a new phase starts.
//
if (Arrived == Partners) {
StNotificationEvent_WaitEx(&PhaseState->Event, 50, NULL);
//
// Get the new phase state and retry.
//
PhaseState = Barrier->PhaseState;
continue;
}
//
// Update the number of partners and, if succeed, return.
//
if (CasLong(&PhaseState->State, State, ((Partners + Count) << PARTNERS_SHIFT) | Arrived)) {
if (ARGUMENT_PRESENT(AddedPhase)) {
*AddedPhase = Barrier->PhaseNumber;
}
return TRUE;
}
} while (TRUE);
}
示例5: SeUnlockSubjectContext
VOID
SeUnlockSubjectContext(
__in PSECURITY_SUBJECT_CONTEXT SubjectContext
)
/*++
Routine Description:
Releases the read locks on the token(s) in the passed SubjectContext.
Arguments:
SubjectContext - Points to a SECURITY_SUBJECT_CONTEXT data structure
which points to a primary token and an optional impersonation token.
Return Value:
None
--*/
{
PAGED_CODE();
SepReleaseTokenReadLock((PTOKEN)(SubjectContext->PrimaryToken));
if (ARGUMENT_PRESENT(SubjectContext->ClientToken)) {
SepReleaseTokenReadLock((PTOKEN)(SubjectContext->ClientToken));
}
}
示例6: SafeDivRound64x64
//
// In safe-arithmetic, perform integer division Dividend/Divisor and return the
// result rounded up or down to the nearest integer where 3.5 and 3.75 are near
// 4, while 3.25 is near 3.
//
// Dividend: A 64-bit unsigned integer dividend.
// Divisor: A 64-bit unsigned integer divisor.
// ResultPtr: A pointer to a 64-bit unsigned integer that receives the result.
//
// Returns error in case of overflow, otherwise returns STATUS_SUCCESS.
//
__forceinline
NTSTATUS
SafeDivRound64x64 (
_In_ ULONGLONG Dividend,
_In_ ULONGLONG Divisor,
_Out_ ULONGLONG* ResultPtr
)
{
ASSERT(ARGUMENT_PRESENT(ResultPtr));
ASSERT(Divisor > 0);
//
// Calculate the following in safe-arithmetic to avoid overflows:
// return (Dividend + (Divisor / 2)) / Divisor;
//
ULONGLONG result;
NTSTATUS status = RtlULongLongAdd(Dividend, Divisor / 2, &result);
if (!NT_SUCCESS(status)) {
return status;
}
*ResultPtr = result / Divisor;
return STATUS_SUCCESS;
}
示例7: MmIsAddressValidEx
BOOL MmIsAddressValidEx(
IN PVOID Pointer
)
{
VALIDITY_CHECK_STATUS MmRet;
ULONG ulTry;
if (!ARGUMENT_PRESENT(Pointer) ||
!Pointer){
return FALSE;
}
/*
//VCS_TRANSITION、VCS_PAGEDOUT内存居然是这样子~~擦~
lkd> dd f8ad5ad8
f8ad5ad8 ???????? ???????? ???????? ????????
f8ad5ae8 ???????? ???????? ???????? ????????
f8ad5af8 ???????? ???????? ???????? ????????
f8ad5b08 ???????? ???????? ???????? ????????
f8ad5b18 ???????? ???????? ???????? ????????
f8ad5b28 ???????? ???????? ???????? ????????
f8ad5b38 ???????? ???????? ???????? ????????
f8ad5b48 ???????? ???????? ???????? ????????
*/
MmRet = MiIsAddressValidEx(Pointer);
if (MmRet != VCS_VALID){
return FALSE;
}
return TRUE;
}
示例8: RtlInitAnsiStringEx
NTSTATUS
RtlInitAnsiStringEx (
OUT PANSI_STRING DestinationString,
IN PCSZ SourceString OPTIONAL
)
{
SIZE_T Length;
DestinationString->Length = 0;
DestinationString->MaximumLength = 0;
DestinationString->Buffer = (PCHAR)SourceString;
if (ARGUMENT_PRESENT(SourceString)) {
Length = strlen(SourceString);
// We are actually limited to 64K - 1 characters since we want to store a meaningful
// MaximumLength also.
if (Length > (MAXUSHORT - 1)) {
return STATUS_NAME_TOO_LONG;
}
DestinationString->Length = (USHORT)Length;
DestinationString->MaximumLength = (USHORT)(Length + 1);
}
return STATUS_SUCCESS;
}
示例9: AllocAndCopyString
HRESULT AllocAndCopyString(_In_ PCWSTR source, _Outptr_ PWSTR *dest)
{
HRESULT hr = S_OK;
size_t len;
if ( !ARGUMENT_PRESENT(source) )
{
return E_INVALIDARG;
}
len = wcslen(source);
// Remember: wcslen excludes the null character when calculating the length.
// Also, StringCchCopyW takes the total length of the destination buffer
*dest = (PWSTR)LocalAlloc(LMEM_ZEROINIT, ((len + 1) * sizeof(wchar_t)));
if ( !(*dest) )
{
wprintf(L"LocalAlloc failed.\n");
hr = E_OUTOFMEMORY;
goto exit_gracefully;
}
hr = StringCchCopyW(*dest, len + 1, source);
FailGracefully(hr, L"StringCchCopyW");
exit_gracefully:
if ( !SUCCEEDED(hr) )
{
LocalFree(*dest);
}
return hr;
}
示例10: RtlpCopyProcString
VOID
RtlpCopyProcString(
IN OUT PWSTR *pDst,
OUT PUNICODE_STRING DestString,
IN PUNICODE_STRING SourceString,
IN ULONG DstAlloc OPTIONAL
)
{
if (!ARGUMENT_PRESENT( DstAlloc )) {
DstAlloc = SourceString->MaximumLength;
}
ASSERT((SourceString->Length == 0) || (SourceString->Buffer != NULL));
if (SourceString->Buffer != NULL && SourceString->Length != 0) {
RtlCopyMemory (*pDst,
SourceString->Buffer,
SourceString->Length);
}
DestString->Buffer = *pDst;
DestString->Length = SourceString->Length;
DestString->MaximumLength = (USHORT)DstAlloc;
if (DestString->Length < DestString->MaximumLength) {
RtlZeroMemory (((PUCHAR)DestString->Buffer) + DestString->Length, DestString->MaximumLength - DestString->Length);
}
*pDst = (PWSTR)((PCHAR)(*pDst) + ROUND_UP( DstAlloc, sizeof( ULONG ) ) );
return;
}
示例11: MoveFileExA
BOOL
APIENTRY
MoveFileExA(
LPCSTR lpExistingFileName,
LPCSTR lpNewFileName,
DWORD dwFlags
)
/*++
Routine Description:
ANSI thunk to MoveFileW
--*/
{
PUNICODE_STRING Unicode;
UNICODE_STRING UnicodeNewFileName;
ANSI_STRING AnsiString;
NTSTATUS Status;
BOOL ReturnValue;
Unicode = &NtCurrentTeb()->StaticUnicodeString;
RtlInitAnsiString(&AnsiString,lpExistingFileName);
Status = Basep8BitStringToUnicodeString(Unicode,&AnsiString,FALSE);
if ( !NT_SUCCESS(Status) ) {
if ( Status == STATUS_BUFFER_OVERFLOW ) {
SetLastError(ERROR_FILENAME_EXCED_RANGE);
}
else {
BaseSetLastNTError(Status);
}
return FALSE;
}
if (ARGUMENT_PRESENT( lpNewFileName )) {
RtlInitAnsiString(&AnsiString,lpNewFileName);
Status = Basep8BitStringToUnicodeString(&UnicodeNewFileName,&AnsiString,TRUE);
if ( !NT_SUCCESS(Status) ) {
BaseSetLastNTError(Status);
return FALSE;
}
}
else {
UnicodeNewFileName.Buffer = NULL;
}
ReturnValue = MoveFileExW((LPCWSTR)Unicode->Buffer,(LPCWSTR)UnicodeNewFileName.Buffer,dwFlags);
if (UnicodeNewFileName.Buffer != NULL) {
RtlFreeUnicodeString(&UnicodeNewFileName);
}
return ReturnValue;
}
示例12: SepFreePrimaryGroup
VOID
SepFreePrimaryGroup(
IN PTOKEN Token
)
/*++
Routine Description:
Free up the space in the dynamic part of the token take up by the primary
group.
The token is assumed to be locked for write access before calling
this routine.
Arguments:
Token - Pointer to the token.
Return Value:
None.
--*/
{
PAGED_CODE();
//
// Add the size of the primary group to the DynamicAvailable field.
//
Token->DynamicAvailable += SeLengthSid( Token->PrimaryGroup );
//
// If there is a default discretionary ACL, and it is not already at the
// beginning of the dynamic part, move it there (remember to update the
// pointer to it).
//
if (ARGUMENT_PRESENT(Token->DefaultDacl)) {
if (Token->DynamicPart != (PULONG)(Token->DefaultDacl)) {
RtlMoveMemory(
(PVOID)(Token->DynamicPart),
(PVOID)(Token->DefaultDacl),
Token->DefaultDacl->AclSize
);
Token->DefaultDacl = (PACL)(Token->DynamicPart);
}
}
return;
}
示例13: WritePhysicalMemory
BOOLEAN WritePhysicalMemory (PHYSICAL_ADDRESS pBufSrc, PUCHAR pBufDest,
ULONG count,PULONG pcTotalBytesWritten)
{
if (ARGUMENT_PRESENT(pcTotalBytesWritten)) {
*pcTotalBytesWritten = 0;
}
return (BOOLEAN)NT_SUCCESS(DbgKdWritePhysicalMemory(pBufSrc,
(PVOID)pBufDest,
count, pcTotalBytesWritten));
}
示例14: ReadVirtualMemory
BOOLEAN ReadVirtualMemory (PUCHAR pBufSrc, PUCHAR pBufDest, ULONG count,
PULONG pcTotalBytesRead)
{
if (ARGUMENT_PRESENT(pcTotalBytesRead)) {
*pcTotalBytesRead = 0;
}
return (BOOLEAN)NT_SUCCESS(DbgKdReadVirtualMemory((PVOID)pBufSrc,
(PVOID)pBufDest,
count, pcTotalBytesRead));
}
示例15: RemoveAllInheritedAces
HRESULT RemoveAllInheritedAces(PACL *ppAcl)
{
BOOL bResult = FALSE;
DWORD errorCode = S_OK;
HRESULT hr = S_OK;
ACL_SIZE_INFORMATION aclInformation;
DWORD totalCount;
DWORD aceIndex = 0;
LPVOID ace = nullptr;
BYTE aceFlags = 0;
if ( !ARGUMENT_PRESENT(*ppAcl) )
{
return E_INVALIDARG;
}
bResult = GetAclInformation(
*ppAcl,
&aclInformation,
sizeof(aclInformation),
AclSizeInformation
);
FailGracefullyGLE(bResult, L"GetAclInformation");
totalCount = aclInformation.AceCount;
while ( aceIndex < totalCount )
{
bResult = GetAce(
*ppAcl,
aceIndex,
&ace
);
FailGracefullyGLE(bResult, L"GetAce");
aceFlags = ((PACE_HEADER)ace)->AceFlags;
if (IS_FLAG_SET(aceFlags,INHERITED_ACE))
{
bResult = DeleteAce(
*ppAcl,
aceIndex);
FailGracefullyGLE(bResult, L"DeleteAce");
totalCount--;
}
else
{
aceIndex++;
}
}
exit_gracefully:
return hr;
}