zip_main.h 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121
  1. /***********************license start************************************
  2. * Copyright (c) 2003-2017 Cavium, Inc.
  3. * All rights reserved.
  4. *
  5. * License: one of 'Cavium License' or 'GNU General Public License Version 2'
  6. *
  7. * This file is provided under the terms of the Cavium License (see below)
  8. * or under the terms of GNU General Public License, Version 2, as
  9. * published by the Free Software Foundation. When using or redistributing
  10. * this file, you may do so under either license.
  11. *
  12. * Cavium License: Redistribution and use in source and binary forms, with
  13. * or without modification, are permitted provided that the following
  14. * conditions are met:
  15. *
  16. * * Redistributions of source code must retain the above copyright
  17. * notice, this list of conditions and the following disclaimer.
  18. *
  19. * * Redistributions in binary form must reproduce the above
  20. * copyright notice, this list of conditions and the following
  21. * disclaimer in the documentation and/or other materials provided
  22. * with the distribution.
  23. *
  24. * * Neither the name of Cavium Inc. nor the names of its contributors may be
  25. * used to endorse or promote products derived from this software without
  26. * specific prior written permission.
  27. *
  28. * This Software, including technical data, may be subject to U.S. export
  29. * control laws, including the U.S. Export Administration Act and its
  30. * associated regulations, and may be subject to export or import
  31. * regulations in other countries.
  32. *
  33. * TO THE MAXIMUM EXTENT PERMITTED BY LAW, THE SOFTWARE IS PROVIDED "AS IS"
  34. * AND WITH ALL FAULTS AND CAVIUM INC. MAKES NO PROMISES, REPRESENTATIONS
  35. * OR WARRANTIES, EITHER EXPRESS, IMPLIED, STATUTORY, OR OTHERWISE, WITH
  36. * RESPECT TO THE SOFTWARE, INCLUDING ITS CONDITION, ITS CONFORMITY TO ANY
  37. * REPRESENTATION OR DESCRIPTION, OR THE EXISTENCE OF ANY LATENT OR PATENT
  38. * DEFECTS, AND CAVIUM SPECIFICALLY DISCLAIMS ALL IMPLIED (IF ANY)
  39. * WARRANTIES OF TITLE, MERCHANTABILITY, NONINFRINGEMENT, FITNESS FOR A
  40. * PARTICULAR PURPOSE, LACK OF VIRUSES, ACCURACY OR COMPLETENESS, QUIET
  41. * ENJOYMENT, QUIET POSSESSION OR CORRESPONDENCE TO DESCRIPTION. THE
  42. * ENTIRE RISK ARISING OUT OF USE OR PERFORMANCE OF THE SOFTWARE LIES
  43. * WITH YOU.
  44. ***********************license end**************************************/
  45. #ifndef __ZIP_MAIN_H__
  46. #define __ZIP_MAIN_H__
  47. #include "zip_device.h"
  48. #include "zip_regs.h"
  49. /* PCI device IDs */
  50. #define PCI_DEVICE_ID_THUNDERX_ZIP 0xA01A
  51. /* ZIP device BARs */
  52. #define PCI_CFG_ZIP_PF_BAR0 0 /* Base addr for normal regs */
  53. /* Maximum available zip queues */
  54. #define ZIP_MAX_NUM_QUEUES 8
  55. #define ZIP_128B_ALIGN 7
  56. /* Command queue buffer size */
  57. #define ZIP_CMD_QBUF_SIZE (8064 + 8)
  58. struct zip_registers {
  59. char *reg_name;
  60. u64 reg_offset;
  61. };
  62. /* ZIP Compression - Decompression stats */
  63. struct zip_stats {
  64. atomic64_t comp_req_submit;
  65. atomic64_t comp_req_complete;
  66. atomic64_t decomp_req_submit;
  67. atomic64_t decomp_req_complete;
  68. atomic64_t comp_in_bytes;
  69. atomic64_t comp_out_bytes;
  70. atomic64_t decomp_in_bytes;
  71. atomic64_t decomp_out_bytes;
  72. atomic64_t decomp_bad_reqs;
  73. };
  74. /* ZIP Instruction Queue */
  75. struct zip_iq {
  76. u64 *sw_head;
  77. u64 *sw_tail;
  78. u64 *hw_tail;
  79. u64 done_cnt;
  80. u64 pend_cnt;
  81. u64 free_flag;
  82. /* ZIP IQ lock */
  83. spinlock_t lock;
  84. };
  85. /* ZIP Device */
  86. struct zip_device {
  87. u32 index;
  88. void __iomem *reg_base;
  89. struct pci_dev *pdev;
  90. /* Different ZIP Constants */
  91. u64 depth;
  92. u64 onfsize;
  93. u64 ctxsize;
  94. struct zip_iq iq[ZIP_MAX_NUM_QUEUES];
  95. struct zip_stats stats;
  96. };
  97. /* Prototypes */
  98. struct zip_device *zip_get_device(int node_id);
  99. int zip_get_node_id(void);
  100. void zip_reg_write(u64 val, u64 __iomem *addr);
  101. u64 zip_reg_read(u64 __iomem *addr);
  102. void zip_update_cmd_bufs(struct zip_device *zip_dev, u32 queue);
  103. u32 zip_load_instr(union zip_inst_s *instr, struct zip_device *zip_dev);
  104. #endif /* ZIP_MAIN_H */