Читаем Встраиваемые системы. Проектирование приложений на микроконтроллерах семейства 68HC12/HCS12 с применением языка С полностью

 /* сохранить результаты ATD-преобразования*/

 /* в глобальном массиве char*/

 sens[0] = ADR7H; /*крайний левый датчик */

 sens[1] = ADR6H; /*средний левый датчик */

 sens[2] = ADR5H; /*центральный датчик */

 sens[3] = ADR4H; /*средний правый датчик */

 sens[4] = ADR3H; /*крайний правый датчик */

 sens[5] = ADR2H; /*Датчик Холла*/

 /*анализ информации датчиков для решения о повороте. Примечание: пороги для*/

 /*датчика Холла(hes_threshold) и для ИК-датчиков (opto_threshold)являются*/

 /* глобальными переменными и определены экспериментально*/

 if (sens[5] hes_threshold) { /*сигнал с датчика Холла, объезд*/

  pwm_motors(back_up); /* робот дает задний ход*/

  /*действия, следующие после того */

  /* как робот отъехал назад */

  if(sens[0] opto_threshold) pwm_motors(right_turn);

  else pwm_motors(left_turn);

  for(i=0; i0xFFFF; i++) { /*задержка перед вращением двигателя */

   for(j=0; j15; j++){

    ;

   }

  }

 }

 /*если обнаружен тупик - задний ход*/

 else if((sens[2]opto_threshold) (sens[0]opto_threshold) (sens[4]opto_threshold)) {

  pwm_motors(back_up);

 }

 /*если стенки спереди и слева, */

 /*поворот робота направо */

 else if((sens[0]opto_threshold) (sens[2]opto_threshold)) {

  pwm_motors(right_turn);

 }

 /*если стенки спереди и справа, */

 /*поворот робота налево */

 else if((sens[2]opto_threshold) (sens[4]opto_threshold)) {

  pwm_motors(left_turn);

 }

 /*если стенка перед средним правым */

 /* датчиком, то полуповорот направо */

 else if (sens[1] opto_threshold) {

  pwm_motors(half_right);

 }

 /*если стенка перед средним левым */

 /* датчиком, то полуповорот налево */

 else if (sens[3]opto_threshold) {

  pwm_motors(half_left);

 }

 /*если сигналов от датчиков нет, продолжить движение вперед*/

 else {

  pwm_motors(forward);

 }

}

Если мы хотим подразделить этот код на три части обрабатываемые ОСРВ без прерывания, мы можем вставить точки прерывания после последовательности инициализации ATD и после последовательности записи данных с ATD. Это позволит функции без проблем прерывать и восстанавливать управление процессором. Чтобы выполнять эти изменения, мы должны ввести переменную, которую мы назовем code_section. Эта переменная позволит нам проследить, какая из трех частей кода должна быть выполнена при очередной активности задачи.

int process_turn(int code_section) {

 switch(code_section) {

 case 0:

  /*Инициализация системы ATD */

  ATDCTL2 = 0x80; /*включение ATD */

  ATDCTL3 = 0x00; /*игнорировать доступ при отладке системы */

  ATDCTL4 = 0x7F; /*Снижение частоты таймера P до 125 кГц */

  /*выборка, время преобразования = 32 ATD цикла */

  /* 1 выборка за каждые 256 мкс */

  for (i=0; i67; i++) {

   /* ожидание 100 мкс при 8 МГц ECLK*/

   ;

  }

  code_section = 1; /*update code_section variable */

  break;

 case 1:

  /*Инициализация ATD-преобразования */

  ATDCTL5 = 0x50; /*Начать многоканальное ATD-преобразование*/

  /* для 8 каналов */

Перейти на страницу:
Нет соединения с сервером, попробуйте зайти чуть позже