⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 scu_as.lst

📁 PATTERNS FOR TIME-TRIGGERED EMBEDDED SYSTEMS by Michael J. Pont This code is copyright (c) 200
💻 LST
📖 第 1 页 / 共 2 页
字号:
C51 COMPILER V6.10  SCU_AS                                                                 04/19/2001 13:54:48 PAGE 1   


C51 COMPILER V6.10, COMPILATION OF MODULE SCU_AS
OBJECT MODULE PLACED IN .\SCU_As.OBJ
COMPILER INVOKED BY: C:\KEIL\C51\BIN\C51.EXE .\SCU_As.c OPTIMIZE(6,SIZE) BROWSE DEBUG OBJECTEXTEND

stmt level    source

   1          /*------------------------------------------------------------------*-
   2          
   3             SCU_As.c (v1.00)
   4          
   5            ------------------------------------------------------------------
   6          
   7             This is an implementation of SCU SCHEDULER (LOCAL) for 8051/52.
   8             AND an implementation of SCU SCHEDULER (RS-232) for 8051/52.
   9          
  10             --- See Chapter 27 ---
  11          
  12             *** MASTER NODE ***
  13             *** CHECKS FOR SLAVE ACKNOWLEDEMENTS ***
  14             *** Local / RS-232 version (no 'enable' support) ***
  15          
  16             *** Uses 1232 watchdog timer ***
  17          
  18             *** Assumes 12 MHz osc (same as Master) ***
  19          
  20             *** Both Master and Slave share the same tick rate (5 ms) ***
  21             *** - See Master code for details ***
  22          
  23          
  24             COPYRIGHT
  25             ---------
  26          
  27             This code is from the book:
  28          
  29             PATTERNS FOR TIME-TRIGGERED EMBEDDED SYSTEMS by Michael J. Pont 
  30             [Pearson Education, 2001; ISBN: 0-201-33138-1].
  31          
  32             This code is copyright (c) 2001 by Michael J. Pont.
  33           
  34             See book for copyright details and other information.
  35          
  36          -*------------------------------------------------------------------*/
  37          
  38          #include "Main.h"
  39          #include "Port.h"
  40          
  41          #include "SCU_As.h"
  42          #include "TLight_B.h"
  43          
  44          // ------ Public variable definitions ------------------------------
  45          
  46          // Data sent from the master to this slave
  47          tByte Tick_message_data_G;
  48          
  49          // Data sent from this slave to the master 
  50          // - data may be sent on, by the master, to another slave  
  51          tByte Ack_message_data_G = '2'; 
  52          
  53          // ------ Public variable declarations -----------------------------
  54          
  55          // The array of tasks (see Sch51.c)
