Главная Микроконтроллеры [0] [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] [62] [63] [64] [65] [66] [67] [68] [69] [70] [71] [72] [73] [74] [75] [76] [77] [78] [79] [80] [81] [82] [83] [ 84 ] [85] [86] [87] [88] [89] [90] [91] [92] [93] Начнем отладку программы, нажав клавишу F11. В появившемся окне Simulator options выберем микроконтроллер: Device AT90S8515 with External SRAM. Для контроля отладки вызовем окна переменных, процессора и памяти: View Watches, View Processor и View New Memory view. В окно Watches введем переменные tmp и cnt. Первые три команды были отлажены в проекте Метогу.арг, поэтому переместим курсор на первую команду ЗАГРУЗКИ ДАННЫХ В БУФЕР: LDItmp,$AA и нажмем Ctrl+FlO. Нажмем F11 - в переменную tmp (смотрите в окне Watch) загрузилась константа $АА. В окне просмотра памяти Memory перейдем на адрес $7FFD (адрес wrBufl), для этого в окне ввода, расположенном в первой строке окна справа, заменим 0x0060 на 0x7FFD. Жмем F11 - в ячейке с адресом 7FFD появились данные АА. Таким же способом переходим к ячейке SBFFE (wrBuf2), дважды жмем F11, проверяем состояние ячейки, оно равно 55. Повторяем действия для ячейки SDFFF - ее состояние станет равным 71. Теперь указатель выполнения команд находится на первой команде ЧТЕНИЯ/ИЗМЕНЕНИЯ ДАННЫХ В БУФЕРАХ: LDS tmp, rdBufI К сожалению, отладчик не позволит правильно отобразить процессы, происходящие в нашей схеме из-за того, что симулятор предполагает подключение к микроконтроллеру лишь внешней памяти размером 65536 Кбайт, поэтому параллельная запись данных в буфер и в соответствующую ячейку памяти никак не отражается симулятором. Возможный выход - до выполнения команды LDS вручную загрузить в ячейки с адресами rdBufl, rdBuf2 и rdBuf3 данные, которые должны бьши в них загрузиться при записи в буферы 1...3 ($АА, $55 и $71 соответственно). Итак, в окне Memory перейдем к ячейке с адресом $FFFD (rdBufl). В этом случае удобнее воспользоваться скроллером, переместив его в самый низ, так как интересующие нас ячейки с адресами $FFFD, $FFFE, $FFFF (rdBufl, rdBuf2 и rdBuf3 соответственно) явля- ются тремя последними ячейками, которые могут отображаться в окне Memory. Щелкнем на третьей от конца ячейке - ее адрес в виде OxFFFD отобразится в окошке адреса (справа в первой строке окна Memory). Вместо содержимого этой ячейки (скорее всего 00) введем АА, курсор автоматически перейдет на следующую ячейку с адресом OxFFFE, введем в нее значение 55, в ячейку OxFFFF - значение 71. Второй вариант (здесь не реализован, проверьте его отладку самостоятельно): после команд записи типа STS wrBuf1,tmp добавлять команды STS rdSufl.tmp то же для буферов 2 и 3. Что при этом произойдет? В реальной схеме: • при выполнении первой из команд запись произойдет как в буфер, так и в микросхему памяти (подробности смотрите в описании схемы); • вторая команда еще раз запишет те же данные в ту же ячейку микросхемы памяти. При отладке: одинаковые данные запишутся в два адреса: один - имитирующий ячейку микросхемы памяти, второй - имитирующий буфер. При этом программа несколько удлиняется. Однако после отладки дополнительные команды можно удалить. Продолжим отладку. Следя за ячейками памяти wrBufl, wrBufl и wrBuD, а также за переменной tmp, выполним 9 команд (9 нажатий F11). Теперь указатель выполнения команд находится на первой команде ЗАГРУЗКИ В ПАМЯТЬ ПЕРВОГО МАССИВА. Интерес в записи первого массива в память представляет первый цикл. В окне Memory перейдем к ячейке с адресом ОхЕОбО (aArBgnl). Переведем курсор на команду INCtmp и нажмем C-trl+FlO. В ячейке с адресом ОхЕОбО появился байт данных FF, соответствующий значению переменной tmp. Нажмем F11 - выполнение команды IN С привело к тому, что переменная tmp стала равна нулю, в результате чего установился бит Z (окно Processor). Поэтому если бы команда INC стояла перед командой BRNE, выполнился бы лищь один цикл записи элементов массива в память. Замечание: $FF+1 = $100, результат - дв)осбайтная величина, но поскольку регистр может хранить только один байт, в нем остается младщая часть, то есть, ноль. Аналогичным образом $00-1 = $FF, при этом вычитание происходит как бы из двухбайтного числа $100. Жмем F11 - выполнение команды DEC уменьшило до 9 значение переменной cnt, то есть, результат не нулевой, поэтому флаг Z сбросился (окно Processor). Отладка аналогичного цикла уже комментировалась, поэтому можно установить курсор на команде с меткой ARR2: и нажать Ctrl+FlO. Заметьте, в регистр Z (окно Processor) записался адрес OxFFFD, соответствующий константе aArBgn2+l. В окне Memory перейдем к ячейке OxFFFD, жмем F11: запись содержимого регистра tmp произошла в ячейку с адресом OxFFFC (aArBgn2), как и было необходимо. Отладка цикла не требует комментариев. Установим курсор на последней команде программы и нажмем Ctrl+FlO. Проконтролируйте содержимое ячеек памяти, в которые записался массив 2. Что будет, если убрать последнюю команду? Вообще-то для проверки удобнее заменить ее командой NOP. Ассемблируем программу, нажмем F11, установим курсор на последней команде NOP. В окне Processor I Cycle counter заметим число циклов процессора (153). Нажмем F11: выполнение программы опять началось с первой команды, но посмотрите на число циклов процессора: их стало 4206! После того, как все команды нашей программы были извлечены из памяти программ и выполнены, продолжался поиск команд в свободной части памяти программ, при переходе к новой свободной ячейке счетчик циклов процессора увеличивал свое состояние, а вместе с ним и счетчик команд (Processor Program counter). Максимальное значение, которое может храниться в этом счетчике для микроконт- [0] [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] [62] [63] [64] [65] [66] [67] [68] [69] [70] [71] [72] [73] [74] [75] [76] [77] [78] [79] [80] [81] [82] [83] [ 84 ] [85] [86] [87] [88] [89] [90] [91] [92] [93] 0.0012 |