×
14.07.2019
219.017.b456

Результат интеллектуальной деятельности: СИСТЕМА И СПОСОБ ПРЕДВАРИТЕЛЬНОГО РАЗМЕЩЕНИЯ ПАМЯТИ

Вид РИД

Изобретение

№ охранного документа
0002415467
Дата охранного документа
27.03.2011
Аннотация: Изобретение относится к области конструирования компьютерных систем и, в частности, описывает способ предварительного размещения памяти в компьютерной системе. Техническим результатом является обеспечение размещения памяти в зависимости от применения к родительскому или дочернему процессу. Способ заключается в том, что на стадии создания родительского процесса получают от пользователя данные о размере памяти для предварительного размещения, проверяют размер памяти для предварительного размещения, размещают память, если ее размер >0, на стадии завершения родительского процесса проверяют размер предварительно размещенной памяти, освобождают предварительно размещенную память, если ее размер >0, на стадии создания дочернего процесса получают данные о размере памяти дочернего процесса, проверяют, был ли предварительно размещен необходимый размер памяти, если да, то выделяют дочернему процессу указатель на принадлежащую ему часть предварительно размещенной памяти, если нет, то размещение памяти выполняют способом, обычным для данной операционной системы, на стадии завершения дочернего процесса проверяют, использует ли дочерний процесс предварительно размещенную память. 2 н.п. ф-лы, 5 ил.

Изобретение относится к области конструирования компьютерных систем, а именно к системам и способам предварительного размещения памяти в компьютерной системе, и может применяться во всех многоядерных и многопроцессорных компьютерных системах с встроенными платформами и многозадачными операционными системами, которые поддерживают как основные, так называемые, «родительские» или «полновесные», системы, так и производные, так называемые «дочерние» или «легковесные», процессы (например, POSIX threads в Linux), созданные под родительскими процессами.

Для создания родительского процесса операционной системе (ОС) приходится заниматься размещением критически необходимых блоков памяти, таких как «текст», «данные», «bss», «куча» (английский термин - heap) и «стек». Пример такого размещения приведен на Фиг.1. Размещение памяти обычно занимает много времени.

На создание дочерних процессов система затрачивает значительно меньше времени по сравнению с затратами на создание родительских процессов. Для создания дочернего процесса необходимо разместить только такие блоки памяти как «стек» и «TLS» (thread local storage). Другие блоки памяти, которые использует дочерний процесс (текст, данные, bss, «куча»), уже размещены его родительским процессом (см. Фиг.1).

Таким образом, использование дочерних процессов имеет явные преимущества с точки зрения временных затрат системы на их создание.

Известен принцип построения диспетчера памяти для встроенной системы, описанный в патентной заявке США №2006/0069898 [1]. Такой диспетчер работает в памяти, организованной в виде предопределенного числа фиксированных блоков памяти, при этом каждый блок имеет предопределенный размер. Данные фиксированные блоки инициализированы для ускорения процесса резервирования памяти. Когда диспетчер памяти получает запрос на предварительное размещение памяти, запрашиваемый размер памяти сравнивают с предопределенным размером. Если диспетчер памяти определяет, что фиксированный блок памяти соответствует запрашиваемому размеру памяти, то диспетчер памяти резервирует один из фиксированных блоков для поданного запроса памяти. Если не существует доступных фиксированных блоков, удовлетворяющих параметрам запроса, то диспетчер памяти может зарезервировать память из общего пула памяти. Кроме того, данный диспетчер памяти может искать доступные свободные блоки памяти для идентификации и размещения оптимального свободного блока, который соответствует поданному запросу на размещение.

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

Наиболее близким к заявленному изобретению является способ резервирования памяти в многотрэдовой (параллельной) компьютерной среде, который описан в патенте СШ №6058460 [2], и в котором предусматривается, что в трэды (т.е. потоки), выполняемые параллельно в одном процессе, объединены в один или несколько пулов памяти в памяти системы. В ходе выполнения способа определяют пулы памяти в памяти системы, назначают каждому трэду один из пулов памяти; и для каждого трэда динамически резервируют блоки памяти из назначенного пула памяти. Способ позволяет преобразовать любой существующий пакет управления размещением памяти для многотрэдовой версии. Данный способ выбран в качестве прототипа заявляемого изобретения.

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

