Стивен Барретт - Встраиваемые системы. Проектирование приложений на микроконтроллерах семейства 68HC12/HCS12 с применением языка С
- Название:Встраиваемые системы. Проектирование приложений на микроконтроллерах семейства 68HC12/HCS12 с применением языка С
- Автор:
- Жанр:
- Издательство:Издательский дом «ДМК-пресс»
- Год:2007
- Город:Москва
- ISBN:5-9706-0034-2
- Рейтинг:
- Избранное:Добавить в избранное
-
Отзывы:
-
Ваша оценка:
Стивен Барретт - Встраиваемые системы. Проектирование приложений на микроконтроллерах семейства 68HC12/HCS12 с применением языка С краткое содержание
В книге последовательно рассматриваются все этапы создания встраиваемых систем на микроконтроллерах с применением современных технологий проектирования. Задумав эту книгу, авторы поставили перед собой задачу научить читателя искусству создания реальных устройств управления на однокристальных микроконтроллерах.
Издание содержит материал, охватывающий все вопросы проектирования, включает множество заданий для самостоятельной работы, примеры программирования, примеры аппаратных решений и эксперименты по исследованию работы различных подсистем микроконтроллеров.
Данная книга является прекрасным учебным пособием для студентов старших курсов технических университетов, которые предполагают связать свою профессиональную деятельность с проектированием и внедрением встраиваемых микропроцессорных систем. Книга также будет полезна разработчикам радиоэлектронной аппаратуры на микроконтроллерах.
Встраиваемые системы. Проектирование приложений на микроконтроллерах семейства 68HC12/HCS12 с применением языка С - читать онлайн бесплатно полную версию (весь текст целиком)
Интервал:
Закладка:
Теперь, когда мы имеем два отдельных пространства RAM в нашей карте памяти, мы можем легко выделить одну из них для стека, а другую — для динамической памяти. Мы рекомендуем использование меньшего пространства для стека и большего для динамической памяти. В данном компиляторе имеются параметры настройки, конфигурируемые пользователем и позволяющие установить адрес начала для стека и области динамической памяти.
Получив способ динамического распределения памяти, мы можем теперь создавать структуры данных для использования в наших ОСРВ. В следующем разделе мы проведем общий обзор структур данных, используемых в ОСРВ: структур (или записей), списков с указателями, очередей, и круговых очередей. Как только мы познакомимся с каждым из этих основных типов, мы сможем объединять их в более сложные структуры данных, используемые для работы ОСРВ.
8.3.3. Структуры данных
В этом разделе мы проведем общий обзор структур данных, используемых в операционных системах, работающих в режиме реального времени. Мы выполним обзор каждой структуры данных отдельно и затем объединим их, чтобы выполнять различные операции внутри ОСРВ.
Структура. Мы будем использовать взаимозаменяемые термины запись и структура. Структуры позволяют программистам при разработке совокупности данных для спецификации, использовать другие основные типы данных. Это позволяет им следить за сложной информацией, которая может содержать различные типы данных. Например, если вы разрабатываете систему описи для автомобильного торгового агента, вы могли бы разработать следующую структуру основных данных для конкретного автомобиля, таких, как год выпуска, изготовитель, модель, номер идентификации транспортного средства (VIN), и прогон, как показано на рис. 8.4.

