что означает системное время
Что означает системное время?
Что такое системное время?
Системное время — это текущая дата и время суток. Система отслеживает время, так что ваши приложения имеют свободный доступ к точному времени. Система основывает системное время на всемирном координированном времени (UTC). Основанное на UTC время примерно определяется как текущая дата и время дня в Гринвиче, Англия.
Как работают системные часы?
Чтобы синхронизировать все операции компьютера, используются системные часы — небольшой кварцевый кристалл, расположенный на материнской плате. Системные часы регулярно посылают сигнал всем остальным компонентам компьютера.
Как проверить системное время?
В правом нижнем углу экрана найдите часы. Щелкните часы правой кнопкой мыши и выберите «Настроить дату / время».
Что означает системная дата?
Текущее время дня в компьютере, которое поддерживается батареей, когда компьютер выключен. Он используется для отметки времени всех вновь созданных файлов и активации процессов, зависящих от времени.
Какая польза от системных часов?
Системные часы или системный таймер — это непрерывный импульс, который помогает часам компьютера сохранять правильное время. Он ведет счет количества секунд, прошедших с начала эпохи, и использует эти данные для вычисления текущей даты и времени.
Как установить текущее время?
Установить время, дату и часовой пояс
Можно ли использовать часы реального времени в качестве системных часов?
В некоторых источниках термин часы реального времени взаимозаменяем с термином системные часы. Часы реального времени существуют во многих встроенных системах и отслеживают время, дату, месяц и год. … Обычно они интегрированы с DRAM с батарейным питанием, как показано на рисунке 11.1.
Компьютерные часы точны?
По этой причине большинство компьютеров с Windows настроены на синхронизацию («синхронизацию») своих системных часов с серверами времени в Интернете, которые являются чрезвычайно точными. … Результат: ваши часы Windows — одни из самых точных из имеющихся у вас.
Зачем нужны часы?
Использование (сигнальных) часов в цифровых схемах позволяет синхронизировать все операции в схеме или системе. Часы могут способствовать изменению состояний триггеров. … Цепи, использующие тактовый сигнал для синхронизации, могут стать активными либо по переднему, либо по заднему фронту тактового сигнала.
Как установить системное время и дату на постоянной основе?
Чтобы предотвратить его изменение, отключите синхронизацию времени.
Как установить дату и время?
Обновите дату и время на вашем устройстве Android
В какое время используется crontab?
Формат времени работы Cron
Задание cron запускается каждый раз, когда системные часы показывают 7 утра (7 вечера будет кодироваться как 19). День месяца — 7, что означает, что задание запускается каждый 7-й день месяца. Числовой месяц — 7, что означает, что задание будет выполняться только в июле.
Как можно установить точную дату и время?
Все ПК имеют электронную схему, называемую «часами реального времени», которая отслеживает дату и время. Схема получает питание от батареи, поэтому, когда вы выключаете компьютер, часы продолжают отсчитывать точное время. Операционная система Windows считывает данные часов всякий раз, когда ей требуется текущая дата или время.
Что такое микрофильмирование?
Микрофильм — это миниатюрная фотографическая репродукция документа. … Микрофильм — отличный способ для библиотек хранить множество документов на небольшом пространстве.
Как изменить системные дату и время
Часто мы сталкиваемся с необходимостью сменить системное время и дату. Например, при переходе на летнее время или в поездке в местность с другим часовым поясом. На сегодняшний день переход на летнее в России отменен. Если автоматический переход на летнее время все же производится, нужно снять галочку в настройках даты и времени «Автоматический переход на летнее время и обратно». Однако, операционные системы многих пользователей не обновлены, такой галочки в настройках нет и данный переход осуществляется в автоматическом режиме.
Настройки даты также могут изменяться пользователями при обходе контроля лицензий приложений, если они привязаны к дате, а также при использовании VPN. В этой статье рассмотрим некоторые способы изменения системных даты и времени.
Изменение системных даты и времени в операционной системе Windows
Меняем дату и время через параметры даты и времени
Независимо от версии Windows можно сменить дату и время, щелкнув левой кнопкой мыши по часам в правом нижнем углу либо открыть Панель инструментов. В версиях более ранних, Windows 10, необходимо выбрать «Изменение настроек даты и времени», в Windows 10 для изменения даты и времени необходимо открыть «Параметры даты и времени». При этом может потребоваться ввод пароля администратора системы.
Далее меняете часовой пояс, дату и время на необходимые.
Меняем дату и время через командную строку
Чтобы воспользоваться командной строкой для изменения даты и времени, откройте командную строку с правами администратора. В Windows 7 и более поздних версий просто введите в строке поиска командная строка или cmd, щелкните по результату правой кнопкой мыши и выберите запуск от имени администратора. (подробнее о работе с командной строкой можно прочитать тут).
Команда для изменения времени time ЧЧ:ММ:СС (где ЧЧ – часы, ММ – минуты, СС – секунды), введите ее и нажмите Enter на клавиатуре.
Команда для изменения даты date ДД/ММ/ГГГГ (где ДД – день, ММ – месяц, ГГГГ – год), введите ее и нажмите Enter на клавиатуре.
Параметры даты и времени изменятся моментально, но сохранятся до первой перезагрузки. При следующем включении компьютера или после перезагрузки дата и время вернутся к исходному значению.
Такой способ удобен, если изменение системных даты и времени необходимы для временной настройки в целях обхода лицензии или использования VPN.
Вся правда об ОСРВ. Статья #27. Системное время
Понятие времени в контексте ОСРВ была введена в одной из предыдущих статей, вместе с идеей о связанных со временем функциях, доступных в ОСРВ.
Тик таймера
Все функции, связанные со временем, управляются аппаратными часами. Это простой осциллятор, который генерирует запросы на прерывание с постоянными интервалами. Чтобы номера тактов имели смысл для прикладных программ, частота генератора должна быть известна.
Обработки таймерных прерываний
Прерывания, генерируемые аппаратным таймером, должны обслуживаться определенным образом в обработчике прерываний (англ. Interrupt Service Routine, ISR), в котором реализованы все функции ОСРВ, связанные со временем. Детали обработчика прерываний таймера в Nucleus SE будут рассмотрены в одной из следующих статей.
Функции, связанные со временем
Nucleus RTOS и Nucleus SE содержат несколько механизмов, связанных со временем:
Точность
А сейчас стоит вкратце рассказать о точности системного таймера.
Точность временных функций напрямую зависит от частоты тактового генератора. Например, если импульсы поступают каждые 10 миллисекунд, а задаче приложения необходима задержка в 100 миллисекунд, ей очевидно нужно 10 импульсов. Однако неизвестно, когда был получен предыдущий импульс: это могло произойти только что или почти 10 миллисекунд назад. Поэтому 100-миллисекундная задержка может занять вплоть до 110 миллисекунд.
Очевидный способ решения этой проблемы — повышение частоты генератора. Если импульсы следуют с интервалами в 1 миллисекунду, 100-миллисекундная задержка никогда не займет больше ста одной миллисекунды. Недостатком такого решения будет то, что обработчика прерываний таймера заберет в 10 раз больше процессорного времени, что будет чрезмерным. Разработчик системы должен найти баланс между необходимой точностью таймера и доступными мощностями процессора.
Настройка системного времени
Как и для большинства объектов Nucleus SE, настройка системного времени по большей части управляется директивами #define в файле nuse_config.h. Основным параметром является NUSE_SYSTEM_TIME_SUPPORT, который активирует механизм поддержки системного времени. Количество объектов указывать не нужно: системное время либо активировано, либо нет.
Выбор ненулевого значения является главным активатором системного времени. Этот параметр используется при определении структур данных, о которых будет подробно рассказано далее в этой статье. Кроме того, ненулевое значение активирует настройки API.
Активация API
Каждая функция API (служебный вызов) в Nucleus SE имеет активирующую директиву #define в файле nuse_config.h. Для системного времени такими символами являются:
NUSE_CLOCK_SET
NUSE_CLOCK_RETRIEVE
По умолчанию, им присваивается значение FALSE, таким образом все служебные вызовы отключены, блокируя включение реализующего их кода. Для настройки системного времени в приложении нужно выбрать необходимые служебные вызовы API и присвоить им значение TRUE.
Ниже приведен фрагмент кода из файла nuse_config.h по умолчанию.
При попытке использования служебного вызова API системного времени при выключенном активаторе системного времени произойдет ошибка компиляции. Если ваш код использует вызов API, который не был активирован, произойдет ошибка компоновки, так как код реализации не был включен в приложение.
Служебные вызовы системного времени
Nucleus RTOS поддерживает два служебных вызова, которые относятся к системному времени и обеспечивают следующий функционал:
Служебные вызовы установки и получения системного времени
С системным временем можно выполнять только операции установки в заданное значение и получения текущего значения. Nucleus RTOS и Nucleus SE предоставляют по два базовых вызова API для реализации этих операций.
Интерпретация значения системного времени зависит от приложения, так как является по своей сути счетчиком количества «тактов» часов, которые произошли с момента последнего сброса счетчика. Для использования этой информации должна быть известна частота генератора.
Установка времени
Любая задача может установить системное время при помощи вызова этой функции API.
Вызов для установки системного времени в Nucleus RTOS
Прототип служебного вызова:
VOID NU_Set_Clock(UNSIGNED new_value);
Параметры:
new_value – значение, которое будет присвоено системному времени
Возвращаемое значение: отсутствует.
Вызов для установки системного времени в Nucleus SE
Этот вызов API поддерживает основной функционал Nucleus RTOS API.
Прототип служебного вызова:
void NUSE_Clock_Set(U32 new_value);
Параметры:
new_value – значение, которое будет присвоено системному времени
Возвращаемое значение: отсутствует
Реализация установки времени в Nucleus SE
Код очень прост. Предоставленное значение записывается в NUSE_Tick_Clock внутри критической секции.
Получение системного времени
Задача может получить значение системного времени при помощи этой функции API.
Вызов для получения системного времени в Nucleus RTOS
Прототип служебного вызова:
UNSIGNED NU_Retrieve_Clock(VOID);
Возвращаемое значение: текущее значение системного времени
Вызов для получения системного времени в Nucleus SE
Прототип служебного вызова:
U32 NUSE_Clock_Retrieve(void);
Возвращаемое значение: текущее значение системного времени
Реализация получения времени в Nucleus SE
Код очень прост. Функция возвращает значение NUSE_Tick_Clock, полученное в критической секции.
Структуры данных
Системное время использует одну структуру данных (находящуюся в ОЗУ), которая представляет из себя 32-битное слово.
Настоятельно рекомендую, чтобы код приложения не использовал прямой доступ к этой структуре данных, а обращался к ней через предоставляемые функции API. Это позволит избежать несовместимости с будущими версиями Nucleus SE и нежелательных побочных эффектов, а также упростит портирование приложений на Nucleus RTOS. Подробная информация о структурах данных приведена ниже, чтобы упростить понимание работы кода служебных вызовов и для отладки.
Данные ОЗУ
Структура данных:
NUSE_Tick_Clock – переменная типа U32, в которой хранится счетчик тактов системного времени.
Эта структура данных инициализируется нулём функцией NUSE_Init_Task() при запуске Nucleus SE. Одна из следующих статей будет содержать полное описание процедур запуска Nucleus SE.
Данные ПЗУ
В ПЗУ нет структур данных, связанных с системным временем.
Объем памяти для системного времени
Как и у всех других объектов Nucleus SE, объем памяти, необходимый для системного времени, предсказуем.
Объем памяти в ПЗУ равен 0.
Объем памяти в ОЗУ (в байтах) всегда равен 4.
Нереализованные вызовы API
Все служебные вызовы API Nucleus RTOS, относящиеся к системному времени, имеют эквивалент в Nucleus SE.
Совместимость с Nucleus PLUS
Как и в случае со всеми другими объектами Nucleus SE, моей целью было обеспечение максимально возможной совместимости кода приложений с Nucleus RTOS. Системное время не является исключением и, с точки зрения пользователя, оно реализовано во многом также, как и в Nucleus RTOS. Вызовы API Nucleus RTOS могут быть напрямую перенесены на Nucleus SE.
В следующей статье мы рассмотрим программные таймеры.
О точном времени
К сервису синхронизации времени по протоколу NTP все уже привыкли — оно включено по умолчанию или легко включается для большинства популярных операционных систем. Однако какая точность при этом достигается? Какие бывают сервера точного времени, и с какими можно работать простым смертным? Какие есть подводные камни, и как выбрать «правильные» сервера времени?
Типы серверов
Сервера бывают Stratum 1 и 2, 3(выше редко).
«Простым» смертным обращаться к Stratum-1 серверам строго запрещено, т.к. нагрузка на них и так очень большая (а на многие Stratum-1 сервера вообще нет публичного доступа). Считается что вы можете подключаться к Stratum-1 серверам или просить доступ к ним, если вы держите NTP сервер, обслуживающий не менее 100 клиентов. Полный список серверов можно увидеть тут: support.ntp.org/bin/view/Servers/StratumOneTimeServers. Естественно, желательно подключатся к серверам в своей стране.
Stratum 2 — получают точное время от Stratum-1 серверов. При правильной настройке и выборе серверов-источников точного времени имеют погрешность менее 1мс. Подключатся обычно можно всем, но многие сервера регулярно умирают от нагрузки (например time.windows.com). www.pool.ntp.org поддерживает round-robin списки публичных Stratum-2 NTP серверов. Таким образом обеспечивается балансировка нагрузки, и они практически всегда доступны. Подключиться к этим серверам можно по адресам 0.ru.pool.ntp.org 1.ru.pool.ntp.org 2.ru.pool.ntp.org и 3.ru.pool.ntp.org (это для России, выбираются случайно из списка
Stratum 3 — получают время от Stratum-2 серверов, и т.д.
Практическая точность
Stratum-1
Это график разницы системного времени с временем полученным со Stratum-1 серверов (canonical.com — Stratum-2 сервер, для сравнения).
*.nist.gov — расположены в США, из-за «большого» пинга иногда случаются жуткие «выбросы». Ошибка с Российских Stratum-1 серверов обычно укладыватся в +- 1 мс.
Stratum-2
Это — разница с Stratum-2 серверами: 4 из Российского пулла, 1 из европейского, дефолтный сервер времени убунты (europium.canonical.com), и те же *.nist.gov:
Сразу бросаются в глаза сервера, имеющие постоянную ошибку до 20 мс.
Резюме
PS. Кстати, по умолчанию в Ubuntu синхронизация времени происходит один раз при загрузке системы. Если аптайм под полгода — время может сильно уехать. Устанавливаете ntpd — он корректирует время постоянно и «плавно» (без резких рывков, «размазывая» замедление/ускорение времени). В Windows синхронизация происходит раз в сутки неделю одним «скачком», что может вызвать сложности при обработке логов, если набежала большая разница.
Товарищи!
Даешь большое публичных NTP серверов в России! Особенно Stratum-1 (с ними вообще у нас напряженка, 2-3 штуки на весь exUSSR). Кстати, точное время можно брать и с Глонасс, кто возьмётся запустить первый Глонасс-powered сервер?
PPS. Не могу понять, в какой блог перенести, подскажите 🙂
Статья #27. Системное время
Понятие времени в контексте ОСРВ была введена Колином Уоллсом в одной из предыдущих статей (#6), вместе с идеей о связанных со временем механизмах, доступных в ОС.
Все функции, связанные со временем, управляются аппаратными часами. Это простой осциллятор, который генерирует запросы на прерывание с постоянными интервалами. Чтобы номера тактов имели смысл для прикладных программ, частота генератора должна быть известна.
Обработки таймерных прерываний
Прерывания, генерируемые аппаратным таймером, должны обслуживаться определенным образом в обработчике прерываний (англ. Interrupt Service Routine, ISR), в котором реализованы все функции ОСРВ, связанные со временем. Детали обработчика прерываний таймера в Nucleus SE будут рассмотрены в одной из следующих статей.
Функции, связанные со временем
Nucleus RTOS и Nucleus SE содержат несколько механизмов, связанных со временем:
А сейчас стоит вкратце рассказать о точности системного таймера.
Точность временных функций напрямую зависит от частоты тактового генератора. Например, если импульсы поступают каждые 10 миллисекунд, а задаче приложения необходима задержка в 100 миллисекунд, ей очевидно нужно 10 импульсов. Однако неизвестно, когда был получен предыдущий импульс: это могло произойти только что или почти 10 миллисекунд назад. Поэтому 100-миллисекундная задержка может занять вплоть до 110 миллисекунд.
Очевидный способ решения этой проблемы — повышение частоты генератора. Если импульсы следуют с интервалами в 1 миллисекунду, 100-миллисекундная задержка никогда не займет больше ста одной миллисекунды. Недостатком такого решения будет то, что обработчика прерываний таймера заберет в 10 раз больше процессорного времени, что будет чрезмерным. Разработчик системы должен найти баланс между необходимой точностью таймера и доступными мощностями процессора.
Настройка системного времени
Как и для большинства объектов Nucleus SE, настройка системного времени по большей части управляется директивами #define в файле nuse_config.h. Основным параметром является NUSE_SYSTEM_TIME_SUPPORT, который активирует механизм поддержки системного времени. Количество объектов указывать не нужно: системное время либо активировано, либо нет.
Выбор ненулевого значения является главным активатором системного времени. Этот параметр используется при определении структур данных, о которых будет подробно рассказано далее в этой статье. Кроме того, ненулевое значение активирует настройки API.
Каждая функция API (служебный вызов) в Nucleus SE имеет активирующую директиву #define в файле nuse_config.h. Для системного времени такими символами являются:
По умолчанию, им присваивается значение FALSE, таким образом все служебные вызовы отключены, блокируя включение реализующего их кода. Для настройки системного времени в приложении нужно выбрать необходимые служебные вызовы API и присвоить им значение TRUE.
Ниже приведен фрагмент кода из файла nuse_config.h по умолчанию.
При попытке использования служебного вызова API системного времени при выключенном активаторе системного времени произойдет ошибка компиляции. Если ваш код использует вызов API, который не был активирован, произойдет ошибка компоновки, так как код реализации не был включен в приложение.
Служебные вызовы системного времени
Nucleus RTOS поддерживает два служебных вызова, которые относятся к системному времени и обеспечивают следующий функционал:
Служебные вызовы установки и получения системного времени
С системным временем можно выполнять только операции установки в заданное значение и получения текущего значения. Nucleus RTOS и Nucleus SE предоставляют по два базовых вызова API для реализации этих операций.
Интерпретация значения системного времени зависит от приложения, так как является по своей сути счетчиком количества «тактов» часов, которые произошли с момента последнего сброса счетчика. Для использования этой информации должна быть известна частота генератора.
Любая задача может установить системное время при помощи вызова этой функции API.
Вызов для установки системного времени в Nucleus RTOS
Прототип служебного вызова:
VOID NU_Set_Clock(UNSIGNED new_value);
Параметры:
new_value – значение, которое будет присвоено системному времени
Возвращаемое значение: отсутствует.
Вызов для установки системного времени в Nucleus SE
Этот вызов API поддерживает основной функционал Nucleus RTOS API.
Прототип служебного вызова:
void NUSE_Clock_Set(U32 new_value);
Параметры:
new_value – значение, которое будет присвоено системному времени
Возвращаемое значение: отсутствует
Реализация установки времени в Nucleus SE
Код очень прост. Предоставленное значение записывается в NUSE_Tick_Clock внутри критической секции.
Получение системного времени
Задача может получить значение системного времени при помощи этой функции API.
Вызов для получения системного времени в Nucleus RTOS
Прототип служебного вызова:
UNSIGNED NU_Retrieve_Clock(VOID);
Возвращаемое значение: текущее значение системного времени
Вызов для получения системного времени в Nucleus SE
Прототип служебного вызова:
U32 NUSE_Clock_Retrieve(void);
Возвращаемое значение: текущее значение системного времени
Реализация получения времени в Nucleus SE
Код очень прост. Функция возвращает значение NUSE_Tick_Clock, полученное в критической секции.
Системное время использует одну структуру данных (находящуюся в ОЗУ), которая представляет из себя 32-битное слово.
Настоятельно рекомендую, чтобы код приложения не использовал прямой доступ к этой структуре данных, а обращался к ней через предоставляемые функции API. Это позволит избежать несовместимости с будущими версиями Nucleus SE и нежелательных побочных эффектов, а также упростит портирование приложений на Nucleus RTOS. Подробная информация о структурах данных приведена ниже, чтобы упростить понимание работы кода служебных вызовов и для отладки.
Структура данных:
NUSE_Tick_Clock – переменная типа U32, в которой хранится счетчик тактов системного времени.
Эта структура данных инициализируется нулём функцией NUSE_Init_Task() при запуске Nucleus SE. Одна из следующих статей будет содержать полное описание процедур запуска Nucleus SE.
В ПЗУ нет структур данных, связанных с системным временем.
Объем памяти для системного времени
Как и у всех других объектов Nucleus SE, объем памяти, необходимый для системного времени, предсказуем.
Объем памяти в ПЗУ равен 0.
Объем памяти в ОЗУ (в байтах) всегда равен 4.
Нереализованные вызовы API
Все служебные вызовы API Nucleus RTOS, относящиеся к системному времени, имеют эквивалент в Nucleus SE.
Совместимость с Nucleus PLUS
Как и в случае со всеми другими объектами Nucleus SE, моей целью было обеспечение максимально возможной совместимости кода приложений с Nucleus RTOS. Системное время не является исключением и, с точки зрения пользователя, оно реализовано во многом также, как и в Nucleus RTOS. Вызовы API Nucleus RTOS могут быть напрямую перенесены на Nucleus SE.
В следующей статье мы рассмотрим программные таймеры.
Об авторе: Колин Уоллс уже более тридцати лет работает в сфере электронной промышленности, значительную часть времени уделяя встроенному ПО. Сейчас он – инженер в области встроенного ПО в Mentor Embedded ( подразделение Mentor Graphics). Колин Уоллс часто выступает на конференциях и семинарах, автор многочисленных технических статей и двух книг по встроенному ПО. Живет в Великобритании. Профессиональный блог Колина: https://blogs.mentor.com/colinwalls/, e-mail: colin_walls@mentor.com
Теги: ОСРВ, RTOS, очереди, взаимодействие задач, микроконтроллеры