bluesleep.txt 1.6 KB

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. * Bluetooth Sleep Protocol driver
  2. Bluetooth controller communicates with the Bluetooth Host using HCI Transport layer.
  3. HCI Transport layer can be based on UART or USB serial communication protocol.
  4. Apart from the transport layer, Bluetooth Controller also supports Low Power Mode
  5. using various mechanisms. One of such mechanism is Out-of-Band Sleep. Also known
  6. as 2-wire sleep mechanism.
  7. Out-of-Band Sleep:
  8. It requires two GPIOs to communicate the sleep protocol between Host and Controller.
  9. One of them is called as Host Wake GPIO where as other is known as a External wake
  10. GPIO.
  11. Host Wake GPIO is used for awake the Host from the Sleep Mode. It is controlled by the
  12. Controller. It should be wakeup interruptible source on the Host.
  13. External Wake GPIO is used for awake the Controller from the Sleep Mode. It is controlled
  14. by the Host.
  15. Required Properties:
  16. - compatible: Should be "qca,ar3002_bluesleep"
  17. - host-wake-gpio: Specify GPIO for Host wake signal (Controller -> Host).
  18. - ext-wake-gpio: Specify GPIO for Controller wake signal(Host -> Controller).
  19. - interrupt-parent: Should be phandle for the interrupt controller
  20. that services interrupts for this device.
  21. - interrupts: Should contain host wake interrupt from controller.
  22. - interrupt-names: indicates interrupts passed to driver
  23. (via interrupts property) by name. "host_wake" is mandatory.
  24. Optional Properties:
  25. None
  26. Example:
  27. bt_sleep {
  28. compatible = "qca,ar3002_bluesleep";
  29. host-wake-gpio = <&msmgpio 12 0>;
  30. ext-wake-gpio = <&msmgpio 13 0>;
  31. interrupt-parent = <&msmgpio>;
  32. interrupts = <12 0>;
  33. interrupt-names = "host_wake";
  34. };