P100脱机下载器
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

73 lines
2.7 KiB

4 years ago
  1. #ifndef __SYS_H
  2. #define __SYS_H
  3. #include "stm32f10x.h"
  4. //////////////////////////////////////////////////////////////////////////////////
  5. //������ֻ��ѧϰʹ�ã�δ���������ɣ��������������κ���;
  6. //ALIENTEK STM32������
  7. //����ԭ��@ALIENTEK
  8. //������̳:www.openedv.com
  9. //�޸�����:2012/8/18
  10. //�汾��V1.7
  11. //��Ȩ���У������ؾ���
  12. //Copyright(C) �������������ӿƼ����޹�˾ 2009-2019
  13. //All rights reserved
  14. //////////////////////////////////////////////////////////////////////////////////
  15. //0,��֧��ucos
  16. //1,֧��ucos
  17. #define SYSTEM_SUPPORT_OS 0 //����ϵͳ�ļ����Ƿ�֧��UCOS
  18. //λ������,ʵ��51���Ƶ�GPIO���ƹ���
  19. //����ʵ��˼��,�ο�<<CM3Ȩ��ָ��>>������(87ҳ~92ҳ).
  20. //IO�ڲ����궨��
  21. #define BITBAND(addr, bitnum) ((addr & 0xF0000000)+0x2000000+((addr &0xFFFFF)<<5)+(bitnum<<2))
  22. #define MEM_ADDR(addr) *((volatile unsigned long *)(addr))
  23. #define BIT_ADDR(addr, bitnum) MEM_ADDR(BITBAND(addr, bitnum))
  24. //IO�ڵ�ַӳ��
  25. #define GPIOA_ODR_Addr (GPIOA_BASE+12) //0x4001080C
  26. #define GPIOB_ODR_Addr (GPIOB_BASE+12) //0x40010C0C
  27. #define GPIOC_ODR_Addr (GPIOC_BASE+12) //0x4001100C
  28. #define GPIOD_ODR_Addr (GPIOD_BASE+12) //0x4001140C
  29. #define GPIOE_ODR_Addr (GPIOE_BASE+12) //0x4001180C
  30. #define GPIOF_ODR_Addr (GPIOF_BASE+12) //0x40011A0C
  31. #define GPIOG_ODR_Addr (GPIOG_BASE+12) //0x40011E0C
  32. #define GPIOA_IDR_Addr (GPIOA_BASE+8) //0x40010808
  33. #define GPIOB_IDR_Addr (GPIOB_BASE+8) //0x40010C08
  34. #define GPIOC_IDR_Addr (GPIOC_BASE+8) //0x40011008
  35. #define GPIOD_IDR_Addr (GPIOD_BASE+8) //0x40011408
  36. #define GPIOE_IDR_Addr (GPIOE_BASE+8) //0x40011808
  37. #define GPIOF_IDR_Addr (GPIOF_BASE+8) //0x40011A08
  38. #define GPIOG_IDR_Addr (GPIOG_BASE+8) //0x40011E08
  39. //IO�ڲ���,ֻ�Ե�һ��IO��!
  40. //ȷ��n��ֵС��16!
  41. #define PAout(n) BIT_ADDR(GPIOA_ODR_Addr,n) //����
  42. #define PAin(n) BIT_ADDR(GPIOA_IDR_Addr,n) //����
  43. #define PBout(n) BIT_ADDR(GPIOB_ODR_Addr,n) //����
  44. #define PBin(n) BIT_ADDR(GPIOB_IDR_Addr,n) //����
  45. #define PCout(n) BIT_ADDR(GPIOC_ODR_Addr,n) //����
  46. #define PCin(n) BIT_ADDR(GPIOC_IDR_Addr,n) //����
  47. #define PDout(n) BIT_ADDR(GPIOD_ODR_Addr,n) //����
  48. #define PDin(n) BIT_ADDR(GPIOD_IDR_Addr,n) //����
  49. #define PEout(n) BIT_ADDR(GPIOE_ODR_Addr,n) //����
  50. #define PEin(n) BIT_ADDR(GPIOE_IDR_Addr,n) //����
  51. #define PFout(n) BIT_ADDR(GPIOF_ODR_Addr,n) //����
  52. #define PFin(n) BIT_ADDR(GPIOF_IDR_Addr,n) //����
  53. #define PGout(n) BIT_ADDR(GPIOG_ODR_Addr,n) //����
  54. #define PGin(n) BIT_ADDR(GPIOG_IDR_Addr,n) //����
  55. //����Ϊ���ຯ��
  56. void WFI_SET(void); //ִ��WFIָ��
  57. void INTX_DISABLE(void);//�ر������ж�
  58. void INTX_ENABLE(void); //���������ж�
  59. void MSR_MSP(u32 addr); //���ö�ջ��ַ
  60. #endif