亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? tlp3nt.c

?? SmardCard Windows驅動
?? C
?? 第 1 頁 / 共 5 頁
字號:
         // We need to translate the system power state to
         // a corresponding device power state.
         //

         POWER_STATE_TYPE powerType = DevicePowerState;

         ASSERT(smartcardExtension->ReaderExtension->ReaderPowerState !=
                PowerReaderUnspecified);

         switch (irpStack->MinorFunction) {

         KIRQL irql;

         case IRP_MN_QUERY_POWER:

            SmartcardDebug(
                          DEBUG_DRIVER,
                          ("%s!TLP3Power: Query Power\n",
                           DRIVER_NAME)
                          );

            switch (irpStack->Parameters.Power.State.SystemState) {

            case PowerSystemMaximum:
            case PowerSystemWorking:
            case PowerSystemSleeping1:
            case PowerSystemSleeping2:
               action = SkipRequest;
               break;

            case PowerSystemSleeping3:
            case PowerSystemHibernate:
            case PowerSystemShutdown:
               KeAcquireSpinLock(&deviceExtension->SpinLock, &irql);
               if (deviceExtension->IoCount == 0) {

                  // Block any further ioctls
                  KeClearEvent(&deviceExtension->ReaderStarted);
                  action = SkipRequest;

               } else {

                  // can't go to sleep mode since the reader is busy.
                  status = STATUS_DEVICE_BUSY;
                  action = CompleteRequest;
               }
               KeReleaseSpinLock(&deviceExtension->SpinLock, irql);
               break;
            }
            break;

         case IRP_MN_SET_POWER:

            SmartcardDebug(
                          DEBUG_DRIVER,
                          ("%s!TLP3Power: PowerSystem S%d\n",
                           DRIVER_NAME,
                           irpStack->Parameters.Power.State.SystemState - 1)
                          );

            switch (irpStack->Parameters.Power.State.SystemState) {

            case PowerSystemMaximum:
            case PowerSystemWorking:
            case PowerSystemSleeping1:
            case PowerSystemSleeping2:

               if (smartcardExtension->ReaderExtension->ReaderPowerState ==
                   PowerReaderWorking) {

                  // We're already in the right state
                  KeSetEvent(&deviceExtension->ReaderStarted, 0, FALSE);
                  action = SkipRequest;
                  break;
               }

               // wake up the underlying stack...
               powerState.DeviceState = PowerDeviceD0;
               action = MarkPending;
               break;

            case PowerSystemSleeping3:
            case PowerSystemHibernate:
            case PowerSystemShutdown:

               if (smartcardExtension->ReaderExtension->ReaderPowerState ==
                   PowerReaderOff) {

                  // We're already in the right state
                  action = SkipRequest;
                  break;
               }

               powerState.DeviceState = PowerDeviceD3;

               // first, inform the power manager of our new state.
               PoSetPowerState (
                               DeviceObject,
                               SystemPowerState,
                               powerState
                               );

               action = MarkPending;
               break;

            default:
               ASSERT(FALSE);
               action = SkipRequest;
               break;
            }
            break;
         }
      }
      break;

   default:
      ASSERT(FALSE);
      action = SkipRequest;
      break;
   }

    switch (action) {

        case CompleteRequest:
            Irp->IoStatus.Status = status;
            Irp->IoStatus.Information = 0;

            SmartcardReleaseRemoveLockWithTag(smartcardExtension, 'rwoP');
            PoStartNextPowerIrp(Irp);
            IoCompleteRequest(Irp, IO_NO_INCREMENT);
         break;

        case MarkPending:

         // initialize the event we need in the completion function
         KeInitializeEvent(
            &event,
            NotificationEvent,
            FALSE
            );

         // request the device power irp
         status = PoRequestPowerIrp (
            DeviceObject,
            IRP_MN_SET_POWER,
            powerState,
            TLP3SystemPowerCompletion,
            &event,
            NULL
            );
            ASSERT(status == STATUS_PENDING);

         if (status == STATUS_PENDING) {

            // wait until the device power irp completed
            status = KeWaitForSingleObject(
               &event,
               Executive,
               KernelMode,
               FALSE,
               NULL
               );

            SmartcardReleaseRemoveLockWithTag(smartcardExtension, 'rwoP');

            if (powerState.SystemState == PowerSystemWorking) {

               PoSetPowerState (
                  DeviceObject,
                  SystemPowerState,
                  powerState
                  );
            }

            PoStartNextPowerIrp(Irp);
            IoSkipCurrentIrpStackLocation(Irp);
            status = PoCallDriver(AttachedDeviceObject, Irp);

         } else {

            SmartcardReleaseRemoveLockWithTag(smartcardExtension, 'rwoP');
            Irp->IoStatus.Status = status;
            IoCompleteRequest(Irp, IO_NO_INCREMENT);
         }

         break;

        case SkipRequest:
            SmartcardReleaseRemoveLockWithTag(smartcardExtension, 'rwoP');
            PoStartNextPowerIrp(Irp);
            IoSkipCurrentIrpStackLocation(Irp);
            status = PoCallDriver(AttachedDeviceObject, Irp);
         break;

        case WaitForCompletion:
            status = PoCallDriver(AttachedDeviceObject, Irp);
         break;

        default:
            ASSERT(FALSE);
            break;
    }

    SmartcardDebug(
        DEBUG_DRIVER,
        ("%s!TLP3Power: Exit %lx\n",
        DRIVER_NAME,
        status)
        );

    return status;
}

