Перейти к содержанию

Слой Абстракции Для Spi


Рекомендуемые сообщения

Написал слой абстракции для мастера SPI, как программного так и аппаратного. Кому не лень посмотрите что можно исправить или доработать.

Единственное, что мне не нравится, что avr-gcc ругается warning'ом на неинициализированную переменную. Я-то знаю, что после 9 сдвигов в ней не останется ни одного родного бита, но как это объяснить компилятору?

char SPI_send(char data){
 char res,i=7;

spi.zip

Ругался на отсутствие форматирования исходного кода (включая отсутствие осмысленных комментариев и наличие неубранного после конфигуратора мусора) не менее 15 раз.

Часть моих наработок.

Ссылка на комментарий
Поделиться на другие сайты

Реклама: ООО ТД Промэлектроника, ИНН: 6659197470, Тел: 8 (800) 1000-321

20% скидка на весь каталог электронных компонентов в ТМ Электроникс!

Акция "Лето ближе - цены ниже", успей сделать выгодные покупки!

Плюс весь апрель действует скидка 10% по промокоду APREL24 + 15% кэшбэк и бесплатная доставка!

Перейти на страницу акции

Реклама: ООО ТМ ЭЛЕКТРОНИКС, ИНН: 7806548420, info@tmelectronics.ru, +7(812)4094849

Выбираем схему BMS для корректной работы литий-железофосфатных (LiFePO4) аккумуляторов

 Обязательным условием долгой и стабильной работы Li-FePO4-аккумуляторов, в том числе и производства EVE Energy, является применение специализированных BMS-микросхем. Литий-железофосфатные АКБ отличаются такими характеристиками, как высокая многократность циклов заряда-разряда, безопасность, возможность быстрой зарядки, устойчивость к буферному режиму работы и приемлемая стоимость. Но для этих АКБ, также как и для других, очень важен контроль процесса заряда и разряда, а специализированных микросхем для этого вида аккумуляторов не так много. Инженеры КОМПЭЛ подготовили список имеющихся микросхем и возможных решений от разных производителей. Подробнее>>

Реклама: АО КОМПЭЛ, ИНН: 7713005406, ОГРН: 1027700032161

А зачем, если это значение все равно сотрется? Если не получится вразумить компилятор, так и сделаю, но неужели нет другого способа?

Ругался на отсутствие форматирования исходного кода (включая отсутствие осмысленных комментариев и наличие неубранного после конфигуратора мусора) не менее 15 раз.

Часть моих наработок.

Ссылка на комментарий
Поделиться на другие сайты

Затем, что это вырабатывает правильные навыки программирования. Компилятор лишь предупреждает, что так делать нехорошо, именно поэтому всего лишь Warning, а не Error.

Если тебе не важно начальное значение - инициализируй нулём. Предупреждение пропадёт и всё будет работать как надо.

Именно таков верный способ вразумить компилятор!

Ссылка на комментарий
Поделиться на другие сайты

Вообще, он правильно ругается. Есть вероятность, что из функции вернётся неинициализированное значение.

В SPI_IN(x) , в условии проверки линии, поставь else. Установка бита в "x" стоит, а сброса нет. Это даже ошибка :)

Или инициализируй переменную нулём.

Ссылка на комментарий
Поделиться на другие сайты

Ерунда. С таким успехом, можно сказать, что .c файлы не подключаются includ'ом.

Если .h файл подключается всего в одном месте, то почему бы там не реализовывать код и не объявлять переменные ?

Ссылка на комментарий
Поделиться на другие сайты

В разных местах - да, будет. И то, не всегда. Возможны просто создания одинаковых экземпляров.

Но, как я уже выше сказал :

Если .h файл подключается всего в одном месте, то почему бы там не реализовывать код и не объявлять переменные ?

Ссылка на комментарий
Поделиться на другие сайты

Самый простой и точный ответ - потому, что это создает возможность появления проблем и прививает неправильные навыки.

Ты сюда за помощью пришел или спорить? Тебе говорят как улучшить код, избавиться от ворнинга. Зачем делать неправильно?

Ссылка на комментарий
Поделиться на другие сайты

Ты сюда за помощью пришел или спорить? Тебе говорят как улучшить код, избавиться от ворнинга. Зачем делать неправильно?

Это кому адресовано ? :shok:
Ссылка на комментарий
Поделиться на другие сайты

Установка бита в "x" стоит, а сброса нет. Это даже ошибка :)
Вроде как Си гарантирует заполнение сдвинутого бита нулем, зачем его еще раз присваивать?
В *.h (заголовочных) файлах реализации функций не пишут! Там только прототипы, а в отдельном *.c файле реализации.
Специально для этого предусмотрены макроопределения MULTISOURCE_PROJECT и HEADER_IMPLEMENTATION, позволяющие при надобности отключить реализацию. Собственно, единственное почему не рекомендуется в *.h файл включать реализацию - дублирование функций с одинаковыми именами в разных *.o файлах, а линкер потом с ума сходит не зная какой использовать. С другой стороны, для проверки какой-нибудь мелочи подключать к проекту лишний *.c файл, переконфигурировать его и т.п. не оправдано. Поэтому и пошел на такой компромисс - если этот модуль используется только в одном файле, реализация подключена, если в нескольких - в настройках указывается MULTISOURCE_PROJECT, а в одном любом *.c файле (проще всего, наверное, main.c) HEADER_IMPLEMENTATION. На тестовых примерах это работает, будет ли удобно в реальности - пока не знаю.
Затем, что это вырабатывает правильные навыки программирования. Компилятор лишь предупреждает, что так делать нехорошо
Нет, компилятор не знает, что начальное значение в данном случае ни на что не повлияет. Так что, нет никакого атрибута или еще какого указания компилятору "я знаю про эту особенность, это не баг а фича"?

Ругался на отсутствие форматирования исходного кода (включая отсутствие осмысленных комментариев и наличие неубранного после конфигуратора мусора) не менее 15 раз.

Часть моих наработок.

Ссылка на комментарий
Поделиться на другие сайты

Вроде как Си гарантирует заполнение сдвинутого бита нулем, зачем его еще раз присваивать?
Это писателю известно, а компилятор считает, что переменная может не измениться.

Всё-таки, ради интереса, попробуй else добавить.

Ссылка на комментарий
Поделиться на другие сайты

Ничего не изменилось. На счет неинициализированной переменной наверное и правда не стоит извращаться и инициализировать, пусть компилятор спит спокойно.

Ругался на отсутствие форматирования исходного кода (включая отсутствие осмысленных комментариев и наличие неубранного после конфигуратора мусора) не менее 15 раз.

Часть моих наработок.

Ссылка на комментарий
Поделиться на другие сайты

Присоединяйтесь к обсуждению

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

Гость
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Ответить в этой теме...

×   Вставлено с форматированием.   Восстановить форматирование

  Разрешено использовать не более 75 эмодзи.

×   Ваша ссылка была автоматически встроена.   Отображать как обычную ссылку

×   Ваш предыдущий контент был восстановлен.   Очистить редактор

×   Вы не можете вставлять изображения напрямую. Загружайте или вставляйте изображения по ссылке.

Загрузка...
  • Последние посетители   0 пользователей онлайн

    • Ни одного зарегистрированного пользователя не просматривает данную страницу
×
×
  • Создать...