Jump to content

    

LPC2214 & IO0PIN

В datasheet на сабжевый контроллер сказано, что IOPIN это read only, и для записи в порт надо использовать IOSET и IOCLR, но в иаровском хедере для LPC2214 регистр IO0PIN определен как read/write, т.е. запись в него разрешена и действительно если в IO0PIN_bit писать биты, то они выставляются на ножках процессора.

Вопрос насколько опасно так делать?

И почему в таком случае в даташите написанно, то он только для чтения?

Share this post


Link to post
Share on other sites
В datasheet на сабжевый контроллер сказано, что IOPIN это read only, и для записи в порт надо использовать IOSET и IOCLR, но в иаровском хедере для LPC2214 регистр IO0PIN определйн как read/write, т.е. запись в него разрешена и действительно если в IO0PIN_bit писать биты, то они выставляются на ножках процессора.

Вопрос насколько опасно так делать?

И почему в таком случае в даташите написанно, то он только для чтения?

 

У LPC2106 про этот регистр написано следующее (хотя он тоже помечен как ReadOnly):

Note: for test purposes, writing to this register stores the value in the output register, bypassing the need to use both the IOSET and IOCLR registers. This feature is of little or no use in an application because it is not possible to write to individual bytes in this register.

 

Иными словами, как только Вы захотите работать с отдельными битами/группами бит, то IOPIN окажется неподходящим средством для решения этой задачи, т.к. определяет значение сразу всех бит GPIO. Думаю, что по этой причине они убрали из DS на 2214 описание возможности записи в этот регистр и оставили описание работы через IOSET/IOCLR.

Share this post


Link to post
Share on other sites

Думаю что во всех LPC-процах регистры IOPIN доступны для чтения/записи. Через них удобно делать инверсию. Без них жутко неудобно. Вобщем этот регистр является содержимым порта. Точнее тех его бит, которые настроены как GPIO. А в мануалах иногда встречается лажа.

Share this post


Link to post
Share on other sites
У LPC2106 про этот регистр написано следующее (хотя он тоже помечен как ReadOnly):

У LPC213x/4x уже официально, как R/W.

Похоже :-(, я по простоте душевной несколько раз пользовал его на "старых" LPC, как R/W без побочных эффектов.

Share this post


Link to post
Share on other sites

У LPC2106 про этот регистр написано следующее (хотя он тоже помечен как ReadOnly):

У LPC213x/4x уже официально, как R/W.

Похоже :-(, я по простоте душевной несколько раз пользовал его на "старых" LPC, как R/W без побочных эффектов.

 

 

Судя по всему у них периферийные блоки практически одни и те же. Не удивлюсь, если их делали одни и те же люди. Так что может статься, что они просто не потрудились описать заложенный функционал. Хотя лично мне этот функционал IOPIN (на запись в регистр) пока ни разу не требовался.

Share this post


Link to post
Share on other sites
Хотя лично мне этот функционал IOPIN (на запись в регистр) пока ни разу не требовался.

Да, обходится можно почти безболезненно.

Share this post


Link to post
Share on other sites

У LPC2106 про этот регистр написано следующее (хотя он тоже помечен как ReadOnly):

У LPC213x/4x уже официально, как R/W.

Похоже :-(, я по простоте душевной несколько раз пользовал его на "старых" LPC, как R/W без побочных эффектов.

 

 

Судя по всему у них периферийные блоки практически одни и те же. Не удивлюсь, если их делали одни и те же люди. Так что может статься, что они просто не потрудились описать заложенный функционал. Хотя лично мне этот функционал IOPIN (на запись в регистр) пока ни разу не требовался.

Похоже это недоработка в доке. В усер мануале на 2119/2129/2192/2292/2294 тоже написано что он read only, но дальше сказано так:
Applications that require instanatneous appearance of zeros and ones on the respected parallel port can use direct access to port’s corresponding GPIO Pin Value Register (IOPIN). 
Assuming that pins P0.8 to P0.15 are configured as output, write to IO0PIN:
IO0PIN = 0x0000 C700
will produce the same output as following sequence of writes:
IO0SET = 0x0000 C700
IO0CLR = 0x0000 3800

Share this post


Link to post
Share on other sites

Я задал этот же вопрос в саппорт филипса, вот их ответ:

Philips Semiconductors answer:

Yes, The write cabability was intented for test purposes so that is why it was not in the documentation since the IOSET and IOCLR are most often used to set port pin states. But, there is no problem writing to IO0PIN.

 

Regards

 

Jim E.

Share this post


Link to post
Share on other sites
вот их ответ:

Что, в общем, и следовало ожидать....

 

Отзывчивые люди - быстро ответили. Филипсу "+1". Как-то я отвык последнее время от быстрых и разумных ответов.

А тут получается, что можно будет пообщаться при необходимости.

Share this post


Link to post
Share on other sites

Create an account or sign in to comment

You need to be a member in order to leave a comment

Create an account

Sign up for a new account in our community. It's easy!

Register a new account

Sign in

Already have an account? Sign in here.

Sign In Now
Sign in to follow this