NTSTATUS
TLP3CreateClose(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    )

/*++

Routine Description:

    This routine is called by the I/O system when the device is opened or closed.

Arguments:

    DeviceObject  - Pointer to device object for this miniport
    Irp        - IRP involved.

Return Value:

    STATUS_SUCCESS.

--*/

{
    PDEVICE_EXTENSION deviceExtension = DeviceObject->DeviceExtension;
    PIO_STACK_LOCATION irpStack = IoGetCurrentIrpStackLocation(Irp);
    NTSTATUS status = STATUS_SUCCESS;

   __try {

      if (irpStack->MajorFunction == IRP_MJ_CREATE) {

         status = SmartcardAcquireRemoveLockWithTag(
            &deviceExtension->SmartcardExtension,
            'lCrC'
            );

         if (status != STATUS_SUCCESS) {

            status = STATUS_DEVICE_REMOVED;
            __leave;
         }

         // test if the device has been opened already
         if (InterlockedCompareExchange(
            &deviceExtension->ReaderOpen,
            TRUE,
            FALSE) == FALSE) {

            SmartcardDebug(
               DEBUG_DRIVER,
               ("%s!TLP3CreateClose: Open\n",
               DRIVER_NAME)
               );

         } else {

            // the device is already in use
            status = STATUS_UNSUCCESSFUL;

            // release the lock
            SmartcardReleaseRemoveLockWithTag(
               &deviceExtension->SmartcardExtension,
               'lCrC'
               );
         }

      } else {

         SmartcardDebug(
            DEBUG_DRIVER,
            ("%s!TLP3CreateClose: Close\n",
            DRIVER_NAME)
            );

         SmartcardReleaseRemoveLockWithTag(
            &deviceExtension->SmartcardExtension,
            'lCrC'
            );

         deviceExtension->ReaderOpen = FALSE;
      }
   }
   __finally {

      Irp->IoStatus.Status = status;
      Irp->IoStatus.Information = 0;
      IoCompleteRequest(Irp, IO_NO_INCREMENT);
   }

    return status;
}

NTSTATUS
TLP3Cancel(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    )

/*++

Routine Description:

    This routine is called by the I/O system
    when the irp should be cancelled

Arguments:

    DeviceObject  - Pointer to device object for this miniport
    Irp        - IRP involved.

Return Value:

    STATUS_CANCELLED

--*/

{
    PDEVICE_EXTENSION deviceExtension = DeviceObject->DeviceExtension;
   PSMARTCARD_EXTENSION smartcardExtension = &deviceExtension->SmartcardExtension;

    SmartcardDebug(
        DEBUG_TRACE,
        ("%s!TLP3Cancel: Enter\n",
        DRIVER_NAME)
        );

    ASSERT(Irp == smartcardExtension->OsData->NotificationIrp);

    IoReleaseCancelSpinLock(
        Irp->CancelIrql
        );

    TLP3CompleteCardTracking(smartcardExtension);

    SmartcardDebug(
        DEBUG_TRACE,
        ("%s!TLP3Cancel: Exit\n",
        DRIVER_NAME)
        );

    return STATUS_CANCELLED;
}

NTSTATUS
TLP3Cleanup(
    IN PDEVICE_OBJECT DeviceObject,
    IN PIRP Irp
    )

/*++

Routine Description:

    This routine is called when the calling application terminates.
    We can actually only have the notification irp that we have to cancel.

--*/

