|
|
  |
Считать лог. |
|
|
|
Oct 19 2015, 06:45
|
Профессионал
    
Группа: Участник
Сообщений: 1 778
Регистрация: 29-03-12
Пользователь №: 71 075

|
я логирую данные во внешнюю память. размерность памяти 8 бит. каждая запись 16 бит то есть каждая запись берет 2 байта. текущий адрес записи я храню в глобальной переменной - param1.logNum. и тут я задумался над оптимальным алгоритмом - считать последних n записей. причем мне эти записи надо послать пакетами по 18 байт каждый пакет. Кое что я набросал. Код void BLUENRG_SendLog(void) //send n deltas from the last {
uint32_t chank = 18; //DELTA_SIZE * AVAILABLE_BUF_SIZE; uint32_t last_log_addr = param1.logNum * DELTA_SIZE; uint32_t packet_size; uint32_t tx_num=0; uint32_t current_addr = last_log_addr - (chank * tx_num);
//check if the overflow occurred while (current_addr > START_LOG_ADRESS) { packet_size = chank;
uint8_t buf[packet_size];
LOGGER_Readlog(current_addr, packet_size, buf);
SendBuf(buf);
tx_num++; current_addr = last_log_addr - (chank * tx_num);
} // send the rest of data ???
} Но мне это не нравиться. Может лучше отсчитать и начать с младшего адреса? Проще и не надо проверять ушел ли я за границы начального адреса.
Сообщение отредактировал Jenya7 - Oct 19 2015, 07:24
|
|
|
|
|
Oct 19 2015, 10:05
|
Гуру
     
Группа: Свой
Сообщений: 2 360
Регистрация: 6-03-06
Из: Кишинев
Пользователь №: 15 025

|
Цитата(Jenya7 @ Oct 19 2015, 08:45)  Но мне это не нравиться. Может лучше отсчитать и начать с младшего адреса? Проще и не надо проверять ушел ли я за границы начального адреса. (выделено мной) Перфекционизм - это опасно и вредно. Работает? успевает? не мешает другим жить? тогда не трогайте! Просто идите дальше. А по существу: есть некоторые общие правила, например- упрощать расчеты, выполняемые в цикле. Например, зачем у Вас там current_addr каждый раз пересобирается с нуля? вполне достаточно просто уменьшать ее на chank.
|
|
|
|
|
Oct 19 2015, 10:20
|

Профессионал
    
Группа: Свой
Сообщений: 1 032
Регистрация: 13-03-08
Из: Маськва
Пользователь №: 35 877

|
Цитата(CrimsonPig @ Oct 19 2015, 13:02)  Делаем копию указателя (или индекса, зависит от имплементации) записи, уменьшаем его на нужное кол-во записей (по модулю размера буфера + отслеживание пересечения границы чтения) и читаем с инкрементом. Атомарность, проверки на переполнение\опустошение и прочие невнятные мелочи опускаем для простоты  Если почитать-таки код в первом сообщении, там именно это и делается. "Для простоты" там, правда, нет указания, сколько же данных у нас запросили. И ещё, там нет кольцевого буфера (запись не вижу, а на чтение - точно нету!). Зато есть как минимум пара лишних переменных (чтоб никто не догадался). И очень удобный формат, в котором они возвращаются - полностью всё перепутано. Я б ТЗ стряс для начала. Сколько записей, сколько хранить, сколько считывать (считывать только так, или это только один из интерфейсов), ... А то опять угадайка "что хотел сказать автор" с нерабочим кодом...
--------------------
Тут обсуждается творческий порыв, а не соответствие каким-либо стандартам ©
|
|
|
|
|
Oct 19 2015, 10:32
|

Местный
  
Группа: Участник
Сообщений: 329
Регистрация: 23-04-14
Пользователь №: 81 502

|
Цитата(esaulenka @ Oct 19 2015, 11:20)  Я б ТЗ стряс для начала. Сколько записей, сколько хранить, сколько считывать (считывать только так, или это только один из интерфейсов), ... А то опять угадайка "что хотел сказать автор" с нерабочим кодом... Мне зачастую проще намекнуть, как надо было бы сделать по-хорошему (естественно, с моей точки зрения), чем разбираться в обрывках чужого кода и строить догадки по поводу того, что хотел автор.. Пусть делает, как хочет
|
|
|
|
|
Oct 19 2015, 10:53
|
Профессионал
    
Группа: Участник
Сообщений: 1 778
Регистрация: 29-03-12
Пользователь №: 71 075

|
Цитата(esaulenka @ Oct 19 2015, 15:20)  Если почитать-таки код в первом сообщении, там именно это и делается. "Для простоты" там, правда, нет указания, сколько же данных у нас запросили. И ещё, там нет кольцевого буфера (запись не вижу, а на чтение - точно нету!). Зато есть как минимум пара лишних переменных (чтоб никто не догадался). И очень удобный формат, в котором они возвращаются - полностью всё перепутано.
Я б ТЗ стряс для начала. Сколько записей, сколько хранить, сколько считывать (считывать только так, или это только один из интерфейсов), ... А то опять угадайка "что хотел сказать автор" с нерабочим кодом... по моему все понятно - надо считать N-ное количество записей. считывается всегда с последней. и какая разница кольцевой буфер или нет?
Сообщение отредактировал Jenya7 - Oct 19 2015, 10:55
|
|
|
|
|
Oct 20 2015, 06:44
|

Практикующий маг
     
Группа: Свой
Сообщений: 3 634
Регистрация: 28-04-05
Из: Дубна, Моск.обл
Пользователь №: 4 576

|
Цитата(Jenya7 @ Oct 19 2015, 18:26)  Код ... int32_t current_addr = last_log_addr-chunk; ... if(current_addr - START_LOG_ADRESS >= chunk) packet_size = chunk; else packet_size = current_addr - START_LOG_ADRESS; ... current_addr -= chunk; } если не лень функцию можно сделать абсолютно генерик стайл без привязки к какой либо железке кольцевая она там или нет. Закольцовка имеет смысл если записи идут и идут, а считывание всё откладывается. Тогда закольцевав буфер сохраняем последние записи (ессно затерев самые старые из них). В конце наверное нужно вычитать не chunk, а packet_size (на случай если блок был укороченный). И похоже нужно смотреть разницу не между текущим адресом и стартовым, а между конечным и стартовым (для примера можно посмотреть что будет если в буфере было 5 записей а считывается 18 -при первом же заходе в функцию будем сразу из нее вылетать, т.к current_addr < START_LOG_ADRESS). Не понятно зачем нужна переменная chunk, если она используется только как копия константы CHUNK
|
|
|
|
|
  |
1 чел. читают эту тему (гостей: 1, скрытых пользователей: 0)
Пользователей: 0
|
|
|