Initial attempt at adding kboot header

This commit is contained in:
Rob McMullen 2016-05-03 23:21:01 -07:00
parent ccebfdf354
commit b977322a4e
3 changed files with 58 additions and 1 deletions

View File

@ -10,7 +10,7 @@ except ImportError:
from errors import * from errors import *
from ataridos import AtariDosDiskImage, AtariDosFile from ataridos import AtariDosDiskImage, AtariDosFile
from diskimages import AtrHeader, BootDiskImage from diskimages import AtrHeader, BootDiskImage
from kboot import KBootImage from kboot import KBootImage, add_kboot_header
from segments import SegmentData, SegmentSaver, DefaultSegment, EmptySegment, ObjSegment, RawSectorsSegment, user_bit_mask, match_bit_mask, comment_bit_mask, data_bit_mask, selected_bit_mask, diff_bit_mask, not_user_bit_mask from segments import SegmentData, SegmentSaver, DefaultSegment, EmptySegment, ObjSegment, RawSectorsSegment, user_bit_mask, match_bit_mask, comment_bit_mask, data_bit_mask, selected_bit_mask, diff_bit_mask, not_user_bit_mask
from spartados import SpartaDosDiskImage from spartados import SpartaDosDiskImage
from utils import to_numpy from utils import to_numpy

View File

@ -54,3 +54,25 @@ class KBootImage(DiskImageBase):
end = dirent.exe_start + dirent.exe_size end = dirent.exe_start + dirent.exe_size
raw = self.rawdata[start:end] raw = self.rawdata[start:end]
return XexSegment(raw, 0, 0, start, end, name="KBoot Executable") return XexSegment(raw, 0, 0, start, end, name="KBoot Executable")
kboot_header = '\x96\x020\x13\x80\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x00\x03\x00\x07\x14\x07L\x14\x07\xff\x97\x00\x00\xa9F\x8d\xc6\x02\xd0\xfe\xa0\x00\xa9k\x91X \xd9\x07\xb0\xee \xc4\x07\xadz\x08\rv\x08\xd0\xe3\xa5\x80\x8d\xe0\x02\xa5\x81\x8d\xe1\x02\xa9\x00\x8d\xe2\x02\x8d\xe3\x02 \xeb\x07\xb0\xcc\xa0\x00\x91\x80\xa5\x80\xc5\x82\xd0\x06\xa5\x81\xc5\x83\xf0\x08\xe6\x80\xd0\x02\xe6\x81\xd0\xe3\xadv\x08\xd0\xaf\xad\xe2\x02\x8dp\x07\r\xe3\x02\xf0\x0e\xad\xe3\x02\x8dq\x07 \xff\xff\xadz\x08\xd0\x13\xa9\x00\x8d\xe2\x02\x8d\xe3\x02 \xae\x07\xadz\x08\xd0\x03L<\x07\xa9\x00\x85\x80\x85\x81\x85\x82\x85\x83\xad\xe0\x02\x85\n\x85\x0c\xad\xe1\x02\x85\x0b\x85\r\xa9\x01\x85\t\xa9\x00\x8dD\x02l\xe0\x02 \xeb\x07\x85\x80 \xeb\x07\x85\x81\xa5\x80\xc9\xff\xd0\x10\xa5\x81\xc9\xff\xd0\n \xeb\x07\x85\x80 \xeb\x07\x85\x81 \xeb\x07\x85\x82 \xeb\x07\x85\x83` \xeb\x07\xc9\xff\xd0\t \xeb\x07\xc9\xff\xd0\x02\x18`8`\xad\t\x07\r\n\x07\r\x0b\x07\xf0y\xacy\x08\x10P\xeew\x08\xd0\x03\xeex\x08\xa91\x8d\x00\x03\xa9\x01\x8d\x01\x03\xa9R\x8d\x02\x03\xa9@\x8d\x03\x03\xa9\x80\x8d\x04\x03\xa9\x08\x8d\x05\x03\xa9\x1f\x8d\x06\x03\xa9\x80\x8d\x08\x03\xa9\x00\x8d\t\x03\xadw\x08\x8d\n\x03\xadx\x08\x8d\x0b\x03 Y\xe4\xad\x03\x03\xc9\x02\xb0"\xa0\x00\x8cy\x08\xb9\x80\x08\xaa\xad\t\x07\xd0\x0b\xad\n\x07\xd0\x03\xce\x0b\x07\xce\n\x07\xce\t\x07\xeey\x08\x8a\x18`\xa0\x01\x8cv\x088`\xa0\x01\x8cz\x088`\x00\x03\x00\x80\x00\x00\x00\x00\x00\x00'
def add_kboot_header(bytes):
sec_size = 128
size = len(bytes)
num_sectors = (size + sec_size - 1) / sec_size
padded_size = num_sectors * sec_size
if size < padded_size:
bytes = np.append(bytes, np.zeros([padded_size - size], dtype=np.uint8))
paragraphs = padded_size / 16
print size, num_sectors, paragraphs
header = np.fromstring(kboot_header, dtype=np.uint8)
image = np.append(header, bytes)
print image
words = image.view(dtype='<u2')
print words
words[1] = paragraphs
print words
words = image[16 + 9:16 + 9 + 2].view('<u2')
words[0] = size
return image

35
test/test_kboot.py Normal file
View File

@ -0,0 +1,35 @@
import os
import numpy as np
from atrcopy import KBootImage, add_kboot_header
class TestKbootHeader(object):
def setup(self):
pass
def check_size(self, data):
size = np.alen(data)
image = add_kboot_header(data)
assert int(image[2:4].view(dtype='<u2')) == ((size + 127) / 128) * 128 / 16
assert int(image[16 + 9:16 + 9 + 2].view('<u2')) == size
return image
def test_simple(self):
for size in range(2000, 40000, 1000):
data = np.arange(size, dtype=np.uint8)
self.check_size(data)
def test_real(self):
data = np.fromfile("air_defense_v18.xex", dtype=np.uint8)
image = self.check_size(data)
with open("air_defense_v18.atr", "wb") as fh:
txt = image.tostring()
fh.write(txt)
if __name__ == "__main__":
t = TestKbootHeader()
t.setup()
t.test_simple()
t.test_real()