zip_main.h 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106
  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 Instruction Queue */
  63. struct zip_iq {
  64. u64 *sw_head;
  65. u64 *sw_tail;
  66. u64 *hw_tail;
  67. u64 done_cnt;
  68. u64 pend_cnt;
  69. u64 free_flag;
  70. /* ZIP IQ lock */
  71. spinlock_t lock;
  72. };
  73. /* ZIP Device */
  74. struct zip_device {
  75. u32 index;
  76. void __iomem *reg_base;
  77. struct pci_dev *pdev;
  78. /* Different ZIP Constants */
  79. u64 depth;
  80. u64 onfsize;
  81. u64 ctxsize;
  82. struct zip_iq iq[ZIP_MAX_NUM_QUEUES];
  83. };
  84. /* Prototypes */
  85. struct zip_device *zip_get_device(int node_id);
  86. int zip_get_node_id(void);
  87. void zip_reg_write(u64 val, u64 __iomem *addr);
  88. u64 zip_reg_read(u64 __iomem *addr);
  89. void zip_update_cmd_bufs(struct zip_device *zip_dev, u32 queue);
  90. u32 zip_load_instr(union zip_inst_s *instr, struct zip_device *zip_dev);
  91. #endif /* ZIP_MAIN_H */