Рис. 8.4.Запись для автомобиля. Запись содержит поля данных, совокупность которых описывает автомобиль
Каждый из типов данных в записи называется полем. Мы объявляем запись или структуру, используя следующий синтаксис:
struct car {
int year; /* год производства* /
char make[10]; /*BWM, Hummer, Saturn */
char model[12]; /*купе, обратимый, SUV, пикап */
char VIN[10]; /* комбинация цифр, букв */
float mileage; /*показания счетчика: от 0 до 500,000+ */
struct car *next; /*указатель на следующий автомобиль в списке*/
};
/*typedef обеспечивает компилятор an alternate???*/
typedef struct car ELEMENT; /*для типа переменной */
typedef ELEMENT *car_temp_ptr; /*определяет указатель на автомобиль*/
Как можно видеть, все поля записи описывают различные параметры данного автомобиля. Мы привели сокращенный список параметров. Структура может содержать столько полей, сколько необходимо. Мы выбрали для каждого поля тот тип данных, который наиболее подходит для описания каждого параметра автомобиля.
Структуры создаются с использованием динамических методов распределения памяти. Как мы уже упоминали, команда malloc()
— предоставляет методику динамического распределения памяти, определяя соответствующий объем памяти для структуры данных. Например, чтобы создать новую запись для автомобиля, можно использовать следующий код:
сar_temp_ptr new_car_entry;
new_car_entry = (car_temp_ptr)malloc(sizeof(ELEMENT));
В главе 3, мы описали, как обращаться к различным полям внутри записи. В этом примере, мы инициализируем недавно созданную автомобильную запись с информацией о конкретном автомобиле. Обратите внимание, что мы использовали оператор –>
, чтобы обратиться к специфическому полю внутри структуры.
/* инициализация новых полей для структуры car */
new_car_entry–>year = 1981; /* год производства */
strcpy(new_car_entry–>make, "Chevy"); /*BWM, Hummer, Saturn */
strcpy(new_car_entry–>model, "Camaro"); /*купе, обратимый, SUV, пикап */
strcpy(new_car_entry–>VIN, " 12Z3 67"); /* комбинация цифр, букв*/
new_car_entry–>mileage = 37456; /*показания спидометра: от 0 до 500,000+ */
new_car_entry–>next = NULL; /* определяет указатель на автомобиль */
Чтобы распечатать различные поля записи, мы могли бы использовать следующий код:
printf("\nyear: %4d ", new_car_entry–>year); / *year mfg */
printf("\nmake: %s ", new_car_entry–>make); /*car делает */
printf("\nmodel: %s ", new_car_entry–>model); /*model*/
printf("\nVIN: является ", new_car_entry–>VIN); /*VIN */
printf("\nMileage: %6.of ", new_car_entry –> mileage); /*odometer reading*/
Поместим все эти части вместе с примером. Мы убедительно просим вас компилировать и выполнить этот код.
#include /*стандартные входные/выходные функции*/
#include /*библиотека и распределение памяти */
void main(void) {
/*определение структуры */
struct car;
int year; /*год выпуска */
char make[10]; /*BWM, Hummer, Saturn*/
char model[12]; /*купе, обратимый, SUV, пикап */
char VIN[10]; /*комбинация цифр и букв*/
float mileage; /*показания одометра: от 0 до 500 000+ */
struct car *next; /*указатель на следующий автомобиль в списке */
typedef struct car ELEMENT;
typedef ELEMENT *car_temp_ptr;
car_temp_ptr new_car_entry; /*ввод записи для автомобиля*/
new_car_entry = (car_temp_ptr)malloc(sizeof(ELEMENT));
/*инициализация новых полей для автомобиля */
new_car_entry->year = 1981; /*год изготовления*/
strcpy(new_car_entry–>make, "Chevy"); /*BWM, Hummer, Saturn */
strcpy(new_car_entry–>model,"Camaro");
/* купе, обратимый, SUV, пикап */
strcpy(new_car_entry–>VIN, "12Z3 67");
/* комбинация цифр и букв */
new_car_entry–>mileage - 37456;/*показания одометра: 0 to 500,000+*/
new_car_entry–>next - NULL; /*указатель на следующий автомобиль в списке*/
printf("\nyear: %4d", new_car_entry–>year); /*год выпуска */
printf("\nmake: %s", new_car_entry–>make) ; /*производитель */
printf("\nmodel: %s", new_car_entry–>model); /*модель */
printf("\nVIN: %s ", new_car_entry –>VIN); /*номер */
printf("\nMileage: %6. Из ", new_car_entry->mileage); /*показания одометра*/
}
Когда эта программа будет откомпилирована и выполнена, на экране вашего ПК появится следующее сообщение:
year: 1981
make: Chevy
model: Camaro
VIN: 12Z367
Mileage: 37456
Пока, наверное, использование динамического распределения памяти не кажется вам очень мощным инструментом. В следующем разделе вы сможете оценить силу динамического распределения памяти, когда мы скомпонуем записи и создадим список, что позволит нам осуществлять изменения в процессе выполнения программы. То есть мы сможем добавлять новые элементы в список, переносить элементы из одного списка в другой, удалять элементы из списка, и т.д. Но не будем здесь углубляться в лес деталей, чтобы сразу в нем не заблудиться. Лучше сосредоточим свое внимание на дороге через этот лес. Не будем забывать, что мы изучаем здесь основные структуры данных, чтобы узнать, как они могут использоваться в построении и реализации операционной системы в режиме реального времени.
Читать дальшеИнтервал:
Закладка: