Skip to content

Commit

Permalink
Merge pull request #12416 from s-hadinger/partition_manager_v0
Browse files Browse the repository at this point in the history
Partition manager v1
  • Loading branch information
arendst authored Jun 19, 2021
2 parents 99d303c + e78396f commit 4c97948
Show file tree
Hide file tree
Showing 2 changed files with 70 additions and 13 deletions.
53 changes: 53 additions & 0 deletions tasmota/berry/modules/partition.be
Original file line number Diff line number Diff line change
Expand Up @@ -119,6 +119,47 @@ class Partition_info
end
end

# check if the parition is a SPIFFS partition
# returns bool
def is_spiffs()
return self.type == 1 && self.subtype == 130
end

# get the actual image size give of the partition
# returns -1 if the partition is not an app ota partition
def get_image_size()
if self.is_ota() == nil return -1 end
try
var addr = self.start
var magic_byte = flash.read(addr, 1).get(0, 1)
if magic_byte != 0xE9 raise "internal_error", string.format("Invalid magic_byte 0x%02X (should be 0xE9)", magic_byte) end

var seg_count = flash.read(addr+1, 1).get(0, 1)
# print("Segment count", seg_count)

var seg_offset = addr + 0x20 # sizeof(esp_image_header_t) + sizeof(esp_image_segment_header_t) = 24 + 8
var seg_size = 0

for seg_num:0..seg_count-1
# print(string.format("Reading 0x%08X", seg_offset))
var segment_header = flash.read(seg_offset - 8, 8)
var seg_start_addr = segment_header.get(0, 4)
var seg_size = segment_header.get(4,4)
# print(string.format("Segment %i: flash_offset=0x%08X start_addr=0x%08X size=0x%08X", seg_num, seg_offset, seg_start_addr, seg_size))

seg_offset += seg_size + 8 # add segment_length + sizeof(esp_image_segment_header_t)
end
var total_size = seg_offset - addr + 1 # add 1KB for safety

# print(string.format("Total size = %i KB", total_size/1024))

return total_size
except .. as e, m
print(string.format("BRY: Exception> '%s' - %s", e, m))
return -1
end
end

def tostring()
import string
var type_s = ""
Expand Down Expand Up @@ -422,6 +463,18 @@ class Partition
flash.write(0x8000, b)
self.otadata.save()
end

#- invalidate SPIFFS partition to force format at next boot -#
#- we simply erase the first byte of the first 2 blocks in the SPIFFS partition -#
def invalidate_spiffs()
#- we expect the SPIFFS partition to be the last one -#
var spiffs = self.slots[-1]
if !spiffs.is_spiffs() raise 'value_error', 'No SPIFFS partition found' end

var b = bytes("00") #- flash memory: we can turn bits from '1' to '0' -#
flash.write(spiffs.start , b) #- block #0 -#
flash.write(spiffs.start + 0x1000, b) #- block #1 -#
end
end

partition.Partition = Partition
Expand Down
30 changes: 17 additions & 13 deletions tasmota/berry/modules/partition_manager.be
Original file line number Diff line number Diff line change
Expand Up @@ -24,14 +24,18 @@ class Partition_manager : Driver
# Show a single OTA Partition
#
def page_show_partition(slot, active)
webserver.content_send("<fieldset><legend><b>&nbsp;" + slot.label)
if active
webserver.content_send(" (active)")
webserver.content_send(string.format("<fieldset><legend><b title='Start: 0x%03X 000'>&nbsp;%s%s</b></legend>",
slot.start / 0x1000, slot.label, active ? " (active)" : ""))

webserver.content_send(string.format("<p><b>Partition size: </b>%i KB</p>", slot.size / 1024))
var used = slot.get_image_size()
if used >= 0
webserver.content_send(string.format("<p><b>Used: </b>%i KB</p>", used / 1024))
webserver.content_send(string.format("<p><b>Free: </b>%i KB</p>", (slot.size - used) / 1024))
else
webserver.content_send("<p><b>Used: unknwon")
webserver.content_send("<p><b>Free: unknwon")
end
webserver.content_send("</b></legend>")

webserver.content_send(string.format("<p><b>Start: </b>0x<b>%03x</b> 000</p>", slot.start / 0x1000))
webserver.content_send(string.format("<p><b>Size: </b>%i KB</p>", slot.size / 1024))

webserver.content_send("<p></p></fieldset><p></p>")
end
Expand All @@ -41,11 +45,10 @@ class Partition_manager : Driver
# Show a single OTA Partition
#
def page_show_spiffs(slot, free_mem)
webserver.content_send("<fieldset><legend><b>&nbsp;" + slot.label)
webserver.content_send("</b></legend>")
webserver.content_send(string.format("<fieldset><legend><b title='Start: 0x%03X 000'>&nbsp;%s</b></legend>",
slot.start / 0x1000, slot.label))

webserver.content_send(string.format("<p><b>Start: </b>0x<b>%03x</b> 000</p>", slot.start / 0x1000))
webserver.content_send(string.format("<p><b>Size: </b>%i KB</p>", slot.size / 1024))
webserver.content_send(string.format("<p><b>Partition size: </b>%i KB</p>", slot.size / 1024))
if free_mem != nil
webserver.content_send(string.format("<p><b>Unallocated: </b>%i KB</p>", free_mem / 1024))
end
Expand All @@ -63,7 +66,7 @@ class Partition_manager : Driver
if ota_num != nil
# we have an OTA partition
self.page_show_partition(slot, ota_num == p.otadata.active_otadata)
elif slot.type == 1 && slot.subtype == 130
elif slot.is_spiffs()
var flash_size = tasmota.memory()['flash'] * 1024
var used_size = (slot.start + slot.size)
self.page_show_spiffs(slot, slot == p.slots[-1] ? flash_size - used_size : nil)
Expand All @@ -78,8 +81,9 @@ class Partition_manager : Driver
webserver.content_start("Partition Manager") #- title of the web page -#
webserver.content_send_style() #- send standard Tasmota styles -#

webserver.content_send("<p><b>Esp32 Partition Manager</b></p><p></p>") #- send any html -#
webserver.content_send("<fieldset><legend><b>&nbsp;Partition Manager</b></legend><p></p>")
self.page_show_partitions()
webserver.content_send("<p></p></fieldset><p></p>")

webserver.content_button(webserver.BUTTON_MANAGEMENT) #- button back to management page -#
webserver.content_stop() #- end of web page -#
Expand Down

0 comments on commit 4c97948

Please sign in to comment.