From 6e043ef57744886858f61633854b9cd62ec6c254 Mon Sep 17 00:00:00 2001 From: marqs Date: Tue, 7 Feb 2017 23:04:30 +0200 Subject: [PATCH] Improve input mode handling * New options and better compatibility for Line5x * Add support for 960i and 1080i * Make TVP HPLL2x option user-selectable --- ossc.cof | 4 +- ossc.qsf | 2 + ossc.sdc | 4 +- rtl/pll_2x.v | 10 +- rtl/scanconverter.v | 323 +-- .../mem_init/sys_onchip_memory2_0.hex | 1864 ++++++++--------- software/sys_controller/ossc/av_controller.c | 90 +- software/sys_controller/ossc/av_controller.h | 1 + software/sys_controller/ossc/avconfig.c | 3 +- software/sys_controller/ossc/avconfig.h | 9 +- software/sys_controller/ossc/menu.c | 23 +- software/sys_controller/tvp7002/tvp7002.c | 14 +- software/sys_controller/tvp7002/tvp7002.h | 4 +- software/sys_controller/tvp7002/video_modes.c | 29 +- software/sys_controller/tvp7002/video_modes.h | 21 +- software/sys_controller_bsp/settings.bsp | 4 +- sys.sopcinfo | 4 +- 17 files changed, 1264 insertions(+), 1145 deletions(-) diff --git a/ossc.cof b/ossc.cof index 72b465a..66dfe12 100644 --- a/ossc.cof +++ b/ossc.cof @@ -13,11 +13,11 @@ output_files/ossc.sof - 9 + 10 0 0 0 - 0 + 1 1 diff --git a/ossc.qsf b/ossc.qsf index 2289db1..a814a35 100644 --- a/ossc.qsf +++ b/ossc.qsf @@ -232,4 +232,6 @@ set_global_assignment -name QIP_FILE rtl/pll_2x.qip set_global_assignment -name QIP_FILE rtl/pll_3x.qip set_global_assignment -name CDF_FILE output_files/Chain1.cdf set_global_assignment -name ROUTER_CLOCKING_TOPOLOGY_ANALYSIS ON +set_global_assignment -name PLACEMENT_EFFORT_MULTIPLIER 8.0 +set_global_assignment -name ROUTER_EFFORT_MULTIPLIER 2.0 set_instance_assignment -name PARTITION_HIERARCHY root_partition -to | -section_id Top \ No newline at end of file diff --git a/ossc.sdc b/ossc.sdc index 963fdbd..f5bb37a 100644 --- a/ossc.sdc +++ b/ossc.sdc @@ -10,10 +10,10 @@ set_false_path -to {sys:sys_inst|sys_pio_1:pio_1|readdata*} ### Scanconverter clock constraints ### create_clock -period 108MHz -name pclk_hdtv [get_ports PCLK_in] -create_clock -period 13.5MHz -name pclk_sdtv_L2 [get_ports PCLK_in] -add +create_clock -period 27MHz -name pclk_sdtv_L2 [get_ports PCLK_in] -add create_clock -period 27MHz -name pclk_sdtv_L3 [get_ports PCLK_in] -add create_clock -period 27MHz -name pclk_sdtv_L4 [get_ports PCLK_in] -add -create_clock -period 16MHz -name pclk_sdtv_L5 [get_ports PCLK_in] -add +create_clock -period 27MHz -name pclk_sdtv_L5 [get_ports PCLK_in] -add #derive_pll_clocks create_generated_clock -master_clock pclk_sdtv_L2 -source {scanconverter_inst|pll_linedouble|altpll_component|auto_generated|pll1|inclk[0]} -multiply_by 2 -duty_cycle 50.00 -name pclk_2x {scanconverter_inst|pll_linedouble|altpll_component|auto_generated|pll1|clk[0]} diff --git a/rtl/pll_2x.v b/rtl/pll_2x.v index 6b63144..e52a3d9 100644 --- a/rtl/pll_2x.v +++ b/rtl/pll_2x.v @@ -117,7 +117,7 @@ module pll_2x ( altpll_component.clk1_multiply_by = 5, altpll_component.clk1_phase_shift = "0", altpll_component.compensate_clock = "CLK0", - altpll_component.inclk0_input_frequency = 74074, + altpll_component.inclk0_input_frequency = 37037, altpll_component.intended_device_family = "Cyclone IV E", altpll_component.lpm_hint = "CBX_MODULE_PREFIX=pll_2x", altpll_component.lpm_type = "altpll", @@ -193,8 +193,8 @@ endmodule // Retrieval info: PRIVATE: DIV_FACTOR1 NUMERIC "1" // Retrieval info: PRIVATE: DUTY_CYCLE0 STRING "50.00000000" // Retrieval info: PRIVATE: DUTY_CYCLE1 STRING "50.00000000" -// Retrieval info: PRIVATE: EFF_OUTPUT_FREQ_VALUE0 STRING "27.000000" -// Retrieval info: PRIVATE: EFF_OUTPUT_FREQ_VALUE1 STRING "67.500000" +// Retrieval info: PRIVATE: EFF_OUTPUT_FREQ_VALUE0 STRING "54.000000" +// Retrieval info: PRIVATE: EFF_OUTPUT_FREQ_VALUE1 STRING "135.000000" // Retrieval info: PRIVATE: EXPLICIT_SWITCHOVER_COUNTER STRING "0" // Retrieval info: PRIVATE: EXT_FEEDBACK_RADIO STRING "0" // Retrieval info: PRIVATE: GLOCKED_COUNTER_EDIT_CHANGED STRING "1" @@ -202,7 +202,7 @@ endmodule // Retrieval info: PRIVATE: GLOCKED_MODE_CHECK STRING "0" // Retrieval info: PRIVATE: GLOCK_COUNTER_EDIT NUMERIC "1048575" // Retrieval info: PRIVATE: HAS_MANUAL_SWITCHOVER STRING "1" -// Retrieval info: PRIVATE: INCLK0_FREQ_EDIT STRING "13.500" +// Retrieval info: PRIVATE: INCLK0_FREQ_EDIT STRING "27.000" // Retrieval info: PRIVATE: INCLK0_FREQ_UNIT_COMBO STRING "MHz" // Retrieval info: PRIVATE: INCLK1_FREQ_EDIT STRING "100.000" // Retrieval info: PRIVATE: INCLK1_FREQ_EDIT_CHANGED STRING "1" @@ -278,7 +278,7 @@ endmodule // Retrieval info: CONSTANT: CLK1_MULTIPLY_BY NUMERIC "5" // Retrieval info: CONSTANT: CLK1_PHASE_SHIFT STRING "0" // Retrieval info: CONSTANT: COMPENSATE_CLOCK STRING "CLK0" -// Retrieval info: CONSTANT: INCLK0_INPUT_FREQUENCY NUMERIC "74074" +// Retrieval info: CONSTANT: INCLK0_INPUT_FREQUENCY NUMERIC "37037" // Retrieval info: CONSTANT: INTENDED_DEVICE_FAMILY STRING "Cyclone IV E" // Retrieval info: CONSTANT: LPM_TYPE STRING "altpll" // Retrieval info: CONSTANT: OPERATION_MODE STRING "SOURCE_SYNCHRONOUS" diff --git a/rtl/scanconverter.v b/rtl/scanconverter.v index c9897b9..7ee3e11 100644 --- a/rtl/scanconverter.v +++ b/rtl/scanconverter.v @@ -83,7 +83,8 @@ wire pclk_1x, pclk_2x, pclk_3x, pclk_4x, pclk_5x; wire linebuf_rdclock; wire pclk_act; -wire [1:0] slid_act; +wire [2:0] line_id_act; +wire [2:0] col_id_act; wire pclk_2x_lock, pclk_3x_lock; @@ -100,15 +101,15 @@ reg DE_pp1, DE_pp2; wire [11:0] linebuf_hoffset; //Offset for line (max. 2047 pixels), MSB indicates which line is read/written wire [11:0] hcnt_act; -reg [11:0] hcnt_1x, hcnt_2x, hcnt_3x, hcnt_4x, hcnt_5x, hcnt_4x_aspfix, hcnt_3x_opt, hcnt_4x_opt, hcnt_5x_opt; +reg [11:0] hcnt_1x, hcnt_2x, hcnt_3x, hcnt_4x, hcnt_5x, hcnt_4x_aspfix, hcnt_2x_opt, hcnt_3x_opt, hcnt_4x_opt, hcnt_5x_opt, hcnt_5x_hscomp; -reg [2:0] hcnt_3x_opt_ctr, hcnt_4x_opt_ctr, hcnt_5x_opt_ctr; +reg [2:0] hcnt_2x_opt_ctr, hcnt_3x_opt_ctr, hcnt_4x_opt_ctr, hcnt_5x_opt_ctr; wire [10:0] vcnt_act; -reg [10:0] vcnt_1x, vcnt_1x_tvp, vcnt_2x, vcnt_4x, vcnt_5x, vcnt_3x_ref, vcnt_4x_ref, vcnt_5x_ref, lines_1x, lines_2x, lines_4x, lines_5x; //max. 2047 +reg [10:0] vcnt_1x, vcnt_1x_tvp, vcnt_2x, vcnt_4x, vcnt_5x, vcnt_2x_ref, vcnt_3x_ref, vcnt_4x_ref, vcnt_5x_ref, lines_1x, lines_2x, lines_4x, lines_5x; //max. 2047 reg [9:0] vcnt_3x, lines_3x; //max. 1023 -reg h_enable_3x_prev4x; +reg DE_3x_prev4x; reg pclk_1x_prev3x; reg [1:0] pclk_3x_cnt; @@ -121,11 +122,7 @@ reg pclk_1x_prevprev5x; reg [2:0] pclk_5x_cnt; // Data enable -reg h_enable_1x, v_enable_1x; -reg h_enable_2x, v_enable_2x; -reg h_enable_3x, v_enable_3x; -reg h_enable_4x, v_enable_4x; -reg h_enable_5x, v_enable_5x; +reg DE_1x, DE_2x, DE_3x, DE_4x, DE_5x; reg prev_hs, prev_vs; reg [11:0] hmax[0:1]; @@ -136,11 +133,11 @@ reg [2:0] line_out_idx_5x; reg [23:0] warn_h_unstable, warn_pll_lock_lost, warn_pll_lock_lost_3x; reg [10:0] H_ACTIVE; //max. 2047 -reg [7:0] H_BACKPORCH; //max. 255 +reg [8:0] H_BACKPORCH; //max. 511 reg [10:0] V_ACTIVE; //max. 2047 reg [5:0] V_BACKPORCH; //max. 63 reg [1:0] V_SCANLINEMODE; -reg [1:0] V_SCANLINEID; +reg [4:0] V_SCANLINEID; reg [7:0] H_SCANLINESTR; reg [5:0] V_MASK; reg [2:0] V_MULTMODE; @@ -151,9 +148,10 @@ reg [9:0] H_OPT_STARTOFF; reg [2:0] H_OPT_SCALE; reg [2:0] H_OPT_SAMPLE_MULT; reg [2:0] H_OPT_SAMPLE_SEL; +reg [9:0] H_L5BORDER; //8 bits per component -> 16.7M colors -reg [7:0] R_1x, G_1x, B_1x, R_pp1, G_pp1, B_pp1, R_pp2, G_pp2, B_pp2; +reg [7:0] R_1x, G_1x, B_1x, R_2x, G_2x, B_2x, R_3x, G_3x, B_3x, R_4x, G_4x, B_4x, R_5x, G_5x, B_5x, R_pp1, G_pp1, B_pp1; wire [7:0] R_lbuf, G_lbuf, B_lbuf; wire [7:0] R_act, G_act, B_act; @@ -166,16 +164,16 @@ function [7:0] apply_scanlines; input [1:0] mode; input [7:0] data; input [7:0] str; - input [1:0] actid; - input [1:0] lineid; - input pixid; + input [4:0] mask; + input [2:0] line_id; + input [2:0] col_id; input fid; begin - if ((mode == `SCANLINES_H) & (actid == lineid)) + if ((mode == `SCANLINES_H) && (mask & (5'h1< str) ? (data-str) : 8'h00; - else if ((mode == `SCANLINES_V) & (actid == pixid)) + else if ((mode == `SCANLINES_V) && (5'h0 == col_id)) apply_scanlines = (data > str) ? (data-str) : 8'h00; - else if ((mode == `SCANLINES_ALT) & ({actid[1], actid[0]^fid} == lineid)) + else if ((mode == `SCANLINES_ALT) && (mask & (5'h1<<(line_id^fid)))) apply_scanlines = (data > str) ? (data-str) : 8'h00; else apply_scanlines = data; @@ -186,6 +184,7 @@ function [7:0] apply_scanlines; function [7:0] apply_mask; input enable; input [7:0] data; + input [3:0] brightness; input [11:0] hoffset; input [11:0] hstart; input [11:0] hend; @@ -194,10 +193,9 @@ function [7:0] apply_mask; input [10:0] vend; begin if (enable & ((hoffset < hstart) | (hoffset >= hend) | (voffset < vstart) | (voffset >= vend))) - apply_mask = {2'h0, H_MASK_BR, 2'h0}; + apply_mask = {2'h0, brightness, 2'h0}; else apply_mask = data; - //apply_mask = (hoffset[0] ^ voffset[0]) ? 8'b11111111 : 8'b00000000; end endfunction @@ -215,41 +213,57 @@ begin R_act = R_1x; G_act = G_1x; B_act = B_1x; - DE_act = (h_enable_1x & v_enable_1x); + DE_act = DE_1x; HSYNC_act = HSYNC_1x; VSYNC_act = VSYNC_1x; lines_out = lines_1x; linebuf_rdclock = 0; linebuf_hoffset = 0; pclk_act = pclk_1x; - slid_act = {1'b0, vcnt_1x[0]}; + line_id_act = {2'b00, vcnt_1x[0]}; + col_id_act = {2'b00, hcnt_1x[0]}; hcnt_act = hcnt_1x; vcnt_act = vcnt_1x; end `V_MULTMODE_2X: begin - R_act = R_lbuf; - G_act = G_lbuf; - B_act = B_lbuf; - DE_act = (h_enable_2x & v_enable_2x); + R_act = R_2x; + G_act = G_2x; + B_act = B_2x; + DE_act = DE_2x; HSYNC_act = HSYNC_2x; VSYNC_act = VSYNC_2x; lines_out = lines_2x; linebuf_rdclock = pclk_2x; - linebuf_hoffset = hcnt_2x; - pclk_act = pclk_2x; - slid_act = {line_out_idx_2x[1], line_out_idx_2x[0]^FID_1x}; + case (H_MULTMODE) + `H_MULTMODE_FULLWIDTH: begin + linebuf_hoffset = hcnt_2x; + pclk_act = pclk_2x; + col_id_act = {2'b00, hcnt_2x[0]}; + end + `H_MULTMODE_OPTIMIZED: begin + linebuf_hoffset = hcnt_2x_opt; + pclk_act = pclk_1x; + col_id_act = {2'b00, hcnt_2x[1]};; + end + default: begin + linebuf_hoffset = hcnt_2x; + pclk_act = pclk_2x; + col_id_act = {2'b00, hcnt_2x[0]}; + end + endcase + line_id_act = {1'b0, line_out_idx_2x[1], line_out_idx_2x[0]^FID_1x}; hcnt_act = hcnt_2x; - vcnt_act = vcnt_2x>>1; + vcnt_act = vcnt_2x_ref; end `V_MULTMODE_3X: begin - R_act = R_lbuf; - G_act = G_lbuf; - B_act = B_lbuf; + R_act = R_3x; + G_act = G_3x; + B_act = B_3x; HSYNC_act = HSYNC_3x; VSYNC_act = VSYNC_1x; - DE_act = (h_enable_3x & v_enable_3x); + DE_act = DE_3x; lines_out = {1'b0, lines_3x}; - slid_act = line_out_idx_3x; + line_id_act = {1'b0, line_out_idx_3x}; vcnt_act = vcnt_3x_ref; case (H_MULTMODE) `H_MULTMODE_FULLWIDTH: begin @@ -257,36 +271,40 @@ begin linebuf_hoffset = hcnt_3x; pclk_act = pclk_3x; hcnt_act = hcnt_3x; + col_id_act = {2'b00, hcnt_3x[0]}; end `H_MULTMODE_ASPECTFIX: begin linebuf_rdclock = pclk_4x; linebuf_hoffset = hcnt_4x_aspfix; pclk_act = pclk_4x; hcnt_act = hcnt_4x_aspfix; + col_id_act = {2'b00, hcnt_4x[0]}; end `H_MULTMODE_OPTIMIZED: begin linebuf_rdclock = pclk_3x; linebuf_hoffset = hcnt_3x_opt; pclk_act = pclk_3x; hcnt_act = hcnt_3x; + col_id_act = hcnt_3x_opt_ctr; end default: begin linebuf_rdclock = pclk_3x; linebuf_hoffset = hcnt_3x; pclk_act = pclk_3x; hcnt_act = hcnt_3x; + col_id_act = {2'b00, hcnt_3x[0]}; end endcase end `V_MULTMODE_4X: begin - R_act = R_lbuf; - G_act = G_lbuf; - B_act = B_lbuf; + R_act = R_4x; + G_act = G_4x; + B_act = B_4x; HSYNC_act = HSYNC_4x; VSYNC_act = VSYNC_1x; - DE_act = (h_enable_4x & v_enable_4x); + DE_act = DE_4x; lines_out = lines_4x; - slid_act = line_out_idx_4x; + line_id_act = {1'b0, line_out_idx_4x}; vcnt_act = vcnt_4x_ref; linebuf_rdclock = pclk_4x; pclk_act = pclk_4x; @@ -294,37 +312,43 @@ begin case (H_MULTMODE) `H_MULTMODE_FULLWIDTH: begin linebuf_hoffset = hcnt_4x; + col_id_act = {2'b00, hcnt_4x[0]}; end `H_MULTMODE_OPTIMIZED: begin linebuf_hoffset = hcnt_4x_opt; + col_id_act = hcnt_4x_opt_ctr; end default: begin linebuf_hoffset = hcnt_4x; + col_id_act = {2'b00, hcnt_4x[0]}; end endcase end `V_MULTMODE_5X: begin - R_act = R_lbuf; - G_act = G_lbuf; - B_act = B_lbuf; + R_act = R_5x; + G_act = G_5x; + B_act = B_5x; HSYNC_act = HSYNC_5x; VSYNC_act = VSYNC_1x; - DE_act = (h_enable_5x & v_enable_5x); + DE_act = DE_5x; lines_out = lines_5x; - slid_act = line_out_idx_5x; + line_id_act = {2'b00, line_out_idx_5x}; vcnt_act = vcnt_5x_ref; linebuf_rdclock = pclk_5x; pclk_act = pclk_5x; hcnt_act = hcnt_5x; case (H_MULTMODE) `H_MULTMODE_FULLWIDTH: begin - linebuf_hoffset = hcnt_5x; + linebuf_hoffset = hcnt_5x_hscomp; + col_id_act = {2'b00, hcnt_5x[0]}; end `H_MULTMODE_OPTIMIZED: begin linebuf_hoffset = hcnt_5x_opt; + col_id_act = hcnt_5x_opt_ctr; end default: begin - linebuf_hoffset = hcnt_5x; + linebuf_hoffset = hcnt_5x_hscomp; + col_id_act = {2'b00, hcnt_5x[0]}; end endcase end @@ -332,20 +356,22 @@ begin R_act = R_1x; G_act = G_1x; B_act = B_1x; - DE_act = (h_enable_1x & v_enable_1x); + DE_act = DE_1x; HSYNC_act = HSYNC_1x; VSYNC_act = VSYNC_1x; lines_out = lines_1x; linebuf_rdclock = 0; linebuf_hoffset = 0; pclk_act = pclk_1x; - slid_act = {1'b0, vcnt_1x[0]}; + line_id_act = {2'b00, vcnt_1x[0]}; + col_id_act = {2'b00, hcnt_1x[0]}; hcnt_act = hcnt_1x; vcnt_act = vcnt_1x; end endcase end +//TODO: use single PLL and ALTPLL_RECONFIG pll_2x pll_linedouble ( .areset ( (V_MULTMODE != `V_MULTMODE_2X) & (V_MULTMODE != `V_MULTMODE_5X) ), .inclk0 ( PCLK_in ), @@ -384,41 +410,28 @@ begin HSYNC_pp1 <= 1'b0; VSYNC_pp1 <= 1'b0; DE_pp1 <= 1'b0; - R_pp2 <= 8'h00; - G_pp2 <= 8'h00; - B_pp2 <= 8'h00; - HSYNC_pp2 <= 1'b0; - VSYNC_pp2 <= 1'b0; - DE_pp2 <= 1'b0; R_out <= 8'h00; G_out <= 8'h00; - G_out <= 8'h00; + B_out <= 8'h00; HSYNC_out <= 1'b0; VSYNC_out <= 1'b0; DE_out <= 1'b0; end else begin - R_pp1 <= R_act; - G_pp1 <= G_act; - B_pp1 <= B_act; + R_pp1 <= apply_scanlines(V_SCANLINEMODE, R_act, H_SCANLINESTR, V_SCANLINEID, line_id_act, col_id_act, FID_1x); + G_pp1 <= apply_scanlines(V_SCANLINEMODE, G_act, H_SCANLINESTR, V_SCANLINEID, line_id_act, col_id_act, FID_1x); + B_pp1 <= apply_scanlines(V_SCANLINEMODE, B_act, H_SCANLINESTR, V_SCANLINEID, line_id_act, col_id_act, FID_1x); HSYNC_pp1 <= HSYNC_act; VSYNC_pp1 <= VSYNC_act; DE_pp1 <= DE_act; - R_pp2 <= apply_scanlines(V_SCANLINEMODE, R_pp1, H_SCANLINESTR, V_SCANLINEID, slid_act, hcnt_act[0], FID_1x); - G_pp2 <= apply_scanlines(V_SCANLINEMODE, G_pp1, H_SCANLINESTR, V_SCANLINEID, slid_act, hcnt_act[0], FID_1x); - B_pp2 <= apply_scanlines(V_SCANLINEMODE, B_pp1, H_SCANLINESTR, V_SCANLINEID, slid_act, hcnt_act[0], FID_1x); - HSYNC_pp2 <= HSYNC_act; - VSYNC_pp2 <= VSYNC_act; - DE_pp2 <= DE_act; - - R_out <= apply_mask(1, R_pp2, hcnt_act, H_BACKPORCH+H_MASK+2'h2, H_BACKPORCH+H_ACTIVE-H_MASK+2'h2, vcnt_act, V_BACKPORCH+V_MASK, V_BACKPORCH+V_ACTIVE-V_MASK); - G_out <= apply_mask(1, G_pp2, hcnt_act, H_BACKPORCH+H_MASK+2'h2, H_BACKPORCH+H_ACTIVE-H_MASK+2'h2, vcnt_act, V_BACKPORCH+V_MASK, V_BACKPORCH+V_ACTIVE-V_MASK); - B_out <= apply_mask(1, B_pp2, hcnt_act, H_BACKPORCH+H_MASK+2'h2, H_BACKPORCH+H_ACTIVE-H_MASK+2'h2, vcnt_act, V_BACKPORCH+V_MASK, V_BACKPORCH+V_ACTIVE-V_MASK); - HSYNC_out <= HSYNC_pp2; - VSYNC_out <= VSYNC_pp2; - DE_out <= DE_pp2; + R_out <= apply_mask(1, R_pp1, H_MASK_BR, hcnt_act, H_BACKPORCH+H_MASK+2'h2, H_BACKPORCH+H_ACTIVE-H_MASK+2'h2, vcnt_act, V_BACKPORCH+V_MASK, V_BACKPORCH+V_ACTIVE-V_MASK); + G_out <= apply_mask(1, G_pp1, H_MASK_BR, hcnt_act, H_BACKPORCH+H_MASK+2'h2, H_BACKPORCH+H_ACTIVE-H_MASK+2'h2, vcnt_act, V_BACKPORCH+V_MASK, V_BACKPORCH+V_ACTIVE-V_MASK); + B_out <= apply_mask(1, B_pp1, H_MASK_BR, hcnt_act, H_BACKPORCH+H_MASK+2'h2, H_BACKPORCH+H_ACTIVE-H_MASK+2'h2, vcnt_act, V_BACKPORCH+V_MASK, V_BACKPORCH+V_ACTIVE-V_MASK); + HSYNC_out <= HSYNC_pp1; + VSYNC_out <= VSYNC_pp1; + DE_out <= DE_pp1; end end @@ -482,6 +495,7 @@ begin H_OPT_SAMPLE_MULT <= 0; H_OPT_SAMPLE_SEL <= 0; H_OPT_SCALE <= 0; + H_L5BORDER <= 0; H_MASK_BR <= 0; prev_hs <= 0; prev_vs <= 0; @@ -491,8 +505,7 @@ begin B_1x <= 8'h00; HSYNC_1x <= 0; VSYNC_1x <= 0; - h_enable_1x <= 0; - v_enable_1x <= 0; + DE_1x <= 0; FID_1x <= 0; end else @@ -542,13 +555,19 @@ begin H_SCANLINESTR <= ((h_info2[22:19]+8'h01)<<4)-1'b1; V_SCANLINEMODE <= v_info[31:30]; - V_SCANLINEID <= v_info[29:28]; + case (v_info[26:24]) + `V_MULTMODE_1X, `V_MULTMODE_2X: V_SCANLINEID <= (5'b00001 << v_info[28]); + `V_MULTMODE_3X: V_SCANLINEID <= (5'b00001 << {v_info[28], 1'b0}); + `V_MULTMODE_4X: V_SCANLINEID <= (5'b00011 << {v_info[28], 1'b0}); + `V_MULTMODE_5X: V_SCANLINEID <= (5'b00011 << {2{v_info[28]}}); + endcase H_OPT_STARTOFF <= h_info2[9:0]; H_OPT_SAMPLE_MULT <= h_info2[12:10]; H_OPT_SAMPLE_SEL <= h_info2[15:13]; H_OPT_SCALE <= h_info2[18:16]; H_MASK_BR <= h_info2[26:23]; + H_L5BORDER <= h_info2[27] ? (1920-h_info[19:9])/2 : (1600-h_info[19:9])/2; end prev_hs <= HSYNC_in; @@ -557,7 +576,11 @@ begin // record start position of HSYNC if (`HSYNC_LEADING_EDGE) HSYNC_start <= hcnt_1x; - + + // Check if extra vsync needed + fpga_vsyncgen[`VSYNCGEN_GENMID_BIT] <= (lines_1x > ({1'b0, V_ACTIVE} << 1)) ? 1'b1 : 1'b0; + + R_1x <= R_in; G_1x <= G_in; B_1x <= B_in; @@ -566,12 +589,8 @@ begin // Ignore possible invalid vsyncs generated by TVP7002 if (vcnt_1x > V_ACTIVE) VSYNC_1x <= VSYNC_in; - - // Check if extra vsync needed - fpga_vsyncgen[`VSYNCGEN_GENMID_BIT] <= (lines_1x > ({1'b0, V_ACTIVE} << 1)) ? 1'b1 : 1'b0; - h_enable_1x <= ((hcnt_1x >= H_BACKPORCH) & (hcnt_1x < H_BACKPORCH + H_ACTIVE)); - v_enable_1x <= ((vcnt_1x >= V_BACKPORCH) & (vcnt_1x < V_BACKPORCH + V_ACTIVE)); //- FID_in ??? + DE_1x <= ((hcnt_1x >= H_BACKPORCH) & (hcnt_1x < H_BACKPORCH + H_ACTIVE)) & ((vcnt_1x >= V_BACKPORCH) & (vcnt_1x < V_BACKPORCH + V_ACTIVE)); end end @@ -582,12 +601,17 @@ begin begin hcnt_2x <= 0; vcnt_2x <= 0; + vcnt_2x_ref <= 0; lines_2x <= 0; + R_2x <= 8'h00; + G_2x <= 8'h00; + B_2x <= 8'h00; HSYNC_2x <= 0; VSYNC_2x <= 0; - h_enable_2x <= 0; - v_enable_2x <= 0; + DE_2x <= 0; line_out_idx_2x <= 0; + hcnt_2x_opt <= 0; + hcnt_2x_opt_ctr <= 0; end else begin @@ -595,32 +619,53 @@ begin begin hcnt_2x <= 0; line_out_idx_2x <= 0; + hcnt_2x_opt <= H_OPT_SAMPLE_SEL; + hcnt_2x_opt_ctr <= 0; end - else if (hcnt_2x == hmax[~line_idx]) //line_idx_prev? + else if (hcnt_2x == hmax[~line_idx]) begin hcnt_2x <= 0; line_out_idx_2x <= line_out_idx_2x + 1'b1; + hcnt_2x_opt <= H_OPT_SAMPLE_SEL; + hcnt_2x_opt_ctr <= 0; end else - hcnt_2x <= hcnt_2x + 1'b1; - - if ((pclk_1x == 1'b0) & (fpga_vsyncgen[`VSYNCGEN_GENMID_BIT] == 1'b1)) begin - if (`VSYNC_TRAILING_EDGE) - vcnt_2x <= 0; - else if (vcnt_2x == lines_1x) + hcnt_2x <= hcnt_2x + 1'b1; + if (hcnt_2x >= H_OPT_STARTOFF) begin - vcnt_2x <= 0; - lines_2x <= vcnt_2x; + if (hcnt_2x_opt_ctr == H_OPT_SCALE-1'b1) + begin + hcnt_2x_opt <= hcnt_2x_opt + H_OPT_SAMPLE_MULT; + hcnt_2x_opt_ctr <= 0; + end + else + hcnt_2x_opt_ctr <= hcnt_2x_opt_ctr + 1'b1; end end - else if ((pclk_1x == 1'b0) & `VSYNC_TRAILING_EDGE & !(`FALSE_FIELD)) //aligned with posedge of pclk_1x + + if ((pclk_1x == 1'b0) & `VSYNC_TRAILING_EDGE & !(`FALSE_FIELD)) //aligned with posedge of pclk_1x begin vcnt_2x <= 0; - lines_2x <= vcnt_2x; + vcnt_2x_ref <= 0; + if (fpga_vsyncgen[`VSYNCGEN_GENMID_BIT] == 1'b0) + lines_2x <= vcnt_2x; end else if (hcnt_2x == hmax[~line_idx]) - vcnt_2x <= vcnt_2x + 1'b1; + begin + if ((fpga_vsyncgen[`VSYNCGEN_GENMID_BIT] == 1'b1) & (vcnt_2x == lines_1x-1)) + begin + vcnt_2x <= 0; + vcnt_2x_ref <= 0; + lines_2x <= lines_1x; + end + else + begin + vcnt_2x <= vcnt_2x + 1'b1; + if (line_out_idx_2x == 1) + vcnt_2x_ref <= vcnt_2x_ref + 1'b1; + end + end if (pclk_1x == 1'b0) begin @@ -630,10 +675,12 @@ begin VSYNC_2x <= VSYNC_in; end + + R_2x <= R_lbuf; + G_2x <= G_lbuf; + B_2x <= B_lbuf; HSYNC_2x <= ~(hcnt_2x >= HSYNC_start); - - h_enable_2x <= ((hcnt_2x >= H_BACKPORCH) & (hcnt_2x < H_BACKPORCH + H_ACTIVE)); - v_enable_2x <= ((vcnt_2x >= (V_BACKPORCH<<1)) & (vcnt_2x < ((V_BACKPORCH + V_ACTIVE)<<1))); + DE_2x <= ((hcnt_2x >= H_BACKPORCH) & (hcnt_2x < H_BACKPORCH + H_ACTIVE)) & ((vcnt_2x >= (V_BACKPORCH<<1)) & (vcnt_2x < ((V_BACKPORCH + V_ACTIVE)<<1))); end end @@ -645,9 +692,11 @@ begin vcnt_3x <= 0; vcnt_3x_ref <= 0; lines_3x <= 0; + R_3x <= 8'h00; + G_3x <= 8'h00; + B_3x <= 8'h00; HSYNC_3x <= 0; - h_enable_3x <= 0; - v_enable_3x <= 0; + DE_3x <= 0; pclk_3x_cnt <= 0; pclk_1x_prev3x <= 0; line_out_idx_3x <= 0; @@ -663,7 +712,7 @@ begin hcnt_3x_opt <= H_OPT_SAMPLE_SEL; hcnt_3x_opt_ctr <= 0; end - else if (hcnt_3x == hmax[~line_idx]) //line_idx_prev? + else if (hcnt_3x == hmax[~line_idx]) begin hcnt_3x <= 0; line_out_idx_3x <= line_out_idx_3x + 1'b1; @@ -698,11 +747,6 @@ begin vcnt_3x_ref <= vcnt_3x_ref + 1'b1; end - HSYNC_3x <= ~(hcnt_3x >= HSYNC_start); - //TODO: VSYNC_3x - h_enable_3x <= ((hcnt_3x >= H_BACKPORCH) & (hcnt_3x < H_BACKPORCH + H_ACTIVE)); - v_enable_3x <= ((vcnt_3x_ref >= V_BACKPORCH) & (vcnt_3x_ref < V_BACKPORCH + V_ACTIVE)); - //track pclk_3x alignment to pclk_1x rising edge (pclk_1x=1 @ 120deg & pclk_1x=0 @ 240deg) if (((pclk_1x_prev3x == 1'b1) & (pclk_1x == 1'b0)) | (pclk_3x_cnt == 2'h2)) pclk_3x_cnt <= 0; @@ -710,6 +754,14 @@ begin pclk_3x_cnt <= pclk_3x_cnt + 1'b1; pclk_1x_prev3x <= pclk_1x; + + + R_3x <= R_lbuf; + G_3x <= G_lbuf; + B_3x <= B_lbuf; + HSYNC_3x <= ~(hcnt_3x >= HSYNC_start); + //TODO: VSYNC_3x + DE_3x <= ((hcnt_3x >= H_BACKPORCH) & (hcnt_3x < H_BACKPORCH + H_ACTIVE)) & ((vcnt_3x_ref >= V_BACKPORCH) & (vcnt_3x_ref < V_BACKPORCH + V_ACTIVE)); end end @@ -718,14 +770,16 @@ begin if (!reset_n) begin hcnt_4x_aspfix <= 0; - h_enable_3x_prev4x <= 0; + DE_3x_prev4x <= 0; hcnt_4x <= 0; vcnt_4x <= 0; vcnt_4x_ref <= 0; lines_4x <= 0; + R_4x <= 8'h00; + G_4x <= 8'h00; + B_4x <= 8'h00; HSYNC_4x <= 0; - h_enable_4x <= 0; - v_enable_4x <= 0; + DE_4x <= 0; pclk_4x_cnt <= 0; pclk_1x_prev4x <= 0; line_out_idx_4x <= 0; @@ -734,13 +788,13 @@ begin end else begin - // Can we sync reliably to h_enable_3x??? - if ((h_enable_3x == 1) & (h_enable_3x_prev4x == 0)) + // TODO: better implementation + if ((DE_3x == 1) & (DE_3x_prev4x == 0)) hcnt_4x_aspfix <= hcnt_3x - 160; else hcnt_4x_aspfix <= hcnt_4x_aspfix + 1'b1; - h_enable_3x_prev4x <= h_enable_3x; + DE_3x_prev4x <= DE_3x; if ((pclk_4x_cnt == 0) & `HSYNC_TRAILING_EDGE) //aligned with posedge of pclk_1x @@ -750,7 +804,7 @@ begin hcnt_4x_opt <= H_OPT_SAMPLE_SEL; hcnt_4x_opt_ctr <= 0; end - else if (hcnt_4x == hmax[~line_idx]) //line_idx_prev? + else if (hcnt_4x == hmax[~line_idx]) begin hcnt_4x <= 0; line_out_idx_4x <= line_out_idx_4x + 1'b1; @@ -785,11 +839,6 @@ begin vcnt_4x_ref <= vcnt_4x_ref + 1'b1; end - HSYNC_4x <= ~(hcnt_4x >= HSYNC_start); - //TODO: VSYNC_4x - h_enable_4x <= ((hcnt_4x >= H_BACKPORCH) & (hcnt_4x < H_BACKPORCH + H_ACTIVE)); - v_enable_4x <= ((vcnt_4x_ref >= V_BACKPORCH) & (vcnt_4x_ref < V_BACKPORCH + V_ACTIVE)); - //track pclk_4x alignment to pclk_1x rising edge (pclk_1x=1 @ 180deg & pclk_1x=0 @ 270deg) if (((pclk_1x_prev4x == 1'b1) & (pclk_1x == 1'b0)) | (pclk_4x_cnt == 2'h3)) pclk_4x_cnt <= 0; @@ -797,6 +846,14 @@ begin pclk_4x_cnt <= pclk_4x_cnt + 1'b1; pclk_1x_prev4x <= pclk_1x; + + + R_4x <= R_lbuf; + G_4x <= G_lbuf; + B_4x <= B_lbuf; + HSYNC_4x <= ~(hcnt_4x >= HSYNC_start); + //TODO: VSYNC_4x + DE_4x <= ((hcnt_4x >= H_BACKPORCH) & (hcnt_4x < H_BACKPORCH + H_ACTIVE)) & ((vcnt_4x_ref >= V_BACKPORCH) & (vcnt_4x_ref < V_BACKPORCH + V_ACTIVE)); end end @@ -808,15 +865,18 @@ begin vcnt_5x <= 0; vcnt_5x_ref <= 0; lines_5x <= 0; + R_5x <= 8'h00; + G_5x <= 8'h00; + B_5x <= 8'h00; HSYNC_5x <= 0; - h_enable_5x <= 0; - v_enable_5x <= 0; + DE_5x <= 0; pclk_5x_cnt <= 0; pclk_1x_prev5x <= 0; pclk_1x_prevprev5x <= 0; line_out_idx_5x <= 0; hcnt_5x_opt <= 0; hcnt_5x_opt_ctr <= 0; + hcnt_5x_hscomp <= 0; end else begin @@ -824,14 +884,14 @@ begin begin hcnt_5x <= 0; line_out_idx_5x <= 0; - hcnt_5x_opt <= H_OPT_SAMPLE_SEL; + hcnt_5x_opt <= 120 + H_OPT_SAMPLE_SEL; hcnt_5x_opt_ctr <= 0; end - else if (hcnt_5x == hmax[~line_idx]) //line_idx_prev? + else if (hcnt_5x == hmax[~line_idx]) begin hcnt_5x <= 0; line_out_idx_5x <= line_out_idx_5x + 1'b1; - hcnt_5x_opt <= H_OPT_SAMPLE_SEL; + hcnt_5x_opt <= 120 + H_OPT_SAMPLE_SEL; hcnt_5x_opt_ctr <= 0; end else @@ -862,11 +922,6 @@ begin vcnt_5x_ref <= vcnt_5x_ref + 1'b1; end - HSYNC_5x <= ~(hcnt_5x >= HSYNC_start); - //TODO: VSYNC_5x - h_enable_5x <= ((hcnt_5x >= H_BACKPORCH-96) & (hcnt_5x < H_BACKPORCH + H_ACTIVE + 96)); - v_enable_5x <= ((vcnt_5x_ref >= V_BACKPORCH) & (vcnt_5x_ref < V_BACKPORCH + V_ACTIVE)); - //track pclk_5x alignment to pclk_1x rising edge (pclk_1x=1 @ 144deg & pclk_1x=0 @ 216deg & pclk_1x=0 @ 288deg) if (((pclk_1x_prevprev5x == 1'b1) & (pclk_1x_prev5x == 1'b0)) | (pclk_5x_cnt == 3'h4)) pclk_5x_cnt <= 0; @@ -875,6 +930,16 @@ begin pclk_1x_prev5x <= pclk_1x; pclk_1x_prevprev5x <= pclk_1x_prev5x; + + hcnt_5x_hscomp <= hcnt_5x + 121; + + + R_5x <= R_lbuf; + G_5x <= G_lbuf; + B_5x <= B_lbuf; + HSYNC_5x <= ~(hcnt_5x >= HSYNC_start); + //TODO: VSYNC_5x + DE_5x <= ((hcnt_5x >= H_BACKPORCH - H_L5BORDER) & (hcnt_5x < H_BACKPORCH + H_ACTIVE + H_L5BORDER)) & ((vcnt_5x_ref >= V_BACKPORCH) & (vcnt_5x_ref < V_BACKPORCH + V_ACTIVE)); end end diff --git a/software/sys_controller/mem_init/sys_onchip_memory2_0.hex b/software/sys_controller/mem_init/sys_onchip_memory2_0.hex index c2ed017..8456e5f 100644 --- a/software/sys_controller/mem_init/sys_onchip_memory2_0.hex +++ b/software/sys_controller/mem_init/sys_onchip_memory2_0.hex @@ -1,7 +1,7 @@ :020000020000FC :2000000000402074084008140800683A0000000000000000000000000000000000000000FE -:2000080006C02074DEE8001406802074D6BE84140080207410A0701400C0207418E1851430 -:2000100010C00326100000151080010410FFFD360815C8000815D600003FFF06DEFFFB04E3 +:2000080006C02074DEE8001406802074D6BF17140080207410A1151400C0207418E2321448 +:2000100010C00326100000151080010410FFFD360815DFC00815EDC0003FFF06DEFFFB0435 :2000180000BFE084D880000500800084D880004500800344D8800085DFC0041529403FCCD7 :200020000080004428800426008000842880041E008014040000030600800C040000010624 :2000280000800404D88000C5D88000C331803FCC10800094D88000C5300002260080080417 @@ -10,20 +10,20 @@ :20004000D8000205D8000245D8000285D80002C5D8000305D8000345D8000385D80003C5A4 :2000480008104640DFC00417DEC00504F800283ADEFFFC04DC000015040020B484041804F5 :20005000DC80021504801304DC400115900B883A2023883A000D883A8009883ADFC003151D -:2000580008164CC089403FCC8009883A000D883A0816530004400044900B883A8009883ACF -:20006000880D883A08164CC0880B883A8009883ADFC00317DC800217DC400117DC0000170A -:20006800DEC0040408165041DEFFFC04DC000015040020B484041804DC800215DC40011534 -:200070002025883A2823883A8009883A000D883A01401304DFC0031508164CC091403FCC2D -:200078008009883A000D883A081653000180004489403FCC8009883ADFC00317DC800217CB -:20008000DC400117DC000017DEC0040408165301DEFFFF0421003FCCDFC000150810130036 +:200058000816648089403FCC8009883A000D883A08166AC004400044900B883A8009883A20 +:20006000880D883A08166480880B883A8009883ADFC00317DC800217DC400117DC00001732 +:20006800DEC0040408166801DEFFFC04DC000015040020B484041804DC800215DC4001155C +:200070002025883A2823883A8009883A000D883A01401304DFC003150816648091403FCC55 +:200078008009883A000D883A08166AC00180004489403FCC8009883ADFC00317DC800217F4 +:20008000DC400117DC000017DEC0040408166AC1DEFFFF0421003FCCDFC00015081013005F :20008800DFC00017DEC00104F800283ADEFFFF0429403FCC21003FCCDFC0001508101A80BF :200090000005883ADFC00017DEC00104F800283ADEFFFB04DCC00315DC800215DC400115A1 :20009800DC000015DFC004152825883A3027883A2023883A2821883A8485C83A14C0060E74 :2000A0008140000389003FCC8400004408101A808C400044003FF8060005883ADFC00417A0 :2000A800DCC00317DC800217DC400117DC000017DEC00504F800283ADEFFFF040140FA04C6 -:2000B000DFC0001508153B401009883ADFC00017DEC001040815D8C1DEFFFF04000B883A4D +:2000B000DFC00015081553001009883ADFC00017DEC001040815F081DEFFFF04000B883A9D :2000B800010003C4DFC00015081022C0000B883A01001844DFC00017DEC00104081022C134 -:2000C000DEFFFD04DC000015040020B4842084048140008301000144DFC00215DC400115DB +:2000C000DEFFFD04DC000015040020B4842129048140008301000144DFC00215DC40011535 :2000C800081022C0808000838100030300FFFEC41004D1FA20C6703A044001041085883A44 :2000D0001085883A1884B03A01400F448809883A80800305081022C00100004408102B8042 :2000D8008809883A01400744081022C001400C0401001844081022C001402C84010002444F @@ -47,7 +47,7 @@ :20016800010003C4DFC00215DC400115081022C0044030448809883A0810210084003FCCFA :20017000800AC03A10803F8C8809883A114AB03A081022C0014000C401003184DFC002178B :20017800DC400117DC000017DEC00304081022C1DEFFF904DCC00315DC800215DC4001156D -:200180002025883A2823883A010001040140074404C020B49CE08404DD000415DC00001536 +:200180002025883A2823883A010001040140074404C020B49CE12904DD000415DC00001590 :20018800DFC006153821883ADD4005153029883A081022C098C0030381C0004C00BFFF4449 :200190001884703A39CF883A11CEB03A99C00305988003171080008C10000226010000444A :200198000810590001001C049C0000C308102100108000CC8D4000CC00C00044100B883A47 @@ -66,11 +66,11 @@ :20020000081021001140054C01000104081022C00400190401000384081021001080040C81 :200208001000321E0100004408102B8080BFFFC41021883A10BFFFCC103FF61E00002B064B :20021000053FE8048C400C0C008008048880081E018000C4D16000C401001CC408102500A8 -:200218000140207401800484295CEB840000090600800C0488800B1E018000C4D16000C4EA -:2002200001001CC4081025000140207401800484295CE28401001D84081025000400008470 +:200218000140207401800484295D6C840000090600800C0488800B1E018000C4D16000C468 +:2002200001001CC4081025000140207401800484295D638401001D840810250004000084EE :20022800003FA306008004048880081E018000C4D160000401001CC40810250001402074AB -:2002300001800484295CDE04003FF206018000C4D160000401001CC408102500014020749A -:2002380001800484295CE704003FEA06000B883A01000304081022C0014010040100034492 +:2002300001800484295D5F04003FF206018000C4D160000401001CC4081025000140207418 +:2002380001800484295D6804003FEA06000B883A01000304081022C0014010040100034410 :20024000081022C00140004401000384081022C0000B883A01000384081022C008102D8089 :2002480000800044DFC00617DD400517DD000417DCC00317DC800217DC400117DC00001793 :20025000DEC00704F800283ADEFFFD04DC0000152021883A01001644DC400115DFC0021576 @@ -78,867 +78,867 @@ :2002600001400044010003C4081022C0800B883A00000906802091BA0100164481400414BC :20026800114AB03A081022C001400044010003C4081022C0000B883A01001704081022C00D :20027000000B883A010003C4DFC00217DC400117DC000017DEC00304081022C10080207446 -:20027800109E4D0410C03217D0A1ED151800042610803517108040180085C83AF800283AF4 -:2002800000BFFFC4F800283ADEFFFD04DC400115280F883A2823883A200B883AD121ED1789 -:20028800DC000015DFC002153021883A0816228010000B1E800D883A8463883A344006260B +:20027800109EE00410C03217D0A1FF151800042610803517108040180085C83AF800283A4F +:2002800000BFFFC4F800283ADEFFFD04DC400115280F883A2823883A200B883AD121FF1777 +:20028800DC000015DFC002153021883A08163A4010000B1E800D883A8463883A3440062633 :20029000308000031005C2721005D63A3180004430BFFFC5003FF9060005883A0000010679 :2002980000BFFFC4DFC00217DC400117DC000017DEC00304F800283ADEFFFA04DC80031597 :2002A000DC400215DC000115DFC00515DCC0041530803FCC2023883A2825883A3021883AC9 -:2002A800100003268805883A8C89883A00001706300A923AD121ED170815F1C01027883AF7 -:2002B000103FF82601402074010020B4018004442959B90421208B04081554C001802074F9 -:2002B800010020B4980F883A3199BC040140044421208B0408154340008020B410A093844A +:2002A800100003268805883A8C89883A00001706300A923AD121FF17081609801027883A0C +:2002B000103FF82601402074010020B401800444295A18042121300408156C80018020741B +:2002B800010020B4980F883A319A1B04014004442121300408155B00008020B410A13884C6 :2002C0001000000500FFCE0400001D061100062610C000031807C2721807D63A10800044AF -:2002C80010FFFFC5003FF906800AD23A800C923AD121ED17280A943ADC800015880F883A57 -:2002D0000815FB000007883A10000D2601402074010020B4018004442959BF0421208B0462 -:2002D800081554C001402074010020B4018004442959C20421209384081554C000FFCDC401 +:2002C80010FFFFC5003FF906800AD23A800C923AD121FF17280A943ADC800015880F883A45 +:2002D000081612C00007883A10000D2601402074010020B401800444295A1E042121300484 +:2002D80008156C8001402074010020B401800444295A21042121388408156C8000FFCDC44B :2002E0001805883ADFC00517DCC00417DC800317DC400217DC000117DEC00604F800283A0C :2002E800DEFFF904DD400515DD000415DCC00315DC800215DC000015DFC00615DC400115EB :2002F0002825883A3029883A3827883A0021883A0007883A0540400484800F2E9423C83A74 :2002F800AC40012E04404004980D883A880B883A8009883A0810A0801000141E800D003AFB -:20030000880B883A9809883A08163E401007883A84004004003FF0060005883A1D000C269D -:2003080001802074010020B43199C4040140044421208B0408154340008020B410A0938445 +:20030000880B883A9809883A081656001007883A84004004003FF0060005883A1D000C26C5 +:2003080001802074010020B4319A2304014004442121300408155B00008020B410A13884C1 :200310001000000500BFCD440000010600BFCD84DFC00617DD400517DD000417DCC003172E :20031800DC800217DC400117DC000017DEC00704F800283ADEFFFD04DC0001152021883A53 -:20032000010020B421208804DFC002150814DA8010803FCC10000B2601802074010020B429 -:200328003199C9040140044421208B0408154340008020B410A09384100000050080004431 -:200330000000090600808004010020B4D8800015000F883A000D883A800B883A212088049E -:200338000814FC4010803FCCDFC00217DC000117DEC00304F800283A014020B4010020B41D -:200340002960938421208B0408139741014020B4010020B42960A60421208F440813974116 +:20032000010020B421212D04DFC002150814F24010803FCC10000B2601802074010020B4AB +:20032800319A2804014004442121300408155B00008020B410A138841000000500800044AD +:200330000000090600808004010020B4D8800015000F883A000D883A800B883A21212D04F8 +:200338000815140010803FCCDFC00217DC000117DEC00304F800283A014020B4010020B444 +:2003400029613884212130040813A801014020B4010020B429614C04212134440813A801DB :20034800DEFFFE04DC0000152021883A01000044DFC001150810590008104240000B883AF0 :200350000009883A0810464084003FCC800F003A000D883A000B883A0100004408105F0074 :200358008000051E000F883A000D883A000B883A01000084081005C00009883ADFC0011791 :20036000DC000017DEC0020408105901DEFFFD04DFC00215DC400115DC00001521003FCC91 -:200368002000271ED0A1EF4300C0020410C01D2600C0040410C0062600C0010410C01C1E01 -:200370000009883A081428400100004400002E06040020B484209804814001170100673418 -:20037800213F300408152F8081000287014007041023883A08153B4000C020B418E0C4844E -:2003800010C5883A1140000B8809883A08153B4000C072B418F0DFC418800236010003C456 -:20038800000001060009883A08142840000015060009883A081428400009883A00001206B2 -:20039000008020B410A0AA4410C00603044000841021883A1C4002260009883A0000010671 -:20039800010003C4081428408100060320803FCC8880042E008001441109C83A21003FCC7D -:2003A00000000106010000C4DFC00217DC400117DC000017DEC003040813C641DEFFF704F3 -:2003A80000C020B4DFC00815DDC00715DD800615DD400515DD000415DCC00315DC80021560 -:2003B000DC400115DC0000150089C40418C4240419800037050020B4A50424043000020EFB -:2003B80010BFFFC4103FFA1E29403FCC21003FCC040020B408147AC0842098041025883A27 -:2003C000808002C310000326A44000378822D43A000001060023883A01000DC40813D4C0DF -:2003C80001000E041027883A0813D4C010C003CC1806923A1CE6B03A1006D1BA18C0004C20 -:2003D00080C00245A0C00037010000848C403FCC89000E26010020B421209804210002C33E -:2003D8002000021E010063C424C0082E010000448900041E9CC9883A18FFFFCC213FFF84A7 -:2003E00020C005361080080C100004269D00322805C00044000003061827883A9D006428D1 -:2003E800002F883A80C002C390803FCC1800101E10001E26A0001D26D0A1EE030100008480 -:2003F00010C03FCC18C0201C18FFE00420C0060E008020B400C0004410A09804D021EE0587 -:2003F80010C002C500000C061080004400000D0610000126A0000D1ED0A1EE0300FFFF04EF -:2004000011003FCC2100201C213FE00420C0040ED021EE05800002C50440010400000506AE -:2004080010BFFFC4D0A1EE0500000106D021EE050023883A01000E440813D4C001000E8479 -:20041000048020B4102D883A94A0AA440813D4C0A0007A26108003CC1004923A80C00017CE -:2004180015ACB03A008020B410A098041CC0051E10C00117B0C0031E10C00203B8803FCCE9 -:2004200018800226D021F24500000C06D0A1F24300C0004411003FCC20C0082610C5883A57 -:20042800D0A1F24510803FCC10C0041E88803FCC00C0008410C0012E1823883A9140020356 -:200430008100074300C020B4008020B418E0AA4410A098042900121E194002431100078335 -:2004380029000F1E19400283110007C329000C1E194002C3110008032900091E194001431B -:20044000110006832900061E19400183110006C32900031E18C001C31080070318800426BC -:2004480088803FCC00C0008410C0012E1823883A90C004438080098318801126008020B4FB -:2004500010A09804110002870140070408153B4000C020B418E0C6C410C5883A1080000382 -:2004580000C0004410BFFF0410803FCC1880043688803FCC00C0008410C0012E1823883AEE -:20046000D0A1F34310002A268500028701400704054020B4A009883A08153B40AD60C084AE -:20046800A885883A1080068B01400704A009883A1080008C1000052608153B40A885883ACF -:200470001500040BA529883A0000030608153B40A885883A1500040BA53FFFCCA00A913AE0 -:200478000100008429403C0C0813DCC0A00AD13A0100004429403FCC0813DCC08100028748 -:200480000140070408153B40A885883A814004031100058308153B4011403FCC010001C46E -:200488000813DCC088803FCC1000011E0440004484C000158580011585C00205914000033F -:200490008100054300C020B4008020B418E0AA4410A098042900151E1940004311000583D8 -:200498002900121E19400083110005C329000F1E194000C31100060329000C1E19400343B8 -:2004A000110008832900091E19400383110008C32900061E194003C3110009032900031EC2 -:2004A80018C00303108008431880032688803FCC1000011E0440004491000483808009C30C -:2004B00004C020B49CE098042080062699400403081432009880044588803FCC1000011EDF -:2004B800044000449100050380800A4320800126081442409100054380800A832080012624 -:2004C0000813F4009100058380800AC3208001260813F4C09100064380800B832080071E64 -:2004C800008020B410A0AA4410C00683008020B410A0980410800BC31880022691400683B1 -:2004D0000813F0C0910004C380800A03208006260140060408153B4001002074211C030454 -:2004D8002089883A081416C09100060380800B43208001260810D8C0910005C380800B03E1 -:2004E0002080012608142CC0014020B4010020B4018001842960A4442120B14408153DC07C -:2004E8001000031E010020B42120A4440813F580014020B4010020B4018008842960AA44C7 -:2004F00021209D44081540C08805883AD021F345DFC00817DDC00717DD800617DD40051709 -:2004F800DD000417DCC00317DC800217DC400117DC000017DEC00904F800283ADEFFF104C3 -:20050000DC400615044020B4DFC00E15DF000D15DDC00C15DD800B15DD400A15DD00091557 -:20050800DCC00815DC800715DC0005158C6098048C800303008000849080071E88800603C8 -:20051000100007268880058300C0004410C00626902D883A000005068D8006030000030655 -:20051800002D883A00000106102D883A88C00543008020B404C020B40100008410A0980481 -:200520009CE0C0841900031E140005838400004400000F060100004419000C1E1100028726 -:200528000140070408153B409885883A1080068B1080004C1000032690000426040000C438 -:20053000000003069020C03A000001060021883A88C0048B0080800418800F2610C0083658 -:200538000080100418800A260080200418800E1E008020B410A098041540084300000B068E -:200540000081000418800626008400041880061E054000C4000005060540010400000306A7 -:200548000540014400000106054000448980028788C00403014007043009883A1DC03FCC69 -:20055000D8C00215D980041508153B40988F883A3A40028BAD003FCCBD39C83A480B883A1D -:20055800E009883AD9C00315DA40011508153B40D98004171024D7FA014007043009883A9F -:200560009085883A1025D07A08153B409885883A11000503B80B883A08153B40E009883ACD -:20056800100B883AD880001508153B40B80B883A1009883A081520009085883AB80B883A98 -:20057000113FFFCC081520001039883A88800343DA400117DA000017100497BA480B883A1D -:20057800B809883A1210B03ADA00001508153B40DA0000171004927A89000883A9403FCC34 -:2005800040AEB03A08153B409085883A1024953A008020B410842C04BCA4B03A14800035E6 -:2005880089000903888005C3D8C00217200895FA100494FAA028943AE00B883A2084B03A13 -:20059000890004432008937A1108B03A88800403100492BA2084B03A19003FCC1528B03AFB -:2005980008153B4010BFFFCCA0A8B03A008020B4108420041500003588800303D9C00317C8 -:2005A000D98004171006963A888008C3014007043009883A100494BA802097BA1884B03AEE -:2005A80038C0054310E2B03A08153B409885883A1080030B100491FA8886B03AB004973AE6 -:2005B0001884B03A1420B03A008020B41084280414000035DFC00E17DF000D17DDC00C17A3 -:2005B800DD800B17DD400A17DD000917DCC00817DC800717DC400617DC000517DEC00F0452 -:2005C000F800283ADEFFF404DC000515040020B484209804DC400615844001170080004407 -:2005C800DFC00B15DD400A15DD000915DCC00815DC800715D0A1F2458800162684C0001725 -:2005D0009800142601006734880B883A213F300408152F801025883A8080020301283BF494 -:2005D800980B883A212EC0041000042608152F80880B883A1009883A0000030608152F8080 -:2005E000880B883A1089883A08152F801023883A000002060445DC04048F550401000EC49A -:2005E8000813D4C001000F041027883A0813D4C08080050300C0207418DA15041085883ACA -:2005F0001085883A1885883A11C000178080020380C000171000021E00801A4400000106DC -:2005F80000801C0401802074010020B4D8C000153199CD040140044421208F44D880011506 -:2006000008154340014019048809883A08152F800140FA049009883A1029883A08152F805C -:20060800014019048809883A102B883A081535C00140FA049009883AD8800215DD00011516 -:20061000081535C0014002841009883A08152F8001802074010020B4D8800015A80F883A7A -:200618003199CF04014004442120A60408154340D0A1F8831000011E0810D0C081000017B6 -:20062000D1E1F30381400203A00D883A044020B4081481C011003FCC2100201C213FE004AB -:2006280000FFFFC48C60980420C0011E00800104888002858480028301400704054020B467 -:20063000D4A1EF0594803FCC9480201C94BFE0049009883A08153B4000C020B418E0C084D8 -:200638001885883A14400603D0E1F30399003FCCAD60980488E2703AD461EF451140040B15 -:2006400008153B40814001171009883A08152F8080C0020389403FCCA98000171800011EF2 -:20064800300CD07A80C0040310803FCCD8800015D8C0041580C00AC3A1C03FCC9009883A38 -:20065000D8C0031580C00BC3D8C0021580C00B83D8C0011508144EC081000B430810D8C0F8 -:20065800810009C381400403081432008080044580800943810003831000041E008020B4FD -:2006600010A09804114003C300000106000B883A08109480DFC00B17DD400A17DD0009171B -:20066800DCC00817DC800717DC400617DC000517DEC00C0408113FC120803FCC00C003C413 -:2006700010C00E2600C0040410C0112600C002C4D121F1C310C0271EDEFFFE04DC00001586 -:20067800DFC00115081365401021883A10000F2601C0207439D9D70400000E06D0A1F1C33A -:2006800010C03FCC1800072610BFFFC400000506D0A1F1C30100020410C03FCC20C001367F -:2006880010800044D0A1F1C5F800283A01C0207439D9D50401802074010020B43199DA042B -:200690000140044421209384081543400810CF808000021E010003C408134940010002341F -:2006980021284804DFC00117DC000017DEC002040815D8C1200F883A01802074010020B4CE -:2006A0003199DB0401400444212093840815434120803FCC00C003C410C00E2600C0040411 -:2006A80010C0112600C002C4D121F1C310C0271EDEFFFE04DC000015DFC0011508134940C1 -:2006B0001021883A10000F2601C0207439D9DF0400000E06D0A1F1C310C03FCC180007264F -:2006B80010BFFFC400000506D0A1F1C30100020410C03FCC20C0013610800044D0A1F1C56C -:2006C000F800283A01C0207439D9DD0401802074010020B43199DA04014004442120938405 -:2006C800081543400810CF808000021E010003C4081349400100023421284804DFC001177C -:2006D000DC000017DEC002040815D8C1200F883A01802074010020B43199DB0401400444B0 -:2006D800212093840815434121003FCC008003C4208026260080040420802926DEFFFD0455 -:2006E000DC000015DFC00215040020B4DC400115008002C48420C0842080281ED461EF030E -:2006E80001400704D461F2058C403FCC8809883A08153B408085883A10C0040B01400704C6 -:2006F0008809883AD0E1F10D10C00583D0E1F38D10C0028BD0E1F08D10C0030BD0E1F00D48 -:2006F80010800503D0A1EE8D08153B408085883A10800543D0A1F28DDFC00217DC4001174B -:20070000DC000017DEC00304F800283AD0A1EF0310C03FCC1800072610BFFFC400000506C7 -:20070800D0A1EF030100068410C03FCC20C0013610800044D0A1EF05F800283AD121EF037A -:200710000140070408153B40010020B401800444808B883A21209384DFC00217DC40011736 -:20071800DC000017DEC00304081554C1DEFFFA04008020B4DD000415DCC00315DC800215AB -:20072000DC400115DC000015DFC0051510A0980410C002C3040020B42029883AD461F203EF -:200728008420C084D4E1EE8BD4A1F28B18001E261080028714401C1E8809883A0140070407 -:2007300008153B408085883A1100040BD0E1F10B20C0131E11000583D0E1F38B20C0101E96 -:200738001100028BD0E1F08B20C00D1E1100030BD0E1F00B20C00A1E10C0050398803FCCFE -:200740001880071E014007048809883A08153B408085883A10C0054390803FCC18800226EB -:2007480000800044D0A1F3458809883A0140070408153B40D0E1F10B8085883A8809883A26 -:2007500010C0040DD0E1F38B0140070410C00585D0E1F08B10C0028DD0E1F00B14C00505BE -:2007580010C0030D08153B4001802074010020B48085883AA1FFFFCC319AD40401400444C1 -:200760002120938414800545DFC00517DD000417DCC00317DC800217DC400117DC0000173E -:20076800DEC0060408154341DEFFFE04DC000015040020B4DFC00115840434040080044443 -:200770008080003580000035008020B410842C0410000035008020B41084280410000035C9 -:200778000109C4040815D8C000BFF444D0A1EF850080344480800035010000F42103500464 -:200780000815D8C0018001B401406734010020B43186A004297F3004210418040816458062 -:20078800081388C00813BEC0100022260009883A0813D4C000C03FC410C0202608143A0054 -:20079000010000840810210010803FCC00C004C410C01C1E0810300008109DC01021883AAE -:2007980010001A1E0812344001402074010020B401800D84295A76042120B304081540C09D -:2007A000010003C408136540D121F1C308136540008020B41084300410800037108000AC2C -:2007A8001000011E08123B400009883A0810D20000000706043FFF8400000506043FFF4454 -:2007B00000000306043FFF0400000106043FFFC48005883ADFC00117DC000017DEC0020438 -:2007B800F800283ADEFFFF04DFC00015081170400813EC00008020B410A0AA441100040359 -:2007C000DFC00017DEC001040810D201DEFFF504DFC00A15DF000915DDC00815DD80071511 -:2007C800DD400615DD000515DCC00415DC800315DC400215DC0001150811DA8010001B16E0 -:2007D0000080130401802074010020B4000F883A3199E2040140044421208F44D8800015FD -:2007D8000815434001402074010020B4018004442959EE042120A604081540C00810D0C0CA -:2007E0000100023421284804054020B40815D8C0AD60AA44A88006C30100024410C03FCC51 -:2007E80020C01136D0A1F18500000F0601802074010020B4100F883A3199E70401400444C5 -:2007F00021208F440815434001402074010020B401800444295AE3042120A604081554C03C -:2007F8000810D0C0003FFF06058020B405C02074070020740029883A0023883A0021883AF5 -:200800000025883AB5A09804BDDA1504E7082A0400C020B418C430041880003710FFFFCCE6 -:20080800D0E1F6150086303A1004D63A18C000ECD0E1F715D0A1F8051000062610FFFF8443 -:2008100018C03FCC010000C420C0022ED0E1F50310C0011ED021F615081255C0D0A1F88361 -:20081800100002260009883A0812FF40B0C00503D0A1F18304C020B49CE098041880011EA0 -:20082000D021F185D0E1F1830100020418BFFFC410803FCC20803836100490BA1705883AA6 -:20082800108000171000683A008120CC008120DC008120F4008121040081211400812128B2 -:20083000008121380081214800812160008003C4D0A1F3050023883A00000306008003C4FD -:20083800D0A1F30504400084040000440025883A00002306008003C4D0A1F305044000C45F -:20084000003FF906008003C4D0A1F305044000C400000306008003C4D0A1F3050440008421 -:200848000021883A003FF10600800404D0A1F3050440004400000D06008003C4D0A1F3053B -:200850000023883A0000090604400084008003C4D0A1F3058821883A8825883A0000080634 -:20085800008003C4D0A1F305044000C4040000848025883A0000020618803FCC10002C26CC -:2008600099400B4398C00505980002C528803FCC00C0004481003FCC1880042E00800144BE -:20086800114BC83A29403FCC00000106014000C40813CD000813E34089403FCC91003FCCFC -:200870000814674098800503010020B4018004441085883A1085883AB885883A11400017D2 -:2008780021208F4498000115081554C001402074010020B4018004442959EB042120A6049E -:20088000081554C0D0A1F8831000011E0810D0C0A5003FCCA0000526A8C006C300800284B2 -:200888001880021E010003C40813494005000044A900040398800943208006260810D20019 -:20089000008020B410A0AA4410800403B0000115B0800945A0803FCC1000322689403FCC14 -:2008980091003FCC0810E9C010803FCC00C0008410C0252600C0010410C0032600C0004427 -:2008A00010C0281E00002406988002C310000926D0A1EF8300C020B418C43404108000942D -:2008A800D0A1EF8510803FCC188000350811EE4000001C06B00001150813E340B08005033E -:2008B000010020B4018004441085883A1085883AB885883A1140001721208F44081554C030 -:2008B80001402074010020B4018004442959EB042120A604081554C0D0A1F8831000091EFD -:2008C0000810D0C000000706988002C3100005260811704000000306988002C31000012665 -:2008C80008113FC0D0A1F71701004B04D021F185D0A1F415D0A1F803D0A1F5050815D8C0BC -:2008D000003F330600C020B418E0AA4401402074DEFFFF041809883A01800884295A2004CA -:2008D800DFC00015081540C01007883A008020B41084300410800037014020741004D4BAFC -:2008E000010020B40180C4041080004C295C0F042120C08418800405081540C0008000445F -:2008E800D0A1F3450005883ADFC00017DEC00104F800283ADEFFF804DD000415DCC003154A -:2008F000DC80021505002074048020B404C020B4DD800615DC000015DFC00715DD40051591 -:2008F800DC400115002D883A0021883AA51A8404948430049CE0B30401402074010020B46C -:2009000001800444295A290421208B04081554C08405883A1085883AA085883A114000176C -:20090800010020B40180044421209384081554C00810CF800023883A05400084908000374C -:2009100010BFFFCCD0A1F61590C0003700C6303A18C000ECD0E1F71510001A26B0801926BA -:200918008407883A98C7883A88000A1E01402074010020B401800444295A2B0421208B04AC -:200920001880000D081554C00810CF800440004400000C0618C0000B10C009260140207429 -:20092800010020B401800444295A2D0421208B04081554C00810CF800023883A0000010609 -:2009300004400084D0A1F41710000F1ED0E1F7170080007418800C1E8000091E0140207435 -:20093800010020B401800D84295A76042120B304081540C004400084040006C40000020608 -:20094000843FFF8404400084D0A1F717D5A1F617D0A1F4158D4003260109C4040815D8C090 -:20094800003FC6068400004400800684143FB20E010003C4DFC00717DD800617DD40051767 -:20095000DD000417DCC00317DC800217DC400117DC000017DEC0080408134941D121F617EF -:20095800DEFFFA04014020B4DFC00515DCC00415DC800315DC400215DC0001150005883AC1 -:200960002960B304018006841087883A1947883A18C0000B040020B48420B3041900032659 -:200968001180CE2610800044003FF70600C006841880CA36100490BA00C0207418C97304EE -:2009700010C5883A108000171000683A008126380081265400812664008126400081265CA8 -:200978000081266C0081264C008128DC008126740081267C00812684008128DC008128DC61 -:20098000008128DC008128DC008128DC008128DC008126A800812720008127400081276C30 -:20098800008127B800812798008128DC008127E40081280C00812834008000440000010641 -:2009900000800084D0A1F1850000A406008000C4003FFC0600800104003FFA0600800144A4 -:20099800003FF80600800184003FF606008001C4003FF40600800204003FF20600800244C1 -:2009A000003FF006D0A1F8831007003AD0E1F8851000031E010000440812FF4000008F0633 -:2009A8000810D0C000008D06008020B410A09804110002870140070408153B4001C020B441 -:2009B00039E0C08401802074010020B4388F883A319A31040140044421208B04081543405E -:2009B800008020B41084240411C0003710800037018020741005D43A010020B439FFFFCC30 -:2009C000108000CC319A34040140044421209384D8800015081543400810CF8000006F06EE -:2009C800D0A1EF8300C020B418C434041080041CD0A1EF8510803FCC18800035000067061A -:2009D00000C020B418E0AA44188000030140004411003FCC290002361145883A00000106D1 -:2009D8000005883A1880000500005C0600C020B418E0AA44188000430140004411003FCC43 -:2009E000290002361145883A000001060005883A1880004500005106008020B410A0AA448A -:2009E80010C0008319003FCC2000012618FFFFC410C000850000490600C020B418E0AA4439 -:2009F000188000830140038411003FCC290002361080004400000106008003C41880008548 -:2009F80000003E0600C020B418E0AA44188004830140078411003FCC2900023610800044E5 -:200A000000000A060005883A0000080600C020B418E0AA441880048311003FCC20000226F4 -:200A080010BFFFC400000106008007C41880048500002A0601402074010020B40180044426 -:200A1000295A380421208B04081554C001402074010020B401800444295A3C042120938478 -:200A1800081554C0044020B40810CF808C443004048006C404C00244888000370009883AA8 -:200A200010BFFFCC2107883A1C07883A18C0000B10C003262100004424BFFA1E0000080603 -:200A280099000716014002842100004408152840010002C4D0A1F1C508119B80000005061A -:200A30008080060B110003260109C4040815D8C0003FE9060810D0C0D021F885D0A1F41714 -:200A38001000191ED0E1F7171880006C10000A26008020B410A098041080050301000244D5 -:200A400011403FCC29000226108000440000010600800044D0A1F18518C000AC18000A2697 -:200A480000C020B418E0AA44188000030140004411003FCC290002361145883A0000010658 -:200A50000005883A18800005DFC00517DCC00417DC800317DC400217DC000117DEC0060469 -:200A5800F800283ADEFF6C04D9000304DC008C15DFC09315DD809215DD409115DD009015EA -:200A6000DCC08F15DC808E15DC408D150810C7401021883A081514008000891E0180010489 -:200A6800D9400304D9008304081554C00140207401800104295A9F04D900830408154EC0B1 -:200A700010000B2601802074010020B4319AA1040140044421208B0408154340008020B47E -:200A780010A09384100000050400004400007406D8800403DC808484D9400484D88084057B -:200A8000D8800443018002049009883AD8808445081554C0D880068BD8008645D8808B0D07 -:200A8800D880070BD8808B8DD9408B17280BC232D880078BD9408715D8808B0DD880080B98 -:200A9000D8808B8DD8808B171005C232D8808815D880088BD8808B0DD880090BD8808B8D27 -:200A9800D8808B171005C232D8808915D8808217D8808B151005C232D8808A1500C07884A0 -:200AA00028BFF98418800B2E01802074010020B4319AA5040140044421208B0408154340AA -:200AA800008020B410A0938410000005043FFFC40000430601800044D900030408163E406E -:200AB000D8C08A1710C00A2601802074010020B4319AA9040140044421208B040815434092 -:200AB800008020B410A09384100000050000330601802074010020B4319AAD0401400444C6 -:200AC00021208B0408154340D9C0881701802074010020B4319AB104014004442120938423 -:200AC800081543400810CF80DCC08817DD4089170021883A0005883A0580800484C0132ED7 -:200AD0009C23C83AB440012E0440800485008004A00CD27A010020B4DC400015000F883A82 -:200AD800D9400304212088040814FC4010803FCC1000121E800D003A880B883AD9000304E2 -:200AE00008163E40A021883A003FEC06A880612601802074010020B4319AB4040140044401 -:200AE80021208B0408154340008020B410A0938410000005043FFF4400000106043FFF84FB -:200AF00004C000C4081514000810CF80010003F4211090040815D8C000BFCE4480804B0E2A -:200AF80098004A2601802074010020B4319ACA040140044421208B04081543409CFFFFC4FC -:200B000001402074010020B401800444295AC20421209384081554C00810CF800025883A42 -:200B08000580800405004004DC4088179440202E8CA3C83AB440012E044080049540800429 -:200B1000A80DD27A010020B4DC400015000F883AD9400304212088040814FC4014003FCC89 -:200B1800803FD81E9025D23A880B883AA440012E01404004900D883AD90003040810A780DC -:200B20001021883A103FCF1EA4400236A825883A003FE50691800044897FC004D900430470 -:200B28000810A7801021883A103FF826003FC50601402074010020B401800444295AC60444 -:200B300021208B04081554C001402074010020B401800444295AC20421209384081554C05F -:200B38000810CF80D9808917D9408817D9C003040009883A0810BA001021883A103FB11E37 -:200B4000081514000005883A0000430600BFFFC400004106D8808487D9C08403D8C08443A9 -:200B48001000032600802074109A69040000020600802074109AE30401802074010020B492 -:200B5000D8C00015319AB9040140044421208B04DC800215D88001150815434001402074A1 -:200B5800010020B401800444295ACE0421209384081540C0044020B4040020B40810CF80BE -:200B60008C4430048420B3048880003780C0000B10BFFFCC10C00E2680C0008B10C0091E2C -:200B680001402074010020B401800444295ABC0421208B04081554C004C000C404000084A6 -:200B7000003F80060109C4040815D8C0003FEE060813E340D0A1EF8300C020B418C434041D -:200B780010800094D0A1EF8510803FCC188000350109C4040815D8C001402074010020B4BB -:200B800001800444295ABF0421208B04081554C004C000C4003F7A06DFC09317DD809217AF -:200B8800DD409117DD009017DCC08F17DC808E17DC408D17DC008C17DEC09404F800283AF2 -:200B900021C03FCC01802074010020B4319AD304014004442120938408154341DEFFFF046B -:200B98000141194421003FCCDFC0001508153B40014019041009883A08152000018020749B -:200BA000010020B4100F883A319AD5040140044421209384DFC00017DEC001040815434100 -:200BA80021C03FCC01802074010020B4319AD704014004442120938408154341014003F4F7 -:200BB000DEFFFC042950900421003FCCDFC00315DC400215DC00011508153B40014018F44E -:200BB800294BA8041009883A1021883A08152F808009883A014659041023883A08152F80B3 -:200BC0000140FA041009883A081535C0014002841009883A08152F8001802074010020B491 -:200BC800D8800015880F883A319ADA04014004442120938408154340DFC00317DC4002172F -:200BD000DC000117DEC00404F800283ADEFFFF04014119C421003FCCDFC0001508153B409A -:200BD800014019041009883A0815200001802074010020B4100F883A319ADD040140044487 -:200BE00021209384DFC00017DEC001040815434121C03FCC01802074010020B4319ADF041F -:200BE80001400444212093840815434121003FCCDEFFFF0401409C4421000044DFC0001525 -:200BF00008153B40014019041009883A0815200001802074010020B4100F883A319AE2045B -:200BF8000140044421209384DFC00017DEC0010408154341D0A1F617DEFFF604018020B458 -:200C0000DCC00315DFC00915DF000815DDC00715DD800615DD400515DD000415DC80021596 -:200C0800DC400115DC00001504C002C431A0B304014004449CC7883A1987883A18C0000BA4 -:200C10001880041E21003FCC9823883A2000051E000003069CC00044997FF61E0000A5069E -:200C180010010026D561F84304802074949CF004AF003FCCE02090FA014005049405883AEF -:200C20001500010315C00017A5803FCCB009883A08153B40B8C00117010001041885883A77 -:200C280088FFFD0418C03FCC20C02936180690BA01002074210C31041907883A18C00017D2 -:200C30001800683A0081310C008130D8008130F00081320400813204B000011EBD00000305 -:200C3800A53FFFC49421883A8500010500008406B94000039421883AB10000448400010478 -:200C4000081528408080000500007D06E0000326AD7FFFC4D561F84500007906D021F8852F -:200C4800DFC00917DF000817DDC00717DD800617DD400517DD000417DCC00317DC8002173E -:200C5000DC400117DC000017DEC00A040810D0C110C00103014000C4194006261900631E10 -:200C580010800217044002C4103EE83A1021883A000064061080031710000226010002C453 -:200C6000103EE83AD461F843014005048C003FCC802690FA94C5883A1540001711000103E7 -:200C6800AD00011708153B40A085883A10C0021718004E2684000044802090FA00802074AD -:200C7000109CF0041405883A1100001719000126100001059421883A94E5883A9100010324 -:200C7800ACC001170140050408153B409885883A108002178C400044D461F84580800015D7 -:200C800000003A0610C00103010000841900202619000336010000C419002F260000380699 -:200C88001180021789C03FCC020003C41100030310C0034331400003108003833A000A1E6C -:200C900019C03FCC2A003FCC3A00022E28BFFFC40000030621003FCC2000011E1805883AC4 -:200C9800308000050000260611C03FCC2A003FCC41C0022E288000440000030621003FCCF8 -:200CA000200001261805883A30800005000010061100021789403FCC018003C420C0000B12 -:200CA8002980061E1080030B197FFFCC1140012E18FFFFC420C0000D000011061080038BE2 -:200CB000197FFFCC2880012E18C0004420C0000D0440040400000A0610800317100008269D -:200CB80099003FCC103EE83A00000506044002C40000030621003FCC200059260023883A3A -:200CC0000021883AD0A1F84300C0207418DCF004100490FA014005041885883A11000103ED -:200CC80014C0001708153B401025883A98800117010020B421208B041485883A11400017FA -:200CD00001800444081554C098800117010001041485883A10C0010320C03536180690BAF2 -:200CD80001002074210CDD041907883A18C000171800683A00813388008133B8008133C8AA -:200CE000008133D8008133EC10C00217110004170180044418C0000318C5883A1085883A19 -:200CE8002085883A11400017010020B421209384081554C000001E0610C002171080041707 -:200CF000190000030000070610C00217108004171900000B00000306108003171000062614 -:200CF8000009883A103EE83A000011068C403FCC00C002C488C00426008020B410A09384A0 -:200D00001000000500000A068000021E11C003170000010611C0041701802074010020B446 -:200D08003199DA04014004442120938408154340DFC00917DF000817DDC00717DD800617B0 -:200D1000DD400517DD000417DCC00317DC800217DC400117DC000017DEC00A040810CF812C -:200D1800103FA61EDFC00917DF000817DDC00717DD800617DD400517DD000417DCC00317CF -:200D2000DC800217DC400117DC000017DEC00A04F800283A21003FCC008003C411005F36F8 -:200D2800009114B4DEFFB6041094D544D88000150080107410951044D8800115008013048F -:200D3000D8800245208002B0DC004015DFC04915DF004815DDC04715DD804615DD40451520 -:200D3800DD004415DCC04315DC804215DC404115D8000205D8800285240004041000151E1F -:200D400000800E04D88002C5D0A1F1C3014020B401800D84D8800345008020B410A0980456 -:200D4800108005032960B304D90003C4D8000305D8800385081540C0800C923A0140114448 -:200D5000D809883A0810A7801004C03A0085C83A0000340600800404014020B4802A923ABF -:200D580001800884D88003452960AA44008000C4D90003C4070020B4D98002C5D800030598 -:200D6000D88003850025883A081540C0002F883A04400C440580C40405004004E720C08429 -:200D6800893FFFCCA10DC83AB0BFFFCCD909883AB97FFFCC94C03FCC11800C16E14B883A47 -:200D7000081540C0A463C83A9D4D883A01404004D809883A8DEF883AB5BFC0040810A780B4 -:200D7800948000440023883A003FED06100D883A008020B410A0C084114B883A081540C08A -:200D8000800C923A01404004D809883A34CD883A0810A7800005883A0000020600BFFFC480 -:200D8800F800283ADFC04917DF004817DDC04717DD804617DD404517DD004417DCC0431758 -:200D9000DC804217DC404117DC004017DEC04A04F800283ADEFFB704DFC04815DDC0471514 -:200D9800DD804615DD404515DD004415DCC04315DC804215DC404115DC00401521003FCC60 -:200DA000008003C41100022E047FFFC400006306240004048008943AD80D883A014040044E -:200DA8000810A080103FF81E0140207401800204295C0004D809883A08154EC01023883AE6 -:200DB0001000531ED88002031000531ED8C00243008013041880501ED88002831000032634 -:200DB80000C0004410C0162600004C06D8800303D8C002C31004923A10C4B03A00C00E048E -:200DC00010C0461ED880034300C0024411003FCC19000136D0A1F1C5D880038311003FCCAE -:200DC80019000136D0A1F185010020B401800D84D94003C42120B304081540C000003706BB -:200DD000D8800317D8C002C311803FCC300C923A30CCB03A00C0088430C0301E1004D23A00 -:200DD80000C0C4041025883A10BFFFCC10C02B1E010020B48020923AD94003C42120AA4479 -:200DE00005C020B4081540C00027883A002D883A05400C4405004004BDE0C084A97FFFCCB3 -:200DE800A14DC83A90BFFFCCB13FFFCCD94B883A11800F16B909883A081540C0990000440C -:200DF0002027883A21003FCC2409883A2008923AA56BC83AD80D883A01404004ADAD883A71 -:200DF80094BFC0040810A080002B883A003FEB06100D883A008020B410A0C0841109883A6C -:200E0000081540C000800044D0A1F345000003060440004400000106044000848805883A99 -:200E0800DFC04817DDC04717DD804617DD404517DD004417DCC04317DC804217DC40411747 -:200E1000DC004017DEC04904F800283ADEFFFD04D9000005010020B4DC0001150180004402 -:200E18002821883A21041804D80B883ADFC0021508165AC0813FFFCC0815D8C0DFC00217E3 -:200E2000DC000117DEC00304F800283AD0E1EF83DEFFFC0400BFE7C41884703ADC400115DD -:200E2800044020B4D0A1EF85DFC00315DC800215DC00001510803FCC8C44340488800035B2 -:200E3000040005048009883A0815D8C0800B883A01000E04081384C0800B883A01000E4436 -:200E3800081384C0800B883A8009883A081384C0800B883A01001C44081384C0800B883AEA -:200E400001001784081384C0800B883A01001B44081384C0800B883A01000304081384C0D7 -:200E48000480C804900B883A01000044081384C0800B883A01000184081384C0900B883AAA -:200E500001000084081384C0D0A1EF8310801014D0A1EF8510803FCC88800035DFC0031791 -:200E5800DC800217DC400117DC000017DEC00404F800283AD0E1EF83DEFFFA0400BFE7C476 -:200E60001884703ADC000015040020B4DC800215DC400115D0A1EF85DFC00515DD0004152A -:200E6800DCC003152025883A2823883A10803FCC84043404808000350140C80401000044C0 -:200E7000081384C0D0A1EF8310800814D0A1EF8510803FCC80800035014004049009883A1B -:200E780008155A001029883A10803FCC1000091E014020749009883A01800444295C020492 -:200E8000081554C09100000301400504081384C0000009060027883AA5003FCC94C5883A21 -:200E880011000003014005049CC00044081384C098803FCC153FF936D0E1EF8300BFF7C4AA -:200E90001884703AD0A1EF8510803FCC808000350140050401003004081384C0D0A1EF8386 -:200E980010800814D0A1EF8510803FCC80800035014004048809883A08155A001027883ACD -:200EA00010803FCC1000091E014020748809883A01800444295C0204081554C08900000327 -:200EA80001400504081384C0000009060025883A9CC03FCC8C85883A1100000301400504F3 -:200EB00094800044081384C090803FCC14FFF936D0A1EF8310801014D0A1EF8510803FCCF7 -:200EB80080800035DFC00517DD000417DCC00317DC800217DC400117DC000017DEC0060438 -:200EC000F800283ADEFFFB04DC000015040020B484041804DC80021504800B04DCC00315B5 -:200EC800900B883A2027883A000D883A8009883ADFC00415DC40011508164CC004400044EE -:200ED000880D883A99403FCC8009883A08165300900B883A8009883A880D883A08164CC0E2 -:200ED800880B883A8009883ADFC00417DCC00317DC800217DC400117DC000017DEC00504A7 -:200EE00008165041DEFFFC04DC000015040020B484041804DC800215DC4001152025883A4D -:200EE8002823883A8009883A000D883A01400B04DFC0031508164CC091403FCC8009883A6B -:200EF000000D883A081653000180004489403FCC8009883ADFC00317DC800217DC4001175C -:200EF800DC000017DEC0040408165301010020B4DEFFFD04000D883A000B883A210418043F -:200F0000DFC00215DC400115DC00001508165300010002840815D8C00400060404400044B5 -:200F0800800B883A8809883A0813B840800B883A010000840813B840800B883A010000C41F -:200F10000813B8408809883A0813B0401405003ADFC00217DC400117DC000017DEC0030479 -:200F1800F800283ADEFFFD04DC400115DC000015044000442021883A84003FCC8809883AF1 -:200F2000DFC00215802090FA0813B04000FFF9C410C4703A80A0B03A84003FCC800B883AA6 -:200F28008809883A0813B840800B883A010000840813B840800B883A010000C4DFC0021794 -:200F3000DC400117DC000017DEC003040813B841DEFFFD04DC4001152023883A0100004467 -:200F3800DC000015DFC00215043FF6040813B0401420703A89003FCC008000842080021E74 -:200F400084000054000003062008917A2080011480A0B03A84003FCC800B883A010000449D -:200F48000813B840800B883A010000840813B840800B883A010000C4DFC00217DC40011793 -:200F5000DC000017DEC003040813B841DEFFFB04DC000015040020B484041804DC80021519 -:200F580004801704DCC00315900B883A2027883A000D883A8009883ADFC00415DC400115BC -:200F600008164CC004400044880D883A99403FCC8009883A08165300900B883A8009883A20 -:200F6800880D883A08164CC0880B883A8009883ADFC00417DCC00317DC800217DC4001172F -:200F7000DC000017DEC0050408165041DEFFFC04DC000015040020B484041804DC8002155B -:200F7800DC4001152025883A2823883A8009883A000D883A01401704DFC0031508164CC0BC -:200F800091403FCC8009883A000D883A081653000180004489403FCC8009883ADFC003174D -:200F8800DC800217DC400117DC000017DEC0040408165301DEFFFC04DC0000150400088437 -:200F90008009883ADFC00315DC800215DC4001150813D4C0014004C4010005841023883A63 -:200F98000489C4040813DCC09009883A0815D8C0014000C4010005C40813DCC09009883A3C -:200FA0000815D8C0017FE004894AB03A29403FCC8009883A0813DCC00100FA040815D8C031 -:200FA80089401FCC8009883ADFC00317DC800217DC400117DC000017DEC004040813DCC177 -:200FB000DEFFFE04DC0000150409C4048009883ADFC001150815D8C00140044401000584B4 -:200FB8000813DCC08009883A0815D8C001400084010005C40813DCC08009883ADFC001171A -:200FC000DC000017DEC002040815D8C1DEFFFE04DC0000152821883A21403FCC01000484F4 -:200FC800DFC001150813DCC081403FCC010004C4DFC00117DC000017DEC002040813DCC102 -:200FD00021403FCC01000F440813DCC121403FCC010004440813DCC1DEFFFE04DFC0011588 -:200FD800DC000015214000C32021883A010002840813DCC081400103010002440813DCC0E0 -:200FE00081400143010002040813DCC081400003010003440813DCC081400043010003045F -:200FE8000813DCC081400083010002C4DFC00117DC000017DEC002040813DCC1DEFFFA0446 -:200FF000DC400115DC0000152023883A2021883A01000104DD000415DCC00315DC80021593 -:200FF8003829883A2825883ADFC005153027883A0813D4C0017FFE04A5003FCC1144703AF5 -:20100000A00006261140005429403FCC010001040813DCC08423883A0000030611403FCC60 -:20100800010001040813DCC08C7FFFCC880AD13A0100004429403FCC0813DCC0880A913ACB -:201010000100008429403C0C0813DCC099403FCC913FFFCC08153B40880B883A1009883A8C -:2010180008153B400140FA041009883A08152F8000E327D41880092E00C0007418C45BC45E -:201020001880082E00C000B418C3D5C41885403A00C000C41885C83A000003060005883AF0 -:20102800000001060080004414003FCCD0A01E041405883A1100000301400A0408153B4056 -:201030008808D07A880B883A1109883A08152000100B883A00C001C410803FCC1880012E94 -:20103800180B883A29403FCC800491BA280A90FA010000C4288AB03A29403FCCDFC0051724 -:20104000DD000417DCC00317DC800217DC400117DC000017DEC006040813DCC1DEFFFE0407 -:20104800DC0000152021883A01000684DFC001150813D4C0017FFE8484003FCC00C0004410 -:201050001144703A80C0021E10800094000001061080029411403FCC01000684DFC0011732 -:20105800DC000017DEC002040813DCC12140028BDEFFFE04DC000015280AD23A2021883A2A -:20106000010012C4DFC001150813DCC081400283010012840813DCC08140030B0100134472 -:20106800280AD23A0813DCC081400303010013040813DCC08140038B010013C4280AD23A78 -:201070000813DCC081400383010013840813DCC08140010B01001444280AD23A0813DCC0F8 -:2010780081400103010014040813DCC08140018B010014C4280AD23A0813DCC08140018363 -:20108000010014840813DCC08140020B01001544280AD23A0813DCC0814002030100150403 -:201088000813DCC08140040B010015C4280AD23A0813DCC081400403010015840813DCC0D9 -:201090008140048B01001644280AD23A0813DCC081400483010016040813DCC08140050BB5 -:20109800010016C4280AD23A0813DCC08140050301001684DFC00117DC000017DEC00204B6 -:2010A0000813DCC1DEFFFD04DC00001504000FC4DC4001152023883A8009883ADFC002159A -:2010A8000813D4C000FFFC0410C4703A888AB03A29403FCC8009883ADFC00217DC40011755 -:2010B000DC000017DEC003040813DCC1DEFFFD04DC40011504400684DC0000152021883AFE -:2010B8008809883ADFC002150813D4C080C03FCC014000C428C7C83A180691BA10800FCC4B -:2010C0008809883A188AB03A29403FCCDFC00217DC400117DC000017DEC003040813DCC181 -:2010C800DEFFFB04DCC0031504C00104DC4001152023883A9809883ADFC00415DC800215EA -:2010D000DC0000152825883A0813D4C0900B883A8809883A1021883A08153B40108007CCB3 -:2010D800100A90FA840001CC9809883A2C0AB03A0813DCC091403FCC89003FCC08153B40C1 -:2010E0001004D17ADFC00417DCC00317DC800217DC400117DC000017DEC00504F800283A84 -:2010E800DEFFFF04DFC000150813E3400009883A081411C0000B883A01000D440813DCC088 -:2010F00001002074211C0304081416C00140004401000404081432000009883A08142840EA -:2010F8000009883A08142CC0010001840813F400014000C401000D040813DCC0010011048C -:201100000813F4C001402204010006C40813DCC00140020401000704DFC00017DEC001046B -:201108000813DCC1DEFFFD04DC0000152021883ADC40011584003FCC044004048809883ADD -:20111000802090FADFC002150813D4C0108001CC808AB03A29403FCC8809883ADFC0021760 -:20111800DC400117DC000017DEC003040813DCC121003FCC20001A26DEFFFD04DC40011597 -:20112000010009842823883A01402004DC000015DFC002153021883A0813DCC089403FCC6A -:201128000080004428800426008002042880041E814016840000030681400244000001064F -:201130008140060429403FCC01000C44DFC00217DC400117DC000017DEC003040000020683 -:20113800000B883A010009840813DCC1DEFFF604D8800A17DF000815DDC00715DD80061507 -:20114000DD400515DD000415DCC00315DC800215DC400115DC000015DFC009152C403FCCE4 -:2011480000C000442021883A302B883A382D883ADCC00B17DD000C17DDC00D17DC800E173C -:2011500017003FCC88C0082600C0020488C00D1E11400C8429403FCC010001440813DCC05C -:201158000140080400000C061140008429403FCC010001440813DCC0014001842809883A19 -:20116000000006061140018429403FCC010001440813DCC001400404010001840813DCC096 -:20116800E00D883A880B883A0100004408144700B9003FCC0813F4C0008004048880021E78 -:2011700001400304000001060140020484003FCC010008848400201C0813DCC0843FE0048F -:201178008009883A01400704044020B408153B408C60C0848885883A11C0068B1100040B8F -:20118000B1803FCC39C0008C380EC03AA97FFFCC0813FBC0A1403FCC99003FCC0813F0C02A -:201188008009883A0140070408153B408885883A114005839009883A08153B4011403FCC21 -:20119000010001C4DFC00917DF000817DDC00717DD800617DD400517DD000417DCC00317A0 -:20119800DC800217DC400117DC000017DEC00A040813DCC1DEFFFD0429BFFF84DC400115BC -:2011A000DC000015DFC0021531803FCC0080004424403FCC2C003FCC118004360080008493 -:2011A8008880071E8805883A000008068800061E8005003A00C000841885C83A0000030646 -:2011B0000005883A0000010600800084880A913A8C47883A10803FCC100491BA18C7883AC0 -:2011B80028CAB03A214AB03A288AB03A29403FCC010006440813DCC0008000C48080041E6E -:2011C00001401744010004040813DCC00000120601401604010004040813DCC0008000847C -:2011C80088800D1E0080004414000B368080021E0140148400000106014014C4010003841A -:2011D0000813DCC00100FA040815D8C0010005040813D4C000000B06014016C40100038427 -:2011D8000813DCC00100FA040815D8C0010005040813D4C0008000C48080021E0140040426 -:2011E00000000106000B883A010006040813DCC0000B883A01000D84DFC00217DC4001170E -:2011E800DC000017DEC003040813DCC1DEFFFD04DC4001152023883A01000504DC00001587 -:2011F000DFC002152821883A0813D4C08C403FCC00C0008488C00A1E81403FCC00C0004414 -:2011F80028C0031E1080240C10802420000006062800031E1080220C10802220000002064D -:201200001004D07A1080004CDFC00217DC400117DC000017DEC00304F800283ADEFFED04E8 -:201208000080010400C020B418E09804DFC01215DDC01015DD800F15DD400E15DD000D15D1 -:20121000DCC00C15DC800B15DC400A15DC000915DF001115D880060D00800204D880068D6F -:201218001880068302C00404018040045884983A020200041B000983D880070D188006C3DC -:20122000028020B4D80008853084983A52A0C68403400104D880078D1880070303802004B4 -:2012280003C100044084983A0400800404400804D880080DD8800884D880001518800744CF -:20123000D880011518800784D8800215188007C4D880031518800804D8800415D880051544 -:20123800048010040005883A04C0020407C0014405000044057FFEC40580008405FFFBC406 -:20124000520000435240000341803FCC3340061E67003FCCE000021EBA52703A00000A06C9 -:20124800E580091E00006F0637C0061E67003FCCE000021EAA52703A00000306E500021E44 -:2012500000006806F980673649D2703A4A403FCC48006426318D883A318D883AD98D883AA6 -:20125800318000175240008B31800003318D883AD98D883A3180060B3278703AE73FFFCC2E -:20126000E00058264A40004C2F003FCC4A40005CE240541E527FFE8B4A4007844900513647 -:2012680007000044024020B41980048D18000385180003C51F00040531BFFFCC4A60980432 -:20127000338033267180113632C02A2659800A363340212634C0431E423FFF0442003FCCDF -:2012780001000044420000B019000305180003451A00038500004206344020263480391EEF -:2012800001000084190003050000260633C028267980073602004004320020263400311EC4 -:20128800010000C4190003050100008400001D060702000437002526020400043200291EA6 -:2012900001000104190003050100008419000345010001840000210642003F4C4200006015 -:2012980048000305480003454A0003854A0003C50000230600C000840000150600C00084A6 -:2012A00048C0030500C0004448C0034500001C0600C0008448C003050000080600C000C4C2 -:2012A80000000B06190003450100010400000B0600C000C448C0030500C0008448C0034575 -:2012B00000C0014448C0040500000D0600C0010448C003054800034500000906190004055F -:2012B80000000706118000443005883A0700070431803FCC52800704373F811E00BFFFC4FB -:2012C000DFC01217DF001117DDC01017DD800F17DD400E17DD000D17DCC00C17DC800B1778 -:2012C800DC400A17DC000917DEC01304F800283A20803FCCDEFFF9041080201CDC40041538 -:2012D000DFC00615DC800515DC00031510BFE0042823883A10000A0E2025883A000B883A1E -:2012D80001001DC40814B300D880028510C03FCC0100004420C02E3694001FCC000001067C -:2012E0002021883A08151400014001040009883A081510C0081512408804D63ADC000005D0 -:2012E800DC400105D88000458804D43A84003FCCD88000858804D23AD88000C500801004D8 -:2012F00080800426008012048080041E00BFE1C40000030600BFE5440000010600800044DC -:2012F80001400184D809883AD880014508150F8001000144081519C01021883A044000446C -:2013000001400044D9000284081510C0D8800287100003168000051E08151F80000003068A -:2013080008151D80147FF626003FFA06D8800283DFC00617DC800517DC400417DC000317DF -:20131000DEC00704F800283ADEFFF604DC000515000B883A2021883A01001244DFC0091509 -:20131800DCC00815DC800715DC4006150814B30010803FCC100002260005883A000043069B -:2013200001000144081519C01023883A0480004404C03FC401400044D9000484081510C01A -:20132800D880048314C003268800051E08151F800000030608151D8014BFF626003FFA0671 -:20133000D8C0048300803F8418BFEB1E01400484D809883A081510C08080010310C0008CA2 -:2013380018001326D8800183D8C001C3D9400143108000CC1004923A294003CC10C8B03A79 -:20134000D88002031006D1BA2105883A1085883AD900028310C4B03AD8C002432008D1FA64 -:2013480018C000CC18C7883A20C8B03A000010061080010C10000B26D88001C3D900020380 -:20135000000B883A10800FCC1004923A1104B03A1006923AD8800243010004441884B03A18 -:2013580000000306000B883A0009883A0005883A10BFFFCC10C0004421003FCC28803FCC80 -:201360002085883A10BFFE441884983ADFC00917DCC00817DC800717DC400617DC00051762 -:20136800DEC00A04F800283ADEFFF60401402074DCC00715018002842027883A295CD3048F -:20137000D809883ADD000815DC400515DFC00915DC800615DC000415050000C4081540C07B -:201378000440004408150DC0081514000815180001400284D809883A08150F80000B883A9A -:2013800098000015010010040814B30010803FCC1440511E01406A84010012040814B30049 -:2013880010803FCC1440271E01400104D9000284081510C0D88003031440471ED8C003438A -:2013900000802A841880441E0100FA04081519C008151D801440032608151D8014400C1EB1 -:20139800000006060150003401003A440814B30010803FCC103FF61E003FF706000B883A4F -:2013A00001001E840814B30010803FCC100002260021883A0000090601400104D900028451 -:2013A800081510C0D88002831080100C1000021E04000104000001060400030408151F80A8 -:2013B00000002606000B883A01003A440814B30010803FCC8880032E0400004404801044E2 -:2013B800000002060400008404BFFA4401003E84081519C094803FCC08151D801440042674 -:2013C00008151D801000081E0021883A00000606000B883A9009883A0814B30010803FCC9C -:2013C800103FF51E003FF60608151F80000B883A01001EC40814B30010803FCC100001265B -:2013D0000021883A01408004010014040814B30010803FCC100001260021883AA0BFFFC496 -:2013D8001029883A10803FCC84803FCC10000A26903F9C26008000449C00010598800015EC -:2013E0009809883A0814C48010BFFFC4988002150815164000000106903FF61E08151200DD -:2013E8009005003ADFC00917DD000817DCC00717DC800617DC400517DC000417DEC00A044D -:2013F000F800283A20800217DEFFF804DC000115DFC00715DD400615DD000515DCC0041560 -:2013F800DC800315DC400215DC0008171180313684BFFFCC90002F26208001032827883A93 -:201400003823883A1080020C300B883A1000011E300A927A010014440814B30010803FCCDC -:20140800100002260400008400001F0601001904081519C00500004405403FC401400044B5 -:20141000D809883A081510C0D88000031540052608151F80D8C0000300803F8418BFF11ED1 -:201418000000030608151D80153FF426003FF806008080841445C83A897FFFCC1421C83A5D -:20142000280002260009883A081510C0900B883A9809883A081510C0817FFFCC0009883A61 -:20142800081510C00021883A081512008005883A00000106008000C4DFC00717DD4006171C -:20143000DD000517DCC00417DC800317DC400217DC000117DEC00804F800283A018001B413 -:2014380001406734010020B43186A004297F30042104100408164581280D883A200B883AAB -:20144000010020B42104100408165AC1280D883A200B883A010020B421041004081656C11E -:20144800F800283AD0A1EF8300C020B418C4340410801FCCD0A1EF8518800035F800283A18 -:20145000D0E1EF8300BFE0041884B03A00C020B4D0A1EF8518C4340410803FCC188000353B -:20145800F800283A01800A7401406734010020B4318CB804297F30042104100408164581F8 -:20146000018001B401406734010020B43186A004297F30042104100408164581D0A1F917B0 -:2014680010000B1EDEFFFF04015A5E04213FFFCCDFC0001508153B40D0A1F9150815DD405E -:201470000005883ADFC00017DEC00104F800283A00800044F800283ADEFFFF04DFC0001530 -:201478000815E100D0E1F91710C5803ADFC00017DEC00104F800283AD021F915F800283AFA -:2014800020001B16000F883A28001616200D883A29001A2E0080080400C0004400000106DF -:2014880010000D26294B883A10BFFFC418C7883A293FFB360005883A180007260005883A2C -:2014900031400236314DC83A10C4B03A1806D07A280AD07A183FFA1E380001260085C83A1C -:20149800F800283A014BC83A39C0005C003FE7060109C83A01C00044003FE30600C00044CE -:2014A000003FEE0620001716000F883A2005883A280012162900162E0180080400C00044A6 -:2014A8000000010630000A26294B883A31BFFFC418C7883A293FFB36180005261806D07AEF -:2014B000114001361145C83A280AD07A183FFB1E380001260085C83AF800283A014BC83AC2 -:2014B800003FEC060109C83A01C00044003FE70600C00044003FF106200D883A2900152E11 -:2014C000280014160080080400C000440000020610000E2628000516294B883A10BFFFC4D3 -:2014C80018C7883A293FFA36180008260005883A31400236314DC83A10C4B03A1806D07A6F -:2014D000280AD07A183FFA1EF800283A0005883AF800283A00C00044003FF4062005883A72 -:2014D8002900122E280011160180080400C000440000020630000C2628000516294B883AC8 -:2014E00031BFFFC418C7883A293FFA36180006261806D07A114001361145C83A280AD07AF8 -:2014E800183FFB1EF800283AF800283A00C00044003FF7060005883A2000072620C0004C40 -:2014F0002008D07A180001261145883A294B883A203FFA1EF800283AF800283A218D883A42 -:2014F800218008262080000328C0000310C0022610C5C83AF800283A21000044294000443C -:20150000003FF7060005883AF800283A2005883A2007883A218D883A19800526290000033E -:2015080018C0004429400044193FFFC5003FFA06F800283ADEFFF504DFC00915DC40081579 -:20151000DC000715D9C00A1500802074109EA304144000172800040E008022C4888000157A -:2015180000BFFFC400001C0600C08204D8C0000DD9000415D90002152800022628FFFFC408 -:20152000000001060007883AD8C00515D8C003151100001700FFFFC4D8C0008D00C0207416 -:2015280018D6D7042821883AD9C00A04D80B883AD8C00115D80006150815630000FFFFC4A0 -:2015300010C0020E00C022C488C0001580000226D8C0041718000005DFC00917DC40081746 -:20153800DC000717DEC00B04F800283A3000152631BFFFC4218D883A2080000328C0000376 -:2015400011C03FCC1A003FCC39C0201C4200201C39FFE004423FE0043A00061E218004262D -:20154800380003262100004429400044003FF2061007883A18C03FCC10803FCC10C5C83AAB -:20155000F800283A0005883AF800283A2005883A200F883A30000C262A00000338C000445D -:2015580031BFFFC43A00000542003FCC4200201C423FE00429400044180F883A403FF51E29 -:20156000198D883A00000106F800283A30C003261800000518C00044003FFC06F800283AB5 -:20156800214B883A2005883A1140021E1105C83AF800283A10C00007183FFC261080004447 -:20157000003FF906DEFFFB04DC800315DC400215DC000115DFC004152025883A2823883ADC -:20157800D98000053821883A04000A0E8880011701C00044D80D883A880B883A9009883A42 -:20158000103EE83A843FFFC4103FF72600BFFFC4000001060005883ADFC00417DC80031769 -:20158800DC400217DC000117DEC00504F800283ADEFFE504D8C00804DDC01815DD8017155C -:20159000DD401615DD001515DCC01415DC801315DC401215DC001115DFC01A15DF00191583 -:201598002029883A2823883A382D883AD9800F150021883AD8000E15D8000A15002B883AB5 -:2015A0000027883A0025883AD8000C15D8000B15002F883AD8C00915D8C00F1719000003E9 -:2015A80020803FCC1080201C10BFE00410011E2600C00044B8C014261DC00216B800062615 -:2015B0000001150601400084B9401D26014000C4B9402B2600011006014009441140FC2697 -:2015B80088800117D900000501C00044D80D883A880B883AA009883A103EE83A1000D81E33 -:2015C000840000440001040601400C041140FA260140094411400A1ED880000588800117F2 -:2015C800B80F883AD80D883A880B883AA009883A103EE83A1000CA1E840000440000F506E8 -:2015D00025FFF404BDC03FCC00C002441DC0093600BFFFC490800426014002849009883A57 -:2015D80008153B40000001060005883AB8A5883A0000E20601400B841140E42605C0008412 -:2015E000213FF40427003FCC00C002441F00093600BFFFC498800426014002849809883A0F -:2015E80008153B40000001060005883AE0A7883A0000D90600C01B0410C0D226013FFFC4AB -:2015F00099000226D8000B150000010604C0004401001A441100162620800916010018C4CB -:2015F800110088260100190411001126010016041100C81E00C00044D8C00E1500001506C2 -:2016000001001CC4110098262080041601001BC41100C01E0540020400000F0601001D44CF -:2016080011000D2601001E0411000A260000B906D8C00A17B700010418000726DF000D15A0 -:20161000B5C00017B800080E05EFC83A024000440000060605400404B0C00104D8C00D155C -:20161800B5C00017D8000A150013883AD839883AB8001726A80B883AB809883ADA4010155B -:2016200008152F80A80B883A1009883A102D883A08153B40B885C83A00C00244DA40101771 -:201628001880021610800C0400000506D8C00E171800022610800DC400000106108015C479 -:20163000E0800005B02F883AE7000044003FE806E6EFC83A9DC5C83A0080090EE085883A43 -:2016380001400C04D8C00917E009883AE0C0032EE700004421400005E0BFFA1EE6EFC83AEE -:20164000D8C00B174DD1883A922DC83A1800162648000A2600800B44D8800805888001170F -:2016480001C00044D9800804880B883AA009883A103EE83A10004A1E840000440580070E0E -:20165000B00F883A01800C04880B883AA009883A08155C401000421E85A1883AE02D883AC8 -:20165800BF2FC83A000020060580090EB00F883A01800804880B883AA009883ADA401015B3 -:2016600008155C40DA4010171000351E85A1883A483FF22600800B44D88008058880011732 -:2016680001C00044D9800804880B883AA009883A103EE83A10002A1E84000044003FE7067C -:20167000B5BFFFC4B080000301C00044D9800804D880080588800117880B883AA009883A41 -:20167800103EE83A10001E1E8585C83AB5C9883AE085883A013FF2161021883ADD800D1767 -:2016800000004406008000441480080E95FFFFC4B80F883A01800804880B883AA009883A65 -:2016880008155C4010000E1E85E1883AB080001701C00044D80D883AD880000588800117B5 -:20169000880B883AA009883AB5C00104103EE83A1000031E84000044B82D883A00002D06BD -:2016980000BFFFC400003106B5C00017B7000104B809883A0815C6409091C83A102D883A69 -:2016A0000200090E400F883A01800804880B883AA009883ADA00101508155C40DA001017FA -:2016A800103FEF1E8221883A88800117B00F883AB80D883A880B883AA009883A103EE83A09 -:2016B000103FE71E85A1883AE02D883A0000110600C0004404FFFFC4D8000E15D8C00A157C -:2016B800054002849825883AD8000C15D8000B15182F883A00000806DDC00B1505C00084BA -:2016C0000000050600C00044D8C00C1505C000C400000106002F883AD8C00F1718C00044E7 -:2016C800D8C00F15003EDC068005883ADFC01A17DF001917DDC01817DD801717DD4016175F -:2016D000DD001517DCC01417DC801317DC401217DC001117DEC01B04F800283A2880000B91 -:2016D80010C0020C1800202628C0008FDEFFFD04DC000015DFC00215DC4001152821883A7D -:2016E0001800150E10C0800C180013262C40051789C0030E10C0200C1800032600000E06CF -:2016E8003C40010E3823883A81000417300B883A880D883A0815C040808005171445C83AB6 -:2016F00080800515808004171463883A844004150005883A00000606108010148080000DFB -:2016F80000BFFFC40000020600BFFFC4F800283ADFC00217DC400117DC000017DEC00304E8 -:20170000F800283A2005883A218F883A290002361007883A00000C062987883A20FFFC2E0F -:20170800380B883A30CDC83A1989883A2000052618FFFFC419000003297FFFC4290000057F -:20171000003FF906F800283A19C005262900000318C0004429400044193FFFC5003FFA06CD -:20171800F800283A2005883A10C000071800022610800044003FFC061105C83AF800283AD2 -:20172000DEFFFF040100207401402074DFC00015211CDE04295EA7042140061E0100207440 -:201728000140207421000804294008042140121E00000B0600C0207418DEA7041907C83A71 -:201730000005883A10FFF526114F883A39C00017110D883A1080010431C00015003FF906BD -:2017380001002074014020742119B9042959B9042140101E00000B0600C0207418C0080419 -:201740001907C83A0005883A10FFF526114F883A39C00017110D883A1080010431C00015C9 -:20174800003FF90608166680DFC00017DEC0010408166D8100C0207418DCDE041907C83A8E -:201750000005883A18BFF726114F883A39C00017110D883A1080010431C00015003FF906D3 -:20175800DEFFFF040009883ADFC000150815D9000815DB00D1A1FA17D161FB17D121FC1758 -:20176000DFC00017DEC001040811F0C108165E81DEFFFF04DFC0001508166DC000800044A6 -:201768001001703ADFC00017DEC00104F800283A008020B410840004D0A1FE1501002074EE -:201770000080673410BF3004211E4D04D0A1FD1508162781D0E1FD17D0A1FE1718000A26CF -:2017780010C001040100020419000035013FFFD41100023511000335008001041880003531 -:201780000005883AF800283A00BFFFC4F800283AD0A1FD1710000926D0E1FE171880040422 -:20178800100000351080003718C005371806943A10BFFFCC1884303AF800283A00BFFFC4B9 -:20179000F800283AD0A1FD17F800283A20001D262804923A20C03017DEFFFD04DC4001156E -:20179800DC000015DFC002152823883A2021883A108000D41880033580C0301718800037F0 -:2017A0001080004C100003260100004408165E80003FF906198000373007D0BA3009D0FA01 -:2017A80018C001CC2100020C1908B03A3007D07A18C0040C1906B03A88C0042600BFF48427 -:2017B0000000020600BFFA84F800283ADFC00217DC400117DC000017DEC00304F800283A9C -:2017B80020000A26280009263000082620800C173080001520800C171000062621000D0453 -:2017C000290000150005883AF800283A00BFFA84F800283A00BFFEC4F800283A2005883A51 -:2017C80020001D262809883A28001B1610C0311728C0192E1140341728FFFFC41906703ABC -:2017D0001800151EDEFFFE04DC000015DFC001151021883A08152F801004923A00C0403456 -:2017D80018FFC00410C4703A80C03017108000941880033580C0301718C0040418800037E7 -:2017E0001080004C10000626008000441880003500BFFEC40000020600BFFA84F800283A20 -:2017E800DFC00117DC000017DEC00204F800283ADEFFF504DC000115DFC00A15DF000915B6 -:2017F000DDC00815DD800715DD400615DD000515DCC00415DC800315DC400215DC000B171D -:2017F80028003A163023883A300038162027883A20003626382B883A3800342620803117A2 -:201800003080322E2880312E208034173147C83A10C7C83A1C002D3680002C1610BFFFC4A0 -:20180800114A703A2800291E0029883A05BFFFC405C000C40700010480002226DD8000150B -:20181000890000CC20000626E105C83A8025883A1400012E1025883A8923C83A00000406D6 -:20181800BC0002368025883A0000010604800104AD0B883A900D883AD909883A081540C02B -:2018200098802E17D8C00017A4A9883A84A1C83A8885883A10C0003598803017108004049B -:2018280010C0003718C0008C1800042600C0008410C0003500BFFEC4000005068C4001044D -:20183000003FDD060005883A0000010600BFFA84DFC00A17DF000917DDC00817DD80071775 -:20183800DD400617DD000517DCC00417DC800317DC400217DC000117DEC00B04F800283A00 -:2018400020001626DEFFF604DD000515DFC00915DDC00815DD800715DD400615DCC0041581 -:20184800DC800315DC400215DC0001153029883A30000C262021883A20802E1780C02F17FC -:201850002823883A2885883A382B883A3889883A10C0042E20C005360000020600BFFA84F2 -:20185800F800283A00BFFA8400002406814034178809883A002D883A08152F80102F883A94 -:2018600080803317B8801C2EA8001B2684C0341704E7C83A9C66703A8CC002268CE5C83AA4 -:20186800000001060025883A980B883A8009883A0815F1C01000111E8080341714A5C83AAF -:20187000AC80012EA825883ADC800015A58F883A880D883A980B883A8009883A0815FB00E8 -:201878001000061EACABC83AB4AD883A8CA3883ABDC00044003FE2060005883ADFC0091741 -:20188000DDC00817DD800717DD400617DD000517DCC00417DC800317DC400217DC00011788 -:20188800DEC00A04F800283A200008263007883A3000062620802E17288B883A20802F1757 -:20189000394D883A2880012E3080023600BFFA84F800283ADEFFFF04380D883A1809883AD0 -:20189800DFC00015081540C00005883ADFC00017DEC00104F800283A20004E26208030176A -:2018A00010004E2620C03217DEFFFB04DFC00415DCC00315DC800215DC400115DC0000159D -:2018A80018001E1E1480023700C0030494803FCC90BFFAC418804336100490BA00C0207449 -:2018B00018D8B40410C5883A108000171000683A0081633C0081634C0081635400816344D0 -:2018B80000816304008163C4008163C4008163C4008163C4008163C4008163C40081630C48 -:2018C00000816314044080040000130604410004000011060442000400000F0614800137A4 -:2018C8000080058494803FCC90800A260080060490800426008005049080221E04400804AB -:2018D00000000506044040040000030604401004000001060440200424C034172021883A63 -:2018D8008809883A980B883A08153B4080C0311710C0021E80C0331788C0022680000C158D -:2018E0000000100600C000448480361580C00C1580000D1580800E1584400F1584C0101508 -:2018E800D16021048009883A081666C00005883A0000050600BFFA84F800283A00BFFB4494 -:2018F000F800283A00BFFB44DFC00417DCC00317DC800217DC400117DC000017DEC00504CD -:2018F800F800283A300001260005C03200FFFF042005883A28C6703A110DC83A30C0042E65 -:2019000011800017300DC0F210800104003FFA06294000CC00C000C428C0041E10C0000BBE -:201908001807C0B2108000830000080600C0008428C0031E1080000B1005C0B20000040694 -:2019100000C0004428C0021E108000031005C0720005C132F800283ADEFFFD04DC4001156F -:20191800DC0000152823883A2021883A014001443009883ADFC0021508153B40100B883A02 -:201920008809883A08152F8010BFFFC480C0020418000035010000448100043511003FCC48 -:20192800810000351004D23A10803FCC808001350080200418800035DFC00217DC4001179B -:20193000DC000017DEC00304F800283A3180004C294B883A298B883A21400335210004043A -:201938000080240420800035208000371080008C103FFD1E208000371004D1FA1080004C23 -:20194000F800283A20C004042800022600801A040000010600800804188000351880003728 -:201948001080008C103FFD1E20800337F800283A29403FCC21400335210004043000022637 -:2019500000801404000001060080040420800035208000371080008C103FFD1E2080003747 -:201958001004D1FA1080004CF800283A21C004042805883A02000B04210003041147C83AEF -:201960001980090E3A00003538C0003718C0008C183FFD1E2800022620C0003710C0000507 -:2019680010800044003FF506F800283A21C003042805883A21000404020007041147C83A90 -:201970001980080E10C0000338C000352200003520C0003718C0008C183FFD1E1080004490 -:20197800003FF606F800283A014AAAF4DEFFFE04296AAA84DC000015DFC001152021883A88 -:2019800008152F8010000F2601600034013555740007883A297FFFC421155584297FFFC4F4 -:20198800283FFE1E18C000448121883A18BFFB168405883A1421883A843FFFC4803FFE1EB1 -:20199000000004068405883A1421883A843FFFC4043FFE160005883ADFC00117DC0000179D -:20199800DEC00204F800283AF800283A20000226208002171000101ED0A0201710000926B2 -:2019A000DEFFFF04DFC00015103EE83A00C0058410C0001500BFFA84DFC00017DEC001045F -:2019A800F800283AD0A1FF0400C0058410C0001500BFFA84F800283A288000172140011556 -:2019B000208000152880001711000115290000150005883AF800283AF800283A000170FA58 -:2019B800F800283A73616C4672652068006573616F727265642520720000000073616C463E -:2019C00072772068006574696F7272650000007273616C4665762068206669726C69616644 -:2019C8000000000053206F4E6163204464206472002E74652520732500632575252E75257F -:2019D0006B75322E25207A482E252E757A4875320000000064616F4C0000646564616F4C88 -:2019D800696166200064656C00007325746F6C5300752520657661530000006465766153F4 -:2019E000696166200064656C4353534F776620207525202E322E252E0000007574696E4969 -:2019E800727265202020726F000064252020202053204F4E00434E59343130323130322DCB -:2019F0006D202037737172610000000074736554746170206E726574000000003A3156417C -:2019F80042475220000000533A31564173475220000000423A315641625059200000725022 -:201A00003A32564162505920000072503A32564173475220000000423A3356414247522066 -:201A0800000056483A33564142475220000000533A33564173475220000000423A33564158 -:201A100062505920000072507473614C6573752000000064008167CC008167DC008167E81C -:201A1800008167F4008168000081680C0081681800816824008168300081683C0081684877 -:201A200000000000000001000001010100000004001000000344060B000001001A8080809B -:201A280000001A1A7365725000000073666E6F43006D72696D73694D686374616572202C36 -:201A300000797274646F4D567325203A00000000203A4F4C56207525203A4D530000752536 -:201A3800666F725020656C6964616F6C0000003A736572702D3020730000003900000031AF -:201A40000000003200000033000000340000003500000036000000370000003800000030E3 -:201A4800554E454D0000000000004B4F4B43414200000000000050554E574F4400000000C1 -:201A50005446454C0000000048474952000000544F464E49000000005F44434C4B4341425E -:201A58004847494C000000544E414353454E494C444F4D5F000000454E414353454E494CD8 -:201A60005059545F000000454E414353454E494C544E495F0000002B4E414353454E494CB6 -:201A6800544E495F0000002D454E494C544C554D444F4D5F000000455341485000002B455D -:201A70005341485000002D45464F52505F454C494B544F48000059453EA93E293EE93E6958 -:201A78003E993E193ED93E593EC93E393E1D3E4D3E2D3EED3EAD3ECD3E653E6D1C483E0191 -:201A80001C501C181CC81CD05ED85E5800003EB9008168FC00816900008169040081690844 -:201A88000081690C008169100081691400816918008168F80081691C00816920008169284B -:201A90000081692C00816934008169380081694000816948008169500081695800816968B6 -:201A9800008169780081698800816998008169A8008169B8008169C0008169C84353534F10 -:201AA0000000000061766E492064696C67616D690000006561766E492064696C64616568C3 -:201AA8000000726561766E492064696C2072646800435243696C6156697461646420676EA3 -:201AB0000061746162207525736574790000000061766E492064696C617461644352432086 -:201AB80000000000252E75252575322E00732573636E6143656C6C65000000646164705517 -:201AC000676E69740057462061656C70772065732E74696100002E2E697265566E69796672 -:201AC8006C6620670068736172746552676E6979647075200065746161647055203F6574B0 -:201AD0002C593D314E3D322000000000202020200000752564206425000067656C2075250D -:201AD80073656E6900000000252E75252075322E000073756D2064250000005670207525DF -:201AE0006C657869000000732525752500000000656469566E69206F6F7270203E2020639D -:201AE80000000000706D6153676E696C74706F203E20202E00000000636E795374706F2074 -:201AF0002020202E3E202020000000007074754F6F207475202E74703E20202000000000BA -:201AF80074736F506F72702D20202E633E20202000000000616F4C3C727020646C69666FD3 -:201B0000003E20657661533C727020656C69666F003E20657365523C732074656974746540 -:201B08003E73676E00000000657365526F6420740000656E2E77463C647075202065746184 -:201B10003E202020000000002D204B4F736C70207365722074726174000000006C69616600 -:201B1800000064656E616353656E696C000000736E616353656E696C727473200000002E70 -:201B20006E616353656E696C70797420000000656E616353656E696C696C61202E6D6E67A3 -:201B28000000000069726F48746E6F7A6D206C61006B7361747265566C61636973616D200C -:201B30000000006B6B73614D697262206E74686700737365703034323838322F72702070FC -:201B38000000636F703438336F72702000000063693038343637352F727020690000636FC5 -:201B4000703038343637352F727020700000636F656E694C6D2078330065646F656E694CE4 -:201B48006D2078340065646F656E694C6D2078350065646F7836353220303432485F334C21 -:201B5000746C756D000000006D2058540065646F74696E49206C616975706E690000007428 -:201B58006C616E417320676F20636E790046504C6C616E417320676F20636E7900687456BB -:201B60006E7973486F7420636172656C0065636E6E797356687420636873657200646C6F83 -:201B68004C502D487250204C6F432D65007473614C502D486F50204C432D74737473616F48 -:201B700000000000706D6153676E696C616870200000657370303834206E6920706D617315 -:201B78000072656C7664413C6974202E676E696D3E2020200000000065646956504C206F8C -:201B800000000046506250596E6920726C6F43200061705372502F5266666F2000746573EF -:201B880020592F477366666F0000746562502F4266666F200074657372502F526961672069 -:201B90000000006E20592F476E6961670000000062502F42696167200000006E73202E484E -:201B98006C706D61746172650000006573202E486C636E7900006E6561202E487669746333 -:201BA0000000006561202E56766974630000006562202E48706B63616863726F000000005D -:201BA80062202E56706B63616863726F0000000000706F5474746F4200006D6F69726F4892 -:201BB000746E6F7A00006C61747265566C6163690000000065746C4174616E7200676E69CA -:201BB8000066664F6F74754100000000756E614D00006C61494D44480000000000495644F6 -:201BC000737361507572687400000000656E694C00007832656E694C00007833656E694CBE -:201BC80000007834656E694C00007835656E65472063697200333A347836353220303432D3 -:201BD0006974706F00002E6D78303233203034326974706F00002E6D656E654720636972A7 -:201BD800393A363100000000484D33336D28207A00296E69484D30316D28207A00296465D2 -:201BE0004D352E3228207A482978616D000000002056544470303834000000004153455641 -:201BE8003034362030383478003036402E63655231303620000000002E6365523930372062 -:201BF00000000000484D35394828207A2056544400294949484D35334828207A20565444EA -:201BF80000002949484D36314528207A29565444000000007A484D39445328200029565447 -:201C000044525355004154410000002000816FAC0000200020002CE5E926F4FD38BC20008F -:201C08000000000000816FB8000020002000323EF113FA043B6120000000000030383231DB -:201C10003034327805000000177000F001060618034810AA0112011278303639003034322D -:201C180003C00000177000F0010604920336108000220112783032330030343201400000F3 -:201C2000177000F0010606A8031F103102400112783635320030343201000000177000F09D -:201C2800010606A90319102704800112783635320036313201000000177000D8010607FEE2 -:201C30000319102710000112703034320000000002D00000177000F00106035A033C1041DB -:201C3800000E01122A3836370036313206000000177000D8010607FE039610EA08000112E4 -:201C40003038323138383278050000001388012001380618034810AA011201127830363945 -:201C48000038383203C0000013880120013804920336108000220112783032334C3034329F -:201C500001400042138800F0013806A8031F293102400112783635324C3034320100004274 -:201C5800138800F0013806A90319292704800112703838320000000002D000001388012056 -:201C600001380360033C1041000E0112703438330000000001F000001686018001A70280D0 -:201C6800033E1D32000E0204783034360034383302800000157C018001EC032002603F3092 -:201C7000000C0210693038340000000002D00000176A00F0020D035A033C1041000F0312CE -:201C7800703038340000000002D00000176A01E0020D035A063E1E3C000C041478303436CC -:201C80000030383402800000177001E0020D032002602130000C051478303436003231350A -:201C880002800000177002000238032002601C3000040010693637350000000002D0000035 -:201C90001388012002710360033C1041000F0312703637350000000002D00000138802402D -:201C980002710360063C2041000C040478303038003030360320000017700258027404205B -:201CA0000480175800040010703032370000000005000000176A02D002EE0672052814FF14 -:201CA80000040008303832313032377805000000177002D002EE0672052814DC000400103D -:201CB000343230313836377804000000177003000326054006881DA000040010303832310A -:201CB800323031780500003417700400042A0698037026F80004001030383031000000699A -:201CC00007800000176A043804650898052C10940005000830383031000000700780000015 -:201CC800176A043804650898052C24BC0004000830323931383031780780003017700438C2 -:201CD00004650898052C249400040010FFFFFFFFFFFFFFFF0000FFFF7665642F6370652F23 -:201CD8006F635F716F72746E72656C6C615F305F6D5F6C7600006D65000000000000000009 -:201CE0000000000000000000000000000000000000000000000000000000000000000000E4 -:201CE8000000000000000000000000000000000000000000000000000000000000000000DC -:201CF0000000000000000000000000000000000000000000000000000000000000000000D4 -:201CF8000000000000000000000000000000000000000000000000000000000000000000CC -:201D00000000000000000000000000000000000000000000000000000000000000000000C3 -:201D08000000000000000000000000000000000000000000000000000000000000000000BB -:201D10000000000000000000000000000000000000000000000000000000000000000000B3 -:201D18000000000000000000000000000000000000000000000000000000000000000000AB -:201D20000000000000000000000000000000000000000000000000000000000000000000A3 -:201D280000000000000000000000000000000000000000000000000000000000000000009B -:201D3000000000000000000000000000000000000000000000000000000000000000000093 -:201D380000000000000000000000000000000000000000000000000000000000000000008B -:201D4000000000000000000000000000000000000000000000000000000000000000000083 -:201D480000000000000000000000000000000000000000000000000000000000000000007B -:201D5000000000000000000000000000000000000000000000000000000000000000000073 -:201D580000000000000000000000000000000000000000000000000000000000000000006B +:200368002000271ED0A2014300C0020410C01D2600C0040410C0062600C0010410C01C1EEE +:200370000009883A081439400100004400002E06040020B484213D04814001170100673461 +:20037800213F30040815474081000287014007041023883A0815530000C020B418E16B0476 +:2003800010C5883A1140000B8809883A0815530000C072B418F0DFC418800236010003C47E +:20038800000001060009883A08143940000015060009883A081439400009883A0000120690 +:20039000008020B410A1504410C006C3044000841021883A1C4002260009883A000001060A +:20039800010003C408143940810006C320803FCC8880042E008001441109C83A21003FCCAC +:2003A00000000106010000C4DFC00217DC400117DC000017DEC003040813D701DEFFF50424 +:2003A80000C020B4DFC00A15DF000915DDC00815DD800715DD400615DD000515DCC00415CF +:2003B000DC800315DC400215DC0001150089C40418C4240419800037050020B4A5042404C5 +:2003B8003000020E10BFFFC4103FFA1E29403FCC21003FCC040020B40814870084213D04EB +:2003C0001025883A808002C310000326A44000378822D43A000001060023883A01000DC497 +:2003C8000813E58001000E041027883A0813E58010C003CC1806923A1CE6B03A1006D1BAF3 +:2003D00018C0004C80C00245A0C00037010000848C403FCC89000E26010020B421213D045A +:2003D800210002C32000021E010063C424C0082E010000448900041E9CC9883A18FFFFCCA4 +:2003E000213FFF8420C005361080080C100004269D00322805800044000003061827883A57 +:2003E8009D006428002D883A80C002C390803FCC1800101E10001E26A0001D26D0A20003CB +:2003F0000100008410C03FCC18C0201C18FFE00420C0060E008020B400C0004410A13D0440 +:2003F800D022000510C002C500000C061080004400000D0610000126A0000D1ED0A20003E7 +:2004000000FFFF0411003FCC2100201C213FE00420C0040ED0220005800002C504400104A4 +:200408000000050610BFFFC4D0A2000500000106D02200050023883A01000E440813E5800A +:2004100001000E84048020B4102B883A94A150440813E580A0008526108003CC1004923A11 +:2004180080C00017156AB03A008020B410A13D041CC0051E10C00117A8C0031E10C0020379 +:20042000B0803FCC18800226D022044500000C06D0A2044300C0004411003FCC20C008268D +:2004280010C5883AD0A2044510803FCC10C0041E88803FCC00C0008410C0012E1823883A82 +:200430009140024380800803010020B400C020B42121504418E13D0428801B1E214002834B +:20043800188008432880181E214002C3188008832880151E21400303188008C32880121E1D +:20044000214003431880090328800F1E214001431880070328800C1E21400183188007439C +:200448002880091E214001C3188007832880061E21400203188007C32880031E21000543B8 +:2004500018800B032080042688803FCC00C0008410C0012E1823883A90C004C380800A8325 +:2004580018801126008020B410A13D0411000287014007040815530000C020B418E16D44DB +:2004600010C5883A1080000300C0004410BFFF0410803FCC1880043688803FCC00C00084B8 +:2004680010C0012E1823883AD0A2054310002C2685C0028701400704050020B4B809883AE6 +:2004700008155300A521670487000403A085883A1140040BE009883A08155300173FFFCCBA +:2004780080800B03A8FFFFCC10000A2601400704B809883AD8C0001508155300A085883AD1 +:200480001180068BD8C00017300CD07A3180004C00000106000D883A180B883AE009883AA2 +:2004880008140C80810002870140070408155300A085883A8140040311000583081553002E +:2004900081400483010001C4114BC83A29403FCC0813ED8088803FCC1000011E044000441A +:2004980084C00015854001158580020591400003810005C300C020B4008020B418E1504472 +:2004A00010A13D042900151E19400043110006032900121E194000831100064329000F1E53 +:2004A800194000C31100068329000C1E194003C3110009832900091E19400403110009C3E2 +:2004B0002900061E1940044311000A032900031E18C00383108009431880032688803FCCC9 +:2004B8001000011E044000449100050380800AC304C020B49CE13D04208006269940040305 +:2004C000081443009880044588803FCC1000011E04400044910005C380800B8320800126E4 +:2004C800081453409100060380800BC320800126081404C09100064380800C0320800126A6 +:2004D000081405809100070380800CC32080071E008020B410A1504410C00743008020B435 +:2004D80010A13D0410800D031880022691400743081401809100058380800B4320800626C7 +:2004E000014006040815530001002074211C7D042089883A081427C0910006C380800C8397 +:2004E800208001260810D8C09100068380800C432080012608143DC0014020B4010020B44A +:2004F0000180018429614A8421215804081555801000031E010020B421214A840814064086 +:2004F800014020B4010020B40180094429615044212142C4081558808805883AD022054546 +:20050000DFC00A17DF000917DDC00817DD800717DD400617DD000517DCC00417DC80031785 +:20050800DC400217DC000117DEC00B04F800283ADEFFF104DC000515040020B484213D041D +:20051000DF000D158700028701400704DD800B15E009883ADD400A15DCC00815DFC00E158F +:20051800DDC00C15DD000915DC800715DC40061508155300058020B480C005C3B5A16704C9 +:20052000B085883A0100008414C0030B154005431900031E848006039480004400000C060F +:20052800010000441900091E1080068B848003031104703A1000032690000426048000C409 +:20053000000003069024C03A000001060025883A80C0050B008020B40100800410A13D04EB +:2005380019001B2620C00836010010041900132601002004190013260100020419002A1EE5 +:200540001440040300002B06010200041900142620C00536010100041900231E108009435E +:200548000440014400000C060104000419001126010800041900142600001B06044000C416 +:2005500000001C06108009430440010400000206044001040000170688A3C83A000015068E +:20055800108007C31000101E9CFFFA04AD40030400000D06108007C310000D1E9CFFFA041D +:20056000AD40030400000A0610C00943108007C30440018488E3C83A1000061E9CFFFA04FE +:20056800AD400304000003060440004400000106044001448240040389803FCCE009883AD6 +:200570004DC03FCCB985C83A01400704D9800415DA400215D880001508155300B085883A50 +:200578001200028BD9000017400B883ADA000315081553001028D7FAE009883A0140070465 +:20058000A085883A1029D07A08155300B085883A11000503B80B883A08155300D90000178C +:20058800100B883AD880011508155300B80B883A1009883A081537C0A085883AB80B883AB8 +:20059000113FFFCC081537C0DA400217100B883A49003FCC0815530087000343DA00031787 +:20059800D8C00117E03897BA400B883AB809883AE0F8B03A102D883A081553001004927A49 +:2005A0008100098389403FCCE0B8B03A08155300A085883A1004953A00C020B418C42C04FE +:2005A800E084B03A1880003581000A0380800643D9800417200895FA100494FA80C007C36A +:2005B000300C943A2084B03A8100044318C00058180696FA2008937AB5BFFFCC1108B03A76 +:2005B80080800403100492BA2084B03A118CB03A358CB03A008020B430C6B03A1084200410 +:2005C00010C0003580C00683808003031806973A1004963A1886B03A808009C3100494BABE +:2005C8001886B03A900497BA18A4B03AA8BFFFCC90A4B03A98BFFFCC100491FA90A4B03AD1 +:2005D000008020B41084280414800035DFC00E17DF000D17DDC00C17DD800B17DD400A17EA +:2005D800DD000917DCC00817DC800717DC400617DC000517DEC00F04F800283ADEFFF004C4 +:2005E000DC000615040020B484213D04DC4007158440011700800044DFC00F15DF000E15A9 +:2005E800DDC00D15DD800C15DD400B15DD000A15DCC00915DC800815D0A2044588001626CB +:2005F00084C000179800142601006734880B883A213F3004081547401025883A8080020399 +:2005F80001283BF4980B883A212EC0041000042608154740880B883A1009883A00000306FC +:2006000008154740880B883A1089883A081547401023883A000002060445DC04048F5504D0 +:2006080001000EC40813E58001000F041027883A0813E5808080058300C0207418DA7404AC +:200610001085883A1085883A1885883A11C000178080020380C000171000021E00801A446B +:200618000000010600801C0401802074010020B4D8C00015319A2C04014004442121344446 +:20062000D880011508155B00014019048809883A081547400140FA049009883A1029883AEA +:2006280008154740014019048809883A102B883A08154D800140FA049009883AD88002156D +:20063000DD00011508154D80014002841009883A0815474001802074010020B4D880001530 +:20063800A80F883A319A2E040140044421214C0408155B00D0A20A831000011E0810D0C0C3 +:2006400081000017D1E2050381400203A00D883A044020B408148E0011003FCC2100201CD7 +:20064800213FE00400FFFFC48C613D0420C0011E0080010488800285858002830140070475 +:20065000048020B4D5A20105B5803FCCB580201CB5BFE004B009883A0815530094A1670421 +:2006580090B9883AE4400603D0A205038500040385C0011788A2703AD4620145E0C0040BE8 +:20066000A1403FCC9CC03FCC193FFFCCD8C00515081553009809883A100B883A0815530032 +:20066800B80B883A1009883A08154740D8C00517A5003FCCA00B883A1809883A102B883ABD +:2006700008155300123FFFCC80800B038C403FCCBDFFFFCC9027883A10000426E480068BCA +:200678009024D07A9480004C000001060025883A80800C0301400704B009883AD8800415CF +:2006800080800D03DA000515AD403FCCD880031580800CC3D8800215081553009885883A61 +:2006880011000583A00B883A0815530080C00483DA000517900F883A10C5C83A10BFFFCC4D +:20069000400B883AD8800115B80D883A8809883ADD40001508145FC081000C830810D8C0C8 +:2006980081000AC381400403081443008080044580800A43810003831000041E008020B4AA +:2006A00010A13D04114003C300000106000B883A08109480DFC00F17DF000E17DDC00D17A7 +:2006A800DD800C17DD400B17DD000A17DCC00917DC800817DC400717DC000617DEC0100459 +:2006B0000811430120803FCC00C003C410C00E2600C0040410C0112600C002C4D12203C389 +:2006B80010C0271EDEFFFE04DC000015DFC00115081376001021883A10000F2601C020746A +:2006C00039DA360400000E06D0A203C310C03FCC1800072610BFFFC400000506D0A203C38C +:2006C8000100020410C03FCC20C0013610800044D0A203C5F800283A01C0207439DA340411 +:2006D00001802074010020B4319A3904014004442121388408155B000810CF808000021E12 +:2006D800010003C408135A000100023421284804DFC00117DC000017DEC002040815F0811D +:2006E000200F883A01802074010020B4319A3A04014004442121388408155B0120803FCC6B +:2006E80000C003C410C00E2600C0040410C0112600C002C4D12203C310C0271EDEFFFE0465 +:2006F000DC000015DFC0011508135A001021883A10000F2601C0207439DA3E0400000E06D9 +:2006F800D0A203C310C03FCC1800072610BFFFC400000506D0A203C30100020410C03FCCD3 +:2007000020C0013610800044D0A203C5F800283A01C0207439DA3C0401802074010020B4C8 +:20070800319A3904014004442121388408155B000810CF808000021E010003C408135A0086 +:200710000100023421284804DFC00117DC000017DEC002040815F081200F883A018020741B +:20071800010020B4319A3A04014004442121388408155B0121003FCC008003C42080262684 +:200720000080040420802926DEFFFD04DC000015DFC00215040020B4DC400115008002C46D +:20072800842167042080281ED462010301400704D46204058C403FCC8809883A081553005C +:200730008085883A10C0040B014007048809883AD0E2030D10C00583D0E2058D10C0028BA9 +:20073800D0E2028D10C0030BD0E2020D10800503D0A2008D081553008085883A108005431B +:20074000D0A2048DDFC00217DC400117DC000017DEC00304F800283AD0A2010310C03FCC67 +:200748001800072610BFFFC400000506D0A20103010006C410C03FCC20C0013610800044A8 +:20075000D0A20105F800283AD12201030140070408155300010020B401800444808B883A99 +:2007580021213884DFC00217DC400117DC000017DEC0030408156C81DEFFFA04008020B4C6 +:20076000DD000415DCC00315DC800215DC400115DC000015DFC0051510A13D0410C002C3F9 +:20076800040020B42029883AD462040384216704D4E2008BD4A2048B18001E261080028786 +:2007700014401C1E8809883A01400704081553008085883A1100040BD0E2030B20C0131E14 +:2007780011000583D0E2058B20C0101E1100028BD0E2028B20C00D1E1100030BD0E2020BB2 +:2007800020C00A1E10C0050398803FCC1880071E014007048809883A081553008085883AC3 +:2007880010C0054390803FCC1880022600800044D0A205458809883A0140070408155300CF +:20079000D0E2030B8085883A8809883A10C0040DD0E2058B0140070410C00585D0E2028B67 +:2007980010C0028DD0E2020B14C0050510C0030D0815530001802074010020B48085883A44 +:2007A000A1FFFFCC319B3304014004442121388414800545DFC00517DD000417DCC00317FD +:2007A800DC800217DC400117DC000017DEC0060408155B01DEFFFE04DC000015040020B4CC +:2007B000DFC0011584043404008004448080003580000035008020B410842C0410000035A5 +:2007B800008020B410842804100000350109C4040815F08000BFF444D0A201850080344482 +:2007C00080800035010000F4210350040815F080018001B401406734010020B43186A004A8 +:2007C800297F30042104180408165D40081399800813CF80100022260009883A0813E580F8 +:2007D00000C03FC410C0202608144B00010000840810210010803FCC00C004C410C01C1EDE +:2007D8000810300008109DC01021883A10001A1E0812450001402074010020B401800D84EE +:2007E000295AD5042121598408155880010003C408137600D12203C308137600008020B492 +:2007E8001084300410800037108000AC1000011E08124C000009883A0810D20000000706CF +:2007F000043FFF8400000506043FFF4400000306043FFF0400000106043FFFC48005883AEF +:2007F800DFC00117DC000017DEC00204F800283ADEFFFF04DFC00015081177C00813FCC07E +:20080000008020B410A1504411000483DFC00017DEC001040810D201DEFFF504DFC00A15CF +:20080800DF000915DDC00815DD800715DD400615DD000515DCC00415DC800315DC40021515 +:20081000DC0001150811EB4010001B160080130401802074010020B4000F883A319A4104EF +:200818000140044421213444D880001508155B0001402074010020B401800444295A4D0451 +:2008200021214C04081558800810D0C00100023421284804054020B40815F080AD61504475 +:20082800A88007830100024410C03FCC20C01136D0A2038500000F0601802074010020B4BC +:20083000100F883A319A4604014004442121344408155B0001402074010020B40180044484 +:20083800295B420421214C0408156C800810D0C0003FFF06058020B405C020740700207402 +:200840000029883A0023883A0021883A0025883AB5A13D04BDDA7404E7086D0400C020B464 +:2008480018C430041880003710FFFFCCD0E208150086303A1004D63A18C000ECD0E2091560 +:20085000D0A20A051000062610FFFF8418C03FCC010000C420C0022ED0E2070310C0011ED6 +:20085800D022081508126680D0A20A83100002260009883A08131000B0C00583D0A2038354 +:2008600004C020B49CE13D041880011ED0220385D0E203830100020418BFFFC410803FCC7D +:2008680020803836100490BA1705883A108000171000683A008121D8008121E80081220026 +:2008700000812210008122200081223400812244008122540081226C008003C4D0A205056B +:200878000023883A00000306008003C4D0A2050504400084040000440025883A000023068F +:20088000008003C4D0A20505044000C4003FF906008003C4D0A20505044000C4000003067B +:20088800008003C4D0A20505044000840021883A003FF10600800404D0A205050440004420 +:2008900000000D06008003C4D0A205050023883A0000090604400084008003C4D0A20505F3 +:200898008821883A8825883A00000806008003C4D0A20505044000C4040000848025883A9E +:2008A0000000020618803FCC10002C2699400C8398C00585980002C528803FCC00C00044CB +:2008A80081003FCC1880042E00800144114BC83A29403FCC00000106014000C40813DDC07F +:2008B0000813F40089403FCC91003FCC0814738098800583010020B4018004441085883A05 +:2008B8001085883AB885883A11400017212134449800011508156C8001402074010020B447 +:2008C00001800444295A4A0421214C0408156C80D0A20A831000011E0810D0C0A5003FCC5D +:2008C800A0000526A8C00783008002841880021E010003C408135A0005000044A9000483DF +:2008D00098800A43208006260810D200008020B410A1504410800483B0000115B0800A45F8 +:2008D800A0803FCC1000322689403FCC91003FCC0810E9C010803FCC00C0008410C0252642 +:2008E00000C0010410C0032600C0004410C0281E00002406988002C310000926D0A20183E4 +:2008E80000C020B418C4340410800094D0A2018510803FCC188000350811FF0000001C068A +:2008F000B00001150813F400B0800583010020B4018004441085883A1085883AB885883A10 +:2008F800114000172121344408156C8001402074010020B401800444295A4A0421214C04DF +:2009000008156C80D0A20A831000091E0810D0C000000706988002C310000526081177C07B +:2009080000000306988002C31000012608114300D0A2091701004B04D0220385D0A206156D +:20091000D0A20A03D0A207050815F080003F330600C020B418E1504401402074DEFFFF04EF +:200918001809883A01800944295A7F04DFC00015081558801007883A008020B4108430046A +:2009200010800037014020741004D4BA010020B40180CB041080004C295C890421216704B9 +:20092800188004850815588000800044D0A205450005883ADFC00017DEC00104F800283A9F +:20093000DEFFF804DD000415DCC00315DC80021505002074048020B404C020B4DD800615B0 +:20093800DC000015DFC00715DD400515DC400115002D883A0021883AA51AE30494843004C6 +:200940009CE1598401402074010020B401800444295A89042121300408156C808405883AF0 +:200948001085883AA085883A11400017010020B4018004442121388408156C800810CF80DD +:200950000023883A054000849080003710BFFFCCD0A2081590C0003700C6303A18C000ECEE +:20095800D0E2091510001A26B08019268407883A98C7883A88000A1E01402074010020B428 +:2009600001800444295A8B04212130041880000D08156C800810CF800440004400000C0677 +:2009680018C0000B10C0092601402074010020B401800444295A8D042121300408156C8087 +:200970000810CF800023883A0000010604400084D0A2061710000F1ED0E2091700800074BA +:2009780018800C1E8000091E01402074010020B401800D84295AD5042121598408155880CA +:2009800004400084040006C400000206843FFF8404400084D0A20917D5A20817D0A20615F6 +:200988008D4003260109C4040815F080003FC6068400004400800684143FB20E010003C442 +:20099000DFC00717DD800617DD400517DD000417DCC00317DC800217DC400117DC0000178D +:20099800DEC0080408135A01D1220817DEFFFA04014020B4DFC00515DCC00415DC8003153B +:2009A000DC400215DC0001150005883A29615984018006841087883A1947883A18C0000B7B +:2009A800040020B484215984190003261180CE2610800044003FF70600C006841880CA361C +:2009B000100490BA00C0207418C9B60410C5883A108000171000683A0081274400812760F6 +:2009B800008127700081274C008127680081277800812758008129E80081278000812788F9 +:2009C00000812790008129E8008129E8008129E8008129E8008129E8008129E8008127B417 +:2009C8000081282C0081284C00812878008128C4008128A4008129E8008128F0008129187D +:2009D00000812940008000440000010600800084D0A203850000A406008000C4003FFC0625 +:2009D80000800104003FFA0600800144003FF80600800184003FF606008001C4003FF4067B +:2009E00000800204003FF20600800244003FF006D0A20A831007003AD0E20A851000031E7D +:2009E800010000440813100000008F060810D0C000008D06008020B410A13D0411000287CF +:2009F000014007040815530001C020B439E1670401802074010020B4388F883A319A91043E +:2009F800014004442121300408155B00008020B41084240411C00037108000370180207474 +:200A00001005D43A010020B439FFFFCC108000CC319A94040140044421213884D880001528 +:200A080008155B000810CF8000006F06D0A2018300C020B418C434041080041CD0A2018534 +:200A100010803FCC188000350000670600C020B418E15044188000030140004411003FCC94 +:200A1800290002361145883A000001060005883A1880000500005C0600C020B418E1504457 +:200A2000188000430140004411003FCC290002361145883A000001060005883A1880004516 +:200A280000005106008020B410A1504410C0008319003FCC2000012618FFFFC410C00085D1 +:200A30000000490600C020B418E15044188000830140038411003FCC290002361080004402 +:200A380000000106008003C41880008500003E0600C020B418E15044188005030140078462 +:200A400011003FCC290002361080004400000A060005883A0000080600C020B418E150443F +:200A48001880050311003FCC2000022610BFFFC400000106008007C41880050500002A06D4 +:200A500001402074010020B401800444295A98042121300408156C8001402074010020B4CB +:200A580001800444295A9C042121388408156C80044020B40810CF808C443004048006C4BA +:200A600004C00244888000370009883A10BFFFCC2107883A1C07883A18C0000B10C003261D +:200A68002100004424BFFA1E0000080699000716014002842100004408154000010002C4FA +:200A7000D0A203C50811AC40000005068080060B110003260109C4040815F080003FE90644 +:200A78000810D0C0D0220A85D0A206171000191ED0E209171880006C10000A26008020B4F5 +:200A800010A13D04108005830100024411403FCC29000226108000440000010600800044B9 +:200A8800D0A2038518C000AC18000A2600C020B418E15044188000030140004411003FCC2B +:200A9000290002361145883A000001060005883A18800005DFC00517DCC00417DC8003177A +:200A9800DC400217DC000117DEC00604F800283ADEFF6C04D9000304DC008C15DFC0931522 +:200AA000DD809215DD409115DD009015DCC08F15DC808E15DC408D150810C7401021883ADE +:200AA80008152BC08000891E01800104D9400304D900830408156C80014020740180010495 +:200AB000295AFE04D90083040815668010000B2601802074010020B4319B000401400444BA +:200AB8002121300408155B00008020B410A13884100000050400004400007406D880040339 +:200AC000DC808484D9400484D8808405D8800443018002049009883AD880844508156C8085 +:200AC800D880068BD8008645D8808B0DD880070BD8808B8DD9408B17280BC232D880078BEC +:200AD000D9408715D8808B0DD880080BD8808B8DD8808B171005C232D8808815D880088BA3 +:200AD800D8808B0DD880090BD8808B8DD8808B171005C232D8808915D8808217D8808B1550 +:200AE0001005C232D8808A1500C0788428BFF98418800B2E01802074010020B4319B040447 +:200AE800014004442121300408155B00008020B410A1388410000005043FFFC40000430652 +:200AF00001800044D900030408165600D8C08A1710C00A2601802074010020B4319B0804D2 +:200AF800014004442121300408155B00008020B410A1388410000005000033060180207443 +:200B0000010020B4319B0C04014004442121300408155B00D9C0881701802074010020B48B +:200B0800319B1004014004442121388408155B000810CF80DCC08817DD4089170021883AAC +:200B10000005883A0580800484C0132E9C23C83AB440012E0440800485008004A00CD27AC3 +:200B1800010020B4DC400015000F883AD940030421212D040815140010803FCC1000121E47 +:200B2000800D003A880B883AD900030408165600A021883A003FEC06A880612601802074CD +:200B2800010020B4319B1304014004442121300408155B00008020B410A1388410000005A8 +:200B3000043FFF4400000106043FFF8404C000C408152BC00810CF80010003F4211090049E +:200B38000815F08000BFCE4480804B0E98004A2601802074010020B4319B29040140044472 +:200B40002121300408155B009CFFFFC401402074010020B401800444295B2104212138842F +:200B480008156C800810CF800025883A0580800405004004DC4088179440202E8CA3C83AD6 +:200B5000B440012E0440800495408004A80DD27A010020B4DC400015000F883AD940030449 +:200B580021212D040815140014003FCC803FD81E9025D23A880B883AA440012E0140400457 +:200B6000900D883AD90003040810A7801021883A103FCF1EA4400236A825883A003FE506F3 +:200B680091800044897FC004D90043040810A7801021883A103FF826003FC50601402074AE +:200B7000010020B401800444295B25042121300408156C8001402074010020B40180044428 +:200B7800295B21042121388408156C800810CF80D9808917D9408817D9C003040009883A2A +:200B80000810BA001021883A103FB11E08152BC00005883A0000430600BFFFC40000410691 +:200B8800D8808487D9C08403D8C084431000032600802074109AC80400000206008020748C +:200B9000109B420401802074010020B4D8C00015319B18040140044421213004DC80021563 +:200B9800D880011508155B0001402074010020B401800444295B2D0421213884081558803C +:200BA000044020B4040020B40810CF808C443004842159848880003780C0000B10BFFFCC34 +:200BA80010C00E2680C0008B10C0091E01402074010020B401800444295B1B0421213004DB +:200BB00008156C8004C000C404000084003F80060109C4040815F080003FEE060813F400A6 +:200BB800D0A2018300C020B418C4340410800094D0A2018510803FCC188000350109C40429 +:200BC0000815F08001402074010020B401800444295B1E042121300408156C8004C000C468 +:200BC800003F7A06DFC09317DD809217DD409117DD009017DCC08F17DC808E17DC408D17B3 +:200BD000DC008C17DEC09404F800283A21C03FCC01802074010020B4319B32040140044495 +:200BD8002121388408155B01DEFFFF040141194421003FCCDFC00015081553000140190459 +:200BE0001009883A081537C001802074010020B4100F883A319B34040140044421213884B0 +:200BE800DFC00017DEC0010408155B0121C03FCC01802074010020B4319B360401400444B6 +:200BF0002121388408155B01014003F4DEFFFC042950900421003FCCDFC00315DC40021536 +:200BF800DC00011508155300014018F4294BA8041009883A1021883A081547408009883A51 +:200C0000014659041023883A081547400140FA041009883A08154D80014002841009883AF1 +:200C08000815474001802074010020B4D8800015880F883A319B39040140044421213884E8 +:200C100008155B00DFC00317DC400217DC000117DEC00404F800283ADEFFFF04014119C46B +:200C180021003FCCDFC0001508155300014019041009883A081537C001802074010020B435 +:200C2000100F883A319B3C040140044421213884DFC00017DEC0010408155B0121C03FCC82 +:200C280001802074010020B4319B3E04014004442121388408155B0121003FCCDEFFFF04A8 +:200C300001409C4421000044DFC0001508155300014019041009883A081537C00180207498 +:200C3800010020B4100F883A319B41040140044421213884DFC00017DEC0010408155B017C +:200C4000D0A20817DEFFF604018020B4DCC00315DFC00915DF000815DDC00715DD80061539 +:200C4800DD400515DD000415DC800215DC400115DC00001504C002C431A159840140044407 +:200C50009CC7883A1987883A18C0000B1880041E21003FCC9823883A2000051E000003066B +:200C58009CC00044997FF61E0000A50610010026D5620A4304802074949D7104AF003FCCD2 +:200C6000E02090FA014005049405883A1500010315C00017A5803FCCB009883A0815530025 +:200C6800B8C00117010001041885883A88FFFD0418C03FCC20C02936180690BA01002074D0 +:200C7000210C74041907883A18C000171800683A00813218008131E4008131FC0081331061 +:200C780000813310B000011EBD000003A53FFFC49421883A8500010500008406B9400003DA +:200C80009421883AB100004484000104081540008080000500007D06E0000326AD7FFFC482 +:200C8800D5620A4500007906D0220A85DFC00917DF000817DDC00717DD800617DD4005179B +:200C9000DD000417DCC00317DC800217DC400117DC000017DEC00A040810D0C110C00103D1 +:200C9800014000C4194006261900631E10800217044002C4103EE83A1021883A0000640698 +:200CA0001080031710000226010002C4103EE83AD4620A43014005048C003FCC802690FA87 +:200CA80094C5883A1540001711000103AD00011708155300A085883A10C0021718004E26FF +:200CB00084000044802090FA00802074109D71041405883A110000171900012610000105A3 +:200CB8009421883A94E5883A91000103ACC0011701400504081553009885883A108002170F +:200CC0008C400044D4620A458080001500003A0610C0010301000084190020261900033620 +:200CC800010000C419002F26000038061180021789C03FCC020003C41100030310C00343A7 +:200CD00031400003108003833A000A1E19C03FCC2A003FCC3A00022E28BFFFC400000306E2 +:200CD80021003FCC2000011E1805883A308000050000260611C03FCC2A003FCC41C0022E8F +:200CE000288000440000030621003FCC200001261805883A308000050000100611000217B8 +:200CE80089403FCC018003C420C0000B2980061E1080030B197FFFCC1140012E18FFFFC4BD +:200CF00020C0000D000011061080038B197FFFCC2880012E18C0004420C0000D0440040433 +:200CF80000000A06108003171000082699003FCC103EE83A00000506044002C400000306B2 +:200D000021003FCC200059260023883A0021883AD0A20A4300C0207418DD7104100490FA25 +:200D0800014005041885883A1100010314C00017081553001025883A98800117010020B4B6 +:200D1000212130041485883A114000170180044408156C8098800117010001041485883A27 +:200D180010C0010320C03536180690BA01002074210D20041907883A18C000171800683AC2 +:200D200000813494008134C4008134D4008134E4008134F810C00217110004170180044444 +:200D280018C0000318C5883A1085883A2085883A11400017010020B42121388408156C802F +:200D300000001E0610C0021710800417190000030000070610C00217108004171900000B0A +:200D38000000030610800317100006260009883A103EE83A000011068C403FCC00C002C4FD +:200D400088C00426008020B410A138841000000500000A068000021E11C0031700000106A9 +:200D480011C0041701802074010020B4319A3904014004442121388408155B00DFC00917EF +:200D5000DF000817DDC00717DD800617DD400517DD000417DCC00317DC800217DC400117C0 +:200D5800DC000017DEC00A040810CF81103FA61EDFC00917DF000817DDC00717DD8006176F +:200D6000DD400517DD000417DCC00317DC800217DC400117DC000017DEC00A04F800283AEA +:200D680021003FCC008003C411005F36009114B4DEFFB6041094D544D88000150080107434 +:200D700010951044D880011500801304D8800245208002B0DC004015DFC04915DF0048150A +:200D7800DDC04715DD804615DD404515DD004415DCC04315DC804215DC404115D800020505 +:200D8000D8800285240004041000151E00800E04D88002C5D0A203C3014020B401800D84F5 +:200D8800D8800345008020B410A13D041080058329615984D90003C4D8000305D880038586 +:200D900008155880800C923A01401144D809883A0810A7801004C03A0085C83A00003406AF +:200D980000800B04014020B4802A923A01800944D880034529615044008000C4D90003C4B1 +:200DA000070020B4D98002C5D8000305D88003850025883A08155880002F883A04400D0456 +:200DA8000580CB0405004004E7216704893FFFCCA10DC83AB0BFFFCCD909883AB97FFFCCF7 +:200DB00094C03FCC11800C16E14B883A08155880A463C83A9D4D883A01404004D809883A51 +:200DB8008DEF883AB5BFC0040810A780948000440023883A003FED06100D883A008020B4C4 +:200DC00010A16704114B883A08155880800C923A01404004D809883A34CD883A0810A78062 +:200DC8000005883A0000020600BFFFC4F800283ADFC04917DF004817DDC04717DD8046176E +:200DD000DD404517DD004417DCC04317DC804217DC404117DC004017DEC04A04F800283ABA +:200DD800DEFFB704DFC04815DDC04715DD804615DD404515DD004415DCC04315DC80421562 +:200DE000DC404115DC00401521003FCC008003C41100022E047FFFC40000630624000404C1 +:200DE8008008943AD80D883A014040040810A080103FF81E0140207401800204295C7A046D +:200DF000D809883A081566801023883A1000531ED88002031000531ED8C002430080130475 +:200DF8001880501ED88002831000032600C0004410C0162600004C06D8800303D8C002C3A2 +:200E00001004923A10C4B03A00C00E0410C0461ED880034300C0024411003FCC190001361E +:200E0800D0A203C5D880038311003FCC19000136D0A20385010020B401800D84D94003C485 +:200E1000212159840815588000003706D8800317D8C002C311803FCC300C923A30CCB03A18 +:200E180000C0094430C0301E1004D23A00C0CB041025883A10BFFFCC10C02B1E010020B441 +:200E20008020923AD94003C42121504405C020B4081558800027883A002D883A05400D04D4 +:200E280005004004BDE16704A97FFFCCA14DC83A90BFFFCCB13FFFCCD94B883A11800F1604 +:200E3000B909883A08155880990000442027883A21003FCC2409883A2008923AA56BC83A22 +:200E3800D80D883A01404004ADAD883A94BFC0040810A080002B883A003FEB06100D883A07 +:200E4000008020B410A167041109883A0815588000800044D0A20545000003060440004440 +:200E480000000106044000848805883ADFC04817DDC04717DD804617DD404517DD00441708 +:200E5000DCC04317DC804217DC404117DC004017DEC04904F800283ADEFFFD04D90000052F +:200E5800010020B4DC000115018000442821883A21041804D80B883ADFC002150816728037 +:200E6000813FFFCC0815F080DFC00217DC000117DEC00304F800283AD0E20183DEFFFC049C +:200E680000BFE7C41884703ADC400115044020B4D0A20185DFC00315DC800215DC0000155D +:200E700010803FCC8C44340488800035040005048009883A0815F080800B883A01000E043D +:200E780008139580800B883A01000E4408139580800B883A8009883A08139580800B883A45 +:200E800001001C4408139580800B883A0100178408139580800B883A01001B4408139580CB +:200E8800800B883A01000304081395800480C804900B883A0100004408139580800B883A56 +:200E90000100018408139580900B883A0100008408139580D0A2018310801014D0A20185D8 +:200E980010803FCC88800035DFC00317DC800217DC400117DC000017DEC00404F800283A0D +:200EA000D0E20183DEFFFA0400BFE7C41884703ADC000015040020B4DC800215DC40011503 +:200EA800D0A20185DFC00515DD000415DCC003152025883A2823883A10803FCC8404340460 +:200EB000808000350140C8040100004408139580D0A2018310800814D0A2018510803FCC36 +:200EB80080800035014004049009883A081571C01029883A10803FCC1000091E0140207451 +:200EC0009009883A01800444295C7C0408156C8091000003014005040813958000000906C3 +:200EC8000027883AA5003FCC94C5883A11000003014005049CC000440813958098803FCC05 +:200ED000153FF936D0E2018300BFF7C41884703AD0A2018510803FCC808000350140050477 +:200ED8000100300408139580D0A2018310800814D0A2018510803FCC8080003501400404E2 +:200EE0008809883A081571C01027883A10803FCC1000091E014020748809883A0180044495 +:200EE800295C7C0408156C80890000030140050408139580000009060025883A9CC03FCC79 +:200EF0008C85883A1100000301400504948000440813958090803FCC14FFF936D0A20183D6 +:200EF80010801014D0A2018510803FCC80800035DFC00517DD000417DCC00317DC80021780 +:200F0000DC400117DC000017DEC00604F800283ADEFFFB04DC000015040020B4840418045F +:200F0800DC80021504800B04DCC00315900B883A2027883A000D883A8009883ADFC00415D7 +:200F1000DC4001150816648004400044880D883A99403FCC8009883A08166AC0900B883ADA +:200F18008009883A880D883A08166480880B883A8009883ADFC00417DCC00317DC80021790 +:200F2000DC400117DC000017DEC0050408166801DEFFFC04DC000015040020B48404180412 +:200F2800DC800215DC4001152025883A2823883A8009883A000D883A01400B04DFC00315CF +:200F30000816648091403FCC8009883A000D883A08166AC00180004489403FCC8009883A7D +:200F3800DFC00317DC800217DC400117DC000017DEC0040408166AC1010020B4DEFFFD04A2 +:200F4000000D883A000B883A21041804DFC00215DC400115DC00001508166AC0010002840C +:200F48000815F0800400060404400044800B883A8809883A0813C900800B883A0100008410 +:200F50000813C900800B883A010000C40813C9008809883A0813C1001405003ADFC002176D +:200F5800DC400117DC000017DEC00304F800283ADEFFFD04DC400115DC00001504400044CA +:200F60002021883A84003FCC8809883ADFC00215802090FA0813C10000FFF9C410C4703A96 +:200F680080A0B03A84003FCC800B883A8809883A0813C900800B883A010000840813C90096 +:200F7000800B883A010000C4DFC00217DC400117DC000017DEC003040813C901DEFFFD0408 +:200F7800DC4001152023883A01000044DC000015DFC00215043FF6040813C1001420703A3F +:200F800089003FCC008000842080021E84000054000003062008917A2080011480A0B03A26 +:200F880084003FCC800B883A010000440813C900800B883A010000840813C900800B883A41 +:200F9000010000C4DFC00217DC400117DC000017DEC003040813C901DEFFFB04DC00001546 +:200F9800040020B484041804DC80021504801704DCC00315900B883A2027883A000D883AC2 +:200FA0008009883ADFC00415DC4001150816648004400044880D883A99403FCC8009883AEC +:200FA80008166AC0900B883A8009883A880D883A08166480880B883A8009883ADFC0041786 +:200FB000DCC00317DC800217DC400117DC000017DEC0050408166801DEFFFC04DC000015D3 +:200FB800040020B484041804DC800215DC4001152025883A2823883A8009883A000D883ACA +:200FC00001401704DFC003150816648091403FCC8009883A000D883A08166AC001800044F9 +:200FC80089403FCC8009883ADFC00317DC800217DC400117DC000017DEC0040408166AC1A6 +:200FD000DEFFFC04DC000015040008848009883ADFC00315DC800215DC4001150813E5807C +:200FD800014004C4010005841023883A0489C4040813ED809009883A0815F080014000C4A7 +:200FE000010005C40813ED809009883A0815F080017FE004894AB03A29403FCC8009883AD7 +:200FE8000813ED800100FA040815F08089401FCC8009883ADFC00317DC800217DC40011774 +:200FF000DC000017DEC004040813ED81DEFFFE04DC0000150409C4048009883ADFC001151A +:200FF8000815F08001400444010005840813ED808009883A0815F08001400084010005C44A +:201000000813ED808009883ADFC00117DC000017DEC002040815F081DEFFFE04DC00001551 +:201008002821883A21403FCC01000484DFC001150813ED8081403FCC010004C4DFC001173F +:20101000DC000017DEC002040813ED8121403FCC01000F440813ED8121403FCC01000444A2 +:201018000813ED81DEFFFE04DFC00115DC000015214000C32021883A010002840813ED8074 +:2010200081400103010002440813ED8081400143010002040813ED8081400003010003447C +:201028000813ED8081400043010003040813ED8081400083010002C4DFC00117DC000017D7 +:20103000DEC002040813ED81DEFFFB04DC400115DC0000152023883A2021883A0100010466 +:20103800DCC00315DC8002153027883A2825883ADFC004150813E580017FFE049CC03FCC28 +:201040001144703A9800092680FFFFCC0101FFC420C006361140005429403FCC0100010480 +:201048000813ED808423883A0000030611403FCC010001040813ED808C7FFFCC880AD13A31 +:201050000100004429403FCC0813ED80880A913A0100008429403C0C0813ED800100673488 +:20105800917FFFCC213F300408154740880B883A1009883A081553000140FA041009883AAB +:201060000815474000E327D41880092E00C0007418C45BC41880082E00C000B418C3D5C43A +:201068001885403A00C000C41885C83A000003060005883A000001060080004414003FCC74 +:20107000D0A01E041405883A1100000301400A04081553008808D07A880B883A1109883A15 +:20107800081537C0100B883A00C001C410803FCC1880012E180B883A29403FCC800491BA58 +:20108000280A90FA010000C4288AB03A29403FCCDFC00417DCC00317DC800217DC400117A6 +:20108800DC000017DEC005040813ED81DEFFFE04DC0000152021883A01000684DFC0011512 +:201090000813E580017FFE8484003FCC00C000441144703A80C0021E1080009400000106A1 +:201098001080029411403FCC01000684DFC00117DC000017DEC002040813ED812140028B66 +:2010A000DEFFFE04DC000015280AD23A2021883A010012C4DFC001150813ED8081400283C5 +:2010A800010012840813ED808140030B01001344280AD23A0813ED8081400303010013043D +:2010B0000813ED808140038B010013C4280AD23A0813ED8081400383010013840813ED8044 +:2010B8008140010B01001444280AD23A0813ED8081400103010014040813ED808140018B79 +:2010C000010014C4280AD23A0813ED8081400183010014840813ED808140020B01001544E3 +:2010C800280AD23A0813ED8081400203010015040813ED808140040B010015C4280AD23AF2 +:2010D0000813ED8081400403010015840813ED808140048B01001644280AD23A0813ED801D +:2010D80081400483010016040813ED808140050B010016C4280AD23A0813ED8081400503D2 +:2010E00001001684DFC00117DC000017DEC002040813ED81DEFFFD04DC00001504000FC4D8 +:2010E800DC4001152023883A8009883ADFC002150813E58000FFFC0410C4703A888AB03AB7 +:2010F00029403FCC8009883ADFC00217DC400117DC000017DEC003040813ED81DEFFFD0436 +:2010F800DC40011504400684DC0000152021883A8809883ADFC002150813E58080C03FCC10 +:20110000014000C428C7C83A180691BA10800FCC8809883A188AB03A29403FCCDFC00217FA +:20110800DC400117DC000017DEC003040813ED81DEFFFB04DCC0031504C00104DC400115E7 +:201110002023883A9809883ADFC00415DC800215DC0000152825883A0813E580900B883A4F +:201118008809883A1021883A08155300108007CC100A90FA840001CC9809883A2C0AB03A26 +:201120000813ED8091403FCC89003FCC081553001004D17ADFC00417DCC00317DC80021703 +:20112800DC400117DC000017DEC00504F800283ADEFFFF04DFC000150813F4000009883A11 +:20113000081422C0000B883A01000D440813ED8001002074211C7D04081427C0014000441F +:2011380001000404081443000009883A081439400009883A08143DC001000184081404C085 +:20114000014000C401000D040813ED80010011040814058001402204010006C40813ED807F +:201148000140020401000704DFC00017DEC001040813ED81DEFFFD04DC0000152021883A80 +:20115000DC40011584003FCC044004048809883A802090FADFC002150813E580108001CC62 +:20115800808AB03A29403FCC8809883ADFC00217DC400117DC000017DEC003040813ED81AF +:2011600021003FCC20001A26DEFFFD04DC400115010009842823883A01402004DC000015E2 +:20116800DFC002153021883A0813ED8089403FCC0080004428800426008002042880041E5C +:20117000814016840000030681400244000001068140060429403FCC01000C44DFC00217A5 +:20117800DC400117DC000017DEC0030400000206000B883A010009840813ED81DEFFF604C8 +:20118000DD0004152829883AD9400A17DF000815DDC00715DD800615DD400515DCC00315F4 +:20118800DC800215DC400115DC000015DFC0091524003FCC00800044302B883A382D883ABD +:20119000DC400B17DC800C17DCC00D17DDC00E172F003FCC808008260080020480800D1EE7 +:2011980029400C8429403FCC010001440813ED800140080400000C062940008429403FCC3C +:2011A000010001440813ED80014001842809883A000006062940018429403FCC01000144F4 +:2011A8000813ED8001400404010001840813ED80E00D883A800B883A010000440814580093 +:2011B000B9003FCC08140580008004048080021E01400304000001060140020401000884EF +:2011B8000813ED80B1803FCCA97FFFCCA13FFFCC08140C8099403FCC91003FCC08140180F0 +:2011C00089403FCC010001C4DFC00917DF000817DDC00717DD800617DD400517DD00041752 +:2011C800DCC00317DC800217DC400117DC000017DEC00A040813ED81DEFFFD0429BFFF8437 +:2011D000DC400115DC000015DFC0021531803FCC0080004424403FCC2C003FCC1180043635 +:2011D800008000848880071E8805883A000008068800061E8005003A00C000841885C83A1B +:2011E000000003060005883A0000010600800084880A913A8C47883A10803FCC100491BA28 +:2011E80018C7883A28CAB03A214AB03A288AB03A29403FCC010006440813ED80008000C4EE +:2011F0008080041E01401744010004040813ED800000120601401604010004040813ED808C +:2011F8000080008488800D1E0080004414000B368080021E0140148400000106014014C46E +:20120000010003840813ED800100FA040815F080010005040813E58000000B06014016C47C +:20120800010003840813ED800100FA040815F080010005040813E580008000C48080021E3C +:201210000140040400000106000B883A010006040813ED80000B883A01000D84DFC00217F7 +:20121800DC400117DC000017DEC003040813ED81DEFFFD04DC4001152023883A0100050442 +:20122000DC000015DFC002152821883A0813E5808C403FCC00C0008488C00A1E81403FCC25 +:2012280000C0004428C0031E1080240C10802420000006062800031E1080220C1080222020 +:20123000000002061004D07A1080004CDFC00217DC400117DC000017DEC00304F800283A7E +:20123800DEFFEC0400800104DC000A15040020B484213D04D880070D00800204D880078DAD +:20124000808007030280040400C040045084983A0182000483000A83D880080D8080074302 +:20124800020020B4DFC013151884983ADF001215DDC01115D880088D80800783DD801015B9 +:20125000DD400F153084983ADD000E15DCC00D15D880090DD8800984D8800015808008042D +:20125800D880011580800844D880021580800884D8800315808008C4D8800415D8800515A2 +:2012600080800904DC800C15203F883ADC400B15D8000985D880061542216D040009883A0F +:20126800034001040380200403C100040480100404C0020405000144054001840580004470 +:2012700005FFFEC40700008440C000432023883A4080000319803FCC3340071E62403FCC19 +:201278004800031E027FFBC44884703A00000A064F00091E00009C063500061E62403FCC09 +:201280004800021EB884703A000003064D80021E00009506A980943611C4703A10803FCC62 +:20128800100091263185883A1085883AD885883A108000174240008B108000031085883AF3 +:20129000D885883A1080070B1256703A5AFFFFCC580085264A40004C2AC03FCC4A40005C93 +:201298005A40811E427FFE8B4A4007844FC07E3602C00044024020B48080050D80000385A5 +:2012A000800003C582C004058000048510BFFFCC4A613D041380502670800B3612804726D3 +:2012A8005080033613401C2614C0222600006E0600C0080410C0432614806B1E00800084D2 +:2012B0008080030500004B0613C04E267880083602C0400412C0432600C0800410C0621E73 +:2012B800008000C480800305008000840000410602C4000412C04A2600C8000410C0512660 +:2012C00002C2000412C0581E0080010480800305800003450000510618C03F4C18C00060B7 +:2012C800480003054800034548C0038548C003C500002006008000441A3FFFC4014020B4AB +:2012D0008080030542003FCC01C0008429613D04008000443A0005360200008429C00345A9 +:2012D8002A00040531C0021E000011062800034518FFFF0418C03FCC10C00A2E0080018421 +:2012E00030800A1E014007040815530000C020B418E16B0410C5883A1080000B10812C303F +:2012E8000000030600800044000001060005883A808003858805883A00003006008000843A +:2012F0000000090600800084488003050080004448800345003FF706008000844880030517 +:2012F80000000B06008000C44880030548000345003FF00680800345008001048080040516 +:20130000003FEC06008000C44880030500800084488003450080014448800405003FE506B4 +:2013080000800104488003050080008448800345008001444880040500801B0448800485D6 +:20131000003FDC0600800104808003050080008480800345008001848080040500801B0416 +:2013180080800485003FD30621000044008007444200070420BF541E00BFFFC4DFC01317FB +:20132000DF001217DDC01117DD801017DD400F17DD000E17DCC00D17DC800C17DC400B179A +:20132800DC000A17DEC01404F800283A20803FCCDEFFF9041080201CDC400415DFC0061558 +:20133000DC800515DC00031510BFE0042823883A10000A0E2025883A000B883A01001DC495 +:201338000814CAC0D880028510C03FCC0100004420C02E3694001FCC000001062021883A23 +:2013400008152BC0014001040009883A0815288008152A008804D63ADC000005DC400105C9 +:20134800D88000458804D43A84003FCCD88000858804D23AD88000C500801004808004266F +:20135000008012048080041E00BFE1C40000030600BFE544000001060080004401400184DF +:20135800D809883AD88001450815274001000144081531801021883A04400044014000449C +:20136000D900028408152880D8800287100003168000051E0815374000000306081535406D +:20136800147FF626003FFA06D8800283DFC00617DC800517DC400417DC000317DEC0070490 +:20137000F800283ADEFFF604DC000515000B883A2021883A01001244DFC00915DCC0081599 +:20137800DC800715DC4006150814CAC010803FCC100002260005883A0000430601000144D7 +:20138000081531801023883A0480004404C03FC401400044D900048408152880D880048371 +:2013880014C003268800051E08153740000003060815354014BFF626003FFA06D8C0048321 +:2013900000803F8418BFEB1E01400484D809883A081528808080010310C0008C1800132638 +:20139800D8800183D8C001C3D9400143108000CC1004923A294003CC10C8B03AD88002030D +:2013A0001006D1BA2105883A1085883AD900028310C4B03AD8C002432008D1FA18C000CCBD +:2013A80018C7883A20C8B03A000010061080010C10000B26D88001C3D9000203000B883AF7 +:2013B00010800FCC1004923A1104B03A1006923AD8800243010004441884B03A000003067C +:2013B800000B883A0009883A0005883A10BFFFCC10C0004421003FCC28803FCC2085883AC2 +:2013C00010BFFE441884983ADFC00917DCC00817DC800717DC400617DC000517DEC00A04BD +:2013C800F800283ADEFFF60401402074DCC00715018002842027883A295D5404D809883AB6 +:2013D000DD000815DC400515DFC00915DC800615DC000415050000C408155880044000445E +:2013D8000815258008152BC008152FC001400284D809883A08152740000B883A98000015B7 +:2013E000010010040814CAC010803FCC1440511E01406A84010012040814CAC010803FCC4D +:2013E8001440271E01400104D900028408152880D88003031440471ED8C0034300802A84BF +:2013F0001880441E0100FA040815318008153540144003260815354014400C1E00000606EB +:2013F8000150003401003A440814CAC010803FCC103FF61E003FF706000B883A01001E8481 +:201400000814CAC010803FCC100002260021883A0000090601400104D900028408152880F7 +:20140800D88002831080100C1000021E040001040000010604000304081537400000260630 +:20141000000B883A01003A440814CAC010803FCC8880032E040000440480104400000206CE +:201418000400008404BFFA4401003E840815318094803FCC081535401440042608153540D9 +:201420001000081E0021883A00000606000B883A9009883A0814CAC010803FCC103FF51EBC +:20142800003FF60608153740000B883A01001EC40814CAC010803FCC100001260021883ACA +:2014300001408004010014040814CAC010803FCC100001260021883AA0BFFFC41029883A46 +:2014380010803FCC84803FCC10000A26903F9C26008000449C000105988000159809883A23 +:201440000814DC4010BFFFC49880021508152E0000000106903FF61E081529C09005003A89 +:20144800DFC00917DD000817DCC00717DC800617DC400517DC000417DEC00A04F800283A61 +:2014500020800217DEFFF804DC000115DFC00715DD400615DD000515DCC00415DC800315E5 +:20145800DC400215DC0008171180313684BFFFCC90002F26208001032827883A3823883A89 +:201460001080020C300B883A1000011E300A927A010014440814CAC010803FCC100002268A +:201468000400008400001F0601001904081531800500004405403FC401400044D809883A12 +:2014700008152880D88000031540052608153740D8C0000300803F8418BFF11E000003065B +:2014780008153540153FF426003FF806008080841445C83A897FFFCC1421C83A28000226DE +:201480000009883A08152880900B883A9809883A08152880817FFFCC0009883A08152880DC +:201488000021883A081529C08005883A00000106008000C4DFC00717DD400617DD000517D9 +:20149000DCC00417DC800317DC400217DC000117DEC00804F800283A018001B401406734D0 +:20149800010020B43186A004297F30042104100408165D41280D883A200B883A010020B47A +:2014A0002104100408167281280D883A200B883A010020B42104100408166E81F800283A89 +:2014A800D0A2018300C020B418C4340410801FCCD0A2018518800035F800283AD0E20183B6 +:2014B00000BFE0041884B03A00C020B4D0A2018518C4340410803FCC18800035F800283A91 +:2014B80001800A7401406734010020B4318CB804297F30042104100408165D41018001B4E4 +:2014C00001406734010020B43186A004297F30042104100408165D41D0A20B1710000B1E62 +:2014C800DEFFFF04015A5E04213FFFCCDFC0001508155300D0A20B150815F5000005883AAD +:2014D000DFC00017DEC00104F800283A00800044F800283ADEFFFF04DFC000150815F8C0C2 +:2014D800D0E20B1710C5803ADFC00017DEC00104F800283AD0220B15F800283A20001B1621 +:2014E000000F883A28001616200D883A29001A2E0080080400C000440000010610000D268D +:2014E800294B883A10BFFFC418C7883A293FFB360005883A180007260005883A3140023666 +:2014F000314DC83A10C4B03A1806D07A280AD07A183FFA1E380001260085C83AF800283A0B +:2014F800014BC83A39C0005C003FE7060109C83A01C00044003FE30600C00044003FEE0695 +:2015000020001716000F883A2005883A280012162900162E0180080400C000440000010671 +:2015080030000A26294B883A31BFFFC418C7883A293FFB36180005261806D07A114001360D +:201510001145C83A280AD07A183FFB1E380001260085C83AF800283A014BC83A003FEC06B8 +:201518000109C83A01C00044003FE70600C00044003FF106200D883A2900152E280014168F +:201520000080080400C000440000020610000E2628000516294B883A10BFFFC418C7883A23 +:20152800293FFA36180008260005883A31400236314DC83A10C4B03A1806D07A280AD07A33 +:20153000183FFA1EF800283A0005883AF800283A00C00044003FF4062005883A2900122E24 +:20153800280011160180080400C000440000020630000C2628000516294B883A31BFFFC41D +:2015400018C7883A293FFA36180006261806D07A114001361145C83A280AD07A183FFB1EDA +:20154800F800283AF800283A00C00044003FF7060005883A2000072620C0004C2008D07ADD +:20155000180001261145883A294B883A203FFA1EF800283AF800283A218D883A2180082684 +:201558002080000328C0000310C0022610C5C83AF800283A2100004429400044003FF7066E +:201560000005883AF800283A2005883A2007883A218D883A198005262900000318C00044FE +:2015680029400044193FFFC5003FFA06F800283ADEFFF504DFC00915DC400815DC0007153D +:20157000D9C00A1500802074109F3604144000172800040E008022C48880001500BFFFC4FC +:2015780000001C0600C08204D8C0000DD9000415D90002152800022628FFFFC40000010623 +:201580000007883AD8C00515D8C003151100001700FFFFC4D8C0008D00C0207418D7360494 +:201588002821883AD9C00A04D80B883AD8C00115D800061508157AC000FFFFC410C0020E52 +:2015900000C022C488C0001580000226D8C0041718000005DFC00917DC400817DC000717CC +:20159800DEC00B04F800283A3000152631BFFFC4218D883A2080000328C0000311C03FCC34 +:2015A0001A003FCC39C0201C4200201C39FFE004423FE0043A00061E218004263800032648 +:2015A8002100004429400044003FF2061007883A18C03FCC10803FCC10C5C83AF800283A52 +:2015B0000005883AF800283A2005883A200F883A30000C262A00000338C0004431BFFFC4A4 +:2015B8003A00000542003FCC4200201C423FE00429400044180F883A403FF51E198D883A14 +:2015C00000000106F800283A30C003261800000518C00044003FFC06F800283A214B883A8F +:2015C8002005883A1140021E1105C83AF800283A10C00007183FFC2610800044003FF906D7 +:2015D000DEFFFB04DC800315DC400215DC000115DFC004152025883A2823883AD98000055C +:2015D8003821883A04000A0E8880011701C00044D80D883A880B883A9009883A103EE83AD0 +:2015E000843FFFC4103FF72600BFFFC4000001060005883ADFC00417DC800317DC40021744 +:2015E800DC000117DEC00504F800283ADEFFE504D8C00804DDC01815DD801715DD401615E9 +:2015F000DD001515DCC01415DC801315DC401215DC001115DFC01A15DF0019152029883A60 +:2015F8002823883A382D883AD9800F150021883AD8000E15D8000A15002B883A0027883A77 +:201600000025883AD8000C15D8000B15002F883AD8C00915D8C00F171900000320803FCCC6 +:201608001080201C10BFE00410011E2600C00044B8C014261DC00216B80006260001150643 +:2016100001400084B9401D26014000C4B9402B2600011006014009441140FC268880011732 +:20161800D900000501C00044D80D883A880B883AA009883A103EE83A1000D81E840000442A +:201620000001040601400C041140FA260140094411400A1ED880000588800117B80F883AD0 +:20162800D80D883A880B883AA009883A103EE83A1000CA1E840000440000F50625FFF404F4 +:20163000BDC03FCC00C002441DC0093600BFFFC490800426014002849009883A08155300A2 +:20163800000001060005883AB8A5883A0000E20601400B841140E42605C00084213FF404F1 +:2016400027003FCC00C002441F00093600BFFFC498800426014002849809883A0815530096 +:20164800000001060005883AE0A7883A0000D90600C01B0410C0D226013FFFC49900022621 +:20165000D8000B150000010604C0004401001A441100162620800916010018C4110088266C +:201658000100190411001126010016041100C81E00C00044D8C00E150000150601001CC43F +:20166000110098262080041601001BC41100C01E0540020400000F0601001D4411000D260C +:2016680001001E0411000A260000B906D8C00A17B700010418000726DF000D15B5C00017F8 +:20167000B800080E05EFC83A024000440000060605400404B0C00104D8C00D15B5C00017FC +:20167800D8000A150013883AD839883AB8001726A80B883AB809883ADA40101508154740E3 +:20168000A80B883A1009883A102D883A08155300B885C83A00C00244DA4010171880021655 +:2016880010800C0400000506D8C00E171800022610800DC400000106108015C4E080000564 +:20169000B02F883AE7000044003FE806E6EFC83A9DC5C83A0080090EE085883A01400C04F7 +:20169800D8C00917E009883AE0C0032EE700004421400005E0BFFA1EE6EFC83AD8C00B1725 +:2016A0004DD1883A922DC83A1800162648000A2600800B44D88008058880011701C0004464 +:2016A800D9800804880B883AA009883A103EE83A10004A1E840000440580070EB00F883A32 +:2016B00001800C04880B883AA009883A081574001000421E85A1883AE02D883ABF2FC83A21 +:2016B800000020060580090EB00F883A01800804880B883AA009883ADA40101508157400B2 +:2016C000DA4010171000351E85A1883A483FF22600800B44D88008058880011701C0004486 +:2016C800D9800804880B883AA009883A103EE83A10002A1E84000044003FE706B5BFFFC4EA +:2016D000B080000301C00044D9800804D880080588800117880B883AA009883A103EE83AA8 +:2016D80010001E1E8585C83AB5C9883AE085883A013FF2161021883ADD800D17000044062D +:2016E000008000441480080E95FFFFC4B80F883A01800804880B883AA009883A08157400BE +:2016E80010000E1E85E1883AB080001701C00044D80D883AD880000588800117880B883AB9 +:2016F000A009883AB5C00104103EE83A1000031E84000044B82D883A00002D0600BFFFC430 +:2016F80000003106B5C00017B7000104B809883A0815DE009091C83A102D883A0200090E9A +:20170000400F883A01800804880B883AA009883ADA00101508157400DA001017103FEF1E7E +:201708008221883A88800117B00F883AB80D883A880B883AA009883A103EE83A103FE71EB0 +:2017100085A1883AE02D883A0000110600C0004404FFFFC4D8000E15D8C00A1505400284A4 +:201718009825883AD8000C15D8000B15182F883A00000806DDC00B1505C000840000050619 +:2017200000C00044D8C00C1505C000C400000106002F883AD8C00F1718C00044D8C00F15D5 +:20172800003EDC068005883ADFC01A17DF001917DDC01817DD801717DD401617DD001517B1 +:20173000DCC01417DC801317DC401217DC001117DEC01B04F800283A2880000B10C0020C5B +:201738001800202628C0008FDEFFFD04DC000015DFC00215DC4001152821883A1800150EBF +:2017400010C0800C180013262C40051789C0030E10C0200C1800032600000E063C40010E1E +:201748003823883A81000417300B883A880D883A0815D800808005171445C83A80800515EE +:20175000808004171463883A844004150005883A00000606108010148080000D00BFFFC432 +:201758000000020600BFFFC4F800283ADFC00217DC400117DC000017DEC00304F800283AAF +:201760002005883A218F883A290002361007883A00000C062987883A20FFFC2E380B883A04 +:2017680030CDC83A1989883A2000052618FFFFC419000003297FFFC429000005003FF906E6 +:20177000F800283A19C005262900000318C0004429400044193FFFC5003FFA06F800283A51 +:201778002005883A10C000071800022610800044003FFC061105C83AF800283ADEFFFF04EC +:201780000100207401402074DFC00015211D5F04295F3A042140061E0100207401402074D5 +:2017880021000804294008042140121E00000B0600C0207418DF3A041907C83A0005883A8B +:2017900010FFF526114F883A39C00017110D883A1080010431C00015003FF906010020748F +:2017980001402074211A1804295A18042140101E00000B0600C0207418C008041907C83A6C +:2017A0000005883A10FFF526114F883A39C00017110D883A1080010431C00015003FF9064D +:2017A80008167E40DFC00017DEC001040816854100C0207418DD5F041907C83A0005883A73 +:2017B00018BFF726114F883A39C00017110D883A1080010431C00015003FF906DEFFFF045A +:2017B8000009883ADFC000150815F0C00815F2C0D1A20C17D1620D17D1220E17DFC000173B +:2017C000DEC001040812018108167641DEFFFF04DFC0001508168580008000441001703ABF +:2017C800DFC00017DEC00104F800283A008020B410840004D0A2101501002074008067341B +:2017D00010BF3004211EE004D0A20F1508163F41D0E20F17D0A2101718000A2610C0010411 +:2017D8000100020419000035013FFFD4110002351100033500800104188000350005883ADF +:2017E000F800283A00BFFFC4F800283AD0A20F1710000926D0E2101718800404100000351E +:2017E8001080003718C005371806943A10BFFFCC1884303AF800283A00BFFFC4F800283A44 +:2017F000D0A20F17F800283A20001D262804923A20C03017DEFFFD04DC400115DC00001564 +:2017F800DFC002152823883A2021883A108000D41880033580C03017188000371080004CA5 +:20180000100003260100004408167640003FF906198000373007D0BA3009D0FA18C001CCFF +:201808002100020C1908B03A3007D07A18C0040C1906B03A88C0042600BFF4840000020663 +:2018100000BFFA84F800283ADFC00217DC400117DC000017DEC00304F800283A20000A26F3 +:20181800280009263000082620800C173080001520800C171000062621000D042900001504 +:201820000005883AF800283A00BFFA84F800283A00BFFEC4F800283A2005883A20001D26CB +:201828002809883A28001B1610C0311728C0192E1140341728FFFFC41906703A1800151E73 +:20183000DEFFFE04DC000015DFC001151021883A081547401004923A00C0403418FFC0048D +:2018380010C4703A80C03017108000941880033580C0301718C00404188000371080004C85 +:2018400010000626008000441880003500BFFEC40000020600BFFA84F800283ADFC00117E4 +:20184800DC000017DEC00204F800283ADEFFF504DC000115DFC00A15DF000915DDC0081552 +:20185000DD800715DD400615DD000515DCC00415DC800315DC400215DC000B1728003A16FE +:201858003023883A300038162027883A20003626382B883A38003426208031173080322EA9 +:201860002880312E208034173147C83A10C7C83A1C002D3680002C1610BFFFC4114A703A4B +:201868002800291E0029883A05BFFFC405C000C40700010480002226DD800015890000CC5B +:2018700020000626E105C83A8025883A1400012E1025883A8923C83A00000406BC000236D7 +:201878008025883A0000010604800104AD0B883A900D883AD909883A0815588098802E178A +:20188000D8C00017A4A9883A84A1C83A8885883A10C00035988030171080040410C0003791 +:2018880018C0008C1800042600C0008410C0003500BFFEC4000005068C400104003FDD06D2 +:201890000005883A0000010600BFFA84DFC00A17DF000917DDC00817DD800717DD400617FD +:20189800DD000517DCC00417DC800317DC400217DC000117DEC00B04F800283A200016267E +:2018A000DEFFF604DD000515DFC00915DDC00815DD800715DD400615DCC00415DC80031509 +:2018A800DC400215DC0001153029883A30000C262021883A20802E1780C02F172823883A03 +:2018B0002885883A382B883A3889883A10C0042E20C005360000020600BFFA84F800283A45 +:2018B80000BFFA8400002406814034178809883A002D883A08154740102F883A808033176C +:2018C000B8801C2EA8001B2684C0341704E7C83A9C66703A8CC002268CE5C83A0000010687 +:2018C8000025883A980B883A8009883A081609801000111E8080341714A5C83AAC80012E22 +:2018D000A825883ADC800015A58F883A880D883A980B883A8009883A081612C01000061ED7 +:2018D800ACABC83AB4AD883A8CA3883ABDC00044003FE2060005883ADFC00917DDC0081759 +:2018E000DD800717DD400617DD000517DCC00417DC800317DC400217DC000117DEC00A0438 +:2018E800F800283A200008263007883A3000062620802E17288B883A20802F17394D883A5B +:2018F0002880012E3080023600BFFA84F800283ADEFFFF04380D883A1809883ADFC0001504 +:2018F800081558800005883ADFC00017DEC00104F800283A20004E262080301710004E2662 +:2019000020C03217DEFFFB04DFC00415DCC00315DC800215DC400115DC00001518001E1E6C +:201908001480023700C0030494803FCC90BFFAC418804336100490BA00C0207418D9130434 +:2019100010C5883A108000171000683A008164B8008164C8008164D0008164C000816480BE +:201918000081654000816540008165400081654000816540008165400081648800816490E9 +:20192000044080040000130604410004000011060442000400000F06148001370080058432 +:2019280094803FCC90800A260080060490800426008005049080221E044008040000050648 +:20193000044040040000030604401004000001060440200424C034172021883A8809883ABA +:20193800980B883A0815530080C0311710C0021E80C0331788C0022680000C150000100691 +:2019400000C000448480361580C00C1580000D1580800E1584400F1584C01015D160210467 +:201948008009883A08167E800005883A0000050600BFFA84F800283A00BFFB44F800283A57 +:2019500000BFFB44DFC00417DCC00317DC800217DC400117DC000017DEC00504F800283A6C +:20195800300001260005C03200FFFF042005883A28C6703A110DC83A30C0042E11800017B6 +:20196000300DC0F210800104003FFA06294000CC00C000C428C0041E10C0000B1807C0B275 +:20196800108000830000080600C0008428C0031E1080000B1005C0B20000040600C00044C1 +:2019700028C0021E108000031005C0720005C132F800283ADEFFFD04DC400115DC00001522 +:201978002823883A2021883A014001443009883ADFC0021508155300100B883A8809883A68 +:201980000815474010BFFFC480C0020418000035010000448100043511003FCC81000035AD +:201988001004D23A10803FCC808001350080200418800035DFC00217DC400117DC000017FE +:20199000DEC00304F800283A3180004C294B883A298B883A21400335210004040080240425 +:2019980020800035208000371080008C103FFD1E208000371004D1FA1080004CF800283A11 +:2019A00020C004042800022600801A04000001060080080418800035188000371080008C06 +:2019A800103FFD1E20800337F800283A29403FCC214003352100040430000226008014045B +:2019B000000001060080040420800035208000371080008C103FFD1E208000371004D1FAA0 +:2019B8001080004CF800283A21C004042805883A02000B04210003041147C83A1980090EBE +:2019C0003A00003538C0003718C0008C183FFD1E2800022620C0003710C000051080004483 +:2019C800003FF506F800283A21C003042805883A21000404020007041147C83A1980080E55 +:2019D00010C0000338C000352200003520C0003718C0008C183FFD1E10800044003FF606A4 +:2019D800F800283A014AAAF4DEFFFE04296AAA84DC000015DFC001152021883A08154740BF +:2019E00010000F2601600034013555740007883A297FFFC421155584297FFFC4283FFE1EDD +:2019E80018C000448121883A18BFFB168405883A1421883A843FFFC4803FFE1E00000406CA +:2019F0008405883A1421883A843FFFC4043FFE160005883ADFC00117DC000017DEC00204A3 +:2019F800F800283AF800283A20000226208002171000101ED0A0201710000926DEFFFF0416 +:201A0000DFC00015103EE83A00C0058410C0001500BFFA84DFC00017DEC00104F800283A84 +:201A0800D0A2110400C0058410C0001500BFFA84F800283A28800017214001152080001587 +:201A10002880001711000115290000150005883AF800283AF800283A000170FAF800283A52 +:201A180073616C4672652068006573616F727265642520720000000073616C4672772068C6 +:201A2000006574696F7272650000007273616C4665762068206669726C6961660000000054 +:201A280053206F4E6163204464206472002E74652520732500632575252E75256B75322EDE +:201A300025207A482E252E757A4875320000000064616F4C0000646564616F4C6961662017 +:201A38000064656C00007325746F6C53007525206576615300000064657661536961662093 +:201A40000064656C4353534F776620207525202E322E252E0000007574696E4972726520EF +:201A48002020726F000064252020202053204F4E00434E59343130323130322D6D202037EF +:201A5000737172610000000074736554746170206E726574000000003A3156414247522004 +:201A5800000000533A31564173475220000000423A31564162505920000072503A325641B9 +:201A600062505920000072503A32564173475220000000423A33564142475220000056486B +:201A68003A33564142475220000000533A33564173475220000000423A335641625059206B +:201A7000000072507473614C65737520000000640081694800816958008169640081697013 +:201A78000081697C0081698800816994008169A0008169AC008169B8008169C40000000088 +:201A8000000001000101010000000100000000000B00011000034406800000011A1A808023 +:201A88000000001A7365725000000073666E6F43006D72696D73694D686374616572202CF0 +:201A900000797274646F4D567325203A00000000203A4F4C56207525203A4D5300007525D6 +:201A9800666F725020656C6964616F6C0000003A736572702D30207300000039000000314F +:201AA00000000032000000330000003400000035000000360000003700000038554E454D7E +:201AA8000000000000004B4F4B43414200000000000050554E574F44000000005446454C6B +:201AB0000000000048474952000000544F464E49000000005F44434C4B4341424847494C05 +:201AB800000000544E414353454E494C444F4D5F000000454E414353454E494C5059545F40 +:201AC000000000454E414353454E494C544E495F0000002B4E414353454E494C544E495F68 +:201AC8000000002D454E494C544C554D444F4D5F000000455341485000002B45534148501B +:201AD00000002D45464F52505F454C494B544F48000059453EA93E293EE93E693E993E19F6 +:201AD8003ED93E593EC93E393E1D3E4D3E2D3EED3EAD3ECD3E653E6D1C483E011C501C18BF +:201AE0001CC81CD05ED85E5800003EB900816A7C00816A8000816A8400816A8800816A8C08 +:201AE80000816A9000816A9400816A9800816A780081710000816A9C00816AA400816AA863 +:201AF00000816AB000816AB400816ABC00816AC400816ACC00816AD400816AE400816AF422 +:201AF80000816B0400816B1400816B2400816B3400816B3C00816B444353534F000000001E +:201B000061766E492064696C67616D690000006561766E492064696C64616568000072658B +:201B080061766E492064696C2072646800435243696C6156697461646420676E00617461E3 +:201B100062207525736574790000000061766E492064696C6174616443524320000000005B +:201B1800252E75252575322E00732573636E6143656C6C650000006461647055676E697404 +:201B20000057462061656C70772065732E74696100002E2E697265566E6979666C6620676A +:201B28000068736172746552676E6979647075200065746161647055203F65742C593D31B5 +:201B30004E3D322000000000202020200000752564206425000067656C20752573656E69F0 +:201B380000000000252E75252075322E000073756D20642500000056702075256C6578697B +:201B4000000000732525752500000000656469566E69206F6F7270203E20206300000000EE +:201B4800706D6153676E696C74706F203E20202E00000000636E795374706F202020202E85 +:201B50003E202020000000007074754F6F207475202E74703E2020200000000074736F5041 +:201B58006F72702D20202E633E20202000000000616F4C3C727020646C69666F003E206555 +:201B60007661533C727020656C69666F003E20657365523C73207465697474653E73676E1D +:201B680000000000657365526F6420740000656E2E77463C64707520206574613E2020200C +:201B7000000000002D204B4F736C70207365722074726174000000006C6961660000646575 +:201B78006E616353656E696C000000736E616353656E696C727473200000002E6E61635354 +:201B8000656E696C70797420000000656E616353656E696C696C61202E6D6E6700000000C8 +:201B880069726F48746E6F7A6D206C61006B7361747265566C61636973616D200000006B41 +:201B90006B73614D697262206E74686700737365703034323838322F727020700000636F35 +:201B9800703438336F72702000000063693038343637352F727020690000636F703038342B +:201BA0003637352F727020700000636F693036393830312F7020693000636F72656E694C4B +:201BA8006D2078330065646F656E694C6D2078340065646F656E694C6D2078350065646FBA +:201BB000656E694C66207835616D726F0000007478363532203034326570736100007463EC +:201BB8006D2058540065646F74696E49206C616975706E69000000746C616E417320676F9D +:201BC00020636E790046504C6C616E417320676F20636E79006874566E7973486F74206330 +:201BC8006172656C0065636E6E797356687420636873657200646C6F4C502D487250204CE4 +:201BD0006F432D65007473614C502D486F50204C432D74737473616F00000000706D61538E +:201BD800676E696C616870200000657370303834206E6920706D61730072656C6F6C6C4173 +:201BE000565420775048205078324C4C000000007664413C6974202E676E696D3E2020208F +:201BE8000000000065646956504C206F00000046506250596E6920726C6F432000617053BE +:201BF00072502F5266666F200074657320592F477366666F0000746562502F4266666F20F7 +:201BF8000074657372502F52696167200000006E20592F476E6961670000000062502F42CE +:201C0000696167200000006E73202E486C706D61746172650000006573202E486C636E7982 +:201C080000006E6561202E48766974630000006561202E56766974630000006562202E48BF +:201C1000706B63616863726F0000000062202E56706B63616863726F0000000000706F54E5 +:201C180074746F4200006D6F69726F48746E6F7A00006C61747265566C61636900000000D3 +:201C200065746C4174616E7200676E690066664F6F74754100000000756E614D00006C6119 +:201C2800494D4448000000000049564400373A38737361507572687400000000656E694C0C +:201C300000007832656E694C2820783229626F6200000000656E694C00007833656E694C59 +:201C380000007834656E694C000078353032393138303178000000303030363130323178CC +:201C400000000030303239313032317800000030656E65472063697200333A3478303233C2 +:201C4800203034326974706F00002E6D78363532203034326974706F00002E6D656E6547CE +:201C500020636972393A363100000000484D33336D28207A00296E69484D30316D28207AED +:201C5800002964654D352E3228207A482978616D0000000020565444703038340000000005 +:201C6000415345563034362030383478003036402E63655231303620000000002E6365527A +:201C68003930372000000000484D35394828207A2056544400294949484D35334828207ABF +:201C70002056544400002949484D36314528207A29565444000000007A484D394453282093 +:201C78000029565400006E4F445253550041544100000020008171900000200020002CE5B5 +:201C8000E926F4FD38BC2000000000000081719C000020002000323EF113FA043B61200034 +:201C880000000000303832313034327805000000177000F001060618034810AA0112011297 +:201C9000783036390030343203C00000177000F001060492033610800022011278303233A5 +:201C98000030343201400000177000F0010601AA031F1031124201127836353200303432B7 +:201CA00001000000177000F0010601550319102724820112703034320000000002D000006B +:201CA800177000F00106035A033C1041000E0112363335313034322A06000000177000F084 +:201CB000010607FE039610EA0802011230383231383832780500000013880120013806185B +:201CB800034810AA01120112783036390038383203C0000013880120013804920336108011 +:201CC00000220112783032334C30343201400042138800F0013801AA031F2931024201121B +:201CC800783635324C30343201000042138800F00138015503192927048201127038383291 +:201CD0000000000002D000001388012001380360033C1041000E011270343833000000000A +:201CD80001F000001686018001A70280033E1D32000E0204783034360034383302800000DD +:201CE000157C018001EC032002603F30000E0210693038340000000002D00000176A00F089 +:201CE800020D035A033C1041000F0312703038340000000002D00000176A01E0020D035A10 +:201CF000063E1E3C000C0414783034360030383402800000177001E0020D03200260213095 +:201CF800000C0514783034360032313502800000177002000238032002601C3000040010D3 +:201D0000693637350000000002D000001388012002710360033C1041000F0312703637358E +:201D08000000000002D000001388024002710360063C2041000C04047830303800303036D9 +:201D1000032000001770025802740420048017580004001070303237000000000500000000 +:201D1800176A02D002EE0672052814FF00040008303832313032377805000000177002D06A +:201D200002EE0672052814DC0004001034323031383637780400000017700300032605402A +:201D280006881DA00004001030383231323031780500003417700400042A0698037026F845 +:201D300000040010783034366930363902800000176A01E0041A032002602130000D061466 +:201D3800303830310000006907800000176A021C04650898052C10BC000D06083038303149 +:201D40000000007007800000176A043804650898052C24BC000400083032393138303178CC +:201D4800078000301770043804650898052C249400040010303036313032317806400030B3 +:201D5000177004B004E2087003C02EFF00040010FFFFFFFFFFFFFFFF0000FFFF7665642F72 +:201D58006370652F6F635F716F72746E72656C6C615F305F6D5F6C7600006D650000000021 :201D6000000000000000000000000000000000000000000000000000000000000000000063 :201D680000000000000000000000000000000000000000000000000000000000000000005B :201D7000000000000000000000000000000000000000000000000000000000000000000053 @@ -979,85 +979,85 @@ :201E880000000000000000000000000000000000000000000000000000000000000000003A :201E9000000000000000000000000000000000000000000000000000000000000000000032 :201E980000000000000000000000000000000000000000000000000000000000000000002A -:201EA00000000000000000000000000000000000000000000000000000000000017804E5C0 -:201EA8003CCE00813FAE03833F333D4905B80383009301B404163C493CD93F9F04163F109E -:201EB000020E04093D0E00C83F6E03833ED03DAC04B2038300E9026404163C933D493F5629 -:201EB80004163E9F00817A18000000000000000000000000000000000000000000816B9084 -:201EC0000000000300817A40000000000000000000816BA40000000300817A3800000000FE -:201EC8000000000000816BB80000000300817A30000000000000000000816BCC000000036D -:201ED00000817A28000000000000000000816BE00000000300817A200000000000000000E5 -:201ED80000816BF40000000300000000008119B80000000000816C040000000300000000C1 -:201EE00000811A900000000000816C14000000040081234400816C2800816B8C00816C341C -:201EE800000000040081296400816C4800816C5C00816C6400000000008182A9000200014A -:201EF000008177B800816C7000000001008182AB000F000000812FAC00816C80000000003E -:201EF800008182AA00020001008177AC00816C9000000000008182AC0001000100817A50FD -:201F000000816CA400000001008182B6003F000000812F9000816CB400000001008182B79B -:201F0800003F000000812F9000816CC400000001008182B8000F000000812E4000816CD40E -:201F100000000000008182B100040001008177C400816CE400000000008182B200010001B4 -:201F180000817A7000816CF000000000008182B30001000100817A6800816D000000000058 -:201F2000008182B40001000100817A6000816D1000000000008182AE00030001008177E4FE -:201F280000816D1C00000000008182AF00020001008177D800816D2800000000008182B041 -:201F30000001000100817A7800816D3400000001008182B50005010000812E4000816D4816 -:201F380000000000008182B90001000100817A5800816D5000000000008182C4000A000168 -:201F40000081782800816D6000000000008182C000030001008177F400816D700000000100 -:201F4800008182BD001F000000812F4C00816D8000000001008182BE00FF000000812EBC04 -:201F500000816D9000000001008182BF00C80A0000812EBC00816DA000000001008182C29F -:201F58000005000000812EA000816DB000000001008182C30005000000812EA000816DC4AA -:201F600000000001008182BB001F000100812E5C00816DD400000000008182BA00020001F5 -:201F68000081780400816DE40000000300817A4800811B680000000000816DF8000000005A -:201F7000008182C1000500010081781000816E0400000000008182BC0001000100817A804F -:201F780000816E1400000001008182C500FF000000812E4000816E2000000001008182C6B6 -:201F800000FF000000812E4000816E2C00000001008182C700FF000000812E4000816E3858 -:201F880000000001008182C800FF000000812E4000816E4400000001008182C900FF000080 -:201F900000812E4000816E5000000001008182CA00FF000000812E4000816E5C00000002FA -:201F9800008181D408FC012C00811C6C00816E6C00000002008181DE00C8000A00811C6C01 -:201FA00000816E7800000002008181D2078000C800811C6C00816E8400000002008181D045 -:201FA80004B000C800811C6C00816E9000000002008181CA00FF000100811C6C00816EA0AF -:201FB00000000002008181DA00FF000100811C6C00816EBC00816EC800816ED400816EE036 -:201FB80000816EE400816EEC00816F0000816F0C00816F1400816F1C00816F2400816F2C2F -:201FC00000816F4800816F3800816F5800816F2C00816F4800816F3800816EE000816F68B6 -:201FC80000816F7400816F8000816EE400816F9000816F9C00816EE400816EE000816FC4F0 -:201FD00000816FD400816FE400816FF4008167CC008167DC008167E8008167F40081680068 -:201FD8000081680C0081681800816824008168300081683C00816848000000000081791469 -:201FE0000081791C00817924000000000000000000000000000000000000000000000000AD -:201FE8000000000000000000000000000000000000000000000000000000000000000000D9 -:201FF0000000000000000000000000000000000000000000000000000000000000000000D1 -:201FF8000000000000000000000000000000000000000000000000000000000000000000C9 -:202000000000000000000000000000000000000000000000000000000000000000000000C0 -:202008000000000000000000000000000000000000000000000000000000000400000000B4 -:202010000001000A000000000002000A000000000000000000000000000000000000000099 -:20201800008173580000000000000000008161000081622800815EE000815F1C00815FB024 -:20202000000000000080000000000000000000000000000000000000000000000000000020 -:20202800000000000000000000000000000000000000000000000000000000000000000098 -:20203000000000000000000000000000000000000000000000000000000000000000000090 -:20203800000000000000000000000000000000000000000000000000000000000000000088 -:2020400000000000000000000000000000815E4C00000000008000000082102000800000A3 -:202048000000000100000080000100000000010000000000001080100000008000000009CC -:20205000008173D8000000070081748C0000000A0081751800000006008175E00000000325 -:20205800008176580000000800817694000000060081773400816EB000816EB400816EF42F -:2020600000816EFC00816F0000816F0C00816F0000816F0C00816F0000816F0C00816F2C95 -:2020680000816F3800816FAC00816FB8C896554B008178540000000000817A9400817A9483 -:20207000000000000000000000000000000000000000000000000000000000000000000050 -:20207800000000000000000000000000000000000000000000000000000000000000000048 -:20208000000000000000000000000000000000000000000000000000000000000000000040 +:201EA000000000000000000000000000000000000000000000000000000000000000000022 +:201EA80000000000000000000000000000000000000000000000000000000000000000001A +:201EB000000000000000000000000000000000000000000000000000000000000000000012 +:201EB80000000000000000000000000000000000000000000000000000000000000000000A +:201EC000000000000000000000000000000000000000000000000000000000000000000002 +:201EC8000000000000000000000000000000000000000000000000000000000000000000FA +:201ED0000000000000000000000000000000000000000000000000000000000000000000F2 +:201ED8000000000000000000000000000000000000000000000000000000000000000000EA +:201EE0000000000000000000000000000000000000000000000000000000000000000000E2 +:201EE8000000000000000000000000000000000000000000000000000000000000000000DA +:201EF0000000000000000000000000000000000000000000000000000000000000000000D2 +:201EF8000000000000000000000000000000000000000000000000000000000000000000CA +:201F00000000000000000000000000000000000000000000000000000000000000000000C1 +:201F08000000000000000000000000000000000000000000000000000000000000000000B9 +:201F10000000000000000000000000000000000000000000000000000000000000000000B1 +:201F18000000000000000000000000000000000000000000000000000000000000000000A9 +:201F20000000000000000000000000000000000000000000000000000000000000000000A1 +:201F2800000000000000000000000000000000000000000000000000000000000000000099 +:201F3000000000000000000000000000000000000000000000000000000000000000000091 +:201F38000000000000000000017804E53CCE00813FAE03833F333D4905B80383009301B4A6 +:201F400004163C493CD93F9F04163F10020E04093D0E00C83F6E03833ED03DAC04B20383F0 +:201F480000E9026404163C933D493F5604163E9F00817C64000000000000000000000000CE +:201F5000000000000000000000816D0C0000000300817C8C000000000000000000816D20DD +:201F58000000000300817C84000000000000000000816D340000000300817C7C0000000047 +:201F60000000000000816D480000000300817C74000000000000000000816D5C000000036A +:201F680000817C6C000000000000000000816D70000000030000000000811AC40000000030 +:201F700000816D80000000030000000000811B9C0000000000816D90000000040081245031 +:201F780000816DA400816D0800816DB00000000400812A7000816DC400816DD800816DE0BE +:201F8000000000000081854100020001008179F800816DEC0000000100818543000F0000D2 +:201F8800008130B800816DFC000000000081854200020001008179EC00816E0C00000000BA +:201F9000008185440001000100817C9C00816E200000000100818550003F00000081309C5A +:201F980000816E300000000100818551003F00000081309C00816E4000000001008185529E +:201FA000000F000000812F4C00816E50000000000081854A0004000100817A0400816E6034 +:201FA800000000000081854B0001000100817CB400816E6C000000000081854C0001000166 +:201FB00000817CBC00816E7C000000000081854D0001000100817CB400816E8C000000006C +:201FB8000081854E0001000100817CBC00816E9C00000000008185460003000100817A30F4 +:201FC00000816EA800000000008185470002000100817A2400816EB400000000008185480A +:201FC8000002000100817A2400816EC000000000008185490002000100817A1800816ED004 +:201FD000000000000081854F0001000100817CAC00816EE0000000000081855300010001C7 +:201FD80000817CA400816EE8000000000081855F000A000100817A7400816EF800000000AB +:201FE0000081855B0003000100817A4000816F080000000100818558001F000000813058C2 +:201FE80000816F18000000010081855900FF000000812FC800816F28000000010081855A81 +:201FF00000C80A0000812FC800816F38000000010081855D0005000000812FAC00816F4862 +:201FF800000000010081855E0005000000812FAC00816F5C0000000100818555001F00013B +:2020000000812F6800816F6C00000000008185540002000100817A5000816F7C0000000038 +:20200800008185560001000100817CCC00816F900000000300817C9400811C74000000006C +:2020100000816FA4000000000081855C0005000100817A5C00816FB0000000000081855760 +:202018000001000100817CC400816FC0000000010081856000FF000000812F4C00816FCC17 +:20202000000000010081856100FF000000812F4C00816FD8000000010081856200FF00000D +:2020280000812F4C00816FE4000000010081856300FF000000812F4C00816FF00000000182 +:202030000081856400FF000000812F4C00816FFC000000010081856500FF000000812F4CD8 +:2020380000817008000000020081846808FC012C00811D7800817018000000020081847257 +:2020400000C8000A00811D78008170240000000200818466078000C800811D780081703090 +:20204800000000020081846404B000C800811D780081703C000000020081845E00FF0001E9 +:2020500000811D780081704C000000020081846E00FF000100811D780081706800817074D4 +:20205800008170800081708C0081709000817098008170B0008170BC008170D4008170DC90 +:20206000008170E4008170EC008170F800817104008171100081711C0081712C0081713C73 +:20206800008171100081711C0081712C0081708C0081714C0081715800817164008170904E +:202070000081717400817180008170900081708C008171A8008171B8008171C8008171D8B2 +:20207800008169480081695800816964008169700081697C0081698800816994008169A04C +:20208000008169AC008169B8008169C40000000000817B6000817B6800817B70000000002E :20208800000000000000000000000000000000000000000000000000000000000000000038 :20209000000000000000000000000000000000000000000000000000000000000000000030 :20209800000000000000000000000000000000000000000000000000000000000000000028 :2020A000000000000000000000000000000000000000000000000000000000000000000020 :2020A800000000000000000000000000000000000000000000000000000000000000000018 -:2020B000000000000000000000000000000000000000000000000000000000000000000010 -:2020B800000000000000000000000000000000000000000000000000000000000000000008 -:2020C000000000000000000000000000000000000000000000000000000000000000000000 +:2020B00000000000000000000000000000000004000000000001000A000000000002000AF5 +:2020B80000000000000000000000000000000000000000000081755C0000000000000000B6 +:2020C0000081627C008163A40081605C008160980081612C000000000080000000000000D5 :2020C8000000000000000000000000000000000000000000000000000000000000000000F8 :2020D0000000000000000000000000000000000000000000000000000000000000000000F0 :2020D8000000000000000000000000000000000000000000000000000000000000000000E8 :2020E0000000000000000000000000000000000000000000000000000000000000000000E0 -:2020E8000000000000000000000000000000000000000000000000000000000000000000D8 -:2020F0000000000000000000000000000000000000000000000000000000000000000000D0 -:2020F8000000000000000000000000000000000000000000000000000000000000000000C8 -:202100000000000000000000000000000000000000000000000000000000000000000000BF -:202108000000000000000000000000000000000000000000000000000000000000000000B7 -:202110000000000000000000000000000000000000000000000000000000000000000000AF +:2020E80000815FC800000000008000000082102000800000000000010000008000010000FC +:2020F0000000010000000000001080100000008000000009008175DC000000070081769046 +:2020F8000000000C0081771C000000060081780C000000040081788400000008008178D447 +:2021000000000006008179740081705C00817060008170A0008170A800817118008170ACDC +:20210800008170B0008170BC008170B0008170C4008171900081719C0081708C008171E4B0 +:20211000C896554B00817AA00000000000817CE000817CE00000000000000000000000005C :202118000000000000000000000000000000000000000000000000000000000000000000A7 :2021200000000000000000000000000000000000000000000000000000000000000000009F :20212800000000000000000000000000000000000000000000000000000000000000000097 diff --git a/software/sys_controller/ossc/av_controller.c b/software/sys_controller/ossc/av_controller.c index e9f197f..c1d8ec8 100644 --- a/software/sys_controller/ossc/av_controller.c +++ b/software/sys_controller/ossc/av_controller.c @@ -92,12 +92,10 @@ inline void SetupAudio(tx_mode_t mode) EnableAudioInfoFrame(FALSE, NULL); if (tc.tx_mode == TX_HDMI) { - alt_u32 pclk_out = (TVP_EXTCLK_HZ/cm.clkcnt)*video_modes[cm.id].h_total; - // TODO: check pixel repetition - if (video_modes[cm.id].flags & MODE_L2ENABLE) + alt_u32 pclk_out = (TVP_EXTCLK_HZ/cm.clkcnt)*video_modes[cm.id].h_total*cm.sample_mult*(cm.fpga_vmultmode+1); + + if (cm.hdmitx_pixelrep == HDMITX_PIXELREP_2X) pclk_out *= 2; - else if (video_modes[cm.id].flags & (MODE_L3_MODE0|MODE_L3_MODE1|MODE_L3_MODE2|MODE_L3_MODE3)) - pclk_out *= 3; printf("PCLK_out: %luHz\n", pclk_out); EnableAudioOutput4OSSC(pclk_out, tc.audio_dw_sampl, tc.audio_swap_lr); @@ -269,23 +267,20 @@ status_t get_status(tvp_input_t input, video_format format) (tc.pm_384p != cm.cc.pm_384p) || (tc.pm_480i != cm.cc.pm_480i) || (tc.pm_480p != cm.cc.pm_480p) || + (tc.pm_1080i != cm.cc.pm_1080i) || (tc.l3_mode != cm.cc.l3_mode) || (tc.l4_mode != cm.cc.l4_mode) || - (tc.l5_mode != cm.cc.l5_mode)) + (tc.l5_mode != cm.cc.l5_mode) || + (tc.l5_fmt != cm.cc.l5_fmt) || + (tc.tvp_hpll2x != cm.cc.tvp_hpll2x)) status = (status < MODE_CHANGE) ? MODE_CHANGE : status; if ((tc.s480p_mode != cm.cc.s480p_mode) && ((video_modes[cm.id].group == GROUP_DTV480P) || (video_modes[cm.id].group == GROUP_VGA480P))) status = (status < MODE_CHANGE) ? MODE_CHANGE : status; if (update_cur_vm) { - if (video_modes[cm.id].flags & MODE_PLLDIVBY2) - h_samplerate = 2*video_modes[cm.id].h_total; - else - h_samplerate = video_modes[cm.id].h_total; - - tvp_writereg(TVP_HPLLDIV_LSB, ((h_samplerate & 0xf) << 4)); - tvp_writereg(TVP_HPLLDIV_MSB, (h_samplerate >> 4)); - tvp_writereg(TVP_HSOUTWIDTH, cm.sample_mult*video_modes[cm.id].h_synclen); + tvp_setup_hpll(cm.sample_mult*video_modes[cm.id].h_total, clkcnt, cm.cc.tvp_hpll2x && (video_modes[cm.id].flags & MODE_PLLDIVBY2)); + tvp_writereg(TVP_HSOUTWIDTH, cm.sample_mult*video_modes[cm.id].h_synclen-cm.hsync_cut); status = (status < INFO_CHANGE) ? INFO_CHANGE : status; } @@ -302,7 +297,7 @@ status_t get_status(tvp_input_t input, video_format format) (tc.h_mask != cm.cc.h_mask) || (tc.v_mask != cm.cc.v_mask) || (tc.mask_br != cm.cc.mask_br) || - (tc.l3m3_hmult != cm.cc.l3m3_hmult)) + (tc.ar_256col != cm.cc.ar_256col)) status = (status < INFO_CHANGE) ? INFO_CHANGE : status; if (tc.sampler_phase != cm.cc.sampler_phase) { @@ -351,27 +346,23 @@ status_t get_status(tvp_input_t input, video_format format) return status; } -// h_info: [31:30] [29:20] [19:9] [8] [7:0] -// | H_MULTMODE[1:0] | H_MASK[9:0] | H_ACTIVE[10:0] | | H_BACKPORCH[7:0] | +// h_info: [31:30] [29:20] [19:9] [8:0] +// | H_MULTMODE[1:0] | H_MASK[9:0] | H_ACTIVE[10:0] | H_BACKPORCH[8:0] | // -// h_info2: [31:27] [26:23] [22:19] [18:16] [15:13] [12:10] [9:0] -// | | H_MASK_BR[3:0] | H_SCANLINESTR[3:0] | H_OPT_SCALE[2:0] | H_OPT_SAMPLE_SEL[2:0] | H_OPT_SAMPLE_MULT[2:0] | H_OPT_STARTOFF[9:0] | +// h_info2: [31:28] [27] [26:23] [22:19] [18:16] [15:13] [12:10] [9:0] +// | | H_L5FMT | H_MASK_BR[3:0] | H_SCANLINESTR[3:0] | H_OPT_SCALE[2:0] | H_OPT_SAMPLE_SEL[2:0] | H_OPT_SAMPLE_MULT[2:0] | H_OPT_STARTOFF[9:0] | // // v_info: [31:30] [29:28] [27] [26:24] [23:18] [17:7] [6] [5:0] // | V_SCANLINEMODE[1:0] | V_SCANLINEID | | V_MULTMODE[2:0] | V_MASK[5:0] | V_ACTIVE[10:0] | | V_BACKPORCH[5:0] | // void set_videoinfo() { - alt_u8 slid_target; alt_u8 sl_mode_fpga; alt_u8 h_opt_scale = 1; alt_u16 h_opt_startoffs = 0; alt_u16 h_border, h_mask; - - if (cm.fpga_vmultmode == FPGA_V_MULTMODE_3X) - slid_target = cm.cc.sl_id ? (cm.cc.sl_type == 1 ? 1 : 2) : 0; - else - slid_target = cm.cc.sl_id; + alt_u16 v_active = video_modes[cm.id].v_active; + alt_u16 v_backporch = video_modes[cm.id].v_backporch; if (cm.cc.sl_mode == 2) { //manual sl_mode_fpga = 1+cm.cc.sl_type; @@ -387,18 +378,40 @@ void set_videoinfo() } switch (cm.target_lm) { + case MODE_L2: + h_opt_scale = cm.sample_mult; + break; case MODE_L3_320_COL: - case MODE_L5_256_COL: h_opt_scale = 3; break; case MODE_L3_256_COL: - h_opt_scale = cm.cc.l3m3_hmult; + h_opt_scale = 4-cm.cc.ar_256col; break; case MODE_L4_320_COL: h_opt_scale = 4; break; case MODE_L4_256_COL: + h_opt_scale = 5-cm.cc.ar_256col; + break; + case MODE_L5_GEN_4_3: + if (cm.cc.l5_fmt == L5FMT_1920x1080) { + v_active -= 24; + v_backporch += 12; + } + break; + case MODE_L5_320_COL: h_opt_scale = 5; + if (cm.cc.l5_fmt == L5FMT_1920x1080) { + v_active -= 24; + v_backporch += 12; + } + break; + case MODE_L5_256_COL: + h_opt_scale = 6-cm.cc.ar_256col; + if (cm.cc.l5_fmt == L5FMT_1920x1080) { + v_active -= 24; + v_backporch += 12; + } break; default: break; @@ -406,13 +419,13 @@ void set_videoinfo() h_border = (((cm.sample_mult-h_opt_scale)*video_modes[cm.id].h_active)/2); h_mask = h_border + h_opt_scale*cm.cc.h_mask; - h_opt_startoffs = h_border + ((cm.sample_mult-h_opt_scale)*(cm.sample_mult*video_modes[cm.id].h_backporch) / cm.sample_mult); + h_opt_startoffs = h_border + ((cm.sample_mult-h_opt_scale)*(cm.sample_mult*(alt_u16)video_modes[cm.id].h_backporch) / cm.sample_mult); h_opt_startoffs = (h_opt_startoffs/cm.sample_mult)*cm.sample_mult; printf("h_opt_startoffs: %u\n", h_opt_startoffs); - IOWR_ALTERA_AVALON_PIO_DATA(PIO_2_BASE, (cm.fpga_hmultmode<<30) | (h_mask<<20) | ((cm.sample_mult*video_modes[cm.id].h_active)<<9) | cm.sample_mult*video_modes[cm.id].h_backporch); - IOWR_ALTERA_AVALON_PIO_DATA(PIO_5_BASE, (cm.cc.mask_br<<23) | (cm.cc.sl_str<<19) | (h_opt_scale<<16) | (cm.sample_sel<<13) | (cm.sample_mult<<10) | h_opt_startoffs); - IOWR_ALTERA_AVALON_PIO_DATA(PIO_3_BASE, (sl_mode_fpga<<30) | (slid_target<<28) | (cm.fpga_vmultmode<<24) | (cm.cc.v_mask<<18) | (video_modes[cm.id].v_active<<7) | video_modes[cm.id].v_backporch); + IOWR_ALTERA_AVALON_PIO_DATA(PIO_2_BASE, (cm.fpga_hmultmode<<30) | (h_mask<<20) | ((cm.sample_mult*video_modes[cm.id].h_active)<<9) | cm.sample_mult*(alt_u16)video_modes[cm.id].h_backporch); + IOWR_ALTERA_AVALON_PIO_DATA(PIO_5_BASE, ((cm.cc.l5_fmt!=L5FMT_1600x1200)<<27) | (cm.cc.mask_br<<23) | (cm.cc.sl_str<<19) | (h_opt_scale<<16) | (cm.sample_sel<<13) | (cm.sample_mult<<10) | h_opt_startoffs); + IOWR_ALTERA_AVALON_PIO_DATA(PIO_3_BASE, (sl_mode_fpga<<30) | (cm.cc.sl_id<<28) | (cm.fpga_vmultmode<<24) | (cm.cc.v_mask<<18) | (v_active<<7) | v_backporch); } // Configure TVP7002 and scan converter logic based on the video mode @@ -454,11 +467,19 @@ void program_mode() vm_sel = cm.id; target_type = target_typemask & video_modes[cm.id].type; - h_synclen_px = ((alt_u32)h_syncinlen * (alt_u32)video_modes[cm.id].h_total) / cm.clkcnt; + h_synclen_px = ((alt_u32)h_syncinlen * (alt_u32)video_modes[cm.id].h_total*cm.sample_mult) / cm.clkcnt; printf("Mode %s selected - hsync width: %upx\n", video_modes[cm.id].name, (unsigned)h_synclen_px); - tvp_source_setup(cm.id, target_type, (cm.progressive ? cm.totlines : cm.totlines/2), v_hz_x100/100, (alt_u8)h_synclen_px, cm.cc.pre_coast, cm.cc.post_coast, cm.cc.vsync_thold, cm.sample_mult); + tvp_source_setup(target_type, + cm.sample_mult*video_modes[cm.id].h_total, + cm.clkcnt, + cm.cc.tvp_hpll2x && (video_modes[cm.id].flags & MODE_PLLDIVBY2), + (alt_u8)h_synclen_px, + cm.sample_mult*video_modes[cm.id].h_synclen-cm.hsync_cut, + cm.cc.pre_coast, + cm.cc.post_coast, + cm.cc.vsync_thold); set_lpf(cm.cc.video_lpf); cm.sample_sel = tvp_set_hpll_phase(cm.cc.sampler_phase, cm.sample_mult); @@ -466,6 +487,9 @@ void program_mode() set_videoinfo(); + // TX re-init skipped to minimize mode switch delay + //TX_enable(cm.cc.tx_mode); + #ifdef DIY_AUDIO #ifdef MANUAL_CTS SetupAudio(cm.cc.tx_mode); diff --git a/software/sys_controller/ossc/av_controller.h b/software/sys_controller/ossc/av_controller.h index abd0090..1cd747f 100644 --- a/software/sys_controller/ossc/av_controller.h +++ b/software/sys_controller/ossc/av_controller.h @@ -98,6 +98,7 @@ typedef struct { alt_u8 hdmitx_pixr_ifr; alt_u8 sample_mult; alt_u8 sample_sel; + alt_u8 hsync_cut; mode_flags target_lm; avinput_t avinput; // Current configuration diff --git a/software/sys_controller/ossc/avconfig.c b/software/sys_controller/ossc/avconfig.c index 5c2c1c5..66e4a6a 100644 --- a/software/sys_controller/ossc/avconfig.c +++ b/software/sys_controller/ossc/avconfig.c @@ -45,7 +45,8 @@ const avconfig_t tc_default = { .pm_240p = 1, .pm_384p = 1, .pm_480i = 1, - .l3m3_hmult = 4, + .pm_1080i = 1, + .tvp_hpll2x = 1, .sampler_phase = DEFAULT_SAMPLER_PHASE, .sync_vth = DEFAULT_SYNC_VTH, .linelen_tol = DEFAULT_LINELEN_TOL, diff --git a/software/sys_controller/ossc/avconfig.h b/software/sys_controller/ossc/avconfig.h index 9e78676..2c22bff 100644 --- a/software/sys_controller/ossc/avconfig.h +++ b/software/sys_controller/ossc/avconfig.h @@ -37,6 +37,10 @@ #define SL_MODE_MAX 2 #define SL_TYPE_MAX 2 +#define L5FMT_1920x1080 0 +#define L5FMT_1600x1200 1 +#define L5FMT_1920x1200 2 + typedef struct { alt_u8 sl_mode; alt_u8 sl_type; @@ -46,17 +50,20 @@ typedef struct { alt_u8 l3_mode; alt_u8 l4_mode; alt_u8 l5_mode; + alt_u8 l5_fmt; alt_u8 pm_240p; alt_u8 pm_384p; alt_u8 pm_480i; alt_u8 pm_480p; - alt_u8 l3m3_hmult; + alt_u8 pm_1080i; + alt_u8 ar_256col; alt_u8 h_mask; alt_u8 v_mask; alt_u8 mask_br; alt_u8 tx_mode; alt_u8 s480p_mode; alt_u8 sampler_phase; + alt_u8 tvp_hpll2x; alt_u8 ypbpr_cs; alt_u8 sync_vth; alt_u8 linelen_tol; diff --git a/software/sys_controller/ossc/menu.c b/software/sys_controller/ossc/menu.c index 9c2f076..a9c8961 100644 --- a/software/sys_controller/ossc/menu.c +++ b/software/sys_controller/ossc/menu.c @@ -49,12 +49,12 @@ static const char *ypbpr_cs_desc[] = { "Rec. 601", "Rec. 709" }; static const char *s480p_mode_desc[] = { LNG("Auto","ジドウ"), "DTV 480p", "VESA 640x480@60" }; static const char *sync_lpf_desc[] = { LNG("Off","オフ"), LNG("33MHz (min)","33MHz (サイショウ)"), LNG("10MHz (med)","10MHz (チュウイ)"), LNG("2.5MHz (max)","2.5MHz (サイダイ)") }; static const char *l3_mode_desc[] = { LNG("Generic 16:9","ハンヨウ 16:9"), LNG("Generic 4:3","ハンヨウ 4:3"), LNG("320x240 optim.","320x240 サイテキ."), LNG("256x240 optim.","256x240 サイテキ.") }; -static const char *l4_mode_desc[] = { LNG("Generic 4:3","ハンヨウ 4:3"), LNG("320x240 optim.","320x240 サイテキ."), LNG("256x240 optim.","256x240 サイテキ.") }; -static const char *l5_mode_desc[] = { LNG("Generic 4:3","ハンヨウ 4:3"), LNG("256x240 optim.","256x240 サイテキ.") }; +static const char *l4l5_mode_desc[] = { LNG("Generic 4:3","ハンヨウ 4:3"), LNG("320x240 optim.","320x240 サイテキ."), LNG("256x240 optim.","256x240 サイテキ.") }; +static const char *l5_fmt_desc[] = { "1920x1080", "1600x1200", "1920x1200" }; static const char *pm_240p_desc[] = { "Passthru", "Line2x", "Line3x", "Line4x", "Line5x" }; -static const char *pm_384p_desc[] = { "Passthru", "Line2x" }; -static const char *pm_480i_desc[] = { "Passthru", "Line2x" }; -static const char *pm_480p_desc[] = { "Passthru", "Line2x" }; +static const char *pm_480i_desc[] = { "Passthru", "Line2x (bob)" }; +static const char *pm_384p_480p_desc[] = { "Passthru", "Line2x" }; +static const char *ar_256col_desc[] = { "4:3", "8:7" }; static const char *tx_mode_desc[] = { "HDMI", "DVI" }; static const char *sl_mode_desc[] = { LNG("Off","オフ"), LNG("Auto","ジドウ"), LNG("Manual","シュドウ") }; static const char *sl_type_desc[] = { LNG("Horizontal","スイヘイ"), LNG("Vertical","スイチョク"), LNG("Alternating","コウゴ") }; @@ -94,6 +94,7 @@ MENU(menu_vinputproc, P99_PROTECT({ \ MENU(menu_sampling, P99_PROTECT({ \ { LNG("Sampling phase","サンヒプリングフェーズ"), OPT_AVCONFIG_NUMVALUE, { .num = { &tc.sampler_phase, OPT_WRAP, 0, SAMPLER_PHASE_MAX, sampler_phase_disp } } }, { LNG("480p in sampler","サンプラーニ480p"), OPT_AVCONFIG_SELECTION, { .sel = { &tc.s480p_mode, OPT_WRAP, SETTING_ITEM(s480p_mode_desc) } } }, + { "Allow TVP HPLL2x", OPT_AVCONFIG_SELECTION, { .sel = { &tc.tvp_hpll2x, OPT_WRAP, SETTING_ITEM(off_on_desc) } } }, { LNG("","<カクシュタイミング>"), OPT_SUBMENU, { .sub = { &menu_advtiming, vm_display } } }, })) @@ -108,13 +109,15 @@ MENU(menu_sync, P99_PROTECT({ \ MENU(menu_output, P99_PROTECT({ \ { "240p/288p proc", OPT_AVCONFIG_SELECTION, { .sel = { &tc.pm_240p, OPT_WRAP, SETTING_ITEM(pm_240p_desc) } } }, - { "384p proc", OPT_AVCONFIG_SELECTION, { .sel = { &tc.pm_384p, OPT_WRAP, SETTING_ITEM(pm_384p_desc) } } }, + { "384p proc", OPT_AVCONFIG_SELECTION, { .sel = { &tc.pm_384p, OPT_WRAP, SETTING_ITEM(pm_384p_480p_desc) } } }, { "480i/576i proc", OPT_AVCONFIG_SELECTION, { .sel = { &tc.pm_480i, OPT_WRAP, SETTING_ITEM(pm_480i_desc) } } }, - { "480p/576p proc", OPT_AVCONFIG_SELECTION, { .sel = { &tc.pm_480p, OPT_WRAP, SETTING_ITEM(pm_480p_desc) } } }, + { "480p/576p proc", OPT_AVCONFIG_SELECTION, { .sel = { &tc.pm_480p, OPT_WRAP, SETTING_ITEM(pm_384p_480p_desc) } } }, + { "960i/1080i proc", OPT_AVCONFIG_SELECTION, { .sel = { &tc.pm_1080i, OPT_WRAP, SETTING_ITEM(pm_480i_desc) } } }, { "Line3x mode", OPT_AVCONFIG_SELECTION, { .sel = { &tc.l3_mode, OPT_WRAP, SETTING_ITEM(l3_mode_desc) } } }, - { "Line4x mode", OPT_AVCONFIG_SELECTION, { .sel = { &tc.l4_mode, OPT_WRAP, SETTING_ITEM(l4_mode_desc) } } }, - { "Line5x mode", OPT_AVCONFIG_SELECTION, { .sel = { &tc.l5_mode, OPT_WRAP, SETTING_ITEM(l5_mode_desc) } } }, - { "256x240 L3_Hmult", OPT_AVCONFIG_NUMVALUE, { .num = { &tc.l3m3_hmult, OPT_NOWRAP, 1, 5, value_disp } } }, + { "Line4x mode", OPT_AVCONFIG_SELECTION, { .sel = { &tc.l4_mode, OPT_WRAP, SETTING_ITEM(l4l5_mode_desc) } } }, + { "Line5x mode", OPT_AVCONFIG_SELECTION, { .sel = { &tc.l5_mode, OPT_WRAP, SETTING_ITEM(l4l5_mode_desc) } } }, + { "Line5x format", OPT_AVCONFIG_SELECTION, { .sel = { &tc.l5_fmt, OPT_WRAP, SETTING_ITEM(l5_fmt_desc) } } }, + { "256x240 aspect", OPT_AVCONFIG_SELECTION, { .sel = { &tc.ar_256col, OPT_WRAP, SETTING_ITEM(ar_256col_desc) } } }, { LNG("TX mode","TXモード"), OPT_AVCONFIG_SELECTION, { .sel = { &tc.tx_mode, OPT_WRAP, SETTING_ITEM(tx_mode_desc) } } }, { LNG("Initial input","ショキニュウリョク"), OPT_AVCONFIG_SELECTION, { .sel = { &tc.def_input, OPT_WRAP, SETTING_ITEM(avinput_str) } } }, })) diff --git a/software/sys_controller/tvp7002/tvp7002.c b/software/sys_controller/tvp7002/tvp7002.c index 01b3451..fa7ecec 100644 --- a/software/sys_controller/tvp7002/tvp7002.c +++ b/software/sys_controller/tvp7002/tvp7002.c @@ -41,8 +41,6 @@ const ypbpr_to_rgb_csc_t csc_coeffs[] = { static const alt_u8 Kvco[] = {75, 85, 150, 200}; static const char *Kvco_str[] = { "Ultra low", "Low", "Medium", "High" }; -extern mode_data_t video_modes[]; - static void tvp_set_clamp(video_format fmt) { switch (fmt) { @@ -201,7 +199,7 @@ void tvp_set_fine_gain_offset(color_setup_t *col) { } // Configure H-PLL (sampling rate, VCO gain and charge pump current) -void tvp_setup_hpll(alt_u16 h_samplerate, alt_u16 v_lines, alt_u8 hz, alt_u8 plldivby2) +void tvp_setup_hpll(alt_u16 h_samplerate, alt_u16 refclks_per_line, alt_u8 plldivby2) { alt_u32 pclk_est; alt_u8 vco_range; @@ -210,7 +208,7 @@ void tvp_setup_hpll(alt_u16 h_samplerate, alt_u16 v_lines, alt_u8 hz, alt_u8 pll alt_u8 status = tvp_readreg(TVP_HPLLPHASE) & 0xF8; // Enable PLL post-div-by-2 with double samplerate - if (plldivby2) { + if (plldivby2 && (h_samplerate < 2048)) { tvp_writereg(TVP_HPLLPHASE, status|1); h_samplerate = 2*h_samplerate; } else { @@ -222,7 +220,7 @@ void tvp_setup_hpll(alt_u16 h_samplerate, alt_u16 v_lines, alt_u8 hz, alt_u8 pll printf("Horizontal samplerate set to %u\n", h_samplerate); - pclk_est = ((alt_u32)h_samplerate * v_lines * hz) / 1000; //in kHz + pclk_est = ((alt_u32)h_samplerate * (TVP_EXTCLK_HZ/(alt_u32)refclks_per_line)) / 1000; //in kHz printf("Estimated PCLK_HPLL: %lu.%.3lu MHz\n", pclk_est/1000, pclk_est%1000); @@ -343,7 +341,7 @@ void tvp_set_alc(alt_u8 en_alc, video_type type, alt_u8 h_syncinlen) } } -void tvp_source_setup(alt_8 modeid, video_type type, alt_u32 vlines, alt_u8 hz, alt_u8 h_syncinlen, alt_u8 pre_coast, alt_u8 post_coast, alt_u8 vsync_thold, alt_u8 sample_mult) +void tvp_source_setup(video_type type, alt_u16 h_samplerate, alt_u16 refclks_per_line, alt_u8 plldivby2, alt_u8 h_syncinlen, alt_u16 h_syncoutlen, alt_u8 pre_coast, alt_u8 post_coast, alt_u8 vsync_thold) { // Clamp position and ALC tvp_set_clamp_position(type, h_syncinlen); @@ -367,13 +365,13 @@ void tvp_source_setup(alt_8 modeid, video_type type, alt_u32 vlines, alt_u8 hz, break; } - tvp_setup_hpll(video_modes[modeid].h_total, vlines, hz, !!(video_modes[modeid].flags & MODE_PLLDIVBY2)); + tvp_setup_hpll(h_samplerate, refclks_per_line, plldivby2); // Default (3,3) coast may lead to PLL jitter and sync loss (e.g. SNES) tvp_set_hpllcoast(pre_coast, post_coast); // Hsync output width - tvp_writereg(TVP_HSOUTWIDTH, sample_mult*video_modes[modeid].h_synclen); + tvp_writereg(TVP_HSOUTWIDTH, h_syncoutlen); } void tvp_source_sel(tvp_input_t input, video_format fmt) diff --git a/software/sys_controller/tvp7002/tvp7002.h b/software/sys_controller/tvp7002/tvp7002.h index 6a784ca..10b22b3 100644 --- a/software/sys_controller/tvp7002/tvp7002.h +++ b/software/sys_controller/tvp7002/tvp7002.h @@ -84,7 +84,7 @@ void tvp_init(); void tvp_set_fine_gain_offset(color_setup_t *col); -void tvp_setup_hpll(alt_u16 h_samplerate, alt_u16 v_lines, alt_u8 hz, alt_u8 plldivby2); +void tvp_setup_hpll(alt_u16 h_samplerate, alt_u16 refclks_per_line, alt_u8 plldivby2); void tvp_sel_clk(tvp_refclk_t refclk); @@ -100,7 +100,7 @@ void tvp_set_sog_thold(alt_u8 val); void tvp_set_alc(alt_u8 en_alc, video_type type, alt_u8 h_syncinlen); -void tvp_source_setup(alt_8 modeid, video_type type, alt_u32 vlines, alt_u8 hz, alt_u8 h_syncinlen, alt_u8 pre_coast, alt_u8 post_coast, alt_u8 vsync_thold, alt_u8 sample_mult); +void tvp_source_setup(video_type type, alt_u16 h_samplerate, alt_u16 refclks_per_line, alt_u8 plldivby2, alt_u8 h_syncinlen, alt_u16 h_syncoutlen, alt_u8 pre_coast, alt_u8 post_coast, alt_u8 vsync_thold); void tvp_source_sel(tvp_input_t input, video_format fmt); diff --git a/software/sys_controller/tvp7002/video_modes.c b/software/sys_controller/tvp7002/video_modes.c index ce19cba..e46194d 100644 --- a/software/sys_controller/tvp7002/video_modes.c +++ b/software/sys_controller/tvp7002/video_modes.c @@ -41,7 +41,7 @@ alt_8 get_mode_id(alt_u32 totlines, alt_u8 progressive, alt_u32 hz, video_type t alt_u8 pt_only = 0; // one for each video_group - alt_u8* group_ptr[] = { &pt_only, &cm.cc.pm_240p, &cm.cc.pm_384p, &cm.cc.pm_480i, &cm.cc.pm_480p, &cm.cc.pm_480p }; + alt_u8* group_ptr[] = { &pt_only, &cm.cc.pm_240p, &cm.cc.pm_384p, &cm.cc.pm_480i, &cm.cc.pm_480p, &cm.cc.pm_480p, &cm.cc.pm_1080i }; for (i=0; i GROUP_VGA480P) { + } else if (video_modes[i].group > GROUP_1080I) { printf("WARNING: Corrupted mode (id %d)\n", i); continue; } @@ -70,6 +70,7 @@ alt_8 get_mode_id(alt_u32 totlines, alt_u8 progressive, alt_u32 hz, video_type t cm.hdmitx_pixelrep = HDMITX_PIXELREP_DISABLE; cm.hdmitx_pixr_ifr = 0; cm.sample_mult = 1; + cm.hsync_cut = 0; cm.target_lm = target_lm; switch (target_lm) { @@ -81,8 +82,16 @@ alt_8 get_mode_id(alt_u32 totlines, alt_u8 progressive, alt_u32 hz, video_type t break; case MODE_L2: cm.fpga_vmultmode = FPGA_V_MULTMODE_2X; - cm.fpga_hmultmode = FPGA_H_MULTMODE_FULLWIDTH; - cm.hdmitx_pixelrep = ((video_modes[i].group == GROUP_DTV480P) || (video_modes[i].group == GROUP_VGA480P)) ? HDMITX_PIXELREP_2X : HDMITX_PIXELREP_DISABLE; + if ((video_modes[i].group == GROUP_240P) || (video_modes[i].group == GROUP_384P) || (video_modes[i].group == GROUP_480I)) { + cm.fpga_hmultmode = FPGA_H_MULTMODE_OPTIMIZED; + cm.sample_mult = 2; + } else { + cm.fpga_hmultmode = FPGA_H_MULTMODE_FULLWIDTH; + } + cm.hdmitx_pixelrep = ((video_modes[i].group == GROUP_384P) || + (video_modes[i].group == GROUP_DTV480P) || + (video_modes[i].group == GROUP_VGA480P) || + ((video_modes[i].group == GROUP_1080I) && (video_modes[i].h_total < 1200))) ? HDMITX_PIXELREP_2X : HDMITX_PIXELREP_DISABLE; break; case MODE_L3_GEN_16_9: cm.fpga_vmultmode = FPGA_V_MULTMODE_3X; @@ -119,13 +128,19 @@ alt_8 get_mode_id(alt_u32 totlines, alt_u8 progressive, alt_u32 hz, video_type t case MODE_L5_GEN_4_3: cm.fpga_vmultmode = FPGA_V_MULTMODE_5X; cm.fpga_hmultmode = FPGA_H_MULTMODE_FULLWIDTH; - cm.hdmitx_pixelrep = HDMITX_PIXELREP_2X; + cm.hsync_cut = 120; + break; + case MODE_L5_320_COL: + cm.fpga_vmultmode = FPGA_V_MULTMODE_5X; + cm.fpga_hmultmode = FPGA_H_MULTMODE_OPTIMIZED; + cm.sample_mult = 5; + cm.hsync_cut = 120; break; case MODE_L5_256_COL: cm.fpga_vmultmode = FPGA_V_MULTMODE_5X; cm.fpga_hmultmode = FPGA_H_MULTMODE_OPTIMIZED; - cm.hdmitx_pixelrep = HDMITX_PIXELREP_2X; - cm.sample_mult = 3; + cm.sample_mult = 6; + cm.hsync_cut = 120; break; default: printf("WARNING: invalid target_lm\n"); diff --git a/software/sys_controller/tvp7002/video_modes.h b/software/sys_controller/tvp7002/video_modes.h index ea9efe1..06793f9 100644 --- a/software/sys_controller/tvp7002/video_modes.h +++ b/software/sys_controller/tvp7002/video_modes.h @@ -58,6 +58,7 @@ typedef enum { GROUP_480I = 3, GROUP_DTV480P = 4, GROUP_VGA480P = 5, + GROUP_1080I = 6, } video_group; typedef enum { @@ -74,7 +75,8 @@ typedef enum { MODE_L4_320_COL = (1<<9), MODE_L4_256_COL = (1<<10), MODE_L5_GEN_4_3 = (1<<11), - MODE_L5_256_COL = (1<<12), + MODE_L5_320_COL = (1<<12), + MODE_L5_256_COL = (1<<13), } mode_flags; typedef struct { @@ -97,18 +99,17 @@ typedef struct { { "1280x240", 1280, 240, 6000, 1560, 262, 170, 16, 72, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_L3_GEN_16_9 | MODE_L4_GEN_4_3 | MODE_PLLDIVBY2) }, \ { "960x240", 960, 240, 6000, 1170, 262, 128, 16, 54, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_L3_GEN_4_3 | MODE_PLLDIVBY2) }, \ /*{ "240p_L3M2", 384, 240, 6000, 512, 262, 66, 16, 31, 3, (VIDEO_LDTV|VIDEO_PC), (MODE_L3_MODE2|MODE_PLLDIVBY2) }, //CPS2*/ \ - { "320x240", 320, 240, 6000, 4*426, 262, 49, 16, 31, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_L3_320_COL | MODE_L4_320_COL) }, \ - { "256x240", 256, 240, 6000, 5*341, 262, 39, 16, 25, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_L3_256_COL | MODE_L4_256_COL) }, \ - { "256x216", 256, 216, 6000, 3*341, 262, 39, 16, 25, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, MODE_L5_256_COL }, \ + { "320x240", 320, 240, 6000, 426, 262, 49, 16, 31, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_L3_320_COL | MODE_L4_320_COL | MODE_L5_320_COL | MODE_PLLDIVBY2) }, \ + { "256x240", 256, 240, 6000, 341, 262, 39, 16, 25, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_L3_256_COL | MODE_L4_256_COL | MODE_L5_256_COL | MODE_PLLDIVBY2) }, \ { "240p", 720, 240, 6000, 858, 262, 65, 16, 60, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_PT | MODE_L2 | MODE_PLLDIVBY2) }, \ - { "768*216", 768, 216, 6000, 1023, 262, 117, 16, 75, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_L5_GEN_4_3) }, \ + { "1536*240", 1536, 240, 6000, 2046, 262, 234, 16, 150, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_L5_GEN_4_3 | MODE_PLLDIVBY2) }, \ { "1280x288", 1280, 288, 5000, 1560, 312, 170, 16, 72, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_L3_GEN_16_9 | MODE_L4_GEN_4_3 | MODE_PLLDIVBY2) }, \ { "960x288", 960, 288, 5000, 1170, 312, 128, 16, 54, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_L3_GEN_4_3 | MODE_PLLDIVBY2) }, \ - { "320x240LB", 320, 240, 5000, 4*426, 312, 49, 41, 31, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_L3_320_COL | MODE_L4_320_COL) }, \ - { "256x240LB", 256, 240, 5000, 5*341, 312, 39, 41, 25, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_L3_256_COL | MODE_L4_256_COL) }, \ + { "320x240LB", 320, 240, 5000, 426, 312, 49, 41, 31, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_L3_320_COL | MODE_L4_320_COL | MODE_PLLDIVBY2) }, \ + { "256x240LB", 256, 240, 5000, 341, 312, 39, 41, 25, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_L3_256_COL | MODE_L4_256_COL | MODE_PLLDIVBY2) }, \ { "288p", 720, 288, 5000, 864, 312, 65, 16, 60, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_240P, (MODE_PT | MODE_L2 | MODE_PLLDIVBY2) }, \ { "384p", 496, 384, 5766, 640, 423, 50, 29, 62, 3, (VIDEO_EDTV), GROUP_384P, (MODE_PT | MODE_L2 | MODE_PLLDIVBY2) }, /* Sega Model 2 */ \ - { "640x384", 640, 384, 5500, 800, 492, 48, 63, 96, 2, VIDEO_PC, GROUP_384P, (MODE_PT | MODE_L2) }, /* X68k @ 24kHz */ \ + { "640x384", 640, 384, 5500, 800, 492, 48, 63, 96, 2, VIDEO_PC, GROUP_384P, (MODE_PT | MODE_L2 | MODE_PLLDIVBY2) }, /* X68k @ 24kHz */ \ { "480i", 720, 240, 5994, 858, 525, 65, 16, 60, 3, (VIDEO_SDTV | VIDEO_PC), GROUP_480I, (MODE_PT | MODE_L2 | MODE_PLLDIVBY2 | MODE_INTERLACED) }, \ { "480p", 720, 480, 5994, 858, 525, 60, 30, 62, 6, (VIDEO_EDTV | VIDEO_PC), GROUP_DTV480P, (MODE_PT | MODE_L2) }, \ { "640x480", 640, 480, 6000, 800, 525, 48, 33, 96, 2, (VIDEO_PC | VIDEO_EDTV), GROUP_VGA480P, (MODE_PT | MODE_L2) }, \ @@ -120,9 +121,11 @@ typedef struct { { "1280x720", 1280, 720, 6000, 1650, 750, 220, 20, 40, 5, VIDEO_PC, GROUP_NONE, MODE_PT }, \ { "1024x768", 1024, 768, 6000, 1344, 806, 160, 29, 136, 6, VIDEO_PC, GROUP_NONE, MODE_PT }, \ { "1280x1024", 1280, 1024, 6000, 1688, 1066, 248, 38, 112, 3, VIDEO_PC, GROUP_NONE, MODE_PT }, \ - { "1080i", 1920, 1080, 5994, 2200, 1125, 148, 16, 44, 5, VIDEO_HDTV, GROUP_NONE, (MODE_PT | MODE_INTERLACED) }, /* Too high freq for L2 PLL */ \ + { "640x960i", 640, 480, 5994, 800, 1050, 48, 33, 96, 2, (VIDEO_EDTV | VIDEO_PC), GROUP_1080I, (MODE_PT | MODE_L2 | MODE_INTERLACED) }, \ + { "1080i", 1920, 540, 5994, 2200, 1125, 188, 16, 44, 5, VIDEO_HDTV, GROUP_1080I, (MODE_PT | MODE_L2 | MODE_INTERLACED) }, \ { "1080p", 1920, 1080, 5994, 2200, 1125, 188, 36, 44, 5, VIDEO_HDTV, GROUP_NONE, MODE_PT }, \ { "1920x1080", 1920, 1080, 6000, 2200, 1125, 148, 36, 44, 5, VIDEO_PC, GROUP_NONE, MODE_PT }, \ + { "1600x1200", 1600, 1200, 6000, 2160, 1250, 255, 46, 192, 3, VIDEO_PC, GROUP_NONE, MODE_PT }, \ } #define VIDEO_MODES_SIZE (sizeof((mode_data_t[])VIDEO_MODES_DEF)) diff --git a/software/sys_controller_bsp/settings.bsp b/software/sys_controller_bsp/settings.bsp index 403dcb1..e0586ef 100644 --- a/software/sys_controller_bsp/settings.bsp +++ b/software/sys_controller_bsp/settings.bsp @@ -2,8 +2,8 @@ hal default - Jan 29, 2017 12:54:52 PM - 1485687292131 + Feb 7, 2017 10:49:51 PM + 1486500591240 ./ settings.bsp ../../sys.sopcinfo diff --git a/sys.sopcinfo b/sys.sopcinfo index f1d6991..df6e275 100644 --- a/sys.sopcinfo +++ b/sys.sopcinfo @@ -1,11 +1,11 @@ - + java.lang.Integer - 1485687165 + 1486500460 false true false