From 4b0e8a592eda6a670b72fce03ab97c207265e145 Mon Sep 17 00:00:00 2001 From: Inoki Date: Thu, 31 Mar 2022 08:48:21 +0200 Subject: [PATCH] Improve code, use endian utility and qefi function --- qefientrystaticlist.cpp | 25 +++++++++---------------- 1 file changed, 9 insertions(+), 16 deletions(-) diff --git a/qefientrystaticlist.cpp b/qefientrystaticlist.cpp index 3021c33..8a327ec 100644 --- a/qefientrystaticlist.cpp +++ b/qefientrystaticlist.cpp @@ -4,6 +4,7 @@ #include #include +#include #include @@ -61,33 +62,25 @@ void QEFIEntryStaticList::load() std::cerr << "BootOrder: "; m_order.clear(); for (int i = 0; i < data.size() / 2; i++, order_num++) { - std::cerr << std::hex << *order_num << ", "; - m_order.append(*order_num); + std::cerr << std::hex << qFromLittleEndian(*order_num) << ", "; + m_order.append(qFromLittleEndian(*order_num)); } std::cerr << std::dec << std::endl; order_num = (quint16 *)data.data(); m_entries.clear(); for (int i = 0; i < data.size() / 2; i++, order_num++) { - QString name = QString::asprintf("Boot%04X", *order_num); + QString name = QString::asprintf("Boot%04X", qFromLittleEndian(*order_num)); QByteArray boot_data = qefi_get_variable(QUuid("8be4df61-93ca-11d2-aa0d-00e098032b8c"), name); - QString entry_name; - if (boot_data.size() > 6) { // TODO: Explain the magic number - quint16 *c = (quint16 *)boot_data.data(); - c = c + 6 / 2; - for (int index = 6; index < boot_data.size(); index += 2, c++) { - if (*c == 0) break; - entry_name.append(*c); - } - } + QString entry_name = qefi_extract_name(boot_data); // Add entry - QEFIEntry entry(*order_num, boot_data); - m_entries.insert(*order_num, entry); + QEFIEntry entry(qFromLittleEndian(*order_num), boot_data); + m_entries.insert(qFromLittleEndian(*order_num), entry); // Cache - m_cachedItem.insert(*order_num, boot_data); + m_cachedItem.insert(qFromLittleEndian(*order_num), boot_data); std::cerr << std::hex << *order_num << " " << entry_name.toStdString(); std::cerr << std::endl; @@ -109,7 +102,7 @@ void QEFIEntryStaticList::setBootOrder(const QList &newOrder) QByteArray orderBuffer(newOrder.size() * 2, 0); quint16 *p = (quint16 *)orderBuffer.data(); for (int i = 0; i < newOrder.size(); i++, p++) { - *p = newOrder[i]; + *p = qToLittleEndian(newOrder[i]); } qefi_set_variable(QUuid("8be4df61-93ca-11d2-aa0d-00e098032b8c"), QStringLiteral("BootOrder"), orderBuffer);