Задача, на решение которой направлено заявляемое изобретение, заключается в создании системы и способа предварительного размещения памяти с увеличенным быстродействием. При этом задача должна решаться за счет уменьшения временных затрат на размещение памяти при создании дочерних процессов путем объединения всех необходимых блоков памяти дочерних процессов (стеков, TLS и других требуемых структур памяти) в единый блок и размещение этого блока при создании родительского процесса, причем данный блок также может включать стек или другие блоки памяти родительского процесса (см. Фиг.2). Таким образом, в системе должна исчезнуть необходимость в осуществлении длительных системных вызовов для размещения памяти при создании каждого дочернего процесса. Вместо этого, предполагается, что вновь создаваемые дочерние процессы будут использовать части предварительно размещенного единого блока памяти.

Поставленная задача решена путем создания системы предварительного размещения памяти в компьютерной системе, содержащей модуль памяти и программную платформу с операционной системой, выполненную с возможностью поддержки родительских и дочерних процессов, которая содержит взаимодействующие с модулем памяти диспетчер родительских процессов, диспетчер дочерних процессов и диспетчер предварительного размещения памяти, который содержит блок создания родительских процессов, блок завершения родительских процессов, блок создания дочерних процессов и блок завершения дочерних процессов, при этом диспетчер родительских процессов выполнен с возможностью передачи в блок создания родительских процессов данных о размере памяти для предварительного размещения на стадии создания родительского процесса, и с возможностью оповещения блока завершения родительских процессов о завершении родительского процесса, диспетчер дочерних процессов выполнен с возможностью передачи в блок создания дочерних процессов данных о размере памяти для дочернего процесса, а также с возможностью оповещения блока завершения дочерних процессов о завершении дочернего процесса, блок создания родительских процессов выполнен с возможностью получения данных о размере памяти для предварительного размещения на стадии создания родительского процесса, с возможностью проверки размера памяти для предварительного размещения и с возможностью размещения памяти, если ее размер больше нуля, блок завершения родительских процессов выполнен с возможностью проверки размера предварительно размещенной памяти и с возможностью освобождения предварительно размещенной памяти, если ее размер больше нуля, блок создания дочерних процессов выполнен с возможностью получения данных о размере памяти для дочерних процессов, с возможностью выделения дочернему процессу указателя на принадлежащую ему часть предварительно размещенной памяти, в случае, если был предварительно размещен необходимый размер памяти для дочернего процесса, блок завершения дочерних процессов выполнен с возможностью не освобождать свою часть предварительно размещенной памяти для повторного использования дочерними процессами, в случае, если дочерний процесс использует предварительно размещенную память.

Поставленная задача также решена путем создания способа предварительного размещения памяти в компьютерной системе, заключающийся в том, что

на стадии создания родительского процесса:

- получают от пользователя данные о размере памяти для предварительного размещения;

- проверяют размер памяти для предварительного размещения;

- размещает память, если ее размер >0;

на стадии завершения родительского процесса:

- проверяют размер предварительно размещенной памяти;

- освобождают предварительно размещенную память, если ее размер >0;

на стадии создания дочернего процесса:

- получают данные о размере памяти дочернего процесса;

- проверяют, был ли предварительно размещен необходимый размер памяти;

- если да, то выделяют дочернему процессу указатель на принадлежащую ему часть предварительно размещенной памяти;

- если нет, то размещение памяти выполняют способом, обычным для данной операционной системы;

на стадии завершения дочернего процесса:

- проверяют, использует ли дочерний процесс предварительно размещенную память;

- если да, то не освобождают предварительно размещенную память для дочернего процесса для повторного использования дочерними процессами и последующего ее освобождения при завершении родительского процесса;

- если нет, то размещение памяти выполняют способом, обычным для данной операционной системы.

Таким образом, в заявляемой системе при создании дочернего процесса модуль ОС проверяет размер предварительно размещенного единого блока памяти, и если этот размер достаточен, выделяет дочернему процессу указатель на принадлежащую ему часть предварительно размещенной памяти (см. Фиг.3). В противном случае, т.е. если объем предварительно размещенной памяти недостаточен, блоки памяти для дочернего процесса размещают способом, обычным для данной ОС. При завершении дочернего процесса не освобождают используемый им предварительно размещенный блок памяти. Он может быть повторно использован другими дочерними процессами. Блок предварительно размещенной памяти освобождают при завершении родительского процесса.

