 
		Views: 729
Системный арбитр.
Разрешает доступ к памяти между выборами уровнями системы (т.е. 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, а периферийное устройство требует:
- Доступ к программной флэш-памяти – периферийное устройство ожидает цикл инструкций, в котором процессор не нуждается в доступе к PFM (например, команда перехода) и использует этот цикл программы для выполнения собственного доступа к Flash Memory, если только не выполняется операция чтения/записи PFM.
- Доступ к SFR/GPR – периферийное устройство ожидает цикл команд, в котором процессор не нуждается в доступе к SFR/GPR (например, MOVLW, CALL, NOP) и использует этот цикл для выполнения собственного доступа к SFR/GPR.
- Доступ к 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");
}
Это может быть интересно
 MAX7219/21 и 8х8 LED дисплеиViews: 1053 MAX7219, MAX7221 предназначены для вывода информации на 8 разрядов семисегментного индикатора, но на нем легко организовать вывод на светодиодные индикаторы 8х8. продолжение следует…. Это может быть интересно MAX7219/21 и 8х8 LED дисплеиViews: 1053 MAX7219, MAX7221 предназначены для вывода информации на 8 разрядов семисегментного индикатора, но на нем легко организовать вывод на светодиодные индикаторы 8х8. продолжение следует…. Это может быть интересно
 Самый простой диммер для светодиодного освещенияViews: 3183 Светодиоды все больше входят в нашу жизнь как источники освещения и как само собой разумеющееся, это вопрос регулировки яркости. Существует множество схемных решений, но в нашем варианте мы … Самый простой диммер для светодиодного освещенияViews: 3183 Светодиоды все больше входят в нашу жизнь как источники освещения и как само собой разумеющееся, это вопрос регулировки яркости. Существует множество схемных решений, но в нашем варианте мы …
 Универсальный терморегулятор ch-c3000Views: 3196 Терморегулятор ch-c3000 предназначен для управления системами регулирования температуры в пределах от – (минус) 55 до + 125 С. Регулятор может использоваться как в системах отопления, так и в … Универсальный терморегулятор ch-c3000Views: 3196 Терморегулятор ch-c3000 предназначен для управления системами регулирования температуры в пределах от – (минус) 55 до + 125 С. Регулятор может использоваться как в системах отопления, так и в …
 Мультизоновый индикатор-терморегулятор ch-c3010Views: 1327 Часто возникает необходимость получить информацию по температуре с множества точек контроля. Вам необходимо знать температуру в комнате, в коридоре, температуру на улице, а в погребе (или на балконе) … Мультизоновый индикатор-терморегулятор ch-c3010Views: 1327 Часто возникает необходимость получить информацию по температуре с множества точек контроля. Вам необходимо знать температуру в комнате, в коридоре, температуру на улице, а в погребе (или на балконе) …
 Униполярный шаговый двигательViews: 2437 В приводах различных устройств часто применяются шаговые двигатели, Шаговый двигатели различают двух типов униполярные – когда обмотки коммутируются током текущим только в одну сторону, например при … Униполярный шаговый двигательViews: 2437 В приводах различных устройств часто применяются шаговые двигатели, Шаговый двигатели различают двух типов униполярные – когда обмотки коммутируются током текущим только в одну сторону, например при …
 OLED RET012864E/REX012864JViews: 1591 RET012864E/REX012864J ОЛЕД индикатор производитель Raystar-Optronics приобретался в http://www.microchip.ua/ к сожалению никакой информации на сайте поставщика нет. Поэтому решил работу с этой версией индикатора на драйвере SSD1305 предоставить на своем сайте. Так как … OLED RET012864E/REX012864JViews: 1591 RET012864E/REX012864J ОЛЕД индикатор производитель Raystar-Optronics приобретался в http://www.microchip.ua/ к сожалению никакой информации на сайте поставщика нет. Поэтому решил работу с этой версией индикатора на драйвере SSD1305 предоставить на своем сайте. Так как …
 TM1650 драйвер LED семисегментного индикатораViews: 18300 UPDATES 2025/10/10 Китайский производитель Shenzhen Titan Micro Electronics Co., Ltd. Выпускает широкую линейку драйверов управления светодиодными дисплеями, которые позволяют разгрузить микроконтроллер для основной работы, главная особенность этих драйверов … TM1650 драйвер LED семисегментного индикатораViews: 18300 UPDATES 2025/10/10 Китайский производитель Shenzhen Titan Micro Electronics Co., Ltd. Выпускает широкую линейку драйверов управления светодиодными дисплеями, которые позволяют разгрузить микроконтроллер для основной работы, главная особенность этих драйверов …
 Датчик контроля протечки воды ch-c0020Views: 2074 Как здорово летом под теплым дождем с тобою вдвоем оказаться. Как классно по лужам бежать босиком, с тобою играть и смеяться! Но совсем грустно оказаться под таким дождем, который течет с … Датчик контроля протечки воды ch-c0020Views: 2074 Как здорово летом под теплым дождем с тобою вдвоем оказаться. Как классно по лужам бежать босиком, с тобою играть и смеяться! Но совсем грустно оказаться под таким дождем, который течет с …
 ch-4060 – регулятор температуры и влажности на датчике DHT11/DHT22/AM2302Views: 2486 На плате ch-4000 очень легко собрать устройство регулятора температуры и влажности. Датчик DHT11 самый недорогой вариант для создания такого устройства, правда точность его не велика, но для бытовых устройств … ch-4060 – регулятор температуры и влажности на датчике DHT11/DHT22/AM2302Views: 2486 На плате ch-4000 очень легко собрать устройство регулятора температуры и влажности. Датчик DHT11 самый недорогой вариант для создания такого устройства, правда точность его не велика, но для бытовых устройств …
 LCD драйвер – UC1601sViews: 1807 http://svetomuzyka.narod.ru/project/UC1601s.html Читайте обновление на http://catcatcat.d-lan.dp.ua/?page_id=178 В данный момент можно приобрести в ООО “Гамма” несколько типов индикаторов на драйвере UC1601s. RDX0048-GC, RDX0077-GS, RDX0154-GC и RDX0120-GC выполнены по технологии COG. LCD драйвер – UC1601sViews: 1807 http://svetomuzyka.narod.ru/project/UC1601s.html Читайте обновление на http://catcatcat.d-lan.dp.ua/?page_id=178 В данный момент можно приобрести в ООО “Гамма” несколько типов индикаторов на драйвере UC1601s. RDX0048-GC, RDX0077-GS, RDX0154-GC и RDX0120-GC выполнены по технологии COG.

