реклама на сайте
подробности

 
 
> предупреждения компилятора, прошу объяснить
dimka76
сообщение Dec 14 2007, 11:33
Сообщение #1


developer
****

Группа: Свой
Сообщений: 902
Регистрация: 12-04-06
Из: Казань
Пользователь №: 16 032



Вот фрагмент текста программы:


Код
__no_init UCHAR RxBuf[2][BUFSIZE] __attribute__ ((section (BUFFER_SECTION))) IAR_SECTION(BUFFER_SECTION);
UCHAR       InputBuf;        
UCHAR       AppBuf;


->     InputBuf = (UCHAR)RxBuf[0];
->     AppBuf = (UCHAR)RxBuf[1];


и в указанных стрелкой строчках компилятор выдает следующие предупреждения

Код
Warning[Pe767]: conversion from pointer to smaller integer
Warning[Pe767]: conversion from pointer to smaller integer


Объясните, пожалуйста, что не так и как с этим бороться.

К хелпу просьба не отсылать, с аглицким туго smile.gif


--------------------
Все может быть и быть все может, и лишь того не может быть-чего уж точно быть не может, хотя..и это может быть.
Go to the top of the page
 
+Quote Post
 
Start new topic
Ответов
xemul
сообщение Dec 14 2007, 12:48
Сообщение #2



*****

Группа: Свой
Сообщений: 1 928
Регистрация: 11-07-06
Пользователь №: 18 731



Цитата(dimka76 @ Dec 14 2007, 14:33) *
Вот фрагмент текста программы:
Код
__no_init UCHAR RxBuf[2][BUFSIZE] __attribute__ ((section (BUFFER_SECTION))) IAR_SECTION(BUFFER_SECTION);
UCHAR       InputBuf;        
UCHAR       AppBuf;
->     InputBuf = (UCHAR)RxBuf[0];
->     AppBuf = (UCHAR)RxBuf[1];

и в указанных стрелкой строчках компилятор выдает следующие предупреждения
Код
Warning[Pe767]: conversion from pointer to smaller integer
Warning[Pe767]: conversion from pointer to smaller integer

Объясните, пожалуйста, что не так и как с этим бороться.

Компилятор, конечно, прав, но при следовании требованиям в usbdrv.h
Цитата
Limitations:
============
Compiling:
You should link the usbdrv.o module first because it has special alignment
requirements for the receive buffer (the buffer must not cross a 256 byte
page boundary, it must not even touch it at the end). If you can't link it
first, you must use other measures to ensure alignment.
Note: gcc does not always assign variable addresses in the order as the modules
are linked or the variables are declared. You can choose a memory section for
the receive buffer with the configuration option "USB_BUFFER_SECTION". This
option defaults to ".bss". If you use your own section, you can place it at
an arbitrary location with a linker option similar to
"-Wl,--section-start=.mybuffer=0x800060". Use "avr-nm -ng" on the binary and
search for "usbRxBuf" to find tbe base address of the 22 bytes rx buffer.

и в usbdrv.c
Цитата
/* usbRxBuf MUST be in 1 byte addressable range (because usbInputBuf is only 1 byte) */

на эти предупреждения можно забить.
Применительно к IAR требования удовлетворяются опцией линкера (Project->Options->Linker->Extra options)
-Z(DATA)USB_BUFFER_SECTION=0100-01FE
Цитата
К хелпу просьба не отсылать, с аглицким туго smile.gif

К сожалению, вариантов немного.
Go to the top of the page
 
+Quote Post
dimka76
сообщение Dec 14 2007, 12:58
Сообщение #3


developer
****

Группа: Свой
Сообщений: 902
Регистрация: 12-04-06
Из: Казань
Пользователь №: 16 032



Цитата(xemul @ Dec 14 2007, 15:48) *
на эти предупреждения можно забить.
Применительно к IAR требования удовлетворяются опцией линкера (Project->Options->Linker->Extra options)
-Z(DATA)USB_BUFFER_SECTION=0100-01FE

К сожалению, вариантов немного.


спасибо за помощь.
А если мой код размещается в секции загрузчика, что тогда мне следует указать в опциях ликера.
Кстати, я использую свой файл .xcl

Ой, извиняюсь, туплю. -Z(DATA)..... это же озу, а не память программ


--------------------
Все может быть и быть все может, и лишь того не может быть-чего уж точно быть не может, хотя..и это может быть.
Go to the top of the page
 
+Quote Post



Reply to this topicStart new topic
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0

 


RSS Текстовая версия Сейчас: 23rd July 2025 - 02:35
Рейтинг@Mail.ru


Страница сгенерированна за 0.01387 секунд с 7
ELECTRONIX ©2004-2016