iwl-scd.h 4.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144
  1. /******************************************************************************
  2. *
  3. * This file is provided under a dual BSD/GPLv2 license. When using or
  4. * redistributing this file, you may do so under either license.
  5. *
  6. * GPL LICENSE SUMMARY
  7. *
  8. * Copyright(c) 2014 Intel Mobile Communications GmbH
  9. *
  10. * This program is free software; you can redistribute it and/or modify
  11. * it under the terms of version 2 of the GNU General Public License as
  12. * published by the Free Software Foundation.
  13. *
  14. * This program is distributed in the hope that it will be useful, but
  15. * WITHOUT ANY WARRANTY; without even the implied warranty of
  16. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
  17. * General Public License for more details.
  18. *
  19. * You should have received a copy of the GNU General Public License
  20. * along with this program; if not, write to the Free Software
  21. * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110,
  22. * USA
  23. *
  24. * The full GNU General Public License is included in this distribution
  25. * in the file called COPYING.
  26. *
  27. * Contact Information:
  28. * Intel Linux Wireless <ilw@linux.intel.com>
  29. * Intel Corporation, 5200 N.E. Elam Young Parkway, Hillsboro, OR 97124-6497
  30. *
  31. * BSD LICENSE
  32. *
  33. * Copyright(c) 2014 Intel Mobile Communications GmbH
  34. * All rights reserved.
  35. *
  36. * Redistribution and use in source and binary forms, with or without
  37. * modification, are permitted provided that the following conditions
  38. * are met:
  39. *
  40. * * Redistributions of source code must retain the above copyright
  41. * notice, this list of conditions and the following disclaimer.
  42. * * Redistributions in binary form must reproduce the above copyright
  43. * notice, this list of conditions and the following disclaimer in
  44. * the documentation and/or other materials provided with the
  45. * distribution.
  46. * * Neither the name Intel Corporation nor the names of its
  47. * contributors may be used to endorse or promote products derived
  48. * from this software without specific prior written permission.
  49. *
  50. * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  51. * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  52. * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  53. * A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  54. * OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  55. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  56. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  57. * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  58. * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  59. * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  60. * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  61. *
  62. *****************************************************************************/
  63. #ifndef __iwl_scd_h__
  64. #define __iwl_scd_h__
  65. #include "iwl-trans.h"
  66. #include "iwl-io.h"
  67. #include "iwl-prph.h"
  68. static inline void iwl_scd_txq_set_chain(struct iwl_trans *trans,
  69. u16 txq_id)
  70. {
  71. iwl_set_bits_prph(trans, SCD_QUEUECHAIN_SEL, BIT(txq_id));
  72. }
  73. static inline void iwl_scd_txq_enable_agg(struct iwl_trans *trans,
  74. u16 txq_id)
  75. {
  76. iwl_set_bits_prph(trans, SCD_AGGR_SEL, BIT(txq_id));
  77. }
  78. static inline void iwl_scd_txq_disable_agg(struct iwl_trans *trans,
  79. u16 txq_id)
  80. {
  81. iwl_clear_bits_prph(trans, SCD_AGGR_SEL, BIT(txq_id));
  82. }
  83. static inline void iwl_scd_disable_agg(struct iwl_trans *trans)
  84. {
  85. iwl_set_bits_prph(trans, SCD_AGGR_SEL, 0);
  86. }
  87. static inline void iwl_scd_activate_fifos(struct iwl_trans *trans)
  88. {
  89. iwl_write_prph(trans, SCD_TXFACT, IWL_MASK(0, 7));
  90. }
  91. static inline void iwl_scd_deactivate_fifos(struct iwl_trans *trans)
  92. {
  93. iwl_write_prph(trans, SCD_TXFACT, 0);
  94. }
  95. static inline void iwl_scd_enable_set_active(struct iwl_trans *trans,
  96. u32 value)
  97. {
  98. iwl_write_prph(trans, SCD_EN_CTRL, value);
  99. }
  100. static inline unsigned int SCD_QUEUE_WRPTR(unsigned int chnl)
  101. {
  102. if (chnl < 20)
  103. return SCD_BASE + 0x18 + chnl * 4;
  104. WARN_ON_ONCE(chnl >= 32);
  105. return SCD_BASE + 0x284 + (chnl - 20) * 4;
  106. }
  107. static inline unsigned int SCD_QUEUE_RDPTR(unsigned int chnl)
  108. {
  109. if (chnl < 20)
  110. return SCD_BASE + 0x68 + chnl * 4;
  111. WARN_ON_ONCE(chnl >= 32);
  112. return SCD_BASE + 0x2B4 + chnl * 4;
  113. }
  114. static inline unsigned int SCD_QUEUE_STATUS_BITS(unsigned int chnl)
  115. {
  116. if (chnl < 20)
  117. return SCD_BASE + 0x10c + chnl * 4;
  118. WARN_ON_ONCE(chnl >= 32);
  119. return SCD_BASE + 0x334 + chnl * 4;
  120. }
  121. static inline void iwl_scd_txq_set_inactive(struct iwl_trans *trans,
  122. u16 txq_id)
  123. {
  124. iwl_write_prph(trans, SCD_QUEUE_STATUS_BITS(txq_id),
  125. (0 << SCD_QUEUE_STTS_REG_POS_ACTIVE)|
  126. (1 << SCD_QUEUE_STTS_REG_POS_SCD_ACT_EN));
  127. }
  128. #endif