{
    PDEVICE_EXTENSION deviceExtension = DeviceObject->DeviceExtension;
   PSMARTCARD_EXTENSION smartcardExtension = &deviceExtension->SmartcardExtension;
   NTSTATUS status = STATUS_SUCCESS;

    SmartcardDebug(
        DEBUG_TRACE,
        ("%s!TLP3Cleanup: Enter\n",
        DRIVER_NAME)
        );

    ASSERT(Irp != smartcardExtension->OsData->NotificationIrp);

    // We need to complete the notification irp
    TLP3CompleteCardTracking(smartcardExtension);

   SmartcardDebug(
      DEBUG_DRIVER,
      ("%s!TLP3Cleanup: Completing IRP %lx\n",
        DRIVER_NAME,
        Irp)
      );

    Irp->IoStatus.Information = 0;
    Irp->IoStatus.Status = STATUS_SUCCESS;

   IoCompleteRequest(
      Irp,
      IO_NO_INCREMENT
      );

    SmartcardDebug(
        DEBUG_TRACE,
        ("%s!TLP3Cleanup: Exit\n",
        DRIVER_NAME)
        );

    return STATUS_SUCCESS;
}

VOID
TLP3RemoveDevice(
   PDEVICE_OBJECT DeviceObject
    )
/*++

Routine Description:
    Remove the device from the system.

--*/
{
    PDEVICE_EXTENSION deviceExtension;
    PSMARTCARD_EXTENSION smartcardExtension;
    NTSTATUS status;

    PAGED_CODE();

    if (DeviceObject == NULL) {

        return;
    }

    deviceExtension = DeviceObject->DeviceExtension;
    smartcardExtension = &deviceExtension->SmartcardExtension;

   SmartcardDebug(
      DEBUG_TRACE,
      ( "%s!TLP3RemoveDevice: Enter\n",
        DRIVER_NAME)
      );

    if (smartcardExtension->OsData) {

        // complete pending card tracking requests (if any)
        TLP3CompleteCardTracking(smartcardExtension);
        ASSERT(smartcardExtension->OsData->NotificationIrp == NULL);

        // Wait until we can safely unload the device
        SmartcardReleaseRemoveLockAndWait(smartcardExtension);
    }

    TLP3StopDevice(DeviceObject);

    if (deviceExtension->SmartcardExtension.ReaderExtension &&
        deviceExtension->SmartcardExtension.ReaderExtension->AttachedDeviceObject) {

        IoDetachDevice(
            deviceExtension->SmartcardExtension.ReaderExtension->AttachedDeviceObject
            );
    }

   if(deviceExtension->PnPDeviceName.Buffer != NULL) {

      RtlFreeUnicodeString(&deviceExtension->PnPDeviceName);
   }

   if(smartcardExtension->OsData != NULL) {

      SmartcardExit(smartcardExtension);
   }

    if (smartcardExtension->ReaderExtension != NULL) {

        ExFreePool(smartcardExtension->ReaderExtension);
    }

   if (deviceExtension->CloseSerial != NULL) {

      IoFreeWorkItem(deviceExtension->CloseSerial);
   }
   IoDeleteDevice(DeviceObject);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人美女视频在线观看| 无码av免费一区二区三区试看| 久久精品国产亚洲高清剧情介绍 | 奇米亚洲午夜久久精品| 日韩欧美国产系列| 精品中文av资源站在线观看| 久久综合精品国产一区二区三区 | 亚洲图片一区二区| 欧美日韩夫妻久久| 另类小说综合欧美亚洲| 久久久亚洲综合| www.66久久| 亚洲国产精品一区二区www| 欧美精品xxxxbbbb| 欧美日韩国产片| 久久精品国产99国产| 国产三级三级三级精品8ⅰ区| 国产成人亚洲综合a∨婷婷| 国产精品久久夜| 99精品热视频| 亚洲电影你懂得| 久久久亚洲午夜电影| 色婷婷精品大在线视频 | 日韩一区二区免费在线电影| 国内精品嫩模私拍在线| 亚洲精品成a人| 欧美mv和日韩mv的网站| 99久久婷婷国产综合精品电影| 丝袜诱惑制服诱惑色一区在线观看| 久久精品视频网| 欧美性生活大片视频| 国产一区二区三区黄视频| 亚洲美女视频在线| 日韩欧美亚洲另类制服综合在线| 国产不卡高清在线观看视频| 亚洲成人免费看| 国产精品久久久久9999吃药| 欧美一区二区免费观在线| 94-欧美-setu| 国产一区二区成人久久免费影院 | 在线精品视频一区二区三四| 极品瑜伽女神91| 亚洲一区二区三区四区不卡| 久久久久国色av免费看影院| 欧美日韩久久久一区| 成人爱爱电影网址| 狠狠狠色丁香婷婷综合久久五月| 亚洲一区二区在线免费看| 国产精品无人区| 精品久久久久一区| 欧美久久久影院| 色婷婷av一区| 成人久久18免费网站麻豆 | 美女视频黄频大全不卡视频在线播放| 中文字幕一区二区日韩精品绯色| 日韩午夜三级在线| 欧美日韩和欧美的一区二区| 91美女在线观看| 国产成人超碰人人澡人人澡| 热久久免费视频| 亚洲成人免费在线观看| 亚洲欧美日韩人成在线播放| 国产精品乱人伦| 欧美国产97人人爽人人喊| 久久久不卡影院| 久久网这里都是精品| 欧美精品一区二区三区四区| 欧美一区二区在线视频| 欧美精品一二三区| 91麻豆精品国产91久久久久久| 欧美亚洲免费在线一区| 色一区在线观看| 日本韩国精品在线| 色先锋aa成人| 在线免费亚洲电影| 欧美三日本三级三级在线播放| 色老汉av一区二区三区| 日本高清无吗v一区| 色婷婷久久久综合中文字幕| 成人中文字幕合集| 国产主播一区二区三区| 国产伦精品一区二区三区视频青涩| 蜜臀99久久精品久久久久久软件| 奇米一区二区三区| 国模少妇一区二区三区| 国产乱码精品一区二区三区忘忧草| 韩国av一区二区三区四区| 精品一区二区三区久久久| 国产一区二区在线观看免费| 国产精品资源在线看| 成人精品高清在线| 91美女片黄在线观看91美女| 在线一区二区观看| 6080亚洲精品一区二区| 日韩色在线观看| 国产亚洲美州欧州综合国| 国产精品久久99| 亚洲色图欧洲色图婷婷| 亚洲成人777| 激情久久五月天| 成人晚上爱看视频| 欧美在线综合视频| 日韩手机在线导航| 国产欧美日韩在线| 一区二区三区国产| 蜜臀av一区二区| 成人免费看黄yyy456| 色哟哟一区二区三区| 欧美一区二区三区四区视频| 久久夜色精品国产欧美乱极品| 国产精品久久久久aaaa| 天天操天天综合网| 国产激情偷乱视频一区二区三区| 97久久精品人人爽人人爽蜜臀| 欧美高清精品3d| 国产欧美精品一区aⅴ影院| 一区二区在线观看免费 | 亚洲精品水蜜桃| 老司机精品视频在线| 成人av电影观看| 日韩一区二区在线观看视频播放| 国产精品女同一区二区三区| 日韩—二三区免费观看av| 国产精品资源在线观看| 欧美日韩国产免费| 国产精品久久久久aaaa樱花| 免费人成精品欧美精品| 99vv1com这只有精品| 欧美精品一区二区三区视频| 亚洲一区二三区| 成人黄页在线观看| 精品国产制服丝袜高跟| 亚洲一区精品在线| 成人av资源站| 亚洲精品在线一区二区| 天天免费综合色| 91激情五月电影| 国产精品家庭影院| 韩国av一区二区三区四区| 欧美乱妇20p| 伊人婷婷欧美激情| 白白色 亚洲乱淫| 久久影院午夜论| 日本美女一区二区三区视频| 色婷婷精品大在线视频| 国产精品三级av| 激情小说欧美图片| 欧美一区二区在线观看| 亚洲国产精品久久一线不卡| 91小视频免费观看| 中文字幕免费在线观看视频一区| 六月丁香婷婷久久| 日韩欧美www| 日本亚洲视频在线| 欧美日本在线播放| 一个色综合av| 91九色最新地址| 一区二区三区美女| 一本久久精品一区二区| 国产精品国产三级国产普通话蜜臀 | 肉肉av福利一精品导航| 91麻豆免费观看| 亚洲品质自拍视频网站| 成年人网站91| 中文字幕欧美日韩一区| 成人午夜私人影院| 国产精品国产三级国产aⅴ原创| 国产精品一线二线三线精华| 国产婷婷精品av在线| 国产成人精品免费在线| 久久久久久99精品| 粉嫩绯色av一区二区在线观看| 日本一区二区视频在线| 成人永久免费视频| 综合网在线视频| 在线免费精品视频| 午夜精品久久久久久久久久| 欧美日韩国产大片| 奇米影视一区二区三区小说| 日韩精品一区国产麻豆| 韩国欧美国产一区| 中文字幕av免费专区久久| a级精品国产片在线观看| 亚洲靠逼com| 91精品国产91综合久久蜜臀| 久久av老司机精品网站导航| 国产片一区二区| 99久久婷婷国产| 亚洲成人第一页| 精品日本一线二线三线不卡| 国产成人在线色| 亚洲精品视频免费观看| 欧美区视频在线观看| 国产最新精品免费| 亚洲欧洲精品一区二区三区不卡| 在线欧美日韩国产| 极品尤物av久久免费看| 中文字幕一区二区在线观看| 欧美精品日韩综合在线| 韩国v欧美v日本v亚洲v|