PIC18 – System Arbitration

Views: 703


Системный арбитр.

Разрешает доступ к памяти между выборами уровнями системы (т.е. Main, Interrupt Service Routine) и выбором периферийных устройств (т.е. DMA и Scanner) на основе назначенных пользователем приоритетов. Каждый из уровней системы и периферийных устройств имеет свои собственные регистры выбора приоритетов. Приоритет доступа к памяти разрешен с использованием номера, записанного в соответствующие регистры приоритета, 0 – наивысший приоритет, а 4 – самый низкий приоритет. Приоритеты по умолчанию перечислены в таблице 3-1.
Если пользователь хочет изменить приоритеты, убедитесь, что каждый регистр приоритета написан с уникальным значением от 0 до 4.

Приоритеты по умолчанию
Выбор Значение приоритета по умолчанию после сброса Регистр Примечание
Системный уровень ISR 0 SRPR Система прерываний
MAIN 1 MAINPR Процессор
Периферийные модули DMA1 2 DMA1PR Модуль DMA 1
DMA2 3 DMA2PR Модуль DMA 2
SCANNER 4 SCANPR Сканер памяти программы

 

PIC18(L)F24/25K42 SYSTEM ARBITER BLOCK DIAGRAM

Управления приоритетами.

Настройка приоритетов доступна, только когда бит PRLOCKED регистра PRLOCK не установлен. По умолчанию, после сброса изменения приоритет разрешено. Во время работы желательно запретить изменения приоритетов.

Для блокировки необходимо выполнить следующую последовательность:

    // заблокировать изменение приоритета
    asm("BCF INTCON0,7"); // запретить прерывания

    // последовательность разрешения доступа
    asm ("BANKSEL PRLOCK");
    asm ("MOVLW 0x55");
    asm ("MOVWF PRLOCK");
    asm ("MOVLW 0xAA");
    asm ("MOVWF PRLOCK");

    asm ("BSF PRLOCK, 0"); // установить бит PRLOCKED
	
    asm("BSF INTCON0,7"); // разрешить прерывания

Последовательность разблокировки имеет следующий вид:

    // заблокировать изменение приоритета
    asm("BCF INTCON0,7");   // запретить прерывания

    // последовательность разрешения доступа	
    asm ("BANKSEL PRLOCK");
    asm ("MOVLW 0x55");
    asm ("MOVWF PRLOCK");
    asm ("MOVLW 0xAA");
    asm ("MOVWF PRLOCK");

    asm ("BCF PRLOCK, 0"); // сбросить бит PRLOCKED
	
    asm("BSF INTCON0,7"); // разрешить прерывания

Схема доступа к памяти

Пользователь может назначать приоритеты как системному уровню, так и периферийным устройствам, на основе которых системный арбитр предоставляет доступ к памяти. Рассмотрим следующие приоритетные сценарии между ISR, MAIN и периферийными устройствами.

Примечание. Всегда требуется, чтобы приоритет ISR был выше, чем главный приоритет.

ISR PRIORITY > MAIN PRIORITY > PERIPHERAL PRIORITY

Вариант когда приоритет периферии (DMAx, Scanner) ниже чем ISR и MAIN Priority, а периферийное устройство требует:

  1. Доступ к программной флэш-памяти – периферийное устройство ожидает цикл инструкций, в котором процессор не нуждается в доступе к PFM (например, команда перехода) и использует этот цикл программы для выполнения собственного доступа к Flash Memory, если только не выполняется операция чтения/записи PFM.
  2. Доступ к SFR/GPR – периферийное устройство ожидает цикл команд, в котором процессор не нуждается в доступе к SFR/GPR (например, MOVLW, CALL, NOP) и использует этот цикл для выполнения собственного доступа к SFR/GPR.
  3. Доступ к EEPROM данных – периферийное устройство получает доступ к EEPROM данных, если не выполняется операция чтения/записи данных в EEPROM.

Это приводит к минимальной пропускной способности периферийного устройства для доступа к памяти и выполняется этот доступ без какого-либо влияния на время выполнения основной программы.

PERIPHERAL PRIORITY > ISR PRIORITY > MAIN PRIORITY

Когда приоритет периферии (DMAx, Scanner) выше, чем ISR и MAIN Priority, работа процессора останавливается, когда периферийное устройство запрашивает память.

Процессор удерживается в остановленном состоянии до тех пор, пока периферийное устройство выполняет свою работу. Поскольку периферийное устройство запрашивает доступ к шине, периферийное устройство не может быть отключено, пока оно не завершит свою работу.

Это приводит к наивысшей пропускной способности периферийного устройства для доступа к памяти, но требует остановки другого процесса, во время возникновения события запускающего работу периферийного устройства (DMAx, Scanner).

ISR PRIORITY > PERIPHERAL PRIORITY > MAIN PRIORITY

В этом случае процедуры прерывания работы периферийных устройств (DMAx, Scanner) остановят процессор. Прерывания прерывает работу периферийного устройства (DMAx, Scanner) .

Это приводит к наименьшей задержке прерывания и максимальной пропускной способности периферии для доступа к памяти.

PERIPHERAL 1 PRIORITY > ISR PRIORITY > MAIN PRIORITY > PERIPHERAL 2 PRIORITY

В этом случае Peripheral 1 остановит работу процессора. Однако Peripheral 2 может получить доступ к памяти в циклах, не используемых Peripheral 1.

 

Управление системным арбитром контролируется с помощью следующих регистров:
Имя Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 Описание
ISRPR ISRPR2 ISRPR1 ISRPR0 Приоритет системы прерываний
MAINPR MAINPR2 MAINPR1 MAINPR0 Приоритет основной программы
DMA1PR DMA1PR2 DMA1PR1 DMA1PR0 Приоритет модуля DM1
DMA2PR DMA2PR2 DMA2PR1 DMA2PR0 Приоритет модуля DMA2
SCANPR SCANPR2 SCANPR1 SCANPR0 Приоритет для сканера
PRLOCK PRLOCKED Регистр блокировки настройки приоритетов

