흠.. 일단 델 인스피론15 7567에서 dw1830 모듈이 맞지 않아 dw1560 & dw1820a 두개를 주문했습니다
이게 3월 말경에 주문한게 이제 도착했네요..
아무튼 1560하고 1830은 가격이 많이 올랐습니다.
제가 첨 노트북 해킨할때 두개가 12~15 달러 했는데 해킨 유져가 많아저서 그런지 가격도 많이 올라가네요
1820A는 까다로워서인지 아직 가격이 착합니다 12달러에 아직 살수 있으니까요..
일단 제가 올린 네트워크 / 블투 모듈 작동가능 한지를 따져보시고 주문하세요
원래 dw1560을 사용할생각이었으나 그냥 주문해서 달면 된다는 사실을 알고있었기에 속도면에서 좀더 좋은걸 찾다가 알게 된게
DW1820a입니다. 성능면에서는 dw1830과 비슷하고 크기는 dw1560과 같기에 제가 가진 노트북에 딱이죠..
하지만 설치 가능한지를 검색하는 중 쉽지는 않고 전원이 안꺼진다. 수동으로 꺼야한다 등등 문제가 많았습니다.
어차피 삽질 할 생각으로 주문한것이기에.. 안되면 dw1560쓰지뭐 이런 심산으로 시작하게 되었습니다.
그러던중 talas 회원님께서 선빵하셔서.. ㅎㅎ
전뭐.. 삽질은 조금 했지만 거희 줏어먹은 느낌이네요 ^^
그래도 흔적은 남겨야겠죠? 아직 해결못하신분 & 앞으로 잘 해결하실분들을 위해서...
일단 메인이 되어야 할것은 아무래도 이곳이 아닌가 생각이 되네요
위 링크에 가면 이런 내용이 있습니다. 이게 기본이 되어야할 사항이라고 생각됩니다.
- Supports AirPort_Brcm4360, AirPort_BrcmNIC and AirPort_BrcmNIC_MFG
- Implements patch for chip identificator checking (0xaa52), in <=10.12 it's required for successful driver starting
- Implements patch for "Failed PCIe configuration patch", required for some cards
- Implements patch for "Third Party Device" (returns vendor name "Apple")
- Implements patch for removing of white-list check
- Implements 5Ghz and country code patch (US by default)
- Implements WOWL (WoWLAN) disabler (turned on by default) - no low speed after wake
- Implements patch to disable LPO panic in AirPortBrcmNIC
- Clover Airport Fix + AirportBrcmFixup
- Clover Airport Fix + AddProperties(fake device-id) + AirportBrcmFixup (preferable)
- Clover Airport Fix + AirportBrcmFixup + FakePCIID + FakePCIID_Broadcom_WiFi.kext
- AirportBrcmFixup + FakePCIID + FakePCIID_Broadcom_WiFi.kext
brcmfx-country=XXchanges the country code to XX (US, CN, #a, ...)
-brcmfxdbgturns on debugging output
-brcmfxbetaenables loading on unsupported osx
-brcmfxoffdisables kext loading
wl_msg_level2=0xXXXXset log level for native network kexts
-brcmfxwowlenables WOWL (WoWLAN) - it is disabled by default
brcmfx-countryalso can be injected via DSDT or AddProperties/Arbitrary in Clover
installation types 부분에 보면 4가지의 방법이 있습니다.
뭐 달리 설명을 안드려도 될것 같구요 kext는 위와 같이 해야하고
여기에서 보통 파일을 받으면 어느걸 넣어야 하는지 많이 헷갈려하시고 남이 이거 넣다해서 똑같이 그거 넣으면 안되겠죠?
모듈에 들어간 칩에 따라 달라지므로 꼭 알아보고 넣으세요 괜히 이부분에서 많이 삽질을 하게 되거든요..
Install one of BrcmPatchRAM.kext or BrcmPatchRAM2.kext depending on OS X version, never both.
BrcmPatchRAM.kext: for 10.10 or earlier.
BrcmPatchRAM2.kext: for 10.11 or later.
Also, install one firmware kext BrcmFirmwareData.kext or BrcmFirmwareRepo.kext, depending on installation location, never both.
BrcmFirmwareRepo.kext: Install to /System/Library/Extensions (/Library/Extensions on 10.11 and later). This kext is much more memory efficient than BrcmFirmwareData.kext and is the preferred configuration.
BrcmFirmwareData.kext: Most appropriate for EFI/Clover/kexts. BrcmFirmwareRepo.kext, while much more memory efficient, cannot be injected as can BrcmFirmwareData.kext
Advanced users: For custom firmware injectors, install the injector plus BrcmFirmwareRepo.kext. This works from either /S/L/E or EFI/Clover/kexts. Optionally, you may remove all the firmwares from BrcmFirmwareRepo.kext/Contents/Resources. If you're using the injector from Clover/kexts, the IOProviderClass in the Info.plist for BrcmFirmwareRepo.kext must be changed from "disabled_IOResources" to "IOResources". And still, you may find it unreliable... as that is the way Clover kext injection is (it does not simulate kext installation perfectly). In testing, best result was obtained if you replace the IOKitPersonalities entry in BrcmFirmwareRepo.kext Info.plist with that of the injector kext (no need for the injector at that point).
Also, if you have a non-PatchRAM device (or you're not sure), install one of BrcmNonPatchRAM.kext or BrcmNonPatchRAM2.kext, depending on OS X version, never both. Although these kexts do not install any firmware (these devices have firmware built-in), they still depend on BrcmPatchRAM/BrcmPatchRAM2.kext.
BrcmNonPatchRAM.kext: for 10.10 or earlier
BrcmNonPatchRAM2.kext: for 10.11 or later.
Note if you have an Apple MacBook/iMac/Mac Pro etc, follow the Mac instructions
Most Broadcom USB Bluetooth devices make use of a system called RAMUSB.
RAMUSB allows the firmware for the device to be updated on-the-fly, however any updates previously applied are lost when shutting down the machine.
The Broadcom Windows driver will upload firmware into the Broadcom Bluetooth device on every startup, however for OS X this functionality is not supported out of the box.
BrcmPatchRAM kext is an OS X driver which applies PatchRAM updates for Broadcom RAMUSB based devices.
It will apply the firmware update to your Broadcom Bluetooth device on every startup / wakeup, identical to the Windows drivers.
The firmware applied is extracted from the Windows drivers and the functionality should be equal to Windows.
Note that the original Apple Broadcom bluetooth devices are not RAMUSB devices, and thus do not have the same firmware mechanism.
To be used for OS X 10.11 or newer.
This kext is a simple injector... it does not contain a firmware uploader. Try this kext if you wish to see if your device will work without a firmware uploader.
Do not use any of the other kexts (BrcmPatchRAM, BrcmPatchRAM2, BrcmFirmwareRepo, or BrcmFirmwareData) with this kext.
This kext is not provided in the distribution ZIP. You can build it if you wish to try it. It was removed as it presense was causing confusion for those that don't read carefully and didn't install the preferred kexts correctly. It is not currently being updated with new devices. If yours is not present, edit the Info.plist as needed.
BrcmPatchRAM supports any Broadcom USB bluetooth device based on the BCM20702 chipset (possibly other chipsets are supported also, but this has not been tested).
The following devices are supported at the moment:
Devices marked with * are tested successfully
Non-PatchRAM devices (BrcmPatchRAM used to speed up recovery after sleep):
[03f0:231d]HP 231d (ProBook BT built-in firmware)
[13d3:3295]Azurewave BCM943225 (20702A bult-in firmware)
Tested PatchRAM devices: *
[0489:e032] 20702 Combo USB *
[0489:e042] 20702A1 Lenovo China *
[0489:e079] Lenovo China 43162 NGFF *
[0489:e07a] Lenovo NGFF (4352 / 20702) *
[04ca:2003] 20702A1 Lenovo China *
[04ca:200a] LiteOn (4352 Combo) *
[04ca:200b] LiteOn (4352 Combo) *
[04ca:200c] LiteOn (4352 Combo) *
[04ca:200f] Acer / LiteOn (4352 Combo) *
[050d:065a] Belkin (20702) *
[0930:0221] Toshiba (4352 / 20702) *
[0930:0223] Toshiba NGFF (4352 / 20702) *
[0a5c:216b] HP Rapture 4352Z NGFF Combo *
[0a5c:216e] HP Blackbird 43162 NGFF *
[0a5c:216f] Dell DW1560 (4352/20702) *
[0a5c:21de] 4352/20702A1 combo *
[0a5c:21e1] HP Softsailing (20702A1) *
[0a5c:21e6] non-UHE Lenovo Bluetooth (20702) *
[0a5c:21e8] Bluetooth USB Dongle (20702A1) *
[0a5c:21ec] Inateck Bluetooth (20702A1) *
[0a5c:21fb] HP Supra 4352 (20702A1 Combo) *
[0a5c:21fd] Broadcom 4352Z *
[0a5c:22be] Broadcom BCM20702 Bluetooth 4.0 USB Device *
[0a5c:6410] Dell Wireless 1830 Bluetooth 4.1 LE *
[0b05:17cb] Asus BT-400 (20702 stand-alone) *
[0b05:17cf] Asus (4352/20702A1 combo) *
[0b05:180a] Azurewave (4360/20702 combo) *
[13d3:3404] Azurewave (4352HMB) *
[13d3:3411] Dell Alienware (4352/20702A1 combo) *
[13d3:3413] Azurewave (4360/20702 combo) *
[13d3:3418] Azurewave (4352/20702 combo) *
[13d3:3435] Azurewave (4352/20702 combo) *
[13d3:3456]Azurewave (4352/20702 combo) *
[413c:8143] Dell DW1550 (4352/20702 combo)
All of the firmwares from the Windows package are present in the kext and automatically associated with their vendor/device-ids. They are expected to work, but have not been confirmed. If you can confirm a working device not listed above, please notify via the "issues" database on github.
More Installation Details
BrcmPatchRAM.kext and BrcmPatchRAM2.kext can be installed either through Clover kext injection or placed in /System/Library/Extensions (/Library/Extensions on 10.11 and later). Install only one, not both, depending on system version.
BrcmFirmwareRepo.kext does not work with Clover kext injection, unless using a device specific firmware injector. BrcmFirmwareData.kext can work with Clover kext injection.
You can also use a device specific firmware injector (in conjunction with BrcmFirmwareRepo.kext). In this scenario, BrcmFirmwareRepo.kext does work from Clover kexts.
You will find device specfic injectors in the 'firmwares' directory of the git repository. They are not included in the distribution ZIP.
There are a number of delays which can be changed with the following kernel flags. You might change these values if you find BrcmPatchRAM is hanging during firmware load.
bpr_probedelay: Changes mProbeDelay. Default value is 0.
bpr_initialdelay: Changes mInitialDelay. Default value is 100.
bpr_preresetdelay: Changes mPreResetDelay. Default value is 20.
bpr_postresetdelay: Changes mPostResetDelay. Default value is 100.
Refer to the source for futher details on these delays.
Example,... to change mPostResetDelay to 400ms, use kernel flag: bpr_postresetdelay=400.
Note: In Clover, kernel flags are specified at config.plist/Boot/Arguments, or you can change them (temporarily for next boot) in Clover Options within the Clover GUI.
Note: Some with the typical "wake from sleep" problems are reporting success with: bpr_probedelay=100 bpr_initialdelay=300 bpr_postresetdelay=300. Or slightly longer delays: bpr_probedelay=200 bpr_initialdelay=400 bpr_postresetdelay=400.
BrcmPatchRAM consists of 2 parts:
- BrcmPatchRAM itself communicates with supported Broadcom Bluetooth USB devices (as configured in the Info.plist), and detects if they require a firmware update.
If a firmware update is required, the matching firmware data will be uploaded to the device and the device will be reset.
- BrcmFirmwareStore (implemented by either BrcmFirmwareData.kext or BrcmFirmwareRepo.kext) is a shared resource which holds all the configured firmwares for different Broadcom Bluetooth USB devices.
Some devices require device specific firmware, while others can use the newest version available in the Windows drivers without issue.
New firmwares are added/configured on a regular basis to support devices, so be sure to follow release updates, or log an issue if you find your device is not supported.
Firmwares can be stored using zlib compression in order to keep the configuration size manageable.
After the device firmware is uploaded, the device control is handed over to Apple's BroadcomBluetoothHostControllerUSBTransport. This means that for all intents and purposes your device will be native on OS X and support all functionalities fully.
It is possible to use the Continuity Activation Patch in combination with BrcmPatchRAM through Clover or through dokterdok's script: https://github.com/dokterdok/Continuity-Activation-Tool
Clover users can patch using KextsToPatch in config.plist.
The patch for 10.10 is:
<dict> <key>Comment</key> <string>10.10.2+ BT4LE-Handoff-Hotspot, Dokterdok</string> <key>Find</key> <data>SIXAdFwPt0g=</data> <key>Name</key> <string>IOBluetoothFamily</string> <key>Replace</key> <data>Qb4PAAAA61k=</data> </dict>
The patch for 10.11 is:
<dict> <key>Comment</key> <string>10.11.dp1+ BT4LE-Handoff-Hotspot, credit RehabMan based on Dokterdok original</string> <key>Find</key> <data>SIX/dEdIiwc=</data> <key>Name</key> <string>IOBluetoothFamily</string> <key>Replace</key> <data>Qb4PAAAA60Q=</data> </dict>
After installing BrcmPatchRAM, even though your Bluetooth icon may show up, it could be that the firmware has not been properly updated.
Verify the firmware is updated by going to System Information and check the Bluetooth firmware version number under the Bluetooth information panel.
If the version number is "4096", this means no firmware was updated for your device and it will not work properly.
Verify any errors in the system log by running the following command in the terminal:
cat /var/log/system.log | grep -i brcm[fp]
Ensure you check only the latest boot messages, as the system.log might go back several days.
If the firmware upload failed with an error, try installing the debug version of BrcmPatchRAM in order to get more detailed information in the log.
In order to report an error log an issue on github with the following information:
- Device product ID
- Device vendor ID
- BrcmPatchRAM version used
- Dump of BrcmPatchRAM debug output from /var/log/system.log showing the firmware upload failure
Some USB devices are very firmware specific and trying to upload any other firmware for the same chipset into them will fail.
This usually displays in the system log as:
BrcmPatchRAM: Version 0.5 starting. BrcmPatchRAM: USB [0a5c:21e8 5CF3706267E9 v274] "BCM20702A0" by "Broadcom Corp" BrcmPatchRAM: Retrieved firmware for firmware key "BCM20702A1_001.002.014.1443.1612_v5708". BrcmPatchRAM: Decompressed firmware (29714 bytes --> 70016 bytes). BrcmPatchRAM: device request failed (0xe000404f). BrcmPatchRAM: Failed to reset the device (0xe00002d5). BrcmPatchRAM: Unable to get device status (0xe000404f). BrcmPatchRAM: Firmware upgrade completed successfully.
The errors in between mean the firmware was not uploaded successfully, and the device will most likely need a specific firmware configured.
For other devices the newest firmware available (even though not specified specifically in the Windows drivers) works fine.
In order to support a new device, the firmware for the device needs to be extracted from existing Windows drivers.
A copy of the (current) latest Broadcom USB bluetooth drivers can be found here: http://drivers.softpedia.com/get/BLUETOOTH/Broadcom/ASUS-X99-DELUXE-Broadcom-Bluetooth-Driver-6515800-12009860.shtml#download
Should you come across newer drivers than 126.96.36.19960, please let me know.
In order to get the device specific firmware for your device take the following steps:
Look up your USB device vendor and product ID, in this example we will be using the BCM94352Z PCI NGFF WiFi/BT combo card, for which the vendor is 0930 and product ID 0233.
Extract the Windows Bluetooth driver package and open the bcbtums-win8x64-brcm.inf file.
Find your vendor / device ID combination in the .inf file
%BRCM20702.DeviceDesc%=BlueRAMUSB0223, USB\VID_0930&PID_0223 ; 20702A1 Toshiba 4352
- Locate the mentioned "RAMUSB0223" device in the .inf file:
;;;;;;;;;;;;;RAMUSB0223;;;;;;;;;;;;;;;;; [RAMUSB0223.CopyList] bcbtums.sys btwampfl.sys BCM20702A1_001.002.014.1443.1457.hex
Copy the firmware hex file matching your device from the Windows package, in this case "BCM20702A1_001.002.014.1443.1457.hex"
The firmware file can now optionally be compressed using the included zlib.pl script:
zlib.pl deflate BCM20702A1_001.002.014.1443.1457.hex > BCM20702A1_001.002.014.1443.1457.zhx
- After this a hex dump can be created for pasting into a plist editor:
xxd -ps BCM20702A1_001.002.014.1443.1457.zhx|tr '\n' ' ' > BCM20702A1_001.002.014.1443.1457.dmp
- Using a plist editor create a new firmware key under the BcmFirmwareStore/Firmwares dictionary.
Note that the version number displayed in OS X is the last number in the file name (1457 in our sample) + 4096.
So in this case the firmware version in OS X would be: "c14 v5553".
- After configuring a key under BcmFirmwareStore/Firmwares, add your device ID as a new device for BrcmPatchRAM.
Firmwares can also be loaded directly from BrcmFirmwareRepo.kext/Contents/Resources, either by firmware key name (see above), or by naming the file with just the vendor and device-id. For example, 0930_0223.hex (uncompressed) or 0930_0223.zhx (compressed).
Copying an existing IOKit personality and modifying its properties is the easiest way to do this. Configure the earlier firmware using its unique firmware key.
Repo activity is currently unavailable.
그리고 /l/e 넣고 캐쉬리빌드 또는 /s/l/e에 넣고 캐쉬 리빌드 또는 저처럼 clover/kext에넣고 사용
편한 방법대로 하시면 됩니다.
아 그리고 저는 dw1820a 모듈이 RP06에 할당되었습니다. 이건 윈도우에서 알아보면 됩니다.
델노트북 답게 델 네트워크 카드는 별도 다운 받지 않아도 그냥 인스톨 되더 군요..
그래서 장치관리자에서 보니 RP06으로 확인되었습니다.
PciRoot(0x0)/Pci(0x1c,0x05)/Pci(0x0,0x0) 1c,0x05 이게 RP06을 의미합니다.
나머지 우측에서 저의 dw1820a는 pci14e4,43a3 참조한 링크에는 4353으로 되어있지만 정확한건 43a3 입니다.
이또한 윈도우에서 얻은 장치 정보입니다.
이두가지만 자신의 모듈 사양에 맞게 변형해주면 됩니다.
나머지는 값유형 string에 맞게 pci 목록에 뜨거든요..
잠자기도 잘되고 깨어나도 잘붙고.. 속도도 잘나오고 버벅임도 없고
깔끔한 dw1820a dw1830만큼 퀘적합니다.
그럼 아무쪼록 안된다고 투정부리지 마시고 즐거운 삽질 하시길 바랍니다.
어차피 해킨의 길은 삽질의 길입니다. 이게 싫다면 리얼맥 사세요. 그게 정신건강에 이롭습니다.