dw_timer.h 1.9 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849
  1. /*
  2. * Copyright (C) 2017 C-SKY Microsystems Co., Ltd. All rights reserved.
  3. *
  4. * Licensed under the Apache License, Version 2.0 (the "License");
  5. * you may not use this file except in compliance with the License.
  6. * You may obtain a copy of the License at
  7. *
  8. * http://www.apache.org/licenses/LICENSE-2.0
  9. *
  10. * Unless required by applicable law or agreed to in writing, software
  11. * distributed under the License is distributed on an "AS IS" BASIS,
  12. * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  13. * See the License for the specific language governing permissions and
  14. * limitations under the License.
  15. */
  16. /******************************************************************************
  17. * @file dw_timer.h
  18. * @brief header file for timer driver
  19. * @version V1.0
  20. * @date 02. June 2017
  21. ******************************************************************************/
  22. #ifndef __DW_TIMER_H
  23. #define __DW_TIMER_H
  24. #include <stdio.h>
  25. #include "soc.h"
  26. /*
  27. * define the bits for TxControl
  28. */
  29. #define DW_TIMER_TXCONTROL_ENABLE (1UL << 0)
  30. #define DW_TIMER_TXCONTROL_MODE (1UL << 1)
  31. #define DW_TIMER_TXCONTROL_INTMASK (1UL << 2)
  32. #define DW_TIMER_INIT_DEFAULT_VALUE 0x7ffffff
  33. typedef struct {
  34. __IOM uint32_t TxLoadCount; /* Offset: 0x000 (R/W) Receive buffer register */
  35. __IM uint32_t TxCurrentValue; /* Offset: 0x004 (R) Transmission hold register */
  36. __IOM uint8_t TxControl: 4; /* Offset: 0x008 (R/W) Clock frequency division low section register */
  37. uint8_t RESERVED0[3];
  38. __IM uint8_t TxEOI: 1; /* Offset: 0x00c (R) Clock frequency division high section register */
  39. uint8_t RESERVED1[3];
  40. __IM uint8_t TxIntStatus: 1; /* Offset: 0x010 (R) Interrupt enable register */
  41. uint8_t RESERVED2[3];
  42. } dw_timer_reg_t;
  43. #endif /* __DW_TIMER_H */