Для лучшего понимания заявленного изобретения далее приводится его подробное описание с соответствующими иллюстративными материалами.

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

Фиг.2. Схема предварительного размещения памяти при создании родительского процесса согласно изобретению.

Фиг.3. Схема использования предварительно размещенной памяти при создании дочерних процессов согласно изобретению.

Фиг.4. Блок-схема системы предварительного размещения памяти согласно изобретению.

Фиг.5. Блок-схема способа предварительного размещения памяти согласно изобретению.

Заявленная система предварительного размещения памяти (см. Фиг.4.) содержит модуль памяти, далее упоминаемый как память 1, и программную платформу 2, которая содержит взаимодействующие с памятью 1 диспетчер 3 родительских процессов, диспетчер 4 дочерних процессов и диспетчер 5 предварительного размещения памяти, который содержит блок 6 создания родительских процессов, блок 7 завершения родительских процессов, блок 8 создания дочерних процессов и блок 9 завершения дочерних процессов.

Рассмотрим способ предварительного размещения памяти (см. Фиг.4, 5). В приложениях, работающих во встроенных системах, разработчик обычно может оценить количество дочерних процессов, которые будут запущены в родительском процессе и размер памяти, который должен быть зарезервирован для каждого дочернего процесса. Таким образом, на первом шаге способа разработчик вычисляет суммарный размер памяти, необходимый для предварительного размещения. При создании родительского процесса блок 6 создания родительских процессов получает от диспетчера 3 родительских процессов входные данные о размере памяти для предварительного размещения, проверяет размер памяти для предварительного размещения и размещает память, если ее размер >0. При завершении родительского процесса диспетчер 3 родительских процессов вызывает блок 7 завершения родительских процессов, который проверяет размер предварительно размещенной памяти и освобождает предварительно размещенную память, если ее размер >0. При создании дочерних процессов блок 8 создания дочерних процессов получает от диспетчера 4 дочерних процессов данные о размере памяти дочернего процесса, проверяет, был ли предварительно размещен размер памяти, достаточный для данного дочернего процесса, и если да - выделяет дочернему процессу указатель на принадлежащую ему часть предварительно размещенной памяти; если нет - то блок 8 заканчивает свою работу, а размещение памяти выполняется способом, обычным для данной операционной системы (см. Фиг.1 - дочерние процессы). При завершении дочерних процессов диспетчер 4 дочерних процессов вызывает блок 9 завершения дочерних процессов, который проверяет, использует ли процесс предварительно размещенную память, и если да, то не освобождает свою часть предварительно размещенной памяти. Она может быть повторно использована дочерними процессами и будет освобождена при завершении родительского процесса. Если же процесс не использует предварительно размещенную память, то блок 9 завершает свою работу, а освобождение памяти выполняется способом, обычным для данной операционной системы. Кроме того, диспетчер 9 предварительного размещения памяти содержит следующую информацию: для каждого родительского процесса - указатель на начало и размер предварительно размещенной памяти (см. Фиг.2); для каждого родительского процесса - указатель на начало и размер свободной предварительно размещенной памяти (см. Фиг.2 и 3);

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

Хотя указанный выше вариант выполнения изобретения был изложен с целью иллюстрации настоящего изобретения, специалистам ясно, что возможны разные модификации, добавления и замены, не выходящие из объема и смысла настоящего изобретения, раскрытого в прилагаемой формуле изобретения.

Источник поступления информации: Роспатент

Showing 41-50 of 125 items.
27.07.2014
№216.012.e31b

Система и способ для автоматического планирования видов в объемных изображениях мозга

Изобретение относится к автоматическому планированию видов в объемных изображениях мозга. Техническим результатом является обеспечение надежности за счет повышения точности обработки изображений как высокой, так низкой разрешающей способности. Способ содержит: получение трехмерного...
Тип: Изобретение
Номер охранного документа: 0002523929
Дата охранного документа: 27.07.2014
27.07.2014
№216.012.e31e

