2017-05-08 3 views
0

init, probe 또는 start가 호출되지 않습니다. 각각의 시작 부분에 "PE_enter_debugger"를 배치했지만 테스트 머신은 디버거에 들어 가지 않습니다.커널 확장이로드되지만 실행되지 않습니다.

kextutil 또는 kextload로 커널 확장을로드 할 수 있으며, 잠시 동안 kextstat에 나타나지만 사라집니다. 커널의 일부분을 언로드했습니다.

$ kextstat | grep MY 
155 0 0xffffff7f82940000 0x2000  0x2000  com.mydomain.MY2000 (1) 420AB8E0-E204-3992-90D8-A55A488448E4 <133 4 3> 

언로드시 kextunload를 사용할 수 있습니다. kextunload를 두 번째로 사용하면 커널 확장을 찾을 수 없다는 오류가 발생합니다.

kext의 모든 파일과 디렉토리는 root가 그룹 휠을 소유합니다.

kextutil -tn은 문제를 찾을 수 없습니다.

시스템 무결성 보호가 비활성화되어 있고 디버그 모드가 활성화되어 있으므로 두 가지 디버거를 사용할 수 있습니다. 나는 PE_enter_debugger()를 호출하는 두 개의 다른 커널 확장을 가지고 있고 그것들은 작동한다.

MY2000은 복합 USB 장치입니다. 이것은 궁극적으로 MY2000의 네 가지 인터페이스 중 세 가지를위한 드라이버가되도록 의도되었습니다. 네 번째 인터페이스는 Windows 드라이버 설치 프로그램이있는 작은 저장소 볼륨입니다.

내 Info.plist에서 세 가지 Ioprovider 클래스 인 USBHostDevice, USBHostInterface 및 AppleUSBHostCompositeDevice를 시도했습니다.

는 (애플은 이전에 그들이 USBDevice 및 USBInterface을했다, 내 생각 엔 엘 캐피 년 일부 클래스의 이름을 바 꾸었습니다.)
<?xml version="1.0" encoding="UTF-8"?> 
<!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> 
<plist version="1.0"> 
<dict> 
    <key>CFBundleDevelopmentRegion</key> 
    <string>en</string> 
    <key>CFBundleExecutable</key> 
    <string>$(EXECUTABLE_NAME)</string> 
    <key>CFBundleIdentifier</key> 
    <string>com.mydomain.MY2000</string> 
    <key>CFBundleInfoDictionaryVersion</key> 
    <string>6.0</string> 
    <key>CFBundleName</key> 
    <string>$(PRODUCT_NAME)</string> 
    <key>CFBundlePackageType</key> 
    <string>KEXT</string> 
    <key>CFBundleShortVersionString</key> 
    <string>1.0</string> 
    <key>CFBundleVersion</key> 
    <string>1</string> 
    <key>IOKitPersonalities</key> 
    <dict> 
     <key>MY2000</key> 
     <dict> 
      <key>IOKitDebug</key> 
      <integer>65535</integer> 
      <key>IOClass</key> 
      <string>com_mydomain_MY2000</string> 
      <key>CFBundleIdentifier</key> 
      <string>com.mydomain.MY2000</string> 
      <key>IOProviderClass</key> 
      <string>AppleUSBHostCompositeDevice</string> 
      <key>IOMatchCategory</key> 
      <string>com_mydomain_MY2000</string> 
      <key>idVendor</key> 
      <string>0x1234</string> 
      <key>idProduct</key> 
      <string>0x2000</string> 
      <key>bInterfaceClass</key> 
      <string>0x10</string> 
      <key>bInterfaceSubclass</key> 
      <string>0x0</string> 
      <key>bInterfaceProtocol</key> 
      <string>0x0</string> 
     </dict> 
    </dict> 
    <key>NSHumanReadableCopyright</key> 
    <string>Copyright © 2017 My Company. All rights reserved.</string> 
    <key>OSBundleLibraries</key> 
    <dict> 
     <key>com.doequalsglory.driver.IOProxyFramebuffer</key> 
     <string>1.0.0d1</string> 
     <key>com.apple.kpi.iokit</key> 
     <string>16.5</string> 
     <key>com.apple.kpi.libkern</key> 
     <string>16.5</string> 
    </dict> 
</dict> 
</plist> 

당신이 내게 줄 수있는 모든 도움을 주셔서 감사합니다.

답변

1

의 Info.plist가 있습니다

 <key>idVendor</key> 
     <string>0x1234</string> 
     <key>idProduct</key> 
     <string>0x2000</string> 

는 "문자열", "정수"재산 목록 편집기에서

 <key>idVendor</key> 
     <integer>1234</integer> 
     <key>idProduct</key> 
     <integer>29193</integer> 

있을 수에 기본 문자열 유형을 변경해야합니다.

FACEPALM.

술을 마시고 코드를 작성하면 안됩니다.

관련 문제