Copy actual partition size instead of hardcoded 16MB (#627)

Signed-off-by: David Schrammel <david.schrammel@iaik.tugraz.at>
This commit is contained in:
David Schrammel 2021-03-04 09:48:04 +01:00 committed by GitHub
parent 7760227f88
commit afea42d650
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
4 changed files with 833 additions and 779 deletions

File diff suppressed because it is too large Load diff

View file

@ -20,7 +20,7 @@ module bootrom (
input logic [63:0] addr_i,
output logic [63:0] rdata_o
);
localparam int RomSize = 866;
localparam int RomSize = 884;
const logic [RomSize-1:0][63:0] mem = {
64'h00000000_00000000,
@ -316,6 +316,24 @@ module bootrom (
64'h00000000_30303030,
64'h30303032_40697073,
64'h2d737078_01000000,
64'h02000000_006c6f72,
64'h746e6f63_11010000,
64'h08000000_03000000,
64'h03000000_47010000,
64'h04000000_03000000,
64'h00100000_00000000,
64'h00000018_00000000,
64'h67000000_10000000,
64'h03000000_07000000,
64'h06000000_05000000,
64'h04000000_58010000,
64'h10000000_03000000,
64'h00007265_6d69745f,
64'h6270612c_706c7570,
64'h1b000000_0f000000,
64'h03000000_00003030,
64'h30303030_38314072,
64'h656d6974_01000000,
64'h02000000_04000000,
64'h6d010000_04000000,
64'h03000000_02000000,
@ -357,7 +375,7 @@ module bootrom (
64'h04000000_03000000,
64'h03000000_b5000000,
64'h04000000_03000000,
64'h03000000_2e010000,
64'h1e000000_2e010000,
64'h04000000_03000000,
64'h07000000_1b010000,
64'h04000000_03000000,
@ -471,7 +489,7 @@ module bootrom (
64'h4b000000_04000000,
64'h03000000_00000030,
64'h40757063_01000000,
64'hc0e1e400_38000000,
64'h40787d01_38000000,
64'h04000000_03000000,
64'h00000000_0f000000,
64'h04000000_03000000,
@ -500,11 +518,11 @@ module bootrom (
64'h00000000_01000000,
64'h00000000_00000000,
64'h00000000_00000000,
64'h00090000_d8020000,
64'h90090000_d8020000,
64'h00000000_10000000,
64'h11000000_28000000,
64'h38090000_38000000,
64'h100c0000_edfe0dd0,
64'hc8090000_38000000,
64'ha00c0000_edfe0dd0,
64'h00000000_00000000,
64'h00000000_00000000,
64'h00000000_00000000,
@ -541,279 +559,279 @@ module bootrom (
64'h00000000_00000000,
64'h00000000_00000000,
64'h00000000_00000000,
64'h00000000_00000000,
64'h00000000_00000000,
64'h00000000_00000000,
64'h00000000_00000000,
64'h00000000_a0018402,
64'h15058593_00000597,
64'h13058593_00000597,
64'h01f41413_0010041b,
64'he911d23f_f0ef057e,
64'h65a14505_edcff0ef,
64'hd8050513_00001517,
64'hea4ff0ef_e4060805,
64'he911d05f_f0ef057e,
64'h65a14505_ebcff0ef,
64'hdf050513_00001517,
64'he84ff0ef_e4060805,
64'h05132005_85931141,
64'h02faf537_65f1bbb5,
64'hf00ff0ef_09450513,
64'h00001517_b3f5dee5,
64'h05130000_1517f98f,
64'hf0ef8526_f1cff0ef,
64'hef050513_00001517,
64'hf28ff0ef_ee450513,
64'h00001517_c50d84aa,
64'hc33ff0ef_8552865a,
64'h020aa583_f44ff0ef,
64'h0c050513_00001517,
64'hf57993e3_08048493,
64'hf58ff0ef_2985e3e5,
64'h05130000_1517ff2c,
64'h1be382ff_f0ef0905,
64'h00094503_f74ff0ef,
64'h0e050513_00001517,
64'h803ff0ef_7088f86f,
64'hf0ef0e25_05130000,
64'h1517815f_f0ef6c88,
64'hf98ff0ef_0e450513,
64'h00001517_827ff0ef,
64'h07048c13_02848913,
64'h6888fb2f_f0ef0ee5,
64'h05130000_1517ff2c,
64'h1be3887f_f0ef0905,
64'h00094503_01090c13,
64'hfd0ff0ef_0ec50513,
64'h00001517_fe991be3,
64'h8a5ff0ef_09050009,
64'h4503ff04_8913feef,
64'hf0ef0ea5_05130000,
64'h15178bff_f0ef0ff9,
64'hf513803f_f0ef0e65,
64'h05130000_1517b5fd,
64'hef050513_00001517,
64'h89bff0ef_854e81ff,
64'hf0efff25_05130000,
64'h151782bf_f0effe65,
64'h05130000_1517c50d,
64'h080489aa_8a8ad39f,
64'hf0ef850a_46057101,
64'h04892583_84dff0ef,
64'hf3050513_00001517,
64'h89bff0ef_455685ff,
64'hf0ef1225_05130000,
64'h15178adf_f0ef4546,
64'h871ff0ef_11450513,
64'h00001517_8ffff0ef,
64'h6526883f_f0ef1065,
64'h05130000_1517911f,
64'hf0ef7502_895ff0ef,
64'h10850513_00001517,
64'h923ff0ef_65628a7f,
64'hf0ef1025_05130000,
64'h15178f5f_f0ef4552,
64'h8b9ff0ef_10450513,
64'h00001517_907ff0ef,
64'h45428cbf_f0ef1065,
64'h05130000_1517919f,
64'hf0ef4532_8ddff0ef,
64'h10850513_00001517,
64'h92bff0ef_45228eff,
64'hf0ef10a5_05130000,
64'h151797df_f0ef4b91,
64'h6502903f_f0ef10e5,
64'h05130000_151790ff,
64'hf0ef0fa5_05130000,
64'h1517bf61_54f991ff,
64'hf0ef0025_05130000,
64'h15179adf_f0ef8526,
64'h931ff0ef_10450513,
64'h00001517_93dff0ef,
64'h0f850513_00001517,
64'hc90584aa_890ae49f,
64'hf0ef850a_45854605,
64'h710195bf_f0ef0fe5,
64'h05130000_15178082,
64'h61616c02_6ba26b42,
64'h6ae27a02_79a27942,
64'h74e26406_852660a6,
64'hfb040113_54fd987f,
64'hf0ef1025_05130000,
64'h1517c51d_df3ff0ef,
64'h8b2e8a2a_0880e062,
64'he45eec56_f44ef84a,
64'hfc26e486_e85af052,
64'he0a2715d_b7655479,
64'h80826169_6baa6b4a,
64'h6aea7a0a_79aa794a,
64'h74ea640e_60ae8522,
64'h547d9d3f_f0ef1265,
64'h05130000_1517c59f,
64'hf0efc5df_f0efc61f,
64'hf0efc65f_f0efc69f,
64'hf0efc6df_f0efc71f,
64'hf0efc75f_f0efa805,
64'hc7bff0ef_c87ff0ef,
64'h45314581_46054401,
64'hf93046e3_19fda17f,
64'h02faf537_65f1b38d,
64'hee0ff0ef_10450513,
64'h00001517_bbd9e5e5,
64'h05130000_1517f78f,
64'hf0ef8526_efcff0ef,
64'hf6050513_00001517,
64'hf08ff0ef_f5450513,
64'h00001517_bbfde865,
64'h05130000_1517fa0f,
64'hf0ef8526_f24ff0ef,
64'hf8850513_00001517,
64'hf30ff0ef_f7c50513,
64'h00001517_c92984aa,
64'hc3dff0ef_8556865e,
64'h020b2583_f4cff0ef,
64'h15850513_00001517,
64'hf3849de3_08090913,
64'h080a0993_f64ff0ef,
64'h2485eda5_05130000,
64'h1517ff3a_1be383bf,
64'hf0ef0a05_000a4503,
64'hf80ff0ef_17c50513,
64'h00001517_80fff0ef,
64'h01093503_f94ff0ef,
64'h18050513_00001517,
64'h823ff0ef_00893503,
64'hfa8ff0ef_18450513,
64'h00001517_837ff0ef,
64'hfb898a13_00093503,
64'hfc0ff0ef_18c50513,
64'h00001517_ff2a1be3,
64'h895ff0ef_0a05000a,
64'h4503f909_8a13fdef,
64'hf0ef18a5_05130000,
64'h1517e799_0359e7b3,
64'h07241a63_29019041,
64'h14428c49_cafff0ef,
64'h90410305_141384a2,
64'h0085151b_cbfff0ef,
64'hfd641ae3_04040413,
64'hff7497e3_892af13f,
64'hf0ef0485_854a0007,
64'hc5830094_07b30400,
64'h0b934481_c67ff0ef,
64'h1517ff9a_19e38b3f,
64'hf0ef0a05_0007c503,
64'h014d07b3_4a01ffef,
64'hf0eff809_8d1318e5,
64'h05130000_15178d3f,
64'hf0ef0ff4_f513817f,
64'hf0ef18a5_05130000,
64'h15174c11_4cc11005,
64'h1b630201_09130801,
64'h099384aa_8b0ad33f,
64'hf0ef850a_46057101,
64'h04892583_845ff0ef,
64'hfb850513_00001517,
64'h893ff0ef_4556857f,
64'hf0ef1aa5_05130000,
64'h15178a5f_f0ef4546,
64'h869ff0ef_19c50513,
64'h00001517_8f7ff0ef,
64'h652687bf_f0ef18e5,
64'h05130000_1517909f,
64'hf0ef7502_88dff0ef,
64'h19050513_00001517,
64'h91bff0ef_656289ff,
64'hf0ef18a5_05130000,
64'h15178edf_f0ef4552,
64'h8b1ff0ef_18c50513,
64'h00001517_8ffff0ef,
64'h45428c3f_f0ef18e5,
64'h05130000_1517911f,
64'hf0ef4532_8d5ff0ef,
64'h19050513_00001517,
64'h923ff0ef_45228e7f,
64'hf0ef1925_05130000,
64'h1517975f_f0ef6502,
64'h8f9ff0ef_19450513,
64'h00001517_905ff0ef,
64'h18050513_00001517,
64'hbf5154f9_915ff0ef,
64'h08850513_00001517,
64'h9a3ff0ef_8526927f,
64'hf0ef18a5_05130000,
64'h1517933f_f0ef17e5,
64'h05130000_1517c905,
64'h84aa890a_e41ff0ef,
64'h850a4585_46057101,
64'h951ff0ef_18450513,
64'h00001517_80826125,
64'h6d026ca2_6c426be2,
64'h7b027aa2_7a4279e2,
64'h690664a6_64468526,
64'h60e6fa04_011354fd,
64'h981ff0ef_18c50513,
64'h00001517_c90ddeff,
64'hf0ef8bae_8aaa1080,
64'he06ae466_e862f05a,
64'hf852fc4e_e0cae4a6,
64'hec86ec5e_f456e8a2,
64'h711db765_54798082,
64'h61696baa_6b4a6aea,
64'h7a0a79aa_794a74ea,
64'h640e60ae_8522547d,
64'h9d1ff0ef_1b450513,
64'h00001517_c5dff0ef,
64'hc61ff0ef_c65ff0ef,
64'hc69ff0ef_c6dff0ef,
64'hc71ff0ef_c75ff0ef,
64'hc79ff0ef_a805c7ff,
64'hf0efc8bf_f0ef4531,
64'h45814605_4401f930,
64'h46e32004_849319fd,
64'ha19ff0ef_21c50513,
64'h00001517_e7990369,
64'he7b30689_1c639041,
64'h29011442_8c49cb7f,
64'hf0ef9041_03051413,
64'h0085151b_cc5ff0ef,
64'hfc941ae3_04040413,
64'hff7a17e3_892af15f,
64'hf0ef0a05_854a0007,
64'hc5830144_07b30400,
64'h0b934a01_c69ff0ef,
64'h850a0400_05938622,
64'h49018426_20048b13,
64'hff451ee3_cffff0ef,
64'h3e800a93_0fe00a13,
64'he951d15f_f0ef4549,
64'h85a20ff6_76130016,
64'h66130015_161bf49f,
64'hf0ef0ff4_7593f51f,
64'hf0ef0ff5_f5930084,
64'h559bf5df_f0ef0ff5,
64'hf5930104_559bf69f,
64'hf0ef4501_0ff5f593,
64'h0184559b_fee79be3,
64'h078500c6_802300f1,
64'h06b30800_0713567d,
64'h47810209_d993842e,
64'h84aae55e_e95aed56,
64'hf152f94a_e586fd26,
64'he1a20206_1993f54e,
64'h71558082_91411542,
64'h8d3d8ff9_0057979b,
64'h17016709_0107d79b,
64'h0105179b_4105551b,
64'h0105151b_8d2d00c5,
64'h95138da9_893d0045,
64'hd51b8da9_91411542,
64'h8d5d0522_0085579b,
64'h808207f5_75138d2d,
64'h00451593_8d2d8d3d,
64'h0045d51b_0075d79b,
64'h8de98082_0141853e,
64'h640260a2_4781c111,
64'h57f5f89f_f0efc511,
64'h57f9efbf_f0efc911,
64'h57fdeb7f_f0effc6d,
64'he03ff0ef_347d4429,
64'hb91ff0ef_2cc50513,
64'h00001517_c89ff0ef,
64'he022e406_11418082,
64'h61050015_351364a2,
64'h644260e2_0004051b,
64'hfc940ce3_e37ff0ef,
64'heb3ff0ef_2f450513,
64'h00001517_85aa842a,
64'he53ff0ef_02900513,
64'h400005b7_07700613,
64'hfbdff0ef_4485e822,
64'hec06e426_11018082,
64'h01410015_3513157d,
64'h640260a2_0004051b,
64'hef3ff0ef_32e50513,
64'h85a20000_1517e89f,
64'hf0ef842a_e97ff0ef,
64'he022e406_03700513,
64'h45810650_06131141,
64'h80826105_690264a2,
64'h644260e2_00153513,
64'hf5650513_0004051b,
64'h01249863_88bd00f9,
64'h1b634501_4785ec9f,
64'hf0efecdf_f0ef842a,
64'hed3ff0ef_84aaed9f,
64'hf0efeddf_f0efee1f,
64'hf0ef892a_eefff0ef,
64'he04ae426_e822ec06,
64'h45211aa0_05930870,
64'h06131101_bfcd4501,
64'h80826105_690264a2,
64'h644260e2_4505f89f,
64'hf0ef4585_3bc50513,
64'h00001517_fe9915e3,
64'hc00df25f_f0ef892a,
64'h347df35f_f0ef4501,
64'h45810950_06134485,
64'h71040413_e04aec06,
64'he4266409_e8221101,
64'hcd1ff06f_61053b65,
64'h05130000_151760e2,
64'h6442da7f_f0ef852e,
64'h65a2cebf_f0ef3fe5,
64'h05130000_1517cf7f,
64'hf0ef8522_cfdff0ef,
64'he42eec06_40450513,
64'h00001517_842ae822,
64'h11018082_614564e2,
64'h740270a2_f47d147d,
64'h0007d463_4187d79b,
64'h0185179b_fa7ff0ef,
64'heb5ff0ef_85320640,
64'h04136622_ec1ff0ef,
64'h0ff47513_ec9ff0ef,
64'h0ff57513_0084551b,
64'hed5ff0ef_0ff57513,
64'h0104551b_ee1ff0ef,
64'h0ff57513_0184551b,
64'heedff0ef_0404e513,
64'hfebff0ef_84aa842e,
64'hec26f022_e432f406,
64'h7179f07f_f06f0ff0,
64'h05138082_557db7e9,
64'h00d70023_078500f6,
64'h073306c8_2683ff79,
64'h8b055178_bf4dd6b8,
64'h07850007_c7038082,
64'h4501d3b8_4719dbb8,
64'h577d2000_07b700b6,
64'hef630007_869b2000,
64'h08372000_0537fff5,
64'h8b85537c_20000737,
64'hd3b82000_07b71060,
64'h0713fff5_37fd0001,
64'h03200793_04b76163,
64'h40a7873b_87aa2000,
64'h06b7dbb8_57792000,
64'h07b706b7_ec631000,
64'h07938082_610564a2,
64'hd3b84719_dbb86442,
64'h60e20ff4_7513577d,
64'h200007b7_e25ff0ef,
64'h50850513_00001517,
64'heb3ff0ef_91011502,
64'h4088e3bf_f0ef5265,
64'h05130000_1517e395,
64'h8b852401_53fc57e0,
64'hff658b05_06478493,
64'h53f8d3b8_10600713,
64'h200007b7_fff537fd,
64'h00010640_0793d7a8,
64'hdbb85779_e426e822,
64'hec062000_07b71101,
64'he81ff06f_61055565,
64'h05130000_151764a2,
64'h60e26442_d03c4799,
64'he99ff0ef_57c50513,
64'h00001517_f27ff0ef,
64'h91010204_95132481,
64'heb1ff0ef_57450513,
64'h00001517_5064d03c,
64'h16600793_ec5ff0ef,
64'h5a850513_00001517,
64'hf53ff0ef_91010204,
64'h95132481_eddff0ef,
64'h5a050513_00001517,
64'h5064d03c_10400793,
64'h20000437_fff537fd,
64'h000147a9_c3b84729,
64'h200007b7_f05ff0ef,
64'he426e822_ec065c05,
64'h05131101_00001517,
64'h80824108_8082c10c,
64'h4901ff55_1ee3cfff,
64'hf0efe004_84133e80,
64'h0b130fe0_0a93e951,
64'h20048493_d1dff0ef,
64'h454985a2_0ff67613,
64'h00166613_0015161b,
64'hf4dff0ef_0ff47593,
64'hf55ff0ef_0ff5f593,
64'h0084559b_f61ff0ef,
64'h0ff5f593_0104559b,
64'hf6dff0ef_45010184,
64'h559bfee7_9be30785,
64'h00c68023_00f106b3,
64'h08000713_567d4781,
64'h0209d993_842e84aa,
64'he55ee95a_ed56f152,
64'hf94ae586_fd26e1a2,
64'h02061993_f54e7155,
64'h80829141_15428d3d,
64'h8ff90057_979b1701,
64'h67090107_d79b0105,
64'h179b4105_551b0105,
64'h151b8d2d_00c59513,
64'h8da9893d_0045d51b,
64'h8da99141_15428d5d,
64'h05220085_579b8082,
64'h07f57513_8d2d0045,
64'h15938d2d_8d3d0045,
64'hd51b0075_d79b8de9,
64'h80820141_853e6402,
64'h60a257f5_e1114781,
64'hf89ff0ef_c51157f9,
64'hefbff0ef_c91157fd,
64'heb7ff0ef_fc6de07f,
64'hf0ef347d_4429b8ff,
64'hf0ef35a5_05130000,
64'h1517c89f_f0efe022,
64'he4061141_80826105,
64'h00153513_64a26442,
64'h60e20004_051bfc94,
64'h0ce3e3bf_f0efeb3f,
64'hf0ef3825_05130000,
64'h151785aa_842ae57f,
64'hf0ef0290_05134000,
64'h05b70770_0613fbdf,
64'hf0ef4485_e822ec06,
64'he4261101_80820141,
64'h00153513_157d6402,
64'h60a20004_051bef3f,
64'hf0ef3bc5_051385a2,
64'h00001517_e8dff0ef,
64'h842ae9bf_f0efe022,
64'he4060370_05134581,
64'h06500613_11418082,
64'h61056902_64a26442,
64'h60e20015_3513f565,
64'h05130004_051b0124,
64'h986388bd_00f91b63,
64'h45014785_ecdff0ef,
64'hed1ff0ef_842aed7f,
64'hf0ef84aa_eddff0ef,
64'hee1ff0ef_ee5ff0ef,
64'h892aef3f_f0efe04a,
64'he426e822_ec064521,
64'h1aa00593_08700613,
64'h1101bfcd_45018082,
64'h61056902_64a26442,
64'h60e24505_f89ff0ef,
64'h458544a5_05130000,
64'h1517fe99_15e3c00d,
64'hf29ff0ef_892a347d,
64'hf39ff0ef_45014581,
64'h09500613_44857104,
64'h0413e04a_ec06e426,
64'h6409e822_1101ccff,
64'hf06f6105_44450513,
64'h00001517_60e26442,
64'hda5ff0ef_852e65a2,
64'hce9ff0ef_48c50513,
64'h00001517_cf5ff0ef,
64'h8522cfbf_f0efe42e,
64'hec064925_05130000,
64'h1517842a_e8221101,
64'h80826145_64e27402,
64'h70a2f47d_147d0007,
64'hd4634187_d79b0185,
64'h179bfabf_f0efeb5f,
64'hf0ef8532_06400413,
64'h6622ec1f_f0ef0ff4,
64'h7513ec9f_f0ef0ff5,
64'h75130084_551bed5f,
64'hf0ef0ff5_75130104,
64'h551bee1f_f0ef0184,
64'h551bee9f_f0ef0404,
64'he513febf_f0ef84aa,
64'h842eec26_f022e432,
64'hf4067179_f03ff06f,
64'h0ff00513_8082557d,
64'hb7d900d7_00230785,
64'h00f60733_06c82683,
64'hff698b05_5178b77d,
64'hd6b80785_00074703,
64'h00f50733_80824501,
64'hd3b84719_dbb8577d,
64'h200007b7_02b6e163,
64'h0007869b_20000837,
64'h20000537_fff58b85,
64'h537c2000_0737d3b8,
64'h200007b7_10600713,
64'hfff537fd_00010320,
64'h079304b7_61630007,
64'h871b4781_200006b7,
64'hdbb85779_200007b7,
64'h06b7ee63_10000793,
64'h80826105_64a2d3b8,
64'h4719dbb8_644260e2,
64'h0ff47513_577d2000,
64'h07b7e23f_f0ef5965,
64'h05130000_1517eb1f,
64'hf0ef9101_15024088,
64'he39ff0ef_5b450513,
64'h00001517_e3958b85,
64'h240153fc_57e0ff65,
64'h8b050647_849353f8,
64'hd3b81060_07132000,
64'h07b7fff5_37fd0001,
64'h06400793_d7a8dbb8,
64'h5779e426_e822ec06,
64'h200007b7_1101e7ff,
64'hf06f6105_5e450513,
64'h00001517_64a260e2,
64'h6442d03c_4799e97f,
64'hf0ef60a5_05130000,
64'h1517f25f_f0ef9101,
64'h02049513_2481eaff,
64'hf0ef6025_05130000,
64'h15175064_d03c1660,
64'h0793ec3f_f0ef6365,
64'h05130000_1517f51f,
64'hf0ef9101_02049513,
64'h2481edbf_f0ef62e5,
64'h05130000_15175064,
64'hd03c1040_07932000,
64'h0437fff5_37fd0001,
64'h47a9c3b8_47292000,
64'h07b7f03f_f0efe426,
64'he822ec06_64e50513,
64'h11010000_15178082,
64'h25014108_8082c10c,
64'h80826105_60e2ecff,
64'hf0ef0091_4503ed7f,
64'hf0ef0081_4503f55f,
@ -885,7 +903,7 @@ module bootrom (
64'h4009091b_02000937,
64'h00448493_0124a023,
64'h00100913_020004b7,
64'h25f000ef_01a11113,
64'h27f000ef_01a11113,
64'h0210011b_03249663,
64'hf1402973_00000493,
64'h30491073_00800913

View file

@ -92,7 +92,7 @@ int gpt_find_boot_partition(uint8_t* dest, uint32_t size)
partition_entries_t *boot = (partition_entries_t *)(lba2_buf);
print_uart("copying boot image ");
res = sd_copy(dest, boot->first_lba, size);
res = sd_copy(dest, boot->first_lba, boot->last_lba - boot->first_lba + 1);
if (res != 0)
{
@ -105,4 +105,4 @@ int gpt_find_boot_partition(uint8_t* dest, uint32_t size)
print_uart(" done!\r\n");
return 0;
}
}

View file

@ -93,7 +93,7 @@ int gpt_find_boot_partition(uint8_t* dest, uint32_t size)
partition_entries_t *boot = (partition_entries_t *)(lba2_buf);
print_uart("copying boot image ");
print_uart("\r\n");
res = sd_copy(dest, boot->first_lba, size);
res = sd_copy(dest, boot->first_lba, boot->last_lba - boot->first_lba + 1);
if (res != 0)
{