C51 COMPILER V6.10  SCU_AS                                                                 04/19/2001 13:54:48 PAGE 2   

  56          extern sTask SCH_tasks_G[SCH_MAX_TASKS];
  57          
  58          // The error code variable (see Sch51.c)
  59          extern tByte Error_code_G;
  60          
  61          // ------ Private function prototypes ------------------------------
  62          
  63          static void  SCU_A_SLAVE_Enter_Safe_State(void);
  64          
  65          static void  SCU_A_SLAVE_Send_Ack_Message_To_Master(void);
  66          static tByte SCU_A_SLAVE_Process_Tick_Message(void);
  67          
  68          static void  SCU_A_SLAVE_Watchdog_Init(void);
  69          static void  SCU_A_SLAVE_Watchdog_Refresh(void) reentrant;
  70          
  71          
  72          // ------ Private constants ----------------------------------------
  73          
  74          // Each slave must have a unique non-zero ID 
  75          #define SLAVE_ID 0x32
  76          
  77          #define NO_NETWORK_ERROR (1) 
  78          #define NETWORK_ERROR (0)
  79          
  80          // ------ Private variables ----------------------------------------
  81          
  82          static bit Message_byte_G;
  83          static bit WATCHDOG_state_G = 0;
  84          static tByte Message_ID_G = 0;
  85          
  86          
  87          /*------------------------------------------------------------------*-
  88            SCU_A_SLAVE_Init_T1()
  89          
  90            Scheduler initialisation function.  Prepares scheduler
  91            data structures and sets up timer interrupts at required rate.
  92            Must call this function before using the scheduler.  
  93           
  94            BAUD_RATE - The required baud rate
  95          
  96          -*------------------------------------------------------------------*/
  97          void SCU_A_SLAVE_Init_T1(const tWord BAUD_RATE) 
  98             {
  99   1         tByte i;
 100   1      
 101   1         // Sort out the tasks
 102   1         for (i = 0; i < SCH_MAX_TASKS; i++) 
 103   1            {
 104   2            SCH_Delete_Task(i);
 105   2            }
 106   1      
 107   1         // Reset the global error variable
 108   1         // - SCH_Delete_Task() will generate an error code, 
 109   1         //   (because the task array is empty)
 110   1         Error_code_G = 0;
 111   1      
 112   1         // Set the network error pin (reset when tick message received)
 113   1         Network_error_pin = NETWORK_ERROR;
 114   1      
 115   1         // Ready for first tick message
 116   1         Message_byte_G = 1;
 117   1       
C51 COMPILER V6.10  SCU_AS                                                                 04/19/2001 13:54:48 PAGE 3   

 118   1         // ------ Set the baud rate (begin) -----------------------------
 119   1         PCON &= 0x7F;   // Set SMOD bit to 0 (don't double baud rates)
 120   1      
 121   1         //  receiver enabled
 122   1         //  9-bit data, 1 start bit, 1 stop bit, variable baud rate (asynchronous)
 123   1         SCON = 0xD2;
 124   1      
 125   1         TMOD |= 0x20;   // T1 in mode 2, 8-bit auto reload
 126   1      
 127   1         TH1 = (256 - (tByte)((((tLong)OSC_FREQ / 100) * 3125) 
 128   1                  / ((tLong) BAUD_RATE * OSC_PER_INST * 1000)));
 129   1      
 130   1         TL1 = TH1;  
 131   1         TR1 = 1;  // Run the timer
 132   1         TI = 1;   // Send first character (dummy)
 133   1      
 134   1         // ------ Set the baud rate (end) -------------------------------
 135   1      
 136   1         // Interrupt enabled
 137   1         // (Both receiving and SENDING a byte will generate a serial interrupt)
 138   1         // Global interrupts not yet enabled.
 139   1         ES = 1;
 140   1      
 141   1         // Start the watchdog
 142   1         SCU_A_SLAVE_Watchdog_Init();  
 143   1         }
 144          
 145          /*------------------------------------------------------------------*-
 146            SCU_A_SLAVE_Start()
 147          
 148            Starts the slave scheduler, by enabling interrupts.
 149          
 150            NOTE: Usually called after all regular tasks are added,
 151            to keep the tasks synchronised.
 152          
 153            NOTE: ONLY THE SCHEDULER INTERRUPT SHOULD BE ENABLED!!! 
 154          
 155          -*------------------------------------------------------------------*/
 156          void SCU_A_SLAVE_Start(void) 
 157             {
 158   1         tByte Command = 0;
 159   1         tByte Message_byte;
 160   1         tByte Count = 0;
 161   1         bit Slave_started = 0;
 162   1      
 163   1         // Disable interrupts 
 164   1         EA = 0;
 165   1      
 166   1         // We can be at this point because:
 167   1         // 1. The network has just been powered up
 168   1         // 2. An error has occurred in the Master, and it is not generating ticks
 169   1         // 3. The network has been damaged and no ticks are being received by this slave
 170   1         //
 171   1         // Try to make sure the system is in a safe state...
 172   1         SCU_A_SLAVE_Enter_Safe_State();
 173   1      
 174   1         // NOTE: Interrupts are disabled here
 175   1         Count = 0;
 176   1      
 177   1         Error_code_G = ERROR_SCH_WAITING_FOR_START_COMMAND_FROM_MASTER;
 178   1         SCH_Report_Status(); // Sch not yet running - do this manually
 179   1      
C51 COMPILER V6.10  SCU_AS                                                                 04/19/2001 13:54:48 PAGE 4   

 180   1         // Now wait (indefinitely) for appropriate signals from the master
 181   1         do {
 182   2            // Wait for tick messages (byte 1), all bits set to 0, to be received 
 183   2            do {
 184   3               SCU_A_SLAVE_Watchdog_Refresh(); // Must keep feeding the watchdog
 185   3               } while (RI == 0);  
 186   2      
 187   2            Message_byte = (tByte) SBUF; 
 188   2            RI = 0;
 189   2      
 190   2            // Must get two ID messages in a row...
 191   2            // (with command bit)
 192   2            // Ack each one
 193   2            if ((Message_byte == (tByte) SLAVE_ID) && (RB8 == 1))
 194   2               {
 195   3               Count++;
 196   3      
 197   3               // Received message for this slave - send ack
 198   3               TI = 0;                                            
 199   3               TB8 = 1; // Set command bit
 200   3               SBUF = (tByte) SLAVE_ID; 
 201   3               }
 202   2            else
 203   2               {
 204   3               Count = 0;
 205   3               }
 206   2            } while (Count < 2);
 207   1      
 208   1         // Start the scheduler
 209   1         EA = 1;
 210   1         }
 211          
 212          /*------------------------------------------------------------------*-
 213          
 214            SCU_A_SLAVE_Update
 215          
 216            This is the scheduler ISR.  It is called at a rate 
 217            determined by the timer settings in SCU_A_SLAVE_Init().
 218          
 219            This Slave is triggered by USART interrupts.
 220           
 221          -*------------------------------------------------------------------*/
 222          void SCU_A_SLAVE_Update(void) interrupt INTERRUPT_UART_Rx_Tx  
 223             {
 224   1         tByte Index;
 225   1      
 226   1         if (RI == 1) // Must check this. 
 227   1            {
 228   2            // Default
 229   2            Network_error_pin = NO_NETWORK_ERROR;
 230   2      
 231   2            // Two-byte messages are sent (Ack) and received (Tick)
 232   2            // - it takes two sched ticks to process each message
 233   2            //
 234   2            // Keep track of the current byte
 235   2            if (Message_byte_G == 0)
 236   2               {
 237   3               Message_byte_G = 1;
 238   3               }
 239   2            else
 240   2               {
 241   3               Message_byte_G = 0;

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -