Так.... Как обычно включаю экстрасенсорные способности, чтобы угадать недосказанное....
Судя по этой фразе:
Цитата(Metallist64 @ May 8 2013, 18:40)

...
получаю отвал PLL ну и остановку контроллера.
...
у автора проблемы с запуском из под JTAG. Иначе - откуда такие выводы про PLL???
А значит - таблица векторов здесь не при чём.
При запуске из под JTAG (по-крайней мере под IAR) абсолютно параллельно что там находится по адресу 0, есть там таблица или нету.
Цитата(KnightIgor @ May 9 2013, 02:23)

Однако процессор об этом ничего не знает, после сброса будет пытаться использовать таблицу по 0х0 и уйдёт в никуда... Поэтому необходимо еще разместить минимальную таблицу векторов из двух слов по стандартному адресу загрузки: первое слово должно содержать значение для загрузки указателя стека, а второе - адрес, куда прыгать.
...
Ну вот здесь Вы совсем зря обманываете товарища....
Читаем "LPC178x/7x User manual" параграф "3.10.1 PLL and startup/boot code interaction":
When there is no valid user code (determined by the checksum word) in the user flash or
the ISP enable pin (P2[10]) is pulled low on startup, the ISP mode will be entered and the
boot code will setup the Main PLL with the IRC.а также "37.3.1.1 Criterion for Valid User Code":
The reserved Cortex-M3 exception vector location 7 (offset 0x001C in the vector table)
should contain the 2’s complement of the check-sum of table entries 0 through 6. This
causes the checksum of the first 8 table entries to be 0. The boot loader code checksums
the first 8 locations in sector 0 of the flash. If the result is 0, then execution control is
transferred to the user code.Так что маловато будет ваших 2-х слов....
Да и вообще - на вышеозначенном CPU более политкорректно прописывать начало таблицы в NVIC таким макаром:
Код
u32 j;
if ((j = (u32)&__Vectors) >= 0x20000000) j |= B29;
NVIC.VTABLE = j;
а то кто-ж его знает - может захочется её в ОЗУ держать. Да и нафиг это делать до си-стартапа? Всё равно во время его прерывания запрещены.
Цитата(KnightIgor @ May 9 2013, 02:23)

LDR R0, =SystemInit
BLX R0
LDR R0, =__main
BX R0
А зачем
BLX и
BX? Вроде и обычные
BL и
B прекрасно достают....