Плоская катушка индуктивности с повышенной добротностью

Изобретение относится к области электротехники и может использоваться в устройствах, в которых необходимы катушки индуктивности. Достигаемый технический результат - повышение добротности без увеличения плотности магнитного потока или индуктивности. Плоская катушка индуктивности с...
Тип: Изобретение
Номер охранного документа: 0002523932
Дата охранного документа: 27.07.2014
27.07.2014
№216.012.e4df

Способ гидрофобизации материалов алкилиминопропилсодержащими силоксанами

Изобретение относится к технологии обработки полимеров и композитов, в частности их гидрофобизации. Способ получения защитного гидрофобного покрытия на полимерном материале заключается в обработке поверхности полимерного материала раствором олиго(органо)алкоксисилоксана. После удаления...
Тип: Изобретение
Номер охранного документа: 0002524381
Дата охранного документа: 27.07.2014
27.07.2014
№216.012.e595

Компактная сверхширокополосная антенна

Изобретение относится к области телекоммуникаций, более конкретно - к конструкции сверхширокополосных (СШП) дипольных антенн, предназначенных для связи между датчиками и другими устройствами на поверхности или вблизи поверхности тела человека. Технический результат - создание беспроводных...
Тип: Изобретение
Номер охранного документа: 0002524563
Дата охранного документа: 27.07.2014
10.08.2014
№216.012.e6f7

Экранированная система беспроводной многопозиционной зарядки мобильных устройств

Изобретение относится к области энергетики, а более конкретно - к устройствам беспроводной передачи энергии и, в частности, к беспроводным зарядным системам, способным зарядить одно или несколько мобильных устройств одновременно. Технический результат - уменьшение побочного электромагнитного...
Тип: Изобретение
Номер охранного документа: 0002524920
Дата охранного документа: 10.08.2014
10.08.2014
№216.012.e884

Оптическое устройство для формирования голографических изображений

Предложено устройство для формирования и наблюдения динамических и статических трехмерных изображений типа голограмм. Устройство содержит лазерный источник излучения, световод и голографические оптические элементы, расположенные на поверхности световода. Устройство дополнительно содержит...
Тип: Изобретение
Номер охранного документа: 0002525317
Дата охранного документа: 10.08.2014
20.08.2014
№216.012.eb51

Способ и устройство для обнаружения игровых эпизодов в полевых видах спорта в видеопоследовательностях

Изобретение относится к технологиям обработки видеоизображений, а именно к автоматизации процесса классификации видеоконтента по жанру и содержанию в реальном режиме времени. Техническим результатом является автоматическая подстройка настроек изображения. Результат достигается тем, что...
Тип: Изобретение
Номер охранного документа: 0002526049
Дата охранного документа: 20.08.2014
27.08.2014
№216.012.ee05

Система и способ для автоматического планирования двухмерных видов в объемных медицинских изображениях

Изобретение относится к технологиям анализа медицинских изображений. Техническим результатом является повышение эффективности автоматического планирования двухмерных видов в объемных медицинских изображениях. Способ включает: оценивают статистическую модель положений анатомических точек,...
Тип: Изобретение
Номер охранного документа: 0002526752
Дата охранного документа: 27.08.2014
27.08.2014
№216.012.ee17

Дефлекторное устройство для электромагнитного излучения (варианты)

Изобретение относится к области телекоммуникаций, а более конкретно - к устройствам для отклонения направленного электромагнитного излучения, и может применяться в радиотехнических конструкциях, в частности в малогабаритных радарных системах. Технический результат - снижение уровня тепловой...
Тип: Изобретение
Номер охранного документа: 0002526770
Дата охранного документа: 27.08.2014
27.08.2014
№216.012.ee84

Способ исследования стереоскопического зрения

Изобретение относится к медицине, а именно к офтальмологии. В условиях разделения полей зрения испытуемому предъявляют стереопары в виде решетки Габора с плавно меняющейся диспаратностью. Измеряют порог стереоскопического зрения, при котором стереопара воспринимается испытуемым как единое...
Тип: Изобретение
Номер охранного документа: 0002526879
Дата охранного документа: 27.08.2014
+ добавить свой РИД