Blame view

kernel/linux-rt-4.4.41/arch/arm/include/debug/sti.S 1.73 KB
5113f6f70   김현기   kernel add
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
  /*
   * arch/arm/include/debug/sti.S
   *
   * Debugging macro include header
   * Copyright (C) 2013 STMicroelectronics (R&D) Limited.
   *
   * This program is free software; you can redistribute it and/or modify
   * it under the terms of the GNU General Public License version 2 as
   * published by the Free Software Foundation.
   */
  
  #define STIH41X_COMMS_BASE              0xfed00000
  #define STIH41X_ASC2_BASE               (STIH41X_COMMS_BASE+0x32000)
  
  #define STIH41X_SBC_LPM_BASE            0xfe400000
  #define STIH41X_SBC_COMMS_BASE          (STIH41X_SBC_LPM_BASE + 0x100000)
  #define STIH41X_SBC_ASC1_BASE           (STIH41X_SBC_COMMS_BASE + 0x31000)
  
  
  #define VIRT_ADDRESS(x)		(x - 0x1000000)
  
  #if IS_ENABLED(CONFIG_STIH41X_DEBUG_ASC2)
  #define DEBUG_LL_UART_BASE	STIH41X_ASC2_BASE
  #endif
  
  #if IS_ENABLED(CONFIG_STIH41X_DEBUG_SBC_ASC1)
  #define DEBUG_LL_UART_BASE	STIH41X_SBC_ASC1_BASE
  #endif
  
  #ifndef DEBUG_LL_UART_BASE
  #error "DEBUG UART is not Configured"
  #endif
  
  #define ASC_TX_BUF_OFF  0x04
  #define ASC_CTRL_OFF    0x0c
  #define ASC_STA_OFF     0x14
  
  #define ASC_STA_TX_FULL         (1<<9)
  #define ASC_STA_TX_EMPTY        (1<<1)
  
  
  		.macro	addruart, rp, rv, tmp
  		ldr	\rp,      =DEBUG_LL_UART_BASE	@ physical base
  		ldr	\rv,      =VIRT_ADDRESS(DEBUG_LL_UART_BASE) @ virt base
  		.endm
  
                  .macro  senduart,rd,rx
                  strb    \rd, [\rx, #ASC_TX_BUF_OFF]
                  .endm
  
                  .macro  waituart,rd,rx
  1001:           ldr     \rd, [\rx, #ASC_STA_OFF]
                  tst     \rd, #ASC_STA_TX_FULL
                  bne     1001b
                  .endm
  
                  .macro  busyuart,rd,rx
  1001:           ldr     \rd, [\rx, #ASC_STA_OFF]
                  tst     \rd, #ASC_STA_TX_EMPTY
                  beq     1001b
                  .endm