Функция для настройки арбитража может быть выполнена следующим образом:

// настройка приоритета
void PRIORITY (uint8_t isrprre, uint8_t mainprre, uint8_t dma1prre, uint8_t dma2prre, uint8_t scanprre)
{
    // разблокировать настройку приоритетов
	asm ("BCF INTCON0,7");
	asm ("BANKSEL PRLOCK");
    asm ("MOVLW 0x55");
    asm ("MOVWF PRLOCK");
    asm ("MOVLW 0xAA");
    asm ("MOVWF PRLOCK");
    asm ("BSF PRLOCK, 0");
	asm ("BCF INTCON0,7");
    // система
    // приоритет прерываний (приоритета приоритета обслуживания прерывания)
    ISRPR = isrprre;
    // приоритет выполнения программы (выбор приоритета основного режима)
    MAINPR = mainprre;
    // переферия
    // приоритет модуля DMA1
    DMA1PR = dma1prre;
    // приоритет модуля DMA2
    DMA2PR = dma2prre;
    // приоритет сканера памяти 
    SCANPR = scanprre;
    	// заблокировать изменение приоритета
	asm ("BCF INTCON0,7");
	asm ("BANKSEL PRLOCK");
    asm ("MOVLW 0x55");
    asm ("MOVWF PRLOCK");
    asm ("MOVLW 0xAA");
    asm ("MOVWF PRLOCK");
    asm ("BSF PRLOCK, 0"); 
	asm ("BSF INTCON0,7");
}

 


Это может быть интересно


  • Простой цифровой милливольтметр постоянного токаПростой цифровой милливольтметр постоянного тока
    Views: 4199 Простой цифровой вольтметр постоянного тока. Три диапазона измерений с автоматическим переключением 1 – 0,001 – 0,999 V, 2 – 0,01-9,99 V, 3 – 0,1-99,9. Четыре управляемых выхода с возможностью задания функции контроля …
  • Простой сенсорный регулятор светаПростой сенсорный регулятор света
    Views: 2482 Простой сенсорный регулятор. Проект – 2007 года. Регулятор выполнена на микроконтроллере PIC12F683 и имеет минимальное количество элементов. Выполняет стандартные функции, включение выключение света, изменение яркости, запоминание последнего установленного уровня …
  • Контроллер управления светодиодным освещением с дистанционным управлениемКонтроллер управления светодиодным освещением с дистанционным управлением
    Views: 2046 Все активнее светодиоды входят в нашу жизнь. Всё эффективнее становится светодиодное освещение. Всё ниже опускаются цены. Всё больше появляется возможностей получения сочных цветов, простоты в управлении. Всё чаще …
  • Altium Designer my Libraries, Project templates, System settings by Catcatcat V23.09Altium Designer my Libraries, Project templates, System settings by Catcatcat V23.09
    Views: 580   September 2023 component base update.  Release updates V.  – 23_09 added new components. Changed the structure of the database. Configuration file name – DXPPreferences1.DXPPrf. Added project CLUBBEST_50_Light. …
  • Мультимедийная сеть – AVC-LAN TOYOTAМультимедийная сеть – AVC-LAN TOYOTA
    Views: 5857 AVC LAN – протокол обмена данными мультимедийных систем автомобиля. Кодирование данных. При кодировании различаться три типа данных : преамбула – её назначение, это сообщение устройствам на шине, что начинается передача данных. …
  • 12-BIT A/D CONVERTER WITH THRESHOLD DETECT на примере PIC24FJ128GA20412-BIT A/D CONVERTER WITH THRESHOLD DETECT на примере PIC24FJ128GA204
    Views: 910 Введение. 12-битный модуль A/D Converter является усовершенствованной версией 10-битного модуля, предлагаемого на некоторых устройствах PIC24. Оба модуля являются преобразователями, в своих ядрах, с последовательным приближением (SAR), в окружении …
  • Просто о внешних переменныхПросто о внешних переменных
    Views: 914  Часто возникает задача когда необходимо предавать данные между модулями программы. Например, передать данные между файлами, или управлять работой модулей. Для этого создаем заголовочный файл и описываем наши переменные как …
  • Acquaintance with audio-bluetooth modules F-6888 (BK3254).Acquaintance with audio-bluetooth modules F-6888 (BK3254).
    Views: 2334 Для проектов появилось необходимость познакомиться с недорогими модулями китайского производства, которые можно приобрести у нас в Украине и у китацев, на алиэкспрессе. Так как меня интересует не просто, …
  • Стабилизатор тока для светодиодов SN3350Стабилизатор тока для светодиодов SN3350
    Views: 2737 SN3350 ближайший аналог ZXLD1350 Как собрать готовый вариант, читайте во второй части – http://catcatcat.d-lan.dp.ua/stabilizator-toka-na-sn3350-chast-2/ 40V  драйвер светодиодов с внутренним ключом  SN3350 – импульсный понижающий преобразователь, разработанный для того, чтобы эффективно управлять одним или …
  • Проект с использованием MCC часть 10Проект с использованием MCC часть 10
    Views: 1027 Алгоритм управления освещением от нажатия кнопки. Обработка удержания кнопки: Мы должны проверить кнопка в настоящий момент нажата и флаг удержания установлен, если да Проверить таймер удержания “отработал” – …



 

Поделись этим!

Catcatcat

catcatcat

Development of embedded systems based on Microchip microcontrollers.

Продолжайте читать

НазадДалее