intel_scu_ipc.h 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. #ifndef _ASM_X86_INTEL_SCU_IPC_H_
  2. #define _ASM_X86_INTEL_SCU_IPC_H_
  3. /* Read single register */
  4. int intel_scu_ipc_ioread8(u16 addr, u8 *data);
  5. /* Read two sequential registers */
  6. int intel_scu_ipc_ioread16(u16 addr, u16 *data);
  7. /* Read four sequential registers */
  8. int intel_scu_ipc_ioread32(u16 addr, u32 *data);
  9. /* Read a vector */
  10. int intel_scu_ipc_readv(u16 *addr, u8 *data, int len);
  11. /* Write single register */
  12. int intel_scu_ipc_iowrite8(u16 addr, u8 data);
  13. /* Write two sequential registers */
  14. int intel_scu_ipc_iowrite16(u16 addr, u16 data);
  15. /* Write four sequential registers */
  16. int intel_scu_ipc_iowrite32(u16 addr, u32 data);
  17. /* Write a vector */
  18. int intel_scu_ipc_writev(u16 *addr, u8 *data, int len);
  19. /* Update single register based on the mask */
  20. int intel_scu_ipc_update_register(u16 addr, u8 data, u8 mask);
  21. /*
  22. * Indirect register read
  23. * Can be used when SCCB(System Controller Configuration Block) register
  24. * HRIM(Honor Restricted IPC Messages) is set (bit 23)
  25. */
  26. int intel_scu_ipc_register_read(u32 addr, u32 *data);
  27. /*
  28. * Indirect register write
  29. * Can be used when SCCB(System Controller Configuration Block) register
  30. * HRIM(Honor Restricted IPC Messages) is set (bit 23)
  31. */
  32. int intel_scu_ipc_register_write(u32 addr, u32 data);
  33. /* Issue commands to the SCU with or without data */
  34. int intel_scu_ipc_simple_command(int cmd, int sub);
  35. int intel_scu_ipc_command(int cmd, int sub, u32 *in, int inlen,
  36. u32 *out, int outlen);
  37. /* I2C control api */
  38. int intel_scu_ipc_i2c_cntrl(u32 addr, u32 *data);
  39. /* Update FW version */
  40. int intel_scu_ipc_fw_update(u8 *buffer, u32 length);
  41. #endif