mirror of
				https://github.com/marqs85/ossc
				synced 2025-10-26 21:46:02 +03:00 
			
		
		
		
	Scanline updates and fixes
* Enable overlay pattern customization * Fix non-alternating mode with line4x interlace sources * Add alternate interval option for pre-linedoubled sources
This commit is contained in:
		
							parent
							
								
									f561f4586e
								
							
						
					
					
						commit
						9e81fb5922
					
				
							
								
								
									
										135
									
								
								ip/sc_config/inc/sc_config_regs.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										135
									
								
								ip/sc_config/inc/sc_config_regs.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,135 @@ | |||||||
|  | //
 | ||||||
|  | // Copyright (C) 2015-2019  Markus Hiienkari <mhiienka@niksula.hut.fi>
 | ||||||
|  | //
 | ||||||
|  | // This file is part of Open Source Scan Converter project.
 | ||||||
|  | //
 | ||||||
|  | // This program is free software: you can redistribute it and/or modify
 | ||||||
|  | // it under the terms of the GNU General Public License as published by
 | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or
 | ||||||
|  | // (at your option) any later version.
 | ||||||
|  | //
 | ||||||
|  | // This program is distributed in the hope that it will be useful,
 | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||||
|  | // GNU General Public License for more details.
 | ||||||
|  | //
 | ||||||
|  | // You should have received a copy of the GNU General Public License
 | ||||||
|  | // along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
|  | //
 | ||||||
|  | 
 | ||||||
|  | #ifndef SC_CONFIG_REGS_H_ | ||||||
|  | #define SC_CONFIG_REGS_H_ | ||||||
|  | 
 | ||||||
|  | #include <alt_types.h> | ||||||
|  | 
 | ||||||
|  | // bit-fields coded as little-endian
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u16 vmax:11; | ||||||
|  |         alt_u8 interlace_flag:1; | ||||||
|  |         alt_u8 sc_rsv2:4; | ||||||
|  |         alt_u8 fpga_vsyncgen:2; | ||||||
|  |         alt_u16 vmax_tvp:11; | ||||||
|  |         alt_u8 sc_rsv:2; | ||||||
|  |         alt_u8 vsync_flag:1; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } sc_status_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u32 pcnt_frame:20; | ||||||
|  |         alt_u16 sc_rsv:12; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } sc_status2_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u16 lt_lat_result:16; | ||||||
|  |         alt_u16 lt_stb_result:12; | ||||||
|  |         alt_u8 lt_rsv:3; | ||||||
|  |         alt_u8 lt_finished:1; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } lt_status_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u16 h_active:11; | ||||||
|  |         alt_u16 h_backporch:9; | ||||||
|  |         alt_u8 h_synclen:8; | ||||||
|  |         alt_u8 h_l3_240x360:1; | ||||||
|  |         alt_u8 h_l5fmt:1; | ||||||
|  |         alt_u8 h_multmode:2; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } h_config_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u16 h_opt_startoff:10; | ||||||
|  |         alt_u8 h_opt_sample_mult:3; | ||||||
|  |         alt_u8 h_opt_sample_sel:3; | ||||||
|  |         alt_u8 h_opt_scale:3; | ||||||
|  |         alt_u16 h_mask:11; | ||||||
|  |         alt_u8 h_rsv:2; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } h_config2_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u16 v_active:11; | ||||||
|  |         alt_u8 v_backporch:6; | ||||||
|  |         alt_u8 v_synclen:3; | ||||||
|  |         alt_u8 v_mask:6; | ||||||
|  |         alt_u8 v_rsv:3; | ||||||
|  |         alt_u8 v_multmode:3; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } v_config_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u8 mask_br:4; | ||||||
|  |         alt_u8 rev_lpf_str:5; | ||||||
|  |         alt_u32 misc_rsv:23; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } misc_config_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u32 sl_l_str_arr:20; | ||||||
|  |         alt_u8 sl_l_overlay:5; | ||||||
|  |         alt_u8 sl_hybr_str:5; | ||||||
|  |         alt_u8 sl_method:1; | ||||||
|  |         alt_u8 sl_no_altern:1; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } sl_config_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u32 sl_c_str_arr:24; | ||||||
|  |         alt_u8 sl_c_overlay:6; | ||||||
|  |         alt_u8 sl_rsv:1; | ||||||
|  |         alt_u8 sl_altiv:1; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } sl_config2_reg; | ||||||
|  | 
 | ||||||
|  | typedef struct { | ||||||
|  |     sc_status_reg sc_status; | ||||||
|  |     sc_status2_reg sc_status2; | ||||||
|  |     lt_status_reg lt_status; | ||||||
|  |     h_config_reg h_config; | ||||||
|  |     h_config2_reg h_config2; | ||||||
|  |     v_config_reg v_config; | ||||||
|  |     misc_config_reg misc_config; | ||||||
|  |     sl_config_reg sl_config; | ||||||
|  |     sl_config2_reg sl_config2; | ||||||
|  | } __attribute__((packed, __may_alias__)) sc_regs; | ||||||
|  | 
 | ||||||
|  | #endif //SC_CONFIG_REGS_H_
 | ||||||
							
								
								
									
										154
									
								
								ip/sc_config/sc_config_hw.tcl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										154
									
								
								ip/sc_config/sc_config_hw.tcl
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,154 @@ | |||||||
|  | #  | ||||||
|  | # request TCL package from ACDS 16.1 | ||||||
|  | #  | ||||||
|  | package require -exact qsys 16.1 | ||||||
|  | 
 | ||||||
|  | #  | ||||||
|  | # module | ||||||
|  | #  | ||||||
|  | set_module_property DESCRIPTION "Scanconverter config" | ||||||
|  | set_module_property NAME sc_config | ||||||
|  | #set_module_property VERSION 18.0 | ||||||
|  | set_module_property INTERNAL false | ||||||
|  | set_module_property OPAQUE_ADDRESS_MAP true | ||||||
|  | set_module_property GROUP "Interface Protocols" | ||||||
|  | set_module_property AUTHOR "" | ||||||
|  | set_module_property DISPLAY_NAME sc_config | ||||||
|  | set_module_property INSTANTIATE_IN_SYSTEM_MODULE true | ||||||
|  | set_module_property EDITABLE true | ||||||
|  | set_module_property REPORT_TO_TALKBACK false | ||||||
|  | set_module_property ALLOW_GREYBOX_GENERATION false | ||||||
|  | set_module_property REPORT_HIERARCHY false | ||||||
|  | 
 | ||||||
|  | #  | ||||||
|  | # file sets | ||||||
|  | #  | ||||||
|  | add_fileset QUARTUS_SYNTH QUARTUS_SYNTH "" "" | ||||||
|  | set_fileset_property QUARTUS_SYNTH TOP_LEVEL sc_config_top | ||||||
|  | set_fileset_property QUARTUS_SYNTH ENABLE_RELATIVE_INCLUDE_PATHS false | ||||||
|  | set_fileset_property QUARTUS_SYNTH ENABLE_FILE_OVERWRITE_MODE false | ||||||
|  | add_fileset_file sc_config_top.sv VERILOG PATH sc_config_top.sv | ||||||
|  | 
 | ||||||
|  | add_fileset SIM_VERILOG SIM_VERILOG "" "" | ||||||
|  | set_fileset_property SIM_VERILOG ENABLE_RELATIVE_INCLUDE_PATHS false | ||||||
|  | set_fileset_property SIM_VERILOG ENABLE_FILE_OVERWRITE_MODE false | ||||||
|  | set_fileset_property SIM_VERILOG TOP_LEVEL sc_config_top | ||||||
|  | add_fileset_file sc_config_top.sv VERILOG PATH sc_config_top.sv | ||||||
|  | 
 | ||||||
|  | #  | ||||||
|  | # parameters | ||||||
|  | #  | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #  | ||||||
|  | # display items | ||||||
|  | #  | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #  | ||||||
|  | # connection point clock_sink | ||||||
|  | #  | ||||||
|  | add_interface clock_sink clock end | ||||||
|  | set_interface_property clock_sink clockRate 0 | ||||||
|  | set_interface_property clock_sink ENABLED true | ||||||
|  | set_interface_property clock_sink EXPORT_OF "" | ||||||
|  | set_interface_property clock_sink PORT_NAME_MAP "" | ||||||
|  | set_interface_property clock_sink CMSIS_SVD_VARIABLES "" | ||||||
|  | set_interface_property clock_sink SVD_ADDRESS_GROUP "" | ||||||
|  | 
 | ||||||
|  | add_interface_port clock_sink clk_i clk Input 1 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #  | ||||||
|  | # connection point reset_sink | ||||||
|  | #  | ||||||
|  | add_interface reset_sink reset end | ||||||
|  | set_interface_property reset_sink associatedClock clock_sink | ||||||
|  | set_interface_property reset_sink synchronousEdges DEASSERT | ||||||
|  | set_interface_property reset_sink ENABLED true | ||||||
|  | set_interface_property reset_sink EXPORT_OF "" | ||||||
|  | set_interface_property reset_sink PORT_NAME_MAP "" | ||||||
|  | set_interface_property reset_sink CMSIS_SVD_VARIABLES "" | ||||||
|  | set_interface_property reset_sink SVD_ADDRESS_GROUP "" | ||||||
|  | 
 | ||||||
|  | add_interface_port reset_sink rst_i reset Input 1 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #  | ||||||
|  | # connection point avalon_s | ||||||
|  | #  | ||||||
|  | add_interface avalon_s avalon end | ||||||
|  | set_interface_property avalon_s addressUnits WORDS | ||||||
|  | set_interface_property avalon_s associatedClock clock_sink | ||||||
|  | set_interface_property avalon_s associatedReset reset_sink | ||||||
|  | set_interface_property avalon_s bitsPerSymbol 8 | ||||||
|  | set_interface_property avalon_s burstOnBurstBoundariesOnly false | ||||||
|  | set_interface_property avalon_s burstcountUnits WORDS | ||||||
|  | set_interface_property avalon_s explicitAddressSpan 0 | ||||||
|  | set_interface_property avalon_s holdTime 0 | ||||||
|  | set_interface_property avalon_s linewrapBursts false | ||||||
|  | set_interface_property avalon_s maximumPendingReadTransactions 0 | ||||||
|  | set_interface_property avalon_s maximumPendingWriteTransactions 0 | ||||||
|  | set_interface_property avalon_s readLatency 0 | ||||||
|  | set_interface_property avalon_s readWaitTime 1 | ||||||
|  | set_interface_property avalon_s setupTime 0 | ||||||
|  | set_interface_property avalon_s timingUnits Cycles | ||||||
|  | set_interface_property avalon_s writeWaitTime 0 | ||||||
|  | set_interface_property avalon_s ENABLED true | ||||||
|  | set_interface_property avalon_s EXPORT_OF "" | ||||||
|  | set_interface_property avalon_s PORT_NAME_MAP "" | ||||||
|  | set_interface_property avalon_s CMSIS_SVD_VARIABLES "" | ||||||
|  | set_interface_property avalon_s SVD_ADDRESS_GROUP "" | ||||||
|  | 
 | ||||||
|  | add_interface_port avalon_s avalon_s_address address Input 4 | ||||||
|  | add_interface_port avalon_s avalon_s_writedata writedata Input 32 | ||||||
|  | add_interface_port avalon_s avalon_s_readdata readdata Output 32 | ||||||
|  | add_interface_port avalon_s avalon_s_byteenable byteenable Input 4 | ||||||
|  | add_interface_port avalon_s avalon_s_write write Input 1 | ||||||
|  | add_interface_port avalon_s avalon_s_read read Input 1 | ||||||
|  | add_interface_port avalon_s avalon_s_chipselect chipselect Input 1 | ||||||
|  | add_interface_port avalon_s avalon_s_waitrequest_n waitrequest_n Output 1 | ||||||
|  | set_interface_assignment avalon_s embeddedsw.configuration.isFlash 0 | ||||||
|  | set_interface_assignment avalon_s embeddedsw.configuration.isMemoryDevice 0 | ||||||
|  | set_interface_assignment avalon_s embeddedsw.configuration.isNonVolatileStorage 0 | ||||||
|  | set_interface_assignment avalon_s embeddedsw.configuration.isPrintableDevice 0 | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #  | ||||||
|  | # connection point bus | ||||||
|  | #  | ||||||
|  | #add_sv_interface bus sc_if | ||||||
|  | 
 | ||||||
|  | # Setting the parameter property to add SV interface parameters | ||||||
|  | #set_parameter_property my_interface_parameter SV_INTERFACE_PARAMETER bus | ||||||
|  | 
 | ||||||
|  | # Setting the port properties to add them to SV interface port set_port_property clk SV_INTERFACE_PORT bus #set_port_property p1 SV_INTERFACE_PORT bus | ||||||
|  | #set_port_property p2 SV_INTERFACE_PORT bus | ||||||
|  | #set_port_property p1 SV_INTERFACE_SIGNAL bus | ||||||
|  | #set_port_property p2 SV_INTERFACE_SIGNAL bus | ||||||
|  | 
 | ||||||
|  | #Adding the SV Interface File | ||||||
|  | #add_fileset_file sc_if.sv SYSTEM_VERILOG PATH sc_if.sv SYSTEMVERILOG_INTERFACE | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #  | ||||||
|  | # connection point sc_if | ||||||
|  | #  | ||||||
|  | add_interface sc_if conduit end | ||||||
|  | set_interface_property sc_if associatedClock "" | ||||||
|  | set_interface_property sc_if associatedReset "" | ||||||
|  | set_interface_property sc_if ENABLED true | ||||||
|  | set_interface_property sc_if EXPORT_OF "" | ||||||
|  | set_interface_property sc_if PORT_NAME_MAP "" | ||||||
|  | set_interface_property sc_if CMSIS_SVD_VARIABLES "" | ||||||
|  | set_interface_property sc_if SVD_ADDRESS_GROUP "" | ||||||
|  | 
 | ||||||
|  | add_interface_port sc_if sc_status_i sc_status_i Input 32 | ||||||
|  | add_interface_port sc_if sc_status2_i sc_status2_i Input 32 | ||||||
|  | add_interface_port sc_if lt_status_i lt_status_i Input 32 | ||||||
|  | add_interface_port sc_if h_config_o h_config_o Output 32 | ||||||
|  | add_interface_port sc_if h_config2_o h_config2_o Output 32 | ||||||
|  | add_interface_port sc_if v_config_o v_config_o Output 32 | ||||||
|  | add_interface_port sc_if misc_config_o misc_config_o Output 32 | ||||||
|  | add_interface_port sc_if sl_config_o sl_config_o Output 32 | ||||||
|  | add_interface_port sc_if sl_config2_o sl_config2_o Output 32 | ||||||
							
								
								
									
										54
									
								
								ip/sc_config/sc_config_sw.tcl
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								ip/sc_config/sc_config_sw.tcl
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,54 @@ | |||||||
|  | # | ||||||
|  | # opencores_i2c_sw.tcl | ||||||
|  | # | ||||||
|  | 
 | ||||||
|  | # Create a new driver | ||||||
|  | create_driver sc_config_driver | ||||||
|  | 
 | ||||||
|  | # Associate it with some hardware known as "opencores_i2c" | ||||||
|  | set_sw_property hw_class_name sc_config | ||||||
|  | 
 | ||||||
|  | # The version of this driver | ||||||
|  | set_sw_property version 1.0 | ||||||
|  | 
 | ||||||
|  | # This driver may be incompatible with versions of hardware less | ||||||
|  | # than specified below. Updates to hardware and device drivers | ||||||
|  | # rendering the driver incompatible with older versions of | ||||||
|  | # hardware are noted with this property assignment. | ||||||
|  | # | ||||||
|  | # Multiple-Version compatibility was introduced in version 7.1; | ||||||
|  | # prior versions are therefore excluded. | ||||||
|  | set_sw_property min_compatible_hw_version 7.1 | ||||||
|  | 
 | ||||||
|  | # Initialize the driver in alt_sys_init() | ||||||
|  | set_sw_property auto_initialize false | ||||||
|  | 
 | ||||||
|  | # Location in generated BSP that above sources will be copied into | ||||||
|  | set_sw_property bsp_subdirectory drivers | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | # Interrupt properties: | ||||||
|  | # This peripheral has an IRQ output but the driver doesn't currently | ||||||
|  | # have any interrupt service routine. To ensure that the BSP tools | ||||||
|  | # do not otherwise limit the BSP functionality for users of the | ||||||
|  | # Nios II enhanced interrupt port, these settings advertise  | ||||||
|  | # compliance with both legacy and enhanced interrupt APIs, and to state | ||||||
|  | # that any driver ISR supports preemption. If an interrupt handler | ||||||
|  | # is added to this driver, these must be re-examined for validity. | ||||||
|  | set_sw_property isr_preemption_supported true | ||||||
|  | set_sw_property supported_interrupt_apis "legacy_interrupt_api enhanced_interrupt_api" | ||||||
|  | 
 | ||||||
|  | # | ||||||
|  | # Source file listings... | ||||||
|  | # | ||||||
|  | 
 | ||||||
|  | # C/C++ source files | ||||||
|  | 
 | ||||||
|  | # Include files | ||||||
|  | add_sw_property include_source inc/sc_config_regs.h | ||||||
|  | 
 | ||||||
|  | # This driver supports HAL & UCOSII BSP (OS) types | ||||||
|  | add_sw_property supported_bsp_type HAL | ||||||
|  | add_sw_property supported_bsp_type UCOSII | ||||||
|  | 
 | ||||||
|  | # End of file | ||||||
							
								
								
									
										179
									
								
								ip/sc_config/sc_config_top.sv
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										179
									
								
								ip/sc_config/sc_config_top.sv
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,179 @@ | |||||||
|  | //
 | ||||||
|  | // Copyright (C) 2015-2019  Markus Hiienkari <mhiienka@niksula.hut.fi>
 | ||||||
|  | //
 | ||||||
|  | // This file is part of Open Source Scan Converter project.
 | ||||||
|  | //
 | ||||||
|  | // This program is free software: you can redistribute it and/or modify
 | ||||||
|  | // it under the terms of the GNU General Public License as published by
 | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or
 | ||||||
|  | // (at your option) any later version.
 | ||||||
|  | //
 | ||||||
|  | // This program is distributed in the hope that it will be useful,
 | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||||
|  | // GNU General Public License for more details.
 | ||||||
|  | //
 | ||||||
|  | // You should have received a copy of the GNU General Public License
 | ||||||
|  | // along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
|  | //
 | ||||||
|  | 
 | ||||||
|  | module sc_config_top( | ||||||
|  |     // common
 | ||||||
|  |     input clk_i, | ||||||
|  |     input rst_i, | ||||||
|  |     // avalon slave
 | ||||||
|  |     input [31:0] avalon_s_writedata, | ||||||
|  |     output [31:0] avalon_s_readdata, | ||||||
|  |     input [3:0] avalon_s_address, | ||||||
|  |     input [3:0] avalon_s_byteenable, | ||||||
|  |     input avalon_s_write, | ||||||
|  |     input avalon_s_read, | ||||||
|  |     input avalon_s_chipselect, | ||||||
|  |     output avalon_s_waitrequest_n, | ||||||
|  |     // SC interface
 | ||||||
|  |     input [31:0] sc_status_i, | ||||||
|  |     input [31:0] sc_status2_i, | ||||||
|  |     input [31:0] lt_status_i, | ||||||
|  |     output reg [31:0] h_config_o, | ||||||
|  |     output reg [31:0] h_config2_o, | ||||||
|  |     output reg [31:0] v_config_o, | ||||||
|  |     output reg [31:0] misc_config_o, | ||||||
|  |     output reg [31:0] sl_config_o, | ||||||
|  |     output reg [31:0] sl_config2_o | ||||||
|  | ); | ||||||
|  | 
 | ||||||
|  | localparam SC_STATUS_REGNUM =   4'h0; | ||||||
|  | localparam SC_STATUS2_REGNUM =  4'h1; | ||||||
|  | localparam LT_STATUS_REGNUM =   4'h2; | ||||||
|  | localparam H_CONFIG_REGNUM =    4'h3; | ||||||
|  | localparam H_CONFIG2_REGNUM =   4'h4; | ||||||
|  | localparam V_CONFIG_REGNUM =    4'h5; | ||||||
|  | localparam MISC_CONFIG_REGNUM = 4'h6; | ||||||
|  | localparam SL_CONFIG_REGNUM =   4'h7; | ||||||
|  | localparam SL_CONFIG2_REGNUM =  4'h8; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | assign avalon_s_waitrequest_n = 1'b1; | ||||||
|  | 
 | ||||||
|  | always @(posedge clk_i or posedge rst_i) begin | ||||||
|  |     if (rst_i) begin | ||||||
|  |         h_config_o <= 0; | ||||||
|  |     end else begin | ||||||
|  |         if (avalon_s_chipselect && avalon_s_write && (avalon_s_address==H_CONFIG_REGNUM)) begin | ||||||
|  |             if (avalon_s_byteenable[3]) | ||||||
|  |                 h_config_o[31:24] <= avalon_s_writedata[31:24]; | ||||||
|  |             if (avalon_s_byteenable[2]) | ||||||
|  |                 h_config_o[23:16] <= avalon_s_writedata[23:16]; | ||||||
|  |             if (avalon_s_byteenable[1]) | ||||||
|  |                 h_config_o[15:8] <= avalon_s_writedata[15:8]; | ||||||
|  |             if (avalon_s_byteenable[0]) | ||||||
|  |                 h_config_o[7:0] <= avalon_s_writedata[7:0]; | ||||||
|  |         end | ||||||
|  |     end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | always @(posedge clk_i or posedge rst_i) begin | ||||||
|  |     if (rst_i) begin | ||||||
|  |         h_config2_o <= 0; | ||||||
|  |     end else begin | ||||||
|  |         if (avalon_s_chipselect && avalon_s_write && (avalon_s_address==H_CONFIG2_REGNUM)) begin | ||||||
|  |             if (avalon_s_byteenable[3]) | ||||||
|  |                 h_config2_o[31:24] <= avalon_s_writedata[31:24]; | ||||||
|  |             if (avalon_s_byteenable[2]) | ||||||
|  |                 h_config2_o[23:16] <= avalon_s_writedata[23:16]; | ||||||
|  |             if (avalon_s_byteenable[1]) | ||||||
|  |                 h_config2_o[15:8] <= avalon_s_writedata[15:8]; | ||||||
|  |             if (avalon_s_byteenable[0]) | ||||||
|  |                 h_config2_o[7:0] <= avalon_s_writedata[7:0]; | ||||||
|  |         end | ||||||
|  |     end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | always @(posedge clk_i or posedge rst_i) begin | ||||||
|  |     if (rst_i) begin | ||||||
|  |         v_config_o <= 0; | ||||||
|  |     end else begin | ||||||
|  |         if (avalon_s_chipselect && avalon_s_write && (avalon_s_address==V_CONFIG_REGNUM)) begin | ||||||
|  |             if (avalon_s_byteenable[3]) | ||||||
|  |                 v_config_o[31:24] <= avalon_s_writedata[31:24]; | ||||||
|  |             if (avalon_s_byteenable[2]) | ||||||
|  |                 v_config_o[23:16] <= avalon_s_writedata[23:16]; | ||||||
|  |             if (avalon_s_byteenable[1]) | ||||||
|  |                 v_config_o[15:8] <= avalon_s_writedata[15:8]; | ||||||
|  |             if (avalon_s_byteenable[0]) | ||||||
|  |                 v_config_o[7:0] <= avalon_s_writedata[7:0]; | ||||||
|  |         end | ||||||
|  |     end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | always @(posedge clk_i or posedge rst_i) begin | ||||||
|  |     if (rst_i) begin | ||||||
|  |         misc_config_o <= 0; | ||||||
|  |     end else begin | ||||||
|  |         if (avalon_s_chipselect && avalon_s_write && (avalon_s_address==MISC_CONFIG_REGNUM)) begin | ||||||
|  |             if (avalon_s_byteenable[3]) | ||||||
|  |                 misc_config_o[31:24] <= avalon_s_writedata[31:24]; | ||||||
|  |             if (avalon_s_byteenable[2]) | ||||||
|  |                 misc_config_o[23:16] <= avalon_s_writedata[23:16]; | ||||||
|  |             if (avalon_s_byteenable[1]) | ||||||
|  |                 misc_config_o[15:8] <= avalon_s_writedata[15:8]; | ||||||
|  |             if (avalon_s_byteenable[0]) | ||||||
|  |                 misc_config_o[7:0] <= avalon_s_writedata[7:0]; | ||||||
|  |         end | ||||||
|  |     end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | always @(posedge clk_i or posedge rst_i) begin | ||||||
|  |     if (rst_i) begin | ||||||
|  |         sl_config_o <= 0; | ||||||
|  |     end else begin | ||||||
|  |         if (avalon_s_chipselect && avalon_s_write && (avalon_s_address==SL_CONFIG_REGNUM)) begin | ||||||
|  |             if (avalon_s_byteenable[3]) | ||||||
|  |                 sl_config_o[31:24] <= avalon_s_writedata[31:24]; | ||||||
|  |             if (avalon_s_byteenable[2]) | ||||||
|  |                 sl_config_o[23:16] <= avalon_s_writedata[23:16]; | ||||||
|  |             if (avalon_s_byteenable[1]) | ||||||
|  |                 sl_config_o[15:8] <= avalon_s_writedata[15:8]; | ||||||
|  |             if (avalon_s_byteenable[0]) | ||||||
|  |                 sl_config_o[7:0] <= avalon_s_writedata[7:0]; | ||||||
|  |         end | ||||||
|  |     end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | always @(posedge clk_i or posedge rst_i) begin | ||||||
|  |     if (rst_i) begin | ||||||
|  |         sl_config2_o <= 0; | ||||||
|  |     end else begin | ||||||
|  |         if (avalon_s_chipselect && avalon_s_write && (avalon_s_address==SL_CONFIG2_REGNUM)) begin | ||||||
|  |             if (avalon_s_byteenable[3]) | ||||||
|  |                 sl_config2_o[31:24] <= avalon_s_writedata[31:24]; | ||||||
|  |             if (avalon_s_byteenable[2]) | ||||||
|  |                 sl_config2_o[23:16] <= avalon_s_writedata[23:16]; | ||||||
|  |             if (avalon_s_byteenable[1]) | ||||||
|  |                 sl_config2_o[15:8] <= avalon_s_writedata[15:8]; | ||||||
|  |             if (avalon_s_byteenable[0]) | ||||||
|  |                 sl_config2_o[7:0] <= avalon_s_writedata[7:0]; | ||||||
|  |         end | ||||||
|  |     end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | always @(*) begin | ||||||
|  |     if (avalon_s_chipselect && avalon_s_read) begin | ||||||
|  |         case (avalon_s_address) | ||||||
|  |             SC_STATUS_REGNUM: avalon_s_readdata = sc_status_i; | ||||||
|  |             SC_STATUS2_REGNUM: avalon_s_readdata = sc_status2_i; | ||||||
|  |             LT_STATUS_REGNUM: avalon_s_readdata = lt_status_i; | ||||||
|  |             H_CONFIG_REGNUM: avalon_s_readdata = h_config_o; | ||||||
|  |             H_CONFIG2_REGNUM: avalon_s_readdata = h_config2_o; | ||||||
|  |             V_CONFIG_REGNUM: avalon_s_readdata = v_config_o; | ||||||
|  |             MISC_CONFIG_REGNUM: avalon_s_readdata = misc_config_o; | ||||||
|  |             SL_CONFIG_REGNUM: avalon_s_readdata = sl_config_o; | ||||||
|  |             SL_CONFIG2_REGNUM: avalon_s_readdata = sl_config2_o; | ||||||
|  |             default: avalon_s_readdata = 32'h00000000; | ||||||
|  |         endcase | ||||||
|  |     end else begin | ||||||
|  |         avalon_s_readdata = 32'h00000000; | ||||||
|  |     end | ||||||
|  | end | ||||||
|  | 
 | ||||||
|  | endmodule | ||||||
							
								
								
									
										2
									
								
								ossc.sdc
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								ossc.sdc
									
									
									
									
									
								
							| @ -73,7 +73,7 @@ set_clock_groups -asynchronous -group \ | |||||||
|                             {pclk_5x_source pclk_5x pclk_5x_postmux pclk_5x_out} |                             {pclk_5x_source pclk_5x pclk_5x_postmux pclk_5x_out} | ||||||
| 
 | 
 | ||||||
| # Ignore paths from registers which are updated only at leading edge of vsync | # Ignore paths from registers which are updated only at leading edge of vsync | ||||||
| set_false_path -from [get_registers {scanconverter_inst|H_* scanconverter_inst|V_* scanconverter_inst|X_* scanconverter_inst|LT_POS_* scanconverter_inst|FID_1x}] | set_false_path -from [get_registers {scanconverter_inst|H_* scanconverter_inst|V_* scanconverter_inst|X_* scanconverter_inst|SL_* scanconverter_inst|LT_POS_* scanconverter_inst|FID_1x}] | ||||||
| 
 | 
 | ||||||
| # Ignore paths from registers which are updated only at leading edge of hsync | # Ignore paths from registers which are updated only at leading edge of hsync | ||||||
| set_false_path -from [get_registers {scanconverter:scanconverter_inst|line_idx scanconverter:scanconverter_inst|line_out_idx* scanconverter:scanconverter_inst|hmax*}] | set_false_path -from [get_registers {scanconverter:scanconverter_inst|line_idx scanconverter:scanconverter_inst|line_out_idx* scanconverter:scanconverter_inst|hmax*}] | ||||||
|  | |||||||
| @ -22,5 +22,5 @@ | |||||||
| `define LT_POS_CENTER       2'b10 | `define LT_POS_CENTER       2'b10 | ||||||
| `define LT_POS_BOTTOMRIGHT  2'b11 | `define LT_POS_BOTTOMRIGHT  2'b11 | ||||||
| 
 | 
 | ||||||
| `define LT_WIDTH_DIV        8 | `define LT_WIDTH_DIV        4'h8 | ||||||
| `define LT_HEIGHT_DIV       8 | `define LT_HEIGHT_DIV       4'h8 | ||||||
|  | |||||||
							
								
								
									
										33
									
								
								rtl/ossc.v
									
									
									
									
									
								
							
							
						
						
									
										33
									
								
								rtl/ossc.v
									
									
									
									
									
								
							| @ -1,5 +1,5 @@ | |||||||
| // | // | ||||||
| // Copyright (C) 2015-2018  Markus Hiienkari <mhiienka@niksula.hut.fi> | // Copyright (C) 2015-2019  Markus Hiienkari <mhiienka@niksula.hut.fi> | ||||||
| // | // | ||||||
| // This file is part of Open Source Scan Converter project. | // This file is part of Open Source Scan Converter project. | ||||||
| // | // | ||||||
| @ -59,10 +59,10 @@ wire [15:0] sys_ctrl; | |||||||
| wire h_unstable; | wire h_unstable; | ||||||
| wire [1:0] pclk_lock; | wire [1:0] pclk_lock; | ||||||
| wire [1:0] pll_lock_lost; | wire [1:0] pll_lock_lost; | ||||||
| wire [31:0] h_info, h_info2, v_info, extra_info; | wire [31:0] h_config, h_config2, v_config, misc_config, sl_config, sl_config2; | ||||||
| wire [10:0] vmax, vmax_tvp; | wire [10:0] vmax, vmax_tvp; | ||||||
| wire [1:0] fpga_vsyncgen; | wire [1:0] fpga_vsyncgen; | ||||||
| wire ilace_flag; | wire ilace_flag, vsync_flag; | ||||||
| wire [19:0] pcnt_frame; | wire [19:0] pcnt_frame; | ||||||
| 
 | 
 | ||||||
| wire [15:0] ir_code; | wire [15:0] ir_code; | ||||||
| @ -242,13 +242,15 @@ sys sys_inst( | |||||||
|     .i2c_opencores_1_export_spi_miso_pad_i  (SD_DAT[0]), |     .i2c_opencores_1_export_spi_miso_pad_i  (SD_DAT[0]), | ||||||
|     .pio_0_sys_ctrl_out_export              (sys_ctrl), |     .pio_0_sys_ctrl_out_export              (sys_ctrl), | ||||||
|     .pio_1_controls_in_export               ({ir_code_cnt, 5'b00000, HDMI_TX_MODE_LL, btn_LL, ir_code}), |     .pio_1_controls_in_export               ({ir_code_cnt, 5'b00000, HDMI_TX_MODE_LL, btn_LL, ir_code}), | ||||||
|     .pio_2_status_in_export                 ({VSYNC_out, 2'b00, vmax_tvp, fpga_vsyncgen, 4'h0, ilace_flag, vmax}), |     .sc_config_0_sc_if_sc_status_i          ({vsync_flag, 2'b00, vmax_tvp, fpga_vsyncgen, 4'h0, ilace_flag, vmax}), | ||||||
|     .pio_3_h_info_out_export                (h_info), |     .sc_config_0_sc_if_sc_status2_i         ({12'h000, pcnt_frame}), | ||||||
|     .pio_4_h_info2_out_export               (h_info2), |     .sc_config_0_sc_if_lt_status_i          ({lt_finished, 3'h0, lt_stb_result, lt_lat_result}), | ||||||
|     .pio_5_v_info_out_export                (v_info), |     .sc_config_0_sc_if_h_config_o           (h_config), | ||||||
|     .pio_6_extra_info_out_export            (extra_info), |     .sc_config_0_sc_if_h_config2_o          (h_config2), | ||||||
|     .pio_7_lt_results_in_export             ({lt_finished, 3'h0, lt_stb_result, lt_lat_result}), |     .sc_config_0_sc_if_v_config_o           (v_config), | ||||||
|     .pio_8_pcnt_vhz_in_export               ({12'h000, pcnt_frame}) |     .sc_config_0_sc_if_misc_config_o        (misc_config), | ||||||
|  |     .sc_config_0_sc_if_sl_config_o          (sl_config), | ||||||
|  |     .sc_config_0_sc_if_sl_config2_o         (sl_config2) | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| scanconverter scanconverter_inst ( | scanconverter scanconverter_inst ( | ||||||
| @ -261,10 +263,12 @@ scanconverter scanconverter_inst ( | |||||||
|     .R_in           (R_in_L), |     .R_in           (R_in_L), | ||||||
|     .G_in           (G_in_L), |     .G_in           (G_in_L), | ||||||
|     .B_in           (B_in_L), |     .B_in           (B_in_L), | ||||||
|     .h_info         (h_info), |     .h_config       (h_config), | ||||||
|     .h_info2        (h_info2), |     .h_config2      (h_config2), | ||||||
|     .v_info         (v_info), |     .v_config       (v_config), | ||||||
|     .extra_info     (extra_info), |     .misc_config    (misc_config), | ||||||
|  |     .sl_config      (sl_config), | ||||||
|  |     .sl_config2     (sl_config2), | ||||||
|     .R_out          (R_out), |     .R_out          (R_out), | ||||||
|     .G_out          (G_out), |     .G_out          (G_out), | ||||||
|     .B_out          (B_out), |     .B_out          (B_out), | ||||||
| @ -280,6 +284,7 @@ scanconverter scanconverter_inst ( | |||||||
|     .vmax_tvp       (vmax_tvp), |     .vmax_tvp       (vmax_tvp), | ||||||
|     .pcnt_frame     (pcnt_frame), |     .pcnt_frame     (pcnt_frame), | ||||||
|     .ilace_flag     (ilace_flag), |     .ilace_flag     (ilace_flag), | ||||||
|  |     .vsync_flag     (vsync_flag), | ||||||
|     .lt_active      (lt_active), |     .lt_active      (lt_active), | ||||||
|     .lt_mode        (lt_mode_synced) |     .lt_mode        (lt_mode_synced) | ||||||
| ); | ); | ||||||
|  | |||||||
| @ -1,5 +1,5 @@ | |||||||
| // | // | ||||||
| // Copyright (C) 2015-2018  Markus Hiienkari <mhiienka@niksula.hut.fi> | // Copyright (C) 2015-2019  Markus Hiienkari <mhiienka@niksula.hut.fi> | ||||||
| // | // | ||||||
| // This file is part of Open Source Scan Converter project. | // This file is part of Open Source Scan Converter project. | ||||||
| // | // | ||||||
| @ -44,11 +44,6 @@ | |||||||
| `define H_MULTMODE_OPTIMIZED    2'h2 | `define H_MULTMODE_OPTIMIZED    2'h2 | ||||||
| `define H_MULTMODE_OPTIMIZED_1X 2'h3 | `define H_MULTMODE_OPTIMIZED_1X 2'h3 | ||||||
| 
 | 
 | ||||||
| `define SCANLINES_OFF           2'h0 |  | ||||||
| `define SCANLINES_H             2'h1 |  | ||||||
| `define SCANLINES_V             2'h2 |  | ||||||
| `define SCANLINES_ALT           2'h3 |  | ||||||
| 
 |  | ||||||
| `define SCANLINES_HYBR_CONTR_LOW  2'h1 | `define SCANLINES_HYBR_CONTR_LOW  2'h1 | ||||||
| `define SCANLINES_HYBR_CONTR_MED  2'h2 | `define SCANLINES_HYBR_CONTR_MED  2'h2 | ||||||
| `define SCANLINES_HYBR_CONTR_HIGH 2'h3 | `define SCANLINES_HYBR_CONTR_HIGH 2'h3 | ||||||
| @ -87,10 +82,12 @@ module scanconverter ( | |||||||
|     input HSYNC_in, |     input HSYNC_in, | ||||||
|     input PCLK_in, |     input PCLK_in, | ||||||
|     input clk27, |     input clk27, | ||||||
|     input [31:0] h_info, |     input [31:0] h_config, | ||||||
|     input [31:0] h_info2, |     input [31:0] h_config2, | ||||||
|     input [31:0] v_info, |     input [31:0] v_config, | ||||||
|     input [31:0] extra_info, |     input [31:0] misc_config, | ||||||
|  |     input [31:0] sl_config, | ||||||
|  |     input [31:0] sl_config2, | ||||||
|     output reg [7:0] R_out, |     output reg [7:0] R_out, | ||||||
|     output reg [7:0] G_out, |     output reg [7:0] G_out, | ||||||
|     output reg [7:0] B_out, |     output reg [7:0] B_out, | ||||||
| @ -106,6 +103,7 @@ module scanconverter ( | |||||||
|     output reg [10:0] vmax_tvp, |     output reg [10:0] vmax_tvp, | ||||||
|     output reg [19:0] pcnt_frame, |     output reg [19:0] pcnt_frame, | ||||||
|     output ilace_flag, |     output ilace_flag, | ||||||
|  |     output vsync_flag, | ||||||
|     input lt_active, |     input lt_active, | ||||||
|     input [1:0] lt_mode |     input [1:0] lt_mode | ||||||
| ); | ); | ||||||
| @ -157,7 +155,8 @@ reg [11:0] hcnt_pp /* synthesis ramstyle = "logic" */; | |||||||
| reg [10:0] vcnt_pp /* synthesis ramstyle = "logic" */; | reg [10:0] vcnt_pp /* synthesis ramstyle = "logic" */; | ||||||
| reg  rlpf_trigger_r[1:`PP_RLPF_PL_START-1] /* synthesis ramstyle = "logic" */; | reg  rlpf_trigger_r[1:`PP_RLPF_PL_START-1] /* synthesis ramstyle = "logic" */; | ||||||
| reg [7:0] R_prev_pp[`PP_RLPF_PL_START:`PP_RLPF_PL_END-1], G_prev_pp[`PP_RLPF_PL_START:`PP_RLPF_PL_END-1], B_prev_pp[`PP_RLPF_PL_START:`PP_RLPF_PL_END-1] /* synthesis ramstyle = "logic" */; | reg [7:0] R_prev_pp[`PP_RLPF_PL_START:`PP_RLPF_PL_END-1], G_prev_pp[`PP_RLPF_PL_START:`PP_RLPF_PL_END-1], B_prev_pp[`PP_RLPF_PL_START:`PP_RLPF_PL_END-1] /* synthesis ramstyle = "logic" */; | ||||||
| reg [2:0] line_id_pp[1:`PP_SLGEN_PL_END-2], col_id_pp[1:`PP_SLGEN_PL_END-2] /* synthesis ramstyle = "logic" */; | reg [2:0] line_id_pp[1:`PP_SLGEN_PL_END-5], col_id_pp[1:`PP_SLGEN_PL_END-5] /* synthesis ramstyle = "logic" */; | ||||||
|  | reg draw_sl_pp[`PP_SLGEN_PL_END-4:`PP_SLGEN_PL_END-1] /* synthesis ramstyle = "logic" */; | ||||||
| reg border_enable_pp[2:`PP_PIPELINE_LENGTH] /* synthesis ramstyle = "logic" */; | reg border_enable_pp[2:`PP_PIPELINE_LENGTH] /* synthesis ramstyle = "logic" */; | ||||||
| reg lt_box_enable_pp[2:`PP_PIPELINE_LENGTH] /* synthesis ramstyle = "logic" */; | reg lt_box_enable_pp[2:`PP_PIPELINE_LENGTH] /* synthesis ramstyle = "logic" */; | ||||||
| 
 | 
 | ||||||
| @ -177,8 +176,6 @@ reg [10:0] V_ACTIVE;    //max. 2047 | |||||||
| reg [6:0] V_AVIDSTART;  //max. 127 | reg [6:0] V_AVIDSTART;  //max. 127 | ||||||
| reg [7:0] H_SYNCLEN; | reg [7:0] H_SYNCLEN; | ||||||
| reg [2:0] V_SYNCLEN; | reg [2:0] V_SYNCLEN; | ||||||
| reg [1:0] V_SCANLINEMODE; |  | ||||||
| reg [4:0] V_SCANLINEID; |  | ||||||
| reg [5:0] V_MASK; | reg [5:0] V_MASK; | ||||||
| reg [2:0] V_MULTMODE; | reg [2:0] V_MULTMODE; | ||||||
| reg [1:0] H_MULTMODE; | reg [1:0] H_MULTMODE; | ||||||
| @ -191,10 +188,15 @@ reg [9:0] H_L5BORDER; | |||||||
| reg [9:0] H_L3BORDER; | reg [9:0] H_L3BORDER; | ||||||
| reg [6:0] H_L3_OPT_SAMPLE_COMP; | reg [6:0] H_L3_OPT_SAMPLE_COMP; | ||||||
| reg [3:0] X_MASK_BR; | reg [3:0] X_MASK_BR; | ||||||
| reg       X_SCANLINE_METHOD; |  | ||||||
| reg [4:0] X_SCANLINE_HYBRSTR; |  | ||||||
| reg [7:0] X_SCANLINESTR; |  | ||||||
| reg [5:0] X_REV_LPF_STR; | reg [5:0] X_REV_LPF_STR; | ||||||
|  | reg [3:0] SL_L_STR[4:0] /* synthesis ramstyle = "logic" */; | ||||||
|  | reg [3:0] SL_C_STR[5:0] /* synthesis ramstyle = "logic" */; | ||||||
|  | reg [4:0] SL_HYBRSTR; | ||||||
|  | reg [4:0] SL_L_OVERLAY; | ||||||
|  | reg [5:0] SL_C_OVERLAY; | ||||||
|  | reg SL_METHOD; | ||||||
|  | reg SL_NO_ALTERN; | ||||||
|  | reg SL_ALTIV; | ||||||
| reg X_REV_LPF_ENABLE; | reg X_REV_LPF_ENABLE; | ||||||
| 
 | 
 | ||||||
| // constants for each frame to be calculated off config-registers | // constants for each frame to be calculated off config-registers | ||||||
| @ -237,28 +239,28 @@ lpm_mult_4_hybr_ref_pre Y_sl_hybr_ref_pre_u | |||||||
| ( | ( | ||||||
|     .clock(pclk_act), |     .clock(pclk_act), | ||||||
|     .dataa(Y[9:2]), |     .dataa(Y[9:2]), | ||||||
|     .datab(X_SCANLINE_HYBRSTR), |     .datab(SL_HYBRSTR), | ||||||
|     .result(Y_sl_hybr_ref_pre) |     .result(Y_sl_hybr_ref_pre) | ||||||
| ); | ); | ||||||
| lpm_mult_4_hybr_ref_pre R_sl_hybr_ref_pre_u | lpm_mult_4_hybr_ref_pre R_sl_hybr_ref_pre_u | ||||||
| ( | ( | ||||||
|     .clock(pclk_act), |     .clock(pclk_act), | ||||||
|     .dataa(R_pp[`PP_RLPF_PL_END]), |     .dataa(R_pp[`PP_RLPF_PL_END]), | ||||||
|     .datab(X_SCANLINE_HYBRSTR), |     .datab(SL_HYBRSTR), | ||||||
|     .result(R_sl_hybr_ref_pre) |     .result(R_sl_hybr_ref_pre) | ||||||
| ); | ); | ||||||
| lpm_mult_4_hybr_ref_pre G_sl_hybr_ref_pre_u | lpm_mult_4_hybr_ref_pre G_sl_hybr_ref_pre_u | ||||||
| ( | ( | ||||||
|     .clock(pclk_act), |     .clock(pclk_act), | ||||||
|     .dataa(G_pp[`PP_RLPF_PL_END]), |     .dataa(G_pp[`PP_RLPF_PL_END]), | ||||||
|     .datab(X_SCANLINE_HYBRSTR), |     .datab(SL_HYBRSTR), | ||||||
|     .result(G_sl_hybr_ref_pre) |     .result(G_sl_hybr_ref_pre) | ||||||
| ); | ); | ||||||
| lpm_mult_4_hybr_ref_pre B_sl_hybr_ref_pre_u | lpm_mult_4_hybr_ref_pre B_sl_hybr_ref_pre_u | ||||||
| ( | ( | ||||||
|     .clock(pclk_act), |     .clock(pclk_act), | ||||||
|     .dataa(B_pp[`PP_RLPF_PL_END]), |     .dataa(B_pp[`PP_RLPF_PL_END]), | ||||||
|     .datab(X_SCANLINE_HYBRSTR), |     .datab(SL_HYBRSTR), | ||||||
|     .result(B_sl_hybr_ref_pre) |     .result(B_sl_hybr_ref_pre) | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| @ -267,32 +269,32 @@ lpm_mult_4_hybr_ref Y_sl_hybr_ref_u | |||||||
| ( | ( | ||||||
|     .clock(pclk_act), |     .clock(pclk_act), | ||||||
|     .dataa(Y_sl_hybr_ref_pre), |     .dataa(Y_sl_hybr_ref_pre), | ||||||
|     .datab(X_SCANLINESTR), |     .datab(sl_str_tmp), | ||||||
|     .result(Y_sl_hybr_ref) |     .result(Y_sl_hybr_ref) | ||||||
| ); | ); | ||||||
| lpm_mult_4_hybr_ref R_sl_hybr_ref_u | lpm_mult_4_hybr_ref R_sl_hybr_ref_u | ||||||
| ( | ( | ||||||
|     .clock(pclk_act), |     .clock(pclk_act), | ||||||
|     .dataa(R_sl_hybr_ref_pre), |     .dataa(R_sl_hybr_ref_pre), | ||||||
|     .datab(X_SCANLINESTR), |     .datab(sl_str_tmp), | ||||||
|     .result(R_sl_hybr_ref) |     .result(R_sl_hybr_ref) | ||||||
| ); | ); | ||||||
| lpm_mult_4_hybr_ref G_sl_hybr_ref_u | lpm_mult_4_hybr_ref G_sl_hybr_ref_u | ||||||
| ( | ( | ||||||
|     .clock(pclk_act), |     .clock(pclk_act), | ||||||
|     .dataa(G_sl_hybr_ref_pre), |     .dataa(G_sl_hybr_ref_pre), | ||||||
|     .datab(X_SCANLINESTR), |     .datab(sl_str_tmp), | ||||||
|     .result(G_sl_hybr_ref) |     .result(G_sl_hybr_ref) | ||||||
| ); | ); | ||||||
| lpm_mult_4_hybr_ref B_sl_hybr_ref_u | lpm_mult_4_hybr_ref B_sl_hybr_ref_u | ||||||
| ( | ( | ||||||
|     .clock(pclk_act), |     .clock(pclk_act), | ||||||
|     .dataa(B_sl_hybr_ref_pre), |     .dataa(B_sl_hybr_ref_pre), | ||||||
|     .datab(X_SCANLINESTR), |     .datab(sl_str_tmp), | ||||||
|     .result(B_sl_hybr_ref) |     .result(B_sl_hybr_ref) | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| reg [7:0] Y_sl_str, R_sl_str, G_sl_str, B_sl_str; | reg [7:0] sl_str, sl_str_tmp, Y_sl_str, R_sl_str, G_sl_str, B_sl_str; | ||||||
| 
 | 
 | ||||||
| reg [7:0] R_sl_sub, G_sl_sub, B_sl_sub; | reg [7:0] R_sl_sub, G_sl_sub, B_sl_sub; | ||||||
| wire [7:0] R_sl_mult, G_sl_mult, B_sl_mult; | wire [7:0] R_sl_mult, G_sl_mult, B_sl_mult; | ||||||
| @ -318,8 +320,6 @@ lpm_mult_4_sl B_sl_mult_u | |||||||
|     .result(B_sl_mult) |     .result(B_sl_mult) | ||||||
| ); | ); | ||||||
| 
 | 
 | ||||||
| reg draw_sl; |  | ||||||
| 
 |  | ||||||
| //Reverse LPF | //Reverse LPF | ||||||
| wire rlpf_trigger_act; | wire rlpf_trigger_act; | ||||||
| reg signed [14:0] R_diff_s15_pre, G_diff_s15_pre, B_diff_s15_pre, R_diff_s15, G_diff_s15, B_diff_s15; | reg signed [14:0] R_diff_s15_pre, G_diff_s15_pre, B_diff_s15_pre, R_diff_s15, G_diff_s15, B_diff_s15; | ||||||
| @ -368,7 +368,7 @@ case (V_MULTMODE) | |||||||
|         HSYNC_act = HSYNC_2x; |         HSYNC_act = HSYNC_2x; | ||||||
|         VSYNC_act = VSYNC_2x; |         VSYNC_act = VSYNC_2x; | ||||||
|         DE_act = DE_2x; |         DE_act = DE_2x; | ||||||
|         line_id_act = {1'b0, line_out_idx_2x[1], line_out_idx_2x[0]^FID_1x}; |         line_id_act = SL_NO_ALTERN ? {2'b0, {line_out_idx_2x[0]+FID_1x}} : {1'b0, line_out_idx_2x}; | ||||||
|         hcnt_act = hcnt_2x; |         hcnt_act = hcnt_2x; | ||||||
|         vcnt_act = vcnt_2x; |         vcnt_act = vcnt_2x; | ||||||
|         case (H_MULTMODE) |         case (H_MULTMODE) | ||||||
| @ -432,7 +432,7 @@ case (V_MULTMODE) | |||||||
|         HSYNC_act = HSYNC_4x; |         HSYNC_act = HSYNC_4x; | ||||||
|         VSYNC_act = VSYNC_4x; |         VSYNC_act = VSYNC_4x; | ||||||
|         DE_act = DE_4x; |         DE_act = DE_4x; | ||||||
|         line_id_act = {1'b0, line_out_idx_4x}; |         line_id_act = SL_NO_ALTERN ? {1'b0, {line_out_idx_4x+{FID_1x, 1'b0}}} : {1'b0, line_out_idx_4x}; | ||||||
|         hcnt_act = hcnt_4x; |         hcnt_act = hcnt_4x; | ||||||
|         vcnt_act = vcnt_4x; |         vcnt_act = vcnt_4x; | ||||||
|         pclk_mux_sel = `PCLK_MUX_4X; |         pclk_mux_sel = `PCLK_MUX_4X; | ||||||
| @ -535,9 +535,9 @@ mux5 mux5_inst ( | |||||||
| integer pp_idx; | integer pp_idx; | ||||||
| always @(posedge pclk_act) | always @(posedge pclk_act) | ||||||
| begin | begin | ||||||
|     line_id_pp[1] <= line_id_act; |     line_id_pp[1] <= SL_ALTIV ? {2'b00, vcnt_act[0]} : line_id_act; | ||||||
|     col_id_pp[1] <= col_id_act; |     col_id_pp[1] <= col_id_act; | ||||||
|     for(pp_idx = 2; pp_idx <= `PP_SLGEN_PL_END-2; pp_idx = pp_idx+1) begin |     for(pp_idx = 2; pp_idx <= `PP_SLGEN_PL_END-5; pp_idx = pp_idx+1) begin | ||||||
|         line_id_pp[pp_idx] <= line_id_pp[pp_idx-1]; |         line_id_pp[pp_idx] <= line_id_pp[pp_idx-1]; | ||||||
|         col_id_pp[pp_idx] <= col_id_pp[pp_idx-1]; |         col_id_pp[pp_idx] <= col_id_pp[pp_idx-1]; | ||||||
|     end |     end | ||||||
| @ -647,30 +647,40 @@ begin | |||||||
|     // modify scanline strength (3 pp-stages) |     // modify scanline strength (3 pp-stages) | ||||||
|     // ... step 1/3 |     // ... step 1/3 | ||||||
|     // Y_sl_hybr_ref_tmp, R_sl_hybr_ref_tmp, G_sl_hybr_ref_tmp, B_sl_hybr_ref_tmp are outputs of multiplier IPs (1 pp-stage delay) |     // Y_sl_hybr_ref_tmp, R_sl_hybr_ref_tmp, G_sl_hybr_ref_tmp, B_sl_hybr_ref_tmp are outputs of multiplier IPs (1 pp-stage delay) | ||||||
|  |     if (|(SL_L_OVERLAY & (5'h1<<line_id_pp[`PP_SLGEN_PL_END-5]))) begin | ||||||
|  |         sl_str_tmp <= ((SL_L_STR[line_id_pp[`PP_SLGEN_PL_END-5]]+8'h01)<<4)-1'b1; | ||||||
|  |         draw_sl_pp[`PP_SLGEN_PL_END-4] <= 1'b1; | ||||||
|  |     end else if (|(SL_C_OVERLAY & (6'h1<<col_id_pp[`PP_SLGEN_PL_END-5]))) begin | ||||||
|  |         sl_str_tmp <= ((SL_C_STR[col_id_pp[`PP_SLGEN_PL_END-5]]+8'h01)<<4)-1'b1; | ||||||
|  |         draw_sl_pp[`PP_SLGEN_PL_END-4] <= 1'b1; | ||||||
|  |     end else begin | ||||||
|  |         draw_sl_pp[`PP_SLGEN_PL_END-4] <= 1'b0; | ||||||
|  |     end | ||||||
|  |     for(pp_idx = `PP_SLGEN_PL_END-3; pp_idx <= `PP_SLGEN_PL_END-1; pp_idx = pp_idx + 1) begin | ||||||
|  |         draw_sl_pp[pp_idx] <= draw_sl_pp[pp_idx-1]; | ||||||
|  |     end | ||||||
| 
 | 
 | ||||||
|     // ... step 2/3 |     // ... step 2/3 | ||||||
|     // Y_sl_hybr_ref,R_sl_hybr_ref,G_sl_hybr_ref,B_sl_hybr_ref are outputs of multiplier IPs (1 pp-stage delay) |     // Y_sl_hybr_ref,R_sl_hybr_ref,G_sl_hybr_ref,B_sl_hybr_ref are outputs of multiplier IPs (1 pp-stage delay) | ||||||
|  |     sl_str <= sl_str_tmp; | ||||||
| 
 | 
 | ||||||
|     // ... step 3/3 |     // ... step 3/3 | ||||||
|     Y_sl_str <= {1'b0,X_SCANLINESTR} < Y_sl_hybr_ref ? 8'h0 : X_SCANLINESTR - Y_sl_hybr_ref[7:0]; |     Y_sl_str <= {1'b0,sl_str} < Y_sl_hybr_ref ? 8'h0 : sl_str - Y_sl_hybr_ref[7:0]; | ||||||
|     R_sl_str <= {1'b0,X_SCANLINESTR} < R_sl_hybr_ref ? 8'h0 : X_SCANLINESTR - R_sl_hybr_ref[7:0]; |     R_sl_str <= {1'b0,sl_str} < R_sl_hybr_ref ? 8'h0 : sl_str - R_sl_hybr_ref[7:0]; | ||||||
|     G_sl_str <= {1'b0,X_SCANLINESTR} < G_sl_hybr_ref ? 8'h0 : X_SCANLINESTR - G_sl_hybr_ref[7:0]; |     G_sl_str <= {1'b0,sl_str} < G_sl_hybr_ref ? 8'h0 : sl_str - G_sl_hybr_ref[7:0]; | ||||||
|     B_sl_str <= {1'b0,X_SCANLINESTR} < B_sl_hybr_ref ? 8'h0 : X_SCANLINESTR - B_sl_hybr_ref[7:0]; |     B_sl_str <= {1'b0,sl_str} < B_sl_hybr_ref ? 8'h0 : sl_str - B_sl_hybr_ref[7:0]; | ||||||
| 
 | 
 | ||||||
|     // perform scanline generation (1 pp-stage) |     // perform scanline generation (1 pp-stage) | ||||||
|     // R_sl_mult, G_sl_mult and B_sl_mult are registered outputs of IP blocks (1 pp-stage delay) |     // R_sl_mult, G_sl_mult and B_sl_mult are registered outputs of IP blocks (1 pp-stage delay) | ||||||
|     R_sl_sub <= (R_pp[`PP_SLGEN_PL_END-2] > R_sl_str) ? (R_pp[`PP_SLGEN_PL_END-2]-R_sl_str) : 8'h00; |     R_sl_sub <= (R_pp[`PP_SLGEN_PL_END-2] > R_sl_str) ? (R_pp[`PP_SLGEN_PL_END-2]-R_sl_str) : 8'h00; | ||||||
|     G_sl_sub <= (G_pp[`PP_SLGEN_PL_END-2] > G_sl_str) ? (G_pp[`PP_SLGEN_PL_END-2]-G_sl_str) : 8'h00; |     G_sl_sub <= (G_pp[`PP_SLGEN_PL_END-2] > G_sl_str) ? (G_pp[`PP_SLGEN_PL_END-2]-G_sl_str) : 8'h00; | ||||||
|     B_sl_sub <= (B_pp[`PP_SLGEN_PL_END-2] > B_sl_str) ? (B_pp[`PP_SLGEN_PL_END-2]-B_sl_str) : 8'h00; |     B_sl_sub <= (B_pp[`PP_SLGEN_PL_END-2] > B_sl_str) ? (B_pp[`PP_SLGEN_PL_END-2]-B_sl_str) : 8'h00; | ||||||
|     draw_sl <= |{(V_SCANLINEMODE == `SCANLINES_H)   && (V_SCANLINEID & (5'h1<<line_id_pp[`PP_SLGEN_PL_END-2])), |  | ||||||
|                  (V_SCANLINEMODE == `SCANLINES_V)   && (5'h0 == col_id_pp[`PP_SLGEN_PL_END-2]), |  | ||||||
|                  (V_SCANLINEMODE == `SCANLINES_ALT) && (V_SCANLINEID & (5'h1<<(line_id_pp[`PP_SLGEN_PL_END-2]^FID_1x)))}; |  | ||||||
| 
 | 
 | ||||||
|     // draw scanline (1 pp-stage) |     // draw scanline (1 pp-stage) | ||||||
|     if (draw_sl) begin |     if (draw_sl_pp[`PP_SLGEN_PL_END-1]) begin | ||||||
|         R_pp[`PP_SLGEN_PL_END] <= X_SCANLINE_METHOD ? R_sl_sub : R_sl_mult; |         R_pp[`PP_SLGEN_PL_END] <= SL_METHOD ? R_sl_sub : R_sl_mult; | ||||||
|         G_pp[`PP_SLGEN_PL_END] <= X_SCANLINE_METHOD ? G_sl_sub : G_sl_mult; |         G_pp[`PP_SLGEN_PL_END] <= SL_METHOD ? G_sl_sub : G_sl_mult; | ||||||
|         B_pp[`PP_SLGEN_PL_END] <= X_SCANLINE_METHOD ? B_sl_sub : B_sl_mult; |         B_pp[`PP_SLGEN_PL_END] <= SL_METHOD ? B_sl_sub : B_sl_mult; | ||||||
|     end |     end | ||||||
| 
 | 
 | ||||||
|     // apply LT box / mask |     // apply LT box / mask | ||||||
| @ -776,9 +786,12 @@ begin | |||||||
|     end |     end | ||||||
| end | end | ||||||
| 
 | 
 | ||||||
|  | //Forward status flag to CPU | ||||||
|  | assign vsync_flag = ~VSYNC_in_cc_LL; | ||||||
| 
 | 
 | ||||||
| wire [11:0] H_L5BORDER_1920_tmp = (11'd1920-h_info[10:0]); | 
 | ||||||
| wire [11:0] H_L5BORDER_1600_tmp = (11'd1600-h_info[10:0]); | wire [11:0] H_L5BORDER_1920_tmp = (11'd1920-h_config[10:0]); | ||||||
|  | wire [11:0] H_L5BORDER_1600_tmp = (11'd1600-h_config[10:0]); | ||||||
| 
 | 
 | ||||||
| //Buffer the inputs using input pixel clock and generate 1x signals | //Buffer the inputs using input pixel clock and generate 1x signals | ||||||
| always @(posedge pclk_1x or negedge reset_n) | always @(posedge pclk_1x or negedge reset_n) | ||||||
| @ -855,48 +868,53 @@ begin | |||||||
| 
 | 
 | ||||||
|         if (frame_change) begin |         if (frame_change) begin | ||||||
|             //Read configuration data from CPU |             //Read configuration data from CPU | ||||||
|             H_MULTMODE <= h_info[31:30];    // Horizontal scaling mode |             H_MULTMODE <= h_config[31:30];    // Horizontal scaling mode | ||||||
|             V_MULTMODE <= v_info[31:29];    // Line multiply mode |             V_MULTMODE <= v_config[31:29];    // Line multiply mode | ||||||
| 
 | 
 | ||||||
|             H_SYNCLEN <= h_info[27:20];                     // Horizontal sync length (0...255) |             H_SYNCLEN <= h_config[27:20];                     // Horizontal sync length (0...255) | ||||||
|             H_AVIDSTART <= h_info[19:11] + h_info[27:20];   // Horizontal sync+backporch length (0...1023) |             H_AVIDSTART <= h_config[19:11] + h_config[27:20];   // Horizontal sync+backporch length (0...1023) | ||||||
|             H_ACTIVE <= h_info[10:0];                       // Horizontal active length (0...2047) |             H_ACTIVE <= h_config[10:0];                       // Horizontal active length (0...2047) | ||||||
| 
 | 
 | ||||||
|             V_SYNCLEN <= v_info[19:17];                     // Vertical sync length (0...7) |             V_SYNCLEN <= v_config[19:17];                     // Vertical sync length (0...7) | ||||||
|             V_AVIDSTART <= v_info[16:11] + v_info[19:17];   // Vertical sync+backporch length (0...127) |             V_AVIDSTART <= v_config[16:11] + v_config[19:17];   // Vertical sync+backporch length (0...127) | ||||||
|             V_ACTIVE <= v_info[10:0];                       // Vertical active length (0...2047) |             V_ACTIVE <= v_config[10:0];                       // Vertical active length (0...2047) | ||||||
| 
 | 
 | ||||||
|             H_MASK <= h_info2[29:19]; |             H_MASK <= h_config2[29:19]; | ||||||
|             V_MASK <= v_info[25:20]; |             V_MASK <= v_config[25:20]; | ||||||
| 
 | 
 | ||||||
|             V_SCANLINEMODE <= v_info[28:27]; | //            H_L5BORDER <= h_config[29] ? (11'd1920-h_config[10:0])/2 : (11'd1600-h_config[10:0])/2; | ||||||
|             case (v_info[31:29]) |             H_L5BORDER <= h_config[29] ? H_L5BORDER_1920_tmp[10:1] : H_L5BORDER_1600_tmp[10:1]; | ||||||
|                 `V_MULTMODE_1X, `V_MULTMODE_2X: V_SCANLINEID <= (5'b00001 << v_info[26]); |  | ||||||
|                 `V_MULTMODE_3X: V_SCANLINEID <= (5'b00001 << {v_info[26], 1'b0}); |  | ||||||
|                 `V_MULTMODE_4X: V_SCANLINEID <= (5'b00011 << {v_info[26], 1'b0}); |  | ||||||
|                 `V_MULTMODE_5X: V_SCANLINEID <= (5'b00011 << {2{v_info[26]}}); |  | ||||||
|             endcase |  | ||||||
| 
 |  | ||||||
| //            H_L5BORDER <= h_info[29] ? (11'd1920-h_info[10:0])/2 : (11'd1600-h_info[10:0])/2; |  | ||||||
|             H_L5BORDER <= h_info[29] ? H_L5BORDER_1920_tmp[10:1] : H_L5BORDER_1600_tmp[10:1]; |  | ||||||
|             // For Line3x 240x360 |             // For Line3x 240x360 | ||||||
|             H_L3BORDER <= h_info[28] ? H_L5BORDER_1920_tmp[10:1] : 10'd0; |             H_L3BORDER <= h_config[28] ? H_L5BORDER_1920_tmp[10:1] : 10'd0; | ||||||
| 
 | 
 | ||||||
|             H_L3_OPT_SAMPLE_COMP <= h_info[28] ? 7'd90 : 7'd0; |             H_L3_OPT_SAMPLE_COMP <= h_config[28] ? 7'd90 : 7'd0; | ||||||
| 
 | 
 | ||||||
|             H_OPT_SCALE <= h_info2[18:16]; |             H_OPT_SCALE <= h_config2[18:16]; | ||||||
|             H_OPT_SAMPLE_SEL <= h_info2[15:13]; |             H_OPT_SAMPLE_SEL <= h_config2[15:13]; | ||||||
|             H_OPT_SAMPLE_MULT <= h_info2[12:10]; |             H_OPT_SAMPLE_MULT <= h_config2[12:10]; | ||||||
|             H_OPT_STARTOFF <= h_info2[9:0]; |             H_OPT_STARTOFF <= h_config2[9:0]; | ||||||
| 
 | 
 | ||||||
|             X_REV_LPF_ENABLE <= (extra_info[18:14] != 5'b00000); |             X_REV_LPF_ENABLE <= (misc_config[8:4] != 5'b00000); | ||||||
|             X_REV_LPF_STR <= (extra_info[18:14] + 6'd16); |             X_REV_LPF_STR <= (misc_config[8:4] + 6'd16); | ||||||
|  |             X_MASK_BR <= misc_config[3:0]; | ||||||
| 
 | 
 | ||||||
|             X_MASK_BR <= extra_info[13:10]; |             SL_NO_ALTERN <= sl_config[31]; | ||||||
| 
 |             SL_METHOD  <= sl_config[30]; | ||||||
|             X_SCANLINE_METHOD  <= extra_info[9]; |             SL_HYBRSTR <= sl_config[29:25]; | ||||||
|             X_SCANLINE_HYBRSTR <= extra_info[8:4]; |             SL_L_OVERLAY <= sl_config[24:20]; | ||||||
|             X_SCANLINESTR      <= ((extra_info[3:0]+8'h01)<<4)-1'b1; |             SL_L_STR[4] <= sl_config[19:16]; | ||||||
|  |             SL_L_STR[3] <= sl_config[15:12]; | ||||||
|  |             SL_L_STR[2] <= sl_config[11:8]; | ||||||
|  |             SL_L_STR[1] <= sl_config[7:4]; | ||||||
|  |             SL_L_STR[0] <= sl_config[3:0]; | ||||||
|  |             SL_ALTIV <= sl_config2[31]; | ||||||
|  |             SL_C_OVERLAY <= sl_config2[29:24]; | ||||||
|  |             SL_C_STR[5] <= sl_config2[23:20]; | ||||||
|  |             SL_C_STR[4] <= sl_config2[19:16]; | ||||||
|  |             SL_C_STR[3] <= sl_config2[15:12]; | ||||||
|  |             SL_C_STR[2] <= sl_config2[11:8]; | ||||||
|  |             SL_C_STR[1] <= sl_config2[7:4]; | ||||||
|  |             SL_C_STR[0] <= sl_config2[3:0]; | ||||||
| 
 | 
 | ||||||
|             CALC_CONSTS <= 1'b1; |             CALC_CONSTS <= 1'b1; | ||||||
|         end |         end | ||||||
| @ -918,10 +936,10 @@ begin | |||||||
| 
 | 
 | ||||||
|             LT_POS_TOPLEFT_BOX_H_STOP <= H_AVIDSTART+(H_ACTIVE/`LT_WIDTH_DIV); |             LT_POS_TOPLEFT_BOX_H_STOP <= H_AVIDSTART+(H_ACTIVE/`LT_WIDTH_DIV); | ||||||
|             LT_POS_TOPLEFT_BOX_V_STOP <= V_AVIDSTART+(V_ACTIVE/`LT_HEIGHT_DIV); |             LT_POS_TOPLEFT_BOX_V_STOP <= V_AVIDSTART+(V_ACTIVE/`LT_HEIGHT_DIV); | ||||||
|             LT_POS_CENTER_BOX_H_START <= H_AVIDSTART+(H_ACTIVE/2)-(H_ACTIVE/(`LT_WIDTH_DIV*2)); |             LT_POS_CENTER_BOX_H_START <= H_AVIDSTART+(H_ACTIVE/2'h2)-(H_ACTIVE/(`LT_WIDTH_DIV*2'h2)); | ||||||
|             LT_POS_CENTER_BOX_H_STOP <= H_AVIDSTART+(H_ACTIVE/2)+(H_ACTIVE/(`LT_WIDTH_DIV*2)); |             LT_POS_CENTER_BOX_H_STOP <= H_AVIDSTART+(H_ACTIVE/2'h2)+(H_ACTIVE/(`LT_WIDTH_DIV*2'h2)); | ||||||
|             LT_POS_CENTER_BOX_V_START <= V_AVIDSTART+(V_ACTIVE/2)-(V_ACTIVE/(`LT_HEIGHT_DIV*2)); |             LT_POS_CENTER_BOX_V_START <= V_AVIDSTART+(V_ACTIVE/2'h2)-(V_ACTIVE/(`LT_HEIGHT_DIV*2'h2)); | ||||||
|             LT_POS_CENTER_BOX_V_STOP <= V_AVIDSTART+(V_ACTIVE/2)+(V_ACTIVE/(`LT_HEIGHT_DIV*2)); |             LT_POS_CENTER_BOX_V_STOP <= V_AVIDSTART+(V_ACTIVE/2'h2)+(V_ACTIVE/(`LT_HEIGHT_DIV*2'h2)); | ||||||
|             LT_POS_BOTTOMRIGHT_H_START <= H_AVIDSTART+H_ACTIVE-(H_ACTIVE/`LT_WIDTH_DIV); |             LT_POS_BOTTOMRIGHT_H_START <= H_AVIDSTART+H_ACTIVE-(H_ACTIVE/`LT_WIDTH_DIV); | ||||||
|             LT_POS_BOTTOMRIGHT_V_START <= V_AVIDSTART+V_ACTIVE-(V_ACTIVE/`LT_HEIGHT_DIV); |             LT_POS_BOTTOMRIGHT_V_START <= V_AVIDSTART+V_ACTIVE-(V_ACTIVE/`LT_HEIGHT_DIV); | ||||||
| 
 | 
 | ||||||
|  | |||||||
| @ -195,7 +195,7 @@ endif | |||||||
| APP_CFLAGS_UNDEFINED_SYMBOLS := | APP_CFLAGS_UNDEFINED_SYMBOLS := | ||||||
| APP_CFLAGS_OPTIMIZATION := -Os | APP_CFLAGS_OPTIMIZATION := -Os | ||||||
| APP_CFLAGS_DEBUG_LEVEL := | APP_CFLAGS_DEBUG_LEVEL := | ||||||
| APP_CFLAGS_WARNINGS := -Wall -Wno-unused-but-set-variable -Wno-unused-variable -Wno-unused-function | APP_CFLAGS_WARNINGS := -Wall -Wno-unused-but-set-variable -Wno-unused-variable -Wno-unused-function -Wno-packed-bitfield-compat | ||||||
| APP_CFLAGS_USER_FLAGS := -fdata-sections -ffunction-sections -fshort-enums -fgnu89-inline | APP_CFLAGS_USER_FLAGS := -fdata-sections -ffunction-sections -fshort-enums -fgnu89-inline | ||||||
| 
 | 
 | ||||||
| APP_ASFLAGS_USER := | APP_ASFLAGS_USER := | ||||||
|  | |||||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @ -48,7 +48,7 @@ | |||||||
| #define MIN_LINES_INTERLACED    400 | #define MIN_LINES_INTERLACED    400 | ||||||
| #define SYNC_LOCK_THOLD         3 | #define SYNC_LOCK_THOLD         3 | ||||||
| #define SYNC_LOSS_THOLD         -5 | #define SYNC_LOSS_THOLD         -5 | ||||||
| #define STATUS_TIMEOUT          10000 | #define STATUS_TIMEOUT          100000 | ||||||
| 
 | 
 | ||||||
| alt_u16 sys_ctrl; | alt_u16 sys_ctrl; | ||||||
| 
 | 
 | ||||||
| @ -83,6 +83,8 @@ alt_u8 pcm1862_active; | |||||||
| alt_u32 pclk_out; | alt_u32 pclk_out; | ||||||
| alt_u32 read_it2(alt_u32 regaddr); | alt_u32 read_it2(alt_u32 regaddr); | ||||||
| 
 | 
 | ||||||
|  | volatile sc_regs *sc = (volatile sc_regs*)SC_CONFIG_0_BASE; | ||||||
|  | 
 | ||||||
| inline void lcd_write_menu() | inline void lcd_write_menu() | ||||||
| { | { | ||||||
|     lcd_write((char*)&menu_row1, (char*)&menu_row2); |     lcd_write((char*)&menu_row1, (char*)&menu_row2); | ||||||
| @ -201,14 +203,14 @@ status_t get_status(tvp_input_t input, video_format format) | |||||||
| 
 | 
 | ||||||
|     // Wait until vsync active (avoid noise coupled to I2C bus on earlier prototypes)
 |     // Wait until vsync active (avoid noise coupled to I2C bus on earlier prototypes)
 | ||||||
|     for (ctr=0; ctr<STATUS_TIMEOUT; ctr++) { |     for (ctr=0; ctr<STATUS_TIMEOUT; ctr++) { | ||||||
|         if (!(IORD_ALTERA_AVALON_PIO_DATA(PIO_2_BASE) & (1<<31))) { |         if (sc->sc_status.vsync_flag) { | ||||||
|             //printf("ctrval %u\n", ctr);
 |             //printf("ctrval %u\n", ctr);
 | ||||||
|             break; |             break; | ||||||
|         } |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     sync_active = tvp_check_sync(input, format); |     sync_active = tvp_check_sync(input, format); | ||||||
|     vsyncmode = cm.sync_active ? ((IORD_ALTERA_AVALON_PIO_DATA(PIO_2_BASE) >> 16) & 0x3) : 0; |     vsyncmode = cm.sync_active ? sc->sc_status.fpga_vsyncgen : 0; | ||||||
| 
 | 
 | ||||||
|     // Read sync information from TVP7002 status registers
 |     // Read sync information from TVP7002 status registers
 | ||||||
|     data1 = tvp_readreg(TVP_LINECNT1); |     data1 = tvp_readreg(TVP_LINECNT1); | ||||||
| @ -221,7 +223,7 @@ status_t get_status(tvp_input_t input, video_format format) | |||||||
|     clkcnt = ((data2 & 0x0f) << 8) | data1; |     clkcnt = ((data2 & 0x0f) << 8) | data1; | ||||||
| 
 | 
 | ||||||
|     // Read how many lines TVP7002 outputs in reality (valid only if output enabled)
 |     // Read how many lines TVP7002 outputs in reality (valid only if output enabled)
 | ||||||
|     totlines_tvp = ((IORD_ALTERA_AVALON_PIO_DATA(PIO_2_BASE) >> 18) & 0x7ff)+1; |     totlines_tvp = sc->sc_status.vmax_tvp+1; | ||||||
| 
 | 
 | ||||||
|     // NOTE: "progressive" may not have correct value if H-PLL is not locked (!cm.sync_active)
 |     // NOTE: "progressive" may not have correct value if H-PLL is not locked (!cm.sync_active)
 | ||||||
|     if ((vsyncmode == 0x2) || (!cm.sync_active && (totlines < MIN_LINES_INTERLACED))) { |     if ((vsyncmode == 0x2) || (!cm.sync_active && (totlines < MIN_LINES_INTERLACED))) { | ||||||
| @ -290,7 +292,7 @@ status_t get_status(tvp_input_t input, video_format format) | |||||||
| 
 | 
 | ||||||
|         if (update_cur_vm) { |         if (update_cur_vm) { | ||||||
|             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_setup_hpll(cm.sample_mult*video_modes[cm.id].h_total, clkcnt, cm.cc.tvp_hpll2x && (video_modes[cm.id].flags & MODE_PLLDIVBY2)); | ||||||
|             status = (status < INFO_CHANGE) ? INFO_CHANGE : status; |             status = (status < SC_CONFIG_CHANGE) ? SC_CONFIG_CHANGE : status; | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         cm.totlines = totlines; |         cm.totlines = totlines; | ||||||
| @ -303,17 +305,21 @@ status_t get_status(tvp_input_t input, video_format format) | |||||||
|         (tc.sl_hybr_str != cm.cc.sl_hybr_str) || |         (tc.sl_hybr_str != cm.cc.sl_hybr_str) || | ||||||
|         (tc.sl_method != cm.cc.sl_method) || |         (tc.sl_method != cm.cc.sl_method) || | ||||||
|         (tc.sl_str != cm.cc.sl_str) || |         (tc.sl_str != cm.cc.sl_str) || | ||||||
|  |         memcmp(tc.sl_cust_l_str, cm.cc.sl_cust_l_str, 5) || | ||||||
|  |         memcmp(tc.sl_cust_c_str, cm.cc.sl_cust_c_str, 6) || | ||||||
|  |         (tc.sl_altern != cm.cc.sl_altern) || | ||||||
|  |         (tc.sl_altiv != cm.cc.sl_altiv) || | ||||||
|         (tc.sl_id != cm.cc.sl_id) || |         (tc.sl_id != cm.cc.sl_id) || | ||||||
|         (tc.h_mask != cm.cc.h_mask) || |         (tc.h_mask != cm.cc.h_mask) || | ||||||
|         (tc.v_mask != cm.cc.v_mask) || |         (tc.v_mask != cm.cc.v_mask) || | ||||||
|         (tc.mask_br != cm.cc.mask_br) || |         (tc.mask_br != cm.cc.mask_br) || | ||||||
|         (tc.ar_256col != cm.cc.ar_256col) || |         (tc.ar_256col != cm.cc.ar_256col) || | ||||||
|         (tc.reverse_lpf != cm.cc.reverse_lpf)) |         (tc.reverse_lpf != cm.cc.reverse_lpf)) | ||||||
|         status = (status < INFO_CHANGE) ? INFO_CHANGE : status; |         status = (status < SC_CONFIG_CHANGE) ? SC_CONFIG_CHANGE : status; | ||||||
| 
 | 
 | ||||||
|     if (tc.sampler_phase != cm.cc.sampler_phase) { |     if (tc.sampler_phase != cm.cc.sampler_phase) { | ||||||
|         cm.sample_sel = tvp_set_hpll_phase(tc.sampler_phase, cm.sample_mult); |         cm.sample_sel = tvp_set_hpll_phase(tc.sampler_phase, cm.sample_mult); | ||||||
|         status = (status < INFO_CHANGE) ? INFO_CHANGE : status; |         status = (status < SC_CONFIG_CHANGE) ? SC_CONFIG_CHANGE : status; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     if (tc.sync_vth != cm.cc.sync_vth) |     if (tc.sync_vth != cm.cc.sync_vth) | ||||||
| @ -358,21 +364,19 @@ status_t get_status(tvp_input_t input, video_format format) | |||||||
|     return status; |     return status; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // h_info:     [31:30]           [29]      [28]           [27:20]          [19:11]            [10:0]
 | void update_sc_config() | ||||||
| //           | H_MULTMODE[1:0] | H_L5FMT | H_L3_240x360 | H_SYNCLEN[7:0] | H_BACKPORCH[8:0] | H_ACTIVE[10:0] |
 |  | ||||||
| //
 |  | ||||||
| // h_info2:   [31:30]   [29:19]       [18:16]            [15:13]                 [12:10]                  [9:0]
 |  | ||||||
| //           |       | H_MASK[10: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:29]           [28:27]               [26]           [25:20]       [19:17]          [16:11]            [10:0]
 |  | ||||||
| //           | V_MULTMODE[2:0] | V_SCANLINEMODE[1:0] | V_SCANLINEID | V_MASK[5:0] | V_SYNCLEN[2:0] | V_BACKPORCH[5:0] | V_ACTIVE[10:0] |
 |  | ||||||
| //
 |  | ||||||
| // extra:      [31:19]  [18:14]         [13:10]          [9]                [8:4]                [3:0]
 |  | ||||||
| //           |        | X_REV_LPF_STR | H_MASK_BR[3:0] | H_SCANLINE_METHOD | H_SL_HYBRSTR[4:0] | H_SCANLINESTR[3:0] |
 |  | ||||||
| //
 |  | ||||||
| void set_videoinfo() |  | ||||||
| { | { | ||||||
|     alt_u8 sl_mode_fpga; |     h_config_reg h_config = {.data=0x00000000}; | ||||||
|  |     h_config2_reg h_config2 = {.data=0x00000000}; | ||||||
|  |     v_config_reg v_config = {.data=0x00000000}; | ||||||
|  |     misc_config_reg misc_config = {.data=0x00000000}; | ||||||
|  |     sl_config_reg sl_config = {.data=0x00000000}; | ||||||
|  |     sl_config2_reg sl_config2 = {.data=0x00000000}; | ||||||
|  | 
 | ||||||
|  |     alt_u8 sl_no_altern = 0; | ||||||
|  |     alt_u8 sl_l_overlay = 0, sl_c_overlay = 0; | ||||||
|  |     alt_u32 sl_l_str_arr = 0, sl_c_str_arr = 0; | ||||||
|  | 
 | ||||||
|     alt_u8 h_opt_scale = cm.sample_mult; |     alt_u8 h_opt_scale = cm.sample_mult; | ||||||
|     alt_u16 h_opt_startoffs = 0; |     alt_u16 h_opt_startoffs = 0; | ||||||
|     alt_u16 h_synclen = video_modes[cm.id].h_synclen; |     alt_u16 h_synclen = video_modes[cm.id].h_synclen; | ||||||
| @ -380,17 +384,66 @@ void set_videoinfo() | |||||||
|     alt_u16 v_active = video_modes[cm.id].v_active; |     alt_u16 v_active = video_modes[cm.id].v_active; | ||||||
|     alt_u16 v_backporch = video_modes[cm.id].v_backporch; |     alt_u16 v_backporch = video_modes[cm.id].v_backporch; | ||||||
| 
 | 
 | ||||||
|     if (cm.cc.sl_mode == 2) {    //manual
 |     int i; | ||||||
|         sl_mode_fpga = 1+cm.cc.sl_type; | 
 | ||||||
|     } else if (cm.cc.sl_mode == 1) {   //auto
 |     // construct default scanline overlay
 | ||||||
|         if (video_modes[cm.id].flags & MODE_INTERLACED) |     if ((cm.cc.sl_type == 0) || (cm.cc.sl_type == 2)) { | ||||||
|             sl_mode_fpga = cm.fpga_vmultmode ? FPGA_SCANLINEMODE_ALT : FPGA_SCANLINEMODE_OFF; |         if (cm.cc.sl_altiv) { | ||||||
|         else if ((cm.fpga_vmultmode) && (video_modes[cm.id].group != GROUP_480P)) |             sl_l_overlay = 1<<(cm.cc.sl_id); | ||||||
|             sl_mode_fpga = FPGA_SCANLINEMODE_H; |  | ||||||
|         else |  | ||||||
|             sl_mode_fpga = FPGA_SCANLINEMODE_OFF; |  | ||||||
|         } else { |         } else { | ||||||
|         sl_mode_fpga = FPGA_SCANLINEMODE_OFF; |             switch (cm.fpga_vmultmode) { | ||||||
|  |                 case FPGA_V_MULTMODE_3X: | ||||||
|  |                     sl_l_overlay = 1<<(2*(cm.cc.sl_id)); | ||||||
|  |                     break; | ||||||
|  |                 case FPGA_V_MULTMODE_4X: | ||||||
|  |                     sl_l_overlay = 3<<(2*(cm.cc.sl_id)); | ||||||
|  |                     break; | ||||||
|  |                 case FPGA_V_MULTMODE_5X: | ||||||
|  |                     sl_l_overlay = 3<<(3*(cm.cc.sl_id)); | ||||||
|  |                     break; | ||||||
|  |                 default: //1x, 2x
 | ||||||
|  |                     sl_l_overlay = 1<<(cm.cc.sl_id); | ||||||
|  |                     break; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     if ((cm.cc.sl_type == 1) || (cm.cc.sl_type == 2)) { | ||||||
|  |         if (cm.sample_mult <= 4) | ||||||
|  |             sl_c_overlay = (1<<((cm.sample_mult-1)*(cm.cc.sl_id))); | ||||||
|  |         else | ||||||
|  |             sl_c_overlay = (3<<((cm.sample_mult-2)*(cm.cc.sl_id))); | ||||||
|  |     } | ||||||
|  |     // construct custom scanline overlay and strength arrays
 | ||||||
|  |     for (i=0; i<5; i++) { | ||||||
|  |         if (cm.cc.sl_type == 3) { | ||||||
|  |             sl_l_str_arr |= ((cm.cc.sl_cust_l_str[i]-1)&0xf)<<(4*i); | ||||||
|  |             sl_l_overlay |= (cm.cc.sl_cust_l_str[i]!=0)<<i; | ||||||
|  |         } else { | ||||||
|  |             sl_l_str_arr |= cm.cc.sl_str<<(4*i); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     for (i=0; i<6; i++) { | ||||||
|  |         if (cm.cc.sl_type == 3) { | ||||||
|  |             sl_c_str_arr |= ((cm.cc.sl_cust_c_str[i]-1)&0xf)<<(4*i); | ||||||
|  |             sl_c_overlay |= (cm.cc.sl_cust_c_str[i]!=0)<<i; | ||||||
|  |         } else { | ||||||
|  |             sl_c_str_arr |= cm.cc.sl_str<<(4*i); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  |     // enable/disable alternating scanlines
 | ||||||
|  |     if ((video_modes[cm.id].flags & MODE_INTERLACED) && (cm.fpga_vmultmode)) | ||||||
|  |         sl_no_altern = !cm.cc.sl_altern; | ||||||
|  |     // oevrride scanline mode
 | ||||||
|  |     if (cm.cc.sl_mode == 1) {   //auto
 | ||||||
|  |         //disable scanlines
 | ||||||
|  |         if ((cm.fpga_vmultmode==0) || (video_modes[cm.id].group == GROUP_480P)) { | ||||||
|  |             sl_l_overlay = 0; | ||||||
|  |             sl_c_overlay = 0; | ||||||
|  |         } | ||||||
|  |     } else if (cm.cc.sl_mode == 0) { //off
 | ||||||
|  |         //disable scanlines
 | ||||||
|  |         sl_l_overlay = 0; | ||||||
|  |         sl_c_overlay = 0; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     switch (cm.target_lm) { |     switch (cm.target_lm) { | ||||||
| @ -446,29 +499,44 @@ void set_videoinfo() | |||||||
|     h_opt_startoffs = h_border + (cm.sample_mult-h_opt_scale)*(h_synclen+(alt_u16)video_modes[cm.id].h_backporch); |     h_opt_startoffs = h_border + (cm.sample_mult-h_opt_scale)*(h_synclen+(alt_u16)video_modes[cm.id].h_backporch); | ||||||
|     printf("h_border: %u, h_opt_startoffs: %u\n", h_border, h_opt_startoffs); |     printf("h_border: %u, h_opt_startoffs: %u\n", h_border, h_opt_startoffs); | ||||||
| 
 | 
 | ||||||
|     IOWR_ALTERA_AVALON_PIO_DATA(PIO_3_BASE, (cm.fpga_hmultmode<<30) | |     h_config.h_multmode = cm.fpga_hmultmode; | ||||||
|                                             ((cm.cc.l5_fmt!=L5FMT_1600x1200)<<29) | |     h_config.h_l5fmt = (cm.cc.l5_fmt!=L5FMT_1600x1200); | ||||||
|                                             ((cm.target_lm==MODE_L3_240x360)<<28) | |     h_config.h_l3_240x360 = (cm.target_lm==MODE_L3_240x360); | ||||||
|                                             (((cm.sample_mult*h_synclen)&0xff)<<20) | |     h_config.h_synclen = (cm.sample_mult*h_synclen); | ||||||
|                                             (((cm.sample_mult*(alt_u16)video_modes[cm.id].h_backporch)&0x1ff)<<11) | |     h_config.h_backporch = (cm.sample_mult*(alt_u16)video_modes[cm.id].h_backporch); | ||||||
|                                             ((cm.sample_mult*video_modes[cm.id].h_active)&0x7ff)); |     h_config.h_active = (cm.sample_mult*video_modes[cm.id].h_active); | ||||||
|     IOWR_ALTERA_AVALON_PIO_DATA(PIO_4_BASE, (h_mask<<19) | | 
 | ||||||
|                                             (h_opt_scale<<16) | |     h_config2.h_mask = h_mask; | ||||||
|                                             (cm.sample_sel<<13) | |     h_config2.h_opt_scale = h_opt_scale; | ||||||
|                                             (cm.sample_mult<<10) | |     h_config2.h_opt_sample_sel = cm.sample_sel; | ||||||
|                                             h_opt_startoffs); |     h_config2.h_opt_sample_mult = cm.sample_mult; | ||||||
|     IOWR_ALTERA_AVALON_PIO_DATA(PIO_5_BASE, (cm.fpga_vmultmode<<29) | |     h_config2.h_opt_startoff = h_opt_startoffs; | ||||||
|                                             (sl_mode_fpga<<27) | | 
 | ||||||
|                                             (cm.cc.sl_id<<26) | |     v_config.v_multmode = cm.fpga_vmultmode; | ||||||
|                                             (cm.cc.v_mask<<20) | |     v_config.v_mask = cm.cc.v_mask; | ||||||
|                                             (video_modes[cm.id].v_synclen<<17) | |     v_config.v_synclen = video_modes[cm.id].v_synclen; | ||||||
|                                             (v_backporch<<11) | |     v_config.v_backporch = v_backporch; | ||||||
|                                             v_active); |     v_config.v_active = v_active; | ||||||
|     IOWR_ALTERA_AVALON_PIO_DATA(PIO_6_BASE, (cm.cc.reverse_lpf<<14) | | 
 | ||||||
|                                             (cm.cc.mask_br<<10) | |     misc_config.rev_lpf_str = cm.cc.reverse_lpf; | ||||||
|                                             (cm.cc.sl_method << 9) | |     misc_config.mask_br = cm.cc.mask_br; | ||||||
|                                             (cm.cc.sl_hybr_str << 4) | | 
 | ||||||
|                                              cm.cc.sl_str); |     sl_config.sl_l_str_arr = sl_l_str_arr; | ||||||
|  |     sl_config.sl_l_overlay = sl_l_overlay; | ||||||
|  |     sl_config.sl_hybr_str = cm.cc.sl_hybr_str; | ||||||
|  |     sl_config.sl_method = cm.cc.sl_method; | ||||||
|  |     sl_config.sl_no_altern = sl_no_altern; | ||||||
|  | 
 | ||||||
|  |     sl_config2.sl_c_str_arr = sl_c_str_arr; | ||||||
|  |     sl_config2.sl_c_overlay = sl_c_overlay; | ||||||
|  |     sl_config2.sl_altiv = cm.cc.sl_altiv; | ||||||
|  | 
 | ||||||
|  |     sc->h_config = h_config; | ||||||
|  |     sc->h_config2 = h_config2; | ||||||
|  |     sc->v_config = v_config; | ||||||
|  |     sc->misc_config = misc_config; | ||||||
|  |     sc->sl_config = sl_config; | ||||||
|  |     sc->sl_config2 = sl_config2; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| // Configure TVP7002 and scan converter logic based on the video mode
 | // Configure TVP7002 and scan converter logic based on the video mode
 | ||||||
| @ -522,7 +590,7 @@ void program_mode() | |||||||
|     set_lpf(cm.cc.video_lpf); |     set_lpf(cm.cc.video_lpf); | ||||||
|     cm.sample_sel = tvp_set_hpll_phase(cm.cc.sampler_phase, cm.sample_mult); |     cm.sample_sel = tvp_set_hpll_phase(cm.cc.sampler_phase, cm.sample_mult); | ||||||
| 
 | 
 | ||||||
|     set_videoinfo(); |     update_sc_config(); | ||||||
| 
 | 
 | ||||||
|     TX_SetPixelRepetition(cm.tx_pixelrep, ((cm.cc.tx_mode!=TX_DVI) && (cm.tx_pixelrep == cm.hdmitx_pixr_ifr)) ? 1 : 0); |     TX_SetPixelRepetition(cm.tx_pixelrep, ((cm.cc.tx_mode!=TX_DVI) && (cm.tx_pixelrep == cm.hdmitx_pixr_ifr)) ? 1 : 0); | ||||||
| 
 | 
 | ||||||
| @ -629,8 +697,8 @@ int init_hw() | |||||||
|     // Reset hardware
 |     // Reset hardware
 | ||||||
|     IOWR_ALTERA_AVALON_PIO_DATA(PIO_0_BASE, AV_RESET_N|LCD_BL); |     IOWR_ALTERA_AVALON_PIO_DATA(PIO_0_BASE, AV_RESET_N|LCD_BL); | ||||||
|     IOWR_ALTERA_AVALON_PIO_DATA(PIO_0_BASE, 0x0000); |     IOWR_ALTERA_AVALON_PIO_DATA(PIO_0_BASE, 0x0000); | ||||||
|     IOWR_ALTERA_AVALON_PIO_DATA(PIO_3_BASE, 0x00000000); |     sc->h_config.data = 0x00000000; | ||||||
|     IOWR_ALTERA_AVALON_PIO_DATA(PIO_5_BASE, 0x00000000); |     sc->v_config.data = 0x00000000; | ||||||
|     usleep(10000); |     usleep(10000); | ||||||
| 
 | 
 | ||||||
|     // unreset hw
 |     // unreset hw
 | ||||||
| @ -705,8 +773,9 @@ int init_hw() | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| int latency_test() { | int latency_test() { | ||||||
|     alt_u32 lt_status, btn_vec, btn_vec_prev=1; |     lt_status_reg lt_status; | ||||||
|     alt_u16 latency_ms_x100, stb_ms_x100; |     alt_u16 latency_ms_x100, stb_ms_x100; | ||||||
|  |     alt_u32 btn_vec, btn_vec_prev=1; | ||||||
|     alt_u8 position = lt_sel+1; |     alt_u8 position = lt_sel+1; | ||||||
| 
 | 
 | ||||||
|     sys_ctrl |= LT_ACTIVE|(position<<LT_MODE_OFFS); |     sys_ctrl |= LT_ACTIVE|(position<<LT_MODE_OFFS); | ||||||
| @ -726,16 +795,17 @@ int latency_test() { | |||||||
|                 usleep(400000); |                 usleep(400000); | ||||||
|                 sys_ctrl |= LT_ARMED|(position<<LT_MODE_OFFS); |                 sys_ctrl |= LT_ARMED|(position<<LT_MODE_OFFS); | ||||||
|                 IOWR_ALTERA_AVALON_PIO_DATA(PIO_0_BASE, sys_ctrl); |                 IOWR_ALTERA_AVALON_PIO_DATA(PIO_0_BASE, sys_ctrl); | ||||||
|                 //while (!((lt_status = IORD_ALTERA_AVALON_PIO_DATA(PIO_7_BASE)) & (1<<31))) {} //Hangs if sync is lost
 |                 //while (!sc->lt_status.lt_finished) {} //Hangs if sync is lost
 | ||||||
|                 SPI_Timer_On(1000); |                 SPI_Timer_On(1000); | ||||||
|                 while ((SPI_Timer_Status()==TRUE)) { |                 while ((SPI_Timer_Status()==TRUE)) { | ||||||
|                     lt_status = IORD_ALTERA_AVALON_PIO_DATA(PIO_7_BASE); |                     lt_status = sc->lt_status; | ||||||
|                     if (lt_status & (1<<31)) |                     if (lt_status.lt_finished) | ||||||
|                         break; |                         break; | ||||||
|                 } |                 } | ||||||
|                 SPI_Timer_Off(); |                 SPI_Timer_Off(); | ||||||
|                 latency_ms_x100 = lt_status & 0xffff; |                 latency_ms_x100 = lt_status.lt_lat_result; | ||||||
|                 stb_ms_x100 = (lt_status >> 16) & 0xfff; |                 stb_ms_x100 = lt_status.lt_stb_result; | ||||||
|  | 
 | ||||||
|                 if (latency_ms_x100 == 0) |                 if (latency_ms_x100 == 0) | ||||||
|                     sniprintf(menu_row2, LCD_ROW_LEN+1, "False trigger"); |                     sniprintf(menu_row2, LCD_ROW_LEN+1, "False trigger"); | ||||||
|                 else if (latency_ms_x100 == 0xffff) |                 else if (latency_ms_x100 == 0xffff) | ||||||
| @ -1009,10 +1079,10 @@ int main() | |||||||
|                     program_mode(); |                     program_mode(); | ||||||
|                 } |                 } | ||||||
|                 break; |                 break; | ||||||
|             case INFO_CHANGE: |             case SC_CONFIG_CHANGE: | ||||||
|                 if (cm.sync_active) { |                 if (cm.sync_active) { | ||||||
|                     printf("Info change\n"); |                     printf("Scanconverter config change\n"); | ||||||
|                     set_videoinfo(); |                     update_sc_config(); | ||||||
|                 } |                 } | ||||||
|                 break; |                 break; | ||||||
|             default: |             default: | ||||||
|  | |||||||
| @ -22,6 +22,7 @@ | |||||||
| 
 | 
 | ||||||
| #include "avconfig.h" | #include "avconfig.h" | ||||||
| #include "sysconfig.h" | #include "sysconfig.h" | ||||||
|  | #include "sc_config_regs.h" | ||||||
| 
 | 
 | ||||||
| // sys_ctrl bits
 | // sys_ctrl bits
 | ||||||
| #define LT_ACTIVE                   (1<<15) | #define LT_ACTIVE                   (1<<15) | ||||||
| @ -57,11 +58,6 @@ | |||||||
| #define FPGA_H_MULTMODE_OPTIMIZED   2 | #define FPGA_H_MULTMODE_OPTIMIZED   2 | ||||||
| #define FPGA_H_MULTMODE_OPTIMIZED_1X 3 | #define FPGA_H_MULTMODE_OPTIMIZED_1X 3 | ||||||
| 
 | 
 | ||||||
| #define FPGA_SCANLINEMODE_OFF       0 |  | ||||||
| #define FPGA_SCANLINEMODE_H         1 |  | ||||||
| #define FPGA_SCANLINEMODE_V         2 |  | ||||||
| #define FPGA_SCANLINEMODE_ALT       3 |  | ||||||
| 
 |  | ||||||
| #define AUTO_OFF                    0 | #define AUTO_OFF                    0 | ||||||
| #define AUTO_CURRENT_INPUT          1 | #define AUTO_CURRENT_INPUT          1 | ||||||
| #define AUTO_MAX_COUNT            100 | #define AUTO_MAX_COUNT            100 | ||||||
| @ -70,7 +66,7 @@ | |||||||
| // In reverse order of importance
 | // In reverse order of importance
 | ||||||
| typedef enum { | typedef enum { | ||||||
|     NO_CHANGE           = 0, |     NO_CHANGE           = 0, | ||||||
|     INFO_CHANGE         = 1, |     SC_CONFIG_CHANGE    = 1, | ||||||
|     MODE_CHANGE         = 2, |     MODE_CHANGE         = 2, | ||||||
|     TX_MODE_CHANGE      = 3, |     TX_MODE_CHANGE      = 3, | ||||||
|     ACTIVITY_CHANGE     = 4 |     ACTIVITY_CHANGE     = 4 | ||||||
|  | |||||||
| @ -47,6 +47,7 @@ const avconfig_t tc_default = { | |||||||
|     .sync_lpf = DEFAULT_SYNC_LPF, |     .sync_lpf = DEFAULT_SYNC_LPF, | ||||||
|     .pre_coast = DEFAULT_PRE_COAST, |     .pre_coast = DEFAULT_PRE_COAST, | ||||||
|     .post_coast = DEFAULT_POST_COAST, |     .post_coast = DEFAULT_POST_COAST, | ||||||
|  |     .sl_altern = 1, | ||||||
| #ifdef ENABLE_AUDIO | #ifdef ENABLE_AUDIO | ||||||
|     .audio_dw_sampl = DEFAULT_ON, |     .audio_dw_sampl = DEFAULT_ON, | ||||||
|     .tx_mode = TX_HDMI_RGB, |     .tx_mode = TX_HDMI_RGB, | ||||||
|  | |||||||
| @ -71,8 +71,12 @@ typedef struct { | |||||||
|     alt_u8 sl_type; |     alt_u8 sl_type; | ||||||
|     alt_u8 sl_hybr_str; |     alt_u8 sl_hybr_str; | ||||||
|     alt_u8 sl_method; |     alt_u8 sl_method; | ||||||
|  |     alt_u8 sl_altern; | ||||||
|  |     alt_u8 sl_altiv; | ||||||
|     alt_u8 sl_str; |     alt_u8 sl_str; | ||||||
|     alt_u8 sl_id; |     alt_u8 sl_id; | ||||||
|  |     alt_u8 sl_cust_l_str[5]; | ||||||
|  |     alt_u8 sl_cust_c_str[6]; | ||||||
|     alt_u8 linemult_target; |     alt_u8 linemult_target; | ||||||
|     alt_u8 l2_mode; |     alt_u8 l2_mode; | ||||||
|     alt_u8 l3_mode; |     alt_u8 l3_mode; | ||||||
|  | |||||||
| @ -45,6 +45,7 @@ extern alt_u8 menu_active; | |||||||
| extern alt_u16 sys_ctrl; | extern alt_u16 sys_ctrl; | ||||||
| extern alt_u8 profile_sel, profile_sel_menu; | extern alt_u8 profile_sel, profile_sel_menu; | ||||||
| extern alt_u8 lcd_bl_timeout; | extern alt_u8 lcd_bl_timeout; | ||||||
|  | extern volatile sc_regs *sc; | ||||||
| 
 | 
 | ||||||
| alt_u32 remote_code; | alt_u32 remote_code; | ||||||
| alt_u8 remote_rpt, remote_rpt_prev; | alt_u8 remote_rpt, remote_rpt_prev; | ||||||
| @ -111,9 +112,9 @@ int parse_control() | |||||||
|     alt_u8 pt_only = 0; |     alt_u8 pt_only = 0; | ||||||
|     avinput_t man_target_input = AV_LAST; |     avinput_t man_target_input = AV_LAST; | ||||||
| 
 | 
 | ||||||
|     alt_u32 fpga_status; |     sc_status_reg sc_status; | ||||||
|  |     sc_status2_reg sc_status2; | ||||||
|     alt_u32 fpga_v_hz_x100; |     alt_u32 fpga_v_hz_x100; | ||||||
|     alt_u8 fpga_ilace; |  | ||||||
| 
 | 
 | ||||||
|     // one for each video_group
 |     // one for each video_group
 | ||||||
|     alt_u8* pmcfg_ptr[] = { &pt_only, &tc.pm_240p, &tc.pm_384p, &tc.pm_480i, &tc.pm_480p, &tc.pm_480p, &tc.pm_1080i }; |     alt_u8* pmcfg_ptr[] = { &pt_only, &tc.pm_240p, &tc.pm_384p, &tc.pm_480i, &tc.pm_480p, &tc.pm_480p, &tc.pm_1080i }; | ||||||
| @ -155,8 +156,8 @@ int parse_control() | |||||||
| 
 | 
 | ||||||
|             break; |             break; | ||||||
|         case RC_INFO: |         case RC_INFO: | ||||||
|             fpga_status = IORD_ALTERA_AVALON_PIO_DATA(PIO_2_BASE); |             sc_status = sc->sc_status; | ||||||
|             fpga_ilace = !!(fpga_status & (1<<11)); |             sc_status2 = sc->sc_status2; | ||||||
|             sniprintf(menu_row1, LCD_ROW_LEN+1, "Prof.%u %9s", profile_sel, video_modes[cm.id].name); |             sniprintf(menu_row1, LCD_ROW_LEN+1, "Prof.%u %9s", profile_sel, video_modes[cm.id].name); | ||||||
|             if (cm.sync_active) { |             if (cm.sync_active) { | ||||||
|                 //fpga_v_hz_x100 = (100*TVP_EXTCLK_HZ)/IORD_ALTERA_AVALON_PIO_DATA(PIO_8_BASE);
 |                 //fpga_v_hz_x100 = (100*TVP_EXTCLK_HZ)/IORD_ALTERA_AVALON_PIO_DATA(PIO_8_BASE);
 | ||||||
| @ -165,10 +166,10 @@ int parse_control() | |||||||
|                                                                               ((fpga_status >> 16) & 0x3) ? '*' : ' ', |                                                                               ((fpga_status >> 16) & 0x3) ? '*' : ' ', | ||||||
|                                                                               fpga_v_hz_x100/100, |                                                                               fpga_v_hz_x100/100, | ||||||
|                                                                               fpga_v_hz_x100%100);*/ |                                                                               fpga_v_hz_x100%100);*/ | ||||||
|                 sniprintf(menu_row2, LCD_ROW_LEN+1, "%4lu%c%c  %lu", (((fpga_status & 0x7ff)+1)<<fpga_ilace)+fpga_ilace, |                 sniprintf(menu_row2, LCD_ROW_LEN+1, "%4lu%c%c  %lu", (unsigned long)((sc_status.vmax+1)<<sc_status.interlace_flag)+sc_status.interlace_flag, | ||||||
|                                                                      fpga_ilace ? 'i' : 'p', |                                                                      sc_status.interlace_flag ? 'i' : 'p', | ||||||
|                                                                      ((fpga_status >> 16) & 0x3) ? '*' : ' ', |                                                                      sc_status.fpga_vsyncgen ? '*' : ' ', | ||||||
|                                                                      IORD_ALTERA_AVALON_PIO_DATA(PIO_8_BASE)); |                                                                      (unsigned long)sc_status2.pcnt_frame); | ||||||
|             } |             } | ||||||
|             lcd_write_menu(); |             lcd_write_menu(); | ||||||
|             break; |             break; | ||||||
|  | |||||||
| @ -24,7 +24,7 @@ | |||||||
| #include "sysconfig.h" | #include "sysconfig.h" | ||||||
| 
 | 
 | ||||||
| #define FW_VER_MAJOR            0 | #define FW_VER_MAJOR            0 | ||||||
| #define FW_VER_MINOR            82 | #define FW_VER_MINOR            83 | ||||||
| 
 | 
 | ||||||
| #ifdef ENABLE_AUDIO | #ifdef ENABLE_AUDIO | ||||||
| #define FW_SUFFIX1              "a" | #define FW_SUFFIX1              "a" | ||||||
|  | |||||||
| @ -62,9 +62,9 @@ static const char *pm_480p_desc[] = { LNG("Passthru","パススルー"), "Lin | |||||||
| static const char *pm_1080i_desc[] = { LNG("Passthru","パススルー"), "Line2x (bob)" }; | static const char *pm_1080i_desc[] = { LNG("Passthru","パススルー"), "Line2x (bob)" }; | ||||||
| static const char *ar_256col_desc[] = { "4:3", "8:7" }; | static const char *ar_256col_desc[] = { "4:3", "8:7" }; | ||||||
| static const char *tx_mode_desc[] = { "HDMI (RGB)", "HDMI (YCbCr444)", "DVI" }; | static const char *tx_mode_desc[] = { "HDMI (RGB)", "HDMI (YCbCr444)", "DVI" }; | ||||||
| static const char *sl_mode_desc[] = { LNG("Off","オフ"), LNG("Auto","オート"), LNG("Manual","カスタム") }; | static const char *sl_mode_desc[] = { LNG("Off","オフ"), LNG("Auto","オート"), LNG("On","オン") }; | ||||||
| static const char *sl_method_desc[] = { LNG("Multiplication","Multiplication"), LNG("Subtraction","Subtraction") }; | static const char *sl_method_desc[] = { LNG("Multiplication","Multiplication"), LNG("Subtraction","Subtraction") }; | ||||||
| static const char *sl_type_desc[] = { LNG("Horizontal","ヨコ"), LNG("Vertical","タテ"), LNG("Alternating","コウゴ") }; | static const char *sl_type_desc[] = { LNG("Horizontal","ヨコ"), LNG("Vertical","タテ"), "Horiz. + Vert.", "Custom" }; | ||||||
| static const char *sl_id_desc[] = { LNG("Top","ウエ"), LNG("Bottom","シタ") }; | static const char *sl_id_desc[] = { LNG("Top","ウエ"), LNG("Bottom","シタ") }; | ||||||
| static const char *audio_dw_sampl_desc[] = { LNG("Off (fs = 96kHz)","オフ (fs = 96kHz)"), "2x  (fs = 48kHz)" }; | static const char *audio_dw_sampl_desc[] = { LNG("Off (fs = 96kHz)","オフ (fs = 96kHz)"), "2x  (fs = 48kHz)" }; | ||||||
| static const char *lt_desc[] = { "Top-left", "Center", "Bottom-right" }; | static const char *lt_desc[] = { "Top-left", "Center", "Bottom-right" }; | ||||||
| @ -77,6 +77,7 @@ static void sync_vth_disp(alt_u8 v) { sniprintf(menu_row2, LCD_ROW_LEN+1, "%d mV | |||||||
| static void intclks_to_time_disp(alt_u8 v) { sniprintf(menu_row2, LCD_ROW_LEN+1, "%u.%.2u us", (unsigned)(((1000000U*v)/(TVP_INTCLK_HZ/1000))/1000), (unsigned)((((1000000U*v)/(TVP_INTCLK_HZ/1000))%1000)/10)); } | static void intclks_to_time_disp(alt_u8 v) { sniprintf(menu_row2, LCD_ROW_LEN+1, "%u.%.2u us", (unsigned)(((1000000U*v)/(TVP_INTCLK_HZ/1000))/1000), (unsigned)((((1000000U*v)/(TVP_INTCLK_HZ/1000))%1000)/10)); } | ||||||
| static void extclks_to_time_disp(alt_u8 v) { sniprintf(menu_row2, LCD_ROW_LEN+1, "%u.%.2u us", (unsigned)(((1000000U*v)/(TVP_EXTCLK_HZ/1000))/1000), (unsigned)((((1000000U*v)/(TVP_EXTCLK_HZ/1000))%1000)/10)); } | static void extclks_to_time_disp(alt_u8 v) { sniprintf(menu_row2, LCD_ROW_LEN+1, "%u.%.2u us", (unsigned)(((1000000U*v)/(TVP_EXTCLK_HZ/1000))/1000), (unsigned)((((1000000U*v)/(TVP_EXTCLK_HZ/1000))%1000)/10)); } | ||||||
| static void sl_str_disp(alt_u8 v) { sniprintf(menu_row2, LCD_ROW_LEN+1, "%u%%", ((v+1)*625)/100); } | static void sl_str_disp(alt_u8 v) { sniprintf(menu_row2, LCD_ROW_LEN+1, "%u%%", ((v+1)*625)/100); } | ||||||
|  | static void sl_cust_str_disp(alt_u8 v) { sniprintf(menu_row2, LCD_ROW_LEN+1, "%u%%", ((v)*625)/100); } | ||||||
| static void sl_hybr_str_disp(alt_u8 v) { sniprintf(menu_row2, LCD_ROW_LEN+1, "%u%%", (v*625)/100); } | static void sl_hybr_str_disp(alt_u8 v) { sniprintf(menu_row2, LCD_ROW_LEN+1, "%u%%", (v*625)/100); } | ||||||
| static void lines_disp(alt_u8 v) { sniprintf(menu_row2, LCD_ROW_LEN+1, LNG("%u lines","%u ライン"), v); } | static void lines_disp(alt_u8 v) { sniprintf(menu_row2, LCD_ROW_LEN+1, LNG("%u lines","%u ライン"), v); } | ||||||
| static void pixels_disp(alt_u8 v) { sniprintf(menu_row2, LCD_ROW_LEN+1, LNG("%u pixels","%u ドット"), v); } | static void pixels_disp(alt_u8 v) { sniprintf(menu_row2, LCD_ROW_LEN+1, LNG("%u pixels","%u ドット"), v); } | ||||||
| @ -103,6 +104,20 @@ MENU(menu_advtiming, P99_PROTECT({ \ | |||||||
|     { LNG("V. active","V. アクティブ"),            OPT_AVCONFIG_NUMVAL_U16,{ .num_u16 = { &tc_v_active,     V_ACTIVE_MIN,  V_ACTIVE_MAX, vm_tweak } } }, |     { LNG("V. active","V. アクティブ"),            OPT_AVCONFIG_NUMVAL_U16,{ .num_u16 = { &tc_v_active,     V_ACTIVE_MIN,  V_ACTIVE_MAX, vm_tweak } } }, | ||||||
| })) | })) | ||||||
| 
 | 
 | ||||||
|  | MENU(menu_cust_sl, P99_PROTECT({ \ | ||||||
|  |     { "Sub-line 0 str",                       OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.sl_cust_l_str[0],      OPT_NOWRAP, 0, SCANLINESTR_MAX+1, sl_cust_str_disp } } }, | ||||||
|  |     { "Sub-line 1 str",                       OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.sl_cust_l_str[1],      OPT_NOWRAP, 0, SCANLINESTR_MAX+1, sl_cust_str_disp } } }, | ||||||
|  |     { "Sub-line 2 str",                       OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.sl_cust_l_str[2],      OPT_NOWRAP, 0, SCANLINESTR_MAX+1, sl_cust_str_disp } } }, | ||||||
|  |     { "Sub-line 3 str",                       OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.sl_cust_l_str[3],      OPT_NOWRAP, 0, SCANLINESTR_MAX+1, sl_cust_str_disp } } }, | ||||||
|  |     { "Sub-line 4 str",                       OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.sl_cust_l_str[4],      OPT_NOWRAP, 0, SCANLINESTR_MAX+1, sl_cust_str_disp } } }, | ||||||
|  |     { "Sub-column 0 str",                     OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.sl_cust_c_str[0],      OPT_NOWRAP, 0, SCANLINESTR_MAX+1, sl_cust_str_disp } } }, | ||||||
|  |     { "Sub-column 1 str",                     OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.sl_cust_c_str[1],      OPT_NOWRAP, 0, SCANLINESTR_MAX+1, sl_cust_str_disp } } }, | ||||||
|  |     { "Sub-column 2 str",                     OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.sl_cust_c_str[2],      OPT_NOWRAP, 0, SCANLINESTR_MAX+1, sl_cust_str_disp } } }, | ||||||
|  |     { "Sub-column 3 str",                     OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.sl_cust_c_str[3],      OPT_NOWRAP, 0, SCANLINESTR_MAX+1, sl_cust_str_disp } } }, | ||||||
|  |     { "Sub-column 4 str",                     OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.sl_cust_c_str[4],      OPT_NOWRAP, 0, SCANLINESTR_MAX+1, sl_cust_str_disp } } }, | ||||||
|  |     { "Sub-column 5 str",                     OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.sl_cust_c_str[5],      OPT_NOWRAP, 0, SCANLINESTR_MAX+1, sl_cust_str_disp } } }, | ||||||
|  | })) | ||||||
|  | 
 | ||||||
| 
 | 
 | ||||||
| MENU(menu_vinputproc, P99_PROTECT({ \ | MENU(menu_vinputproc, P99_PROTECT({ \ | ||||||
|     { LNG("Video LPF","ビデオ LPF"),             OPT_AVCONFIG_SELECTION, { .sel = { &tc.video_lpf,     OPT_WRAP,   SETTING_ITEM(video_lpf_desc) } } }, |     { LNG("Video LPF","ビデオ LPF"),             OPT_AVCONFIG_SELECTION, { .sel = { &tc.video_lpf,     OPT_WRAP,   SETTING_ITEM(video_lpf_desc) } } }, | ||||||
| @ -149,13 +164,19 @@ MENU(menu_output, P99_PROTECT({ \ | |||||||
|     { "HDMI ITC",                              OPT_AVCONFIG_SELECTION, { .sel = { &tc.hdmi_itc,        OPT_WRAP, SETTING_ITEM(off_on_desc) } } }, |     { "HDMI ITC",                              OPT_AVCONFIG_SELECTION, { .sel = { &tc.hdmi_itc,        OPT_WRAP, SETTING_ITEM(off_on_desc) } } }, | ||||||
| })) | })) | ||||||
| 
 | 
 | ||||||
| MENU(menu_postproc, P99_PROTECT({ \ | MENU(menu_scanlines, P99_PROTECT({ \ | ||||||
|     { LNG("Scanlines","スキャンライン"),                  OPT_AVCONFIG_SELECTION, { .sel = { &tc.sl_mode,     OPT_WRAP,   SETTING_ITEM(sl_mode_desc) } } }, |     { LNG("Scanlines","スキャンライン"),                  OPT_AVCONFIG_SELECTION, { .sel = { &tc.sl_mode,     OPT_WRAP,   SETTING_ITEM(sl_mode_desc) } } }, | ||||||
|     { LNG("Scanline str.","スキャンラインツヨサ"),           OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.sl_str,      OPT_NOWRAP, 0, SCANLINESTR_MAX, sl_str_disp } } }, |     { LNG("Sl. strength","スキャンラインツヨサ"),            OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.sl_str,      OPT_NOWRAP, 0, SCANLINESTR_MAX, sl_str_disp } } }, | ||||||
|     { LNG("Sl. hybrid str.","Sl. hybrid str."),     OPT_AVCONFIG_NUMVALUE, { .num = { &tc.sl_hybr_str, OPT_NOWRAP,   0, SL_HYBRIDSTR_MAX, sl_hybr_str_disp } } }, |     { "Sl. hybrid str.",                          OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.sl_hybr_str, OPT_NOWRAP, 0, SL_HYBRIDSTR_MAX, sl_hybr_str_disp } } }, | ||||||
|     { LNG("Scanline method","Scanline method"),     OPT_AVCONFIG_SELECTION, { .sel = { &tc.sl_method,     OPT_WRAP,   SETTING_ITEM(sl_method_desc) } } }, |     { "Sl. method",                               OPT_AVCONFIG_SELECTION, { .sel = { &tc.sl_method,   OPT_WRAP,   SETTING_ITEM(sl_method_desc) } } }, | ||||||
|     { LNG("Scanline type","スキャンラインルイ"),            OPT_AVCONFIG_SELECTION, { .sel = { &tc.sl_type,     OPT_WRAP,   SETTING_ITEM(sl_type_desc) } } }, |     { "Sl. alternating",                          OPT_AVCONFIG_SELECTION, { .sel = { &tc.sl_altern,   OPT_WRAP,   SETTING_ITEM(off_on_desc) } } }, | ||||||
|     { LNG("Scanline alignm.","スキャンラインポジション"),    OPT_AVCONFIG_SELECTION, { .sel = { &tc.sl_id,       OPT_WRAP,   SETTING_ITEM(sl_id_desc) } } }, |     { LNG("Sl. alignment","スキャンラインポジション"),        OPT_AVCONFIG_SELECTION, { .sel = { &tc.sl_id,       OPT_WRAP,   SETTING_ITEM(sl_id_desc) } } }, | ||||||
|  |     { "Sl. alt interval",                         OPT_AVCONFIG_SELECTION, { .sel = { &tc.sl_altiv,    OPT_WRAP,   SETTING_ITEM(off_on_desc) } } }, | ||||||
|  |     { LNG("Sl. type","スキャンラインルイ"),                 OPT_AVCONFIG_SELECTION, { .sel = { &tc.sl_type,     OPT_WRAP,   SETTING_ITEM(sl_type_desc) } } }, | ||||||
|  |     { "<  Custom Sl.  >",                         OPT_SUBMENU,            { .sub = { &menu_cust_sl, NULL, NULL } } }, | ||||||
|  | })) | ||||||
|  | 
 | ||||||
|  | MENU(menu_postproc, P99_PROTECT({ \ | ||||||
|     { LNG("Horizontal mask","スイヘイマスク"),           OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.h_mask,      OPT_NOWRAP, 0, H_MASK_MAX, pixels_disp } } }, |     { LNG("Horizontal mask","スイヘイマスク"),           OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.h_mask,      OPT_NOWRAP, 0, H_MASK_MAX, pixels_disp } } }, | ||||||
|     { LNG("Vertical mask","スイチョクマスク"),            OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.v_mask,      OPT_NOWRAP, 0, V_MASK_MAX, pixels_disp } } }, |     { LNG("Vertical mask","スイチョクマスク"),            OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.v_mask,      OPT_NOWRAP, 0, V_MASK_MAX, pixels_disp } } }, | ||||||
|     { LNG("Mask brightness","マスクアカルサ"),           OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.mask_br,     OPT_NOWRAP, 0, HV_MASK_MAX_BR, value_disp } } }, |     { LNG("Mask brightness","マスクアカルサ"),           OPT_AVCONFIG_NUMVALUE,  { .num = { &tc.mask_br,     OPT_NOWRAP, 0, HV_MASK_MAX_BR, value_disp } } }, | ||||||
| @ -203,6 +224,7 @@ MENU(menu_main, P99_PROTECT({ \ | |||||||
|     { LNG("Sampling opt.  >","サンプリングオプション>"),  OPT_SUBMENU,            { .sub = { &menu_sampling, NULL, NULL } } }, |     { LNG("Sampling opt.  >","サンプリングオプション>"),  OPT_SUBMENU,            { .sub = { &menu_sampling, NULL, NULL } } }, | ||||||
|     { LNG("Sync opt.      >","ドウキオプション    >"),  OPT_SUBMENU,            { .sub = { &menu_sync, NULL, NULL } } }, |     { LNG("Sync opt.      >","ドウキオプション    >"),  OPT_SUBMENU,            { .sub = { &menu_sync, NULL, NULL } } }, | ||||||
|     { LNG("Output opt.    >","シュツリョクオプション  >"),  OPT_SUBMENU,            { .sub = { &menu_output, NULL, NULL } } }, |     { LNG("Output opt.    >","シュツリョクオプション  >"),  OPT_SUBMENU,            { .sub = { &menu_output, NULL, NULL } } }, | ||||||
|  |     { LNG("Scanline opt.  >","スキャンラインオプション >"),  OPT_SUBMENU,            { .sub = { &menu_scanlines, NULL, NULL } } }, | ||||||
|     { LNG("Post-proc.     >","アトショリ         >"),  OPT_SUBMENU,            { .sub = { &menu_postproc, NULL, NULL } } }, |     { LNG("Post-proc.     >","アトショリ         >"),  OPT_SUBMENU,            { .sub = { &menu_postproc, NULL, NULL } } }, | ||||||
|     { LNG("Compatibility  >","ゴカンセイ        >"), OPT_SUBMENU,             { .sub = { &menu_compatibility, NULL, NULL } } }, |     { LNG("Compatibility  >","ゴカンセイ        >"), OPT_SUBMENU,             { .sub = { &menu_compatibility, NULL, NULL } } }, | ||||||
|     AUDIO_MENU |     AUDIO_MENU | ||||||
|  | |||||||
							
								
								
									
										135
									
								
								software/sys_controller_bsp/drivers/inc/sc_config_regs.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										135
									
								
								software/sys_controller_bsp/drivers/inc/sc_config_regs.h
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,135 @@ | |||||||
|  | //
 | ||||||
|  | // Copyright (C) 2015-2019  Markus Hiienkari <mhiienka@niksula.hut.fi>
 | ||||||
|  | //
 | ||||||
|  | // This file is part of Open Source Scan Converter project.
 | ||||||
|  | //
 | ||||||
|  | // This program is free software: you can redistribute it and/or modify
 | ||||||
|  | // it under the terms of the GNU General Public License as published by
 | ||||||
|  | // the Free Software Foundation, either version 3 of the License, or
 | ||||||
|  | // (at your option) any later version.
 | ||||||
|  | //
 | ||||||
|  | // This program is distributed in the hope that it will be useful,
 | ||||||
|  | // but WITHOUT ANY WARRANTY; without even the implied warranty of
 | ||||||
|  | // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | ||||||
|  | // GNU General Public License for more details.
 | ||||||
|  | //
 | ||||||
|  | // You should have received a copy of the GNU General Public License
 | ||||||
|  | // along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | ||||||
|  | //
 | ||||||
|  | 
 | ||||||
|  | #ifndef SC_CONFIG_REGS_H_ | ||||||
|  | #define SC_CONFIG_REGS_H_ | ||||||
|  | 
 | ||||||
|  | #include <alt_types.h> | ||||||
|  | 
 | ||||||
|  | // bit-fields coded as little-endian
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u16 vmax:11; | ||||||
|  |         alt_u8 interlace_flag:1; | ||||||
|  |         alt_u8 sc_rsv2:4; | ||||||
|  |         alt_u8 fpga_vsyncgen:2; | ||||||
|  |         alt_u16 vmax_tvp:11; | ||||||
|  |         alt_u8 sc_rsv:2; | ||||||
|  |         alt_u8 vsync_flag:1; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } sc_status_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u32 pcnt_frame:20; | ||||||
|  |         alt_u16 sc_rsv:12; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } sc_status2_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u16 lt_lat_result:16; | ||||||
|  |         alt_u16 lt_stb_result:12; | ||||||
|  |         alt_u8 lt_rsv:3; | ||||||
|  |         alt_u8 lt_finished:1; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } lt_status_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u16 h_active:11; | ||||||
|  |         alt_u16 h_backporch:9; | ||||||
|  |         alt_u8 h_synclen:8; | ||||||
|  |         alt_u8 h_l3_240x360:1; | ||||||
|  |         alt_u8 h_l5fmt:1; | ||||||
|  |         alt_u8 h_multmode:2; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } h_config_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u16 h_opt_startoff:10; | ||||||
|  |         alt_u8 h_opt_sample_mult:3; | ||||||
|  |         alt_u8 h_opt_sample_sel:3; | ||||||
|  |         alt_u8 h_opt_scale:3; | ||||||
|  |         alt_u16 h_mask:11; | ||||||
|  |         alt_u8 h_rsv:2; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } h_config2_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u16 v_active:11; | ||||||
|  |         alt_u8 v_backporch:6; | ||||||
|  |         alt_u8 v_synclen:3; | ||||||
|  |         alt_u8 v_mask:6; | ||||||
|  |         alt_u8 v_rsv:3; | ||||||
|  |         alt_u8 v_multmode:3; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } v_config_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u8 mask_br:4; | ||||||
|  |         alt_u8 rev_lpf_str:5; | ||||||
|  |         alt_u32 misc_rsv:23; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } misc_config_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u32 sl_l_str_arr:20; | ||||||
|  |         alt_u8 sl_l_overlay:5; | ||||||
|  |         alt_u8 sl_hybr_str:5; | ||||||
|  |         alt_u8 sl_method:1; | ||||||
|  |         alt_u8 sl_no_altern:1; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } sl_config_reg; | ||||||
|  | 
 | ||||||
|  | typedef union { | ||||||
|  |     struct { | ||||||
|  |         alt_u32 sl_c_str_arr:24; | ||||||
|  |         alt_u8 sl_c_overlay:6; | ||||||
|  |         alt_u8 sl_rsv:1; | ||||||
|  |         alt_u8 sl_altiv:1; | ||||||
|  |     } __attribute__((packed, __may_alias__)); | ||||||
|  |     alt_u32 data; | ||||||
|  | } sl_config2_reg; | ||||||
|  | 
 | ||||||
|  | typedef struct { | ||||||
|  |     sc_status_reg sc_status; | ||||||
|  |     sc_status2_reg sc_status2; | ||||||
|  |     lt_status_reg lt_status; | ||||||
|  |     h_config_reg h_config; | ||||||
|  |     h_config2_reg h_config2; | ||||||
|  |     v_config_reg v_config; | ||||||
|  |     misc_config_reg misc_config; | ||||||
|  |     sl_config_reg sl_config; | ||||||
|  |     sl_config2_reg sl_config2; | ||||||
|  | } __attribute__((packed, __may_alias__)) sc_regs; | ||||||
|  | 
 | ||||||
|  | #endif //SC_CONFIG_REGS_H_
 | ||||||
										
											Binary file not shown.
										
									
								
							| @ -382,192 +382,13 @@ | |||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| /*
 | /*
 | ||||||
|  * pio_2 configuration |  * sc_config configuration | ||||||
|  * |  * | ||||||
|  */ |  */ | ||||||
| 
 | 
 | ||||||
| #define ALT_MODULE_CLASS_pio_2 altera_avalon_pio | #define ALT_MODULE_CLASS_sc_config_0 sc_config | ||||||
| #define PIO_2_BASE 0x210c0 | #define SC_CONFIG_0_BASE 0x22000 | ||||||
| #define PIO_2_BIT_CLEARING_EDGE_REGISTER 0 | #define SC_CONFIG_0_SPAN 16 | ||||||
| #define PIO_2_BIT_MODIFYING_OUTPUT_REGISTER 0 |  | ||||||
| #define PIO_2_CAPTURE 0 |  | ||||||
| #define PIO_2_DATA_WIDTH 32 |  | ||||||
| #define PIO_2_DO_TEST_BENCH_WIRING 0 |  | ||||||
| #define PIO_2_DRIVEN_SIM_VALUE 0 |  | ||||||
| #define PIO_2_EDGE_TYPE "NONE" |  | ||||||
| #define PIO_2_FREQ 27000000 |  | ||||||
| #define PIO_2_HAS_IN 1 |  | ||||||
| #define PIO_2_HAS_OUT 0 |  | ||||||
| #define PIO_2_HAS_TRI 0 |  | ||||||
| #define PIO_2_IRQ -1 |  | ||||||
| #define PIO_2_IRQ_INTERRUPT_CONTROLLER_ID -1 |  | ||||||
| #define PIO_2_IRQ_TYPE "NONE" |  | ||||||
| #define PIO_2_NAME "/dev/pio_2" |  | ||||||
| #define PIO_2_RESET_VALUE 0 |  | ||||||
| #define PIO_2_SPAN 16 |  | ||||||
| #define PIO_2_TYPE "altera_avalon_pio" |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| /*
 |  | ||||||
|  * pio_3 configuration |  | ||||||
|  * |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| #define ALT_MODULE_CLASS_pio_3 altera_avalon_pio |  | ||||||
| #define PIO_3_BASE 0x210b0 |  | ||||||
| #define PIO_3_BIT_CLEARING_EDGE_REGISTER 0 |  | ||||||
| #define PIO_3_BIT_MODIFYING_OUTPUT_REGISTER 0 |  | ||||||
| #define PIO_3_CAPTURE 0 |  | ||||||
| #define PIO_3_DATA_WIDTH 32 |  | ||||||
| #define PIO_3_DO_TEST_BENCH_WIRING 0 |  | ||||||
| #define PIO_3_DRIVEN_SIM_VALUE 0 |  | ||||||
| #define PIO_3_EDGE_TYPE "NONE" |  | ||||||
| #define PIO_3_FREQ 27000000 |  | ||||||
| #define PIO_3_HAS_IN 0 |  | ||||||
| #define PIO_3_HAS_OUT 1 |  | ||||||
| #define PIO_3_HAS_TRI 0 |  | ||||||
| #define PIO_3_IRQ -1 |  | ||||||
| #define PIO_3_IRQ_INTERRUPT_CONTROLLER_ID -1 |  | ||||||
| #define PIO_3_IRQ_TYPE "NONE" |  | ||||||
| #define PIO_3_NAME "/dev/pio_3" |  | ||||||
| #define PIO_3_RESET_VALUE 0 |  | ||||||
| #define PIO_3_SPAN 16 |  | ||||||
| #define PIO_3_TYPE "altera_avalon_pio" |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| /*
 |  | ||||||
|  * pio_4 configuration |  | ||||||
|  * |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| #define ALT_MODULE_CLASS_pio_4 altera_avalon_pio |  | ||||||
| #define PIO_4_BASE 0x210a0 |  | ||||||
| #define PIO_4_BIT_CLEARING_EDGE_REGISTER 0 |  | ||||||
| #define PIO_4_BIT_MODIFYING_OUTPUT_REGISTER 0 |  | ||||||
| #define PIO_4_CAPTURE 0 |  | ||||||
| #define PIO_4_DATA_WIDTH 32 |  | ||||||
| #define PIO_4_DO_TEST_BENCH_WIRING 0 |  | ||||||
| #define PIO_4_DRIVEN_SIM_VALUE 0 |  | ||||||
| #define PIO_4_EDGE_TYPE "NONE" |  | ||||||
| #define PIO_4_FREQ 27000000 |  | ||||||
| #define PIO_4_HAS_IN 0 |  | ||||||
| #define PIO_4_HAS_OUT 1 |  | ||||||
| #define PIO_4_HAS_TRI 0 |  | ||||||
| #define PIO_4_IRQ -1 |  | ||||||
| #define PIO_4_IRQ_INTERRUPT_CONTROLLER_ID -1 |  | ||||||
| #define PIO_4_IRQ_TYPE "NONE" |  | ||||||
| #define PIO_4_NAME "/dev/pio_4" |  | ||||||
| #define PIO_4_RESET_VALUE 0 |  | ||||||
| #define PIO_4_SPAN 16 |  | ||||||
| #define PIO_4_TYPE "altera_avalon_pio" |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| /*
 |  | ||||||
|  * pio_5 configuration |  | ||||||
|  * |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| #define ALT_MODULE_CLASS_pio_5 altera_avalon_pio |  | ||||||
| #define PIO_5_BASE 0x21090 |  | ||||||
| #define PIO_5_BIT_CLEARING_EDGE_REGISTER 0 |  | ||||||
| #define PIO_5_BIT_MODIFYING_OUTPUT_REGISTER 0 |  | ||||||
| #define PIO_5_CAPTURE 0 |  | ||||||
| #define PIO_5_DATA_WIDTH 32 |  | ||||||
| #define PIO_5_DO_TEST_BENCH_WIRING 0 |  | ||||||
| #define PIO_5_DRIVEN_SIM_VALUE 0 |  | ||||||
| #define PIO_5_EDGE_TYPE "NONE" |  | ||||||
| #define PIO_5_FREQ 27000000 |  | ||||||
| #define PIO_5_HAS_IN 0 |  | ||||||
| #define PIO_5_HAS_OUT 1 |  | ||||||
| #define PIO_5_HAS_TRI 0 |  | ||||||
| #define PIO_5_IRQ -1 |  | ||||||
| #define PIO_5_IRQ_INTERRUPT_CONTROLLER_ID -1 |  | ||||||
| #define PIO_5_IRQ_TYPE "NONE" |  | ||||||
| #define PIO_5_NAME "/dev/pio_5" |  | ||||||
| #define PIO_5_RESET_VALUE 0 |  | ||||||
| #define PIO_5_SPAN 16 |  | ||||||
| #define PIO_5_TYPE "altera_avalon_pio" |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| /*
 |  | ||||||
|  * pio_6 configuration |  | ||||||
|  * |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| #define ALT_MODULE_CLASS_pio_6 altera_avalon_pio |  | ||||||
| #define PIO_6_BASE 0x21080 |  | ||||||
| #define PIO_6_BIT_CLEARING_EDGE_REGISTER 0 |  | ||||||
| #define PIO_6_BIT_MODIFYING_OUTPUT_REGISTER 0 |  | ||||||
| #define PIO_6_CAPTURE 0 |  | ||||||
| #define PIO_6_DATA_WIDTH 32 |  | ||||||
| #define PIO_6_DO_TEST_BENCH_WIRING 0 |  | ||||||
| #define PIO_6_DRIVEN_SIM_VALUE 0 |  | ||||||
| #define PIO_6_EDGE_TYPE "NONE" |  | ||||||
| #define PIO_6_FREQ 27000000 |  | ||||||
| #define PIO_6_HAS_IN 0 |  | ||||||
| #define PIO_6_HAS_OUT 1 |  | ||||||
| #define PIO_6_HAS_TRI 0 |  | ||||||
| #define PIO_6_IRQ -1 |  | ||||||
| #define PIO_6_IRQ_INTERRUPT_CONTROLLER_ID -1 |  | ||||||
| #define PIO_6_IRQ_TYPE "NONE" |  | ||||||
| #define PIO_6_NAME "/dev/pio_6" |  | ||||||
| #define PIO_6_RESET_VALUE 0 |  | ||||||
| #define PIO_6_SPAN 16 |  | ||||||
| #define PIO_6_TYPE "altera_avalon_pio" |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| /*
 |  | ||||||
|  * pio_7 configuration |  | ||||||
|  * |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| #define ALT_MODULE_CLASS_pio_7 altera_avalon_pio |  | ||||||
| #define PIO_7_BASE 0x21070 |  | ||||||
| #define PIO_7_BIT_CLEARING_EDGE_REGISTER 0 |  | ||||||
| #define PIO_7_BIT_MODIFYING_OUTPUT_REGISTER 0 |  | ||||||
| #define PIO_7_CAPTURE 0 |  | ||||||
| #define PIO_7_DATA_WIDTH 32 |  | ||||||
| #define PIO_7_DO_TEST_BENCH_WIRING 0 |  | ||||||
| #define PIO_7_DRIVEN_SIM_VALUE 0 |  | ||||||
| #define PIO_7_EDGE_TYPE "NONE" |  | ||||||
| #define PIO_7_FREQ 27000000 |  | ||||||
| #define PIO_7_HAS_IN 1 |  | ||||||
| #define PIO_7_HAS_OUT 0 |  | ||||||
| #define PIO_7_HAS_TRI 0 |  | ||||||
| #define PIO_7_IRQ -1 |  | ||||||
| #define PIO_7_IRQ_INTERRUPT_CONTROLLER_ID -1 |  | ||||||
| #define PIO_7_IRQ_TYPE "NONE" |  | ||||||
| #define PIO_7_NAME "/dev/pio_7" |  | ||||||
| #define PIO_7_RESET_VALUE 0 |  | ||||||
| #define PIO_7_SPAN 16 |  | ||||||
| #define PIO_7_TYPE "altera_avalon_pio" |  | ||||||
| 
 |  | ||||||
| 
 |  | ||||||
| /*
 |  | ||||||
|  * pio_8 configuration |  | ||||||
|  * |  | ||||||
|  */ |  | ||||||
| 
 |  | ||||||
| #define ALT_MODULE_CLASS_pio_8 altera_avalon_pio |  | ||||||
| #define PIO_8_BASE 0x21060 |  | ||||||
| #define PIO_8_BIT_CLEARING_EDGE_REGISTER 0 |  | ||||||
| #define PIO_8_BIT_MODIFYING_OUTPUT_REGISTER 0 |  | ||||||
| #define PIO_8_CAPTURE 0 |  | ||||||
| #define PIO_8_DATA_WIDTH 32 |  | ||||||
| #define PIO_8_DO_TEST_BENCH_WIRING 0 |  | ||||||
| #define PIO_8_DRIVEN_SIM_VALUE 0 |  | ||||||
| #define PIO_8_EDGE_TYPE "NONE" |  | ||||||
| #define PIO_8_FREQ 27000000 |  | ||||||
| #define PIO_8_HAS_IN 1 |  | ||||||
| #define PIO_8_HAS_OUT 0 |  | ||||||
| #define PIO_8_HAS_TRI 0 |  | ||||||
| #define PIO_8_IRQ -1 |  | ||||||
| #define PIO_8_IRQ_INTERRUPT_CONTROLLER_ID -1 |  | ||||||
| #define PIO_8_IRQ_TYPE "NONE" |  | ||||||
| #define PIO_8_NAME "/dev/pio_8" |  | ||||||
| #define PIO_8_RESET_VALUE 0 |  | ||||||
| #define PIO_8_SPAN 16 |  | ||||||
| #define PIO_8_TYPE "altera_avalon_pio" |  | ||||||
| 
 | 
 | ||||||
| 
 | 
 | ||||||
| /*
 | /*
 | ||||||
|  | |||||||
							
								
								
									
										431
									
								
								sys.qsys
									
									
									
									
									
								
							
							
						
						
									
										431
									
								
								sys.qsys
									
									
									
									
									
								
							| @ -219,153 +219,6 @@ | |||||||
|          type = "String"; |          type = "String"; | ||||||
|       } |       } | ||||||
|    } |    } | ||||||
|    element pio_2 |  | ||||||
|    { |  | ||||||
|       datum _sortIndex |  | ||||||
|       { |  | ||||||
|          value = "12"; |  | ||||||
|          type = "int"; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
|    element pio_2.s1 |  | ||||||
|    { |  | ||||||
|       datum _lockedAddress |  | ||||||
|       { |  | ||||||
|          value = "1"; |  | ||||||
|          type = "boolean"; |  | ||||||
|       } |  | ||||||
|       datum baseAddress |  | ||||||
|       { |  | ||||||
|          value = "135360"; |  | ||||||
|          type = "String"; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
|    element pio_3 |  | ||||||
|    { |  | ||||||
|       datum _sortIndex |  | ||||||
|       { |  | ||||||
|          value = "13"; |  | ||||||
|          type = "int"; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
|    element pio_3.s1 |  | ||||||
|    { |  | ||||||
|       datum _lockedAddress |  | ||||||
|       { |  | ||||||
|          value = "1"; |  | ||||||
|          type = "boolean"; |  | ||||||
|       } |  | ||||||
|       datum baseAddress |  | ||||||
|       { |  | ||||||
|          value = "135344"; |  | ||||||
|          type = "String"; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
|    element pio_4 |  | ||||||
|    { |  | ||||||
|       datum _sortIndex |  | ||||||
|       { |  | ||||||
|          value = "14"; |  | ||||||
|          type = "int"; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
|    element pio_4.s1 |  | ||||||
|    { |  | ||||||
|       datum _lockedAddress |  | ||||||
|       { |  | ||||||
|          value = "1"; |  | ||||||
|          type = "boolean"; |  | ||||||
|       } |  | ||||||
|       datum baseAddress |  | ||||||
|       { |  | ||||||
|          value = "135328"; |  | ||||||
|          type = "String"; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
|    element pio_5 |  | ||||||
|    { |  | ||||||
|       datum _sortIndex |  | ||||||
|       { |  | ||||||
|          value = "15"; |  | ||||||
|          type = "int"; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
|    element pio_5.s1 |  | ||||||
|    { |  | ||||||
|       datum _lockedAddress |  | ||||||
|       { |  | ||||||
|          value = "1"; |  | ||||||
|          type = "boolean"; |  | ||||||
|       } |  | ||||||
|       datum baseAddress |  | ||||||
|       { |  | ||||||
|          value = "135312"; |  | ||||||
|          type = "String"; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
|    element pio_6 |  | ||||||
|    { |  | ||||||
|       datum _sortIndex |  | ||||||
|       { |  | ||||||
|          value = "16"; |  | ||||||
|          type = "int"; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
|    element pio_6.s1 |  | ||||||
|    { |  | ||||||
|       datum _lockedAddress |  | ||||||
|       { |  | ||||||
|          value = "1"; |  | ||||||
|          type = "boolean"; |  | ||||||
|       } |  | ||||||
|       datum baseAddress |  | ||||||
|       { |  | ||||||
|          value = "135296"; |  | ||||||
|          type = "String"; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
|    element pio_7 |  | ||||||
|    { |  | ||||||
|       datum _sortIndex |  | ||||||
|       { |  | ||||||
|          value = "17"; |  | ||||||
|          type = "int"; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
|    element pio_7.s1 |  | ||||||
|    { |  | ||||||
|       datum _lockedAddress |  | ||||||
|       { |  | ||||||
|          value = "1"; |  | ||||||
|          type = "boolean"; |  | ||||||
|       } |  | ||||||
|       datum baseAddress |  | ||||||
|       { |  | ||||||
|          value = "135280"; |  | ||||||
|          type = "String"; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
|    element pio_8 |  | ||||||
|    { |  | ||||||
|       datum _sortIndex |  | ||||||
|       { |  | ||||||
|          value = "18"; |  | ||||||
|          type = "int"; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
|    element pio_8.s1 |  | ||||||
|    { |  | ||||||
|       datum _lockedAddress |  | ||||||
|       { |  | ||||||
|          value = "1"; |  | ||||||
|          type = "boolean"; |  | ||||||
|       } |  | ||||||
|       datum baseAddress |  | ||||||
|       { |  | ||||||
|          value = "135264"; |  | ||||||
|          type = "String"; |  | ||||||
|       } |  | ||||||
|    } |  | ||||||
|    element pulpino_0 |    element pulpino_0 | ||||||
|    { |    { | ||||||
|       datum _sortIndex |       datum _sortIndex | ||||||
| @ -382,6 +235,27 @@ | |||||||
|          type = "boolean"; |          type = "boolean"; | ||||||
|       } |       } | ||||||
|    } |    } | ||||||
|  |    element sc_config_0 | ||||||
|  |    { | ||||||
|  |       datum _sortIndex | ||||||
|  |       { | ||||||
|  |          value = "12"; | ||||||
|  |          type = "int"; | ||||||
|  |       } | ||||||
|  |    } | ||||||
|  |    element sc_config_0.avalon_s | ||||||
|  |    { | ||||||
|  |       datum _lockedAddress | ||||||
|  |       { | ||||||
|  |          value = "1"; | ||||||
|  |          type = "boolean"; | ||||||
|  |       } | ||||||
|  |       datum baseAddress | ||||||
|  |       { | ||||||
|  |          value = "139264"; | ||||||
|  |          type = "String"; | ||||||
|  |       } | ||||||
|  |    } | ||||||
|    element timer_0 |    element timer_0 | ||||||
|    { |    { | ||||||
|       datum _sortIndex |       datum _sortIndex | ||||||
| @ -450,47 +324,17 @@ | |||||||
|    internal="pio_1.external_connection" |    internal="pio_1.external_connection" | ||||||
|    type="conduit" |    type="conduit" | ||||||
|    dir="end" /> |    dir="end" /> | ||||||
|  <interface |  | ||||||
|    name="pio_2_status_in" |  | ||||||
|    internal="pio_2.external_connection" |  | ||||||
|    type="conduit" |  | ||||||
|    dir="end" /> |  | ||||||
|  <interface |  | ||||||
|    name="pio_3_h_info_out" |  | ||||||
|    internal="pio_3.external_connection" |  | ||||||
|    type="conduit" |  | ||||||
|    dir="end" /> |  | ||||||
|  <interface |  | ||||||
|    name="pio_4_h_info2_out" |  | ||||||
|    internal="pio_4.external_connection" |  | ||||||
|    type="conduit" |  | ||||||
|    dir="end" /> |  | ||||||
|  <interface |  | ||||||
|    name="pio_5_v_info_out" |  | ||||||
|    internal="pio_5.external_connection" |  | ||||||
|    type="conduit" |  | ||||||
|    dir="end" /> |  | ||||||
|  <interface |  | ||||||
|    name="pio_6_extra_info_out" |  | ||||||
|    internal="pio_6.external_connection" |  | ||||||
|    type="conduit" |  | ||||||
|    dir="end" /> |  | ||||||
|  <interface |  | ||||||
|    name="pio_7_lt_results_in" |  | ||||||
|    internal="pio_7.external_connection" |  | ||||||
|    type="conduit" |  | ||||||
|    dir="end" /> |  | ||||||
|  <interface |  | ||||||
|    name="pio_8_pcnt_vhz_in" |  | ||||||
|    internal="pio_8.external_connection" |  | ||||||
|    type="conduit" |  | ||||||
|    dir="end" /> |  | ||||||
|  <interface |  <interface | ||||||
|    name="pulpino_0_config" |    name="pulpino_0_config" | ||||||
|    internal="pulpino_0.config" |    internal="pulpino_0.config" | ||||||
|    type="conduit" |    type="conduit" | ||||||
|    dir="end" /> |    dir="end" /> | ||||||
|  <interface name="reset" internal="clk_27.clk_in_reset" type="reset" dir="end" /> |  <interface name="reset" internal="clk_27.clk_in_reset" type="reset" dir="end" /> | ||||||
|  |  <interface | ||||||
|  |    name="sc_config_0_sc_if" | ||||||
|  |    internal="sc_config_0.sc_if" | ||||||
|  |    type="conduit" | ||||||
|  |    dir="end" /> | ||||||
|  <module name="clk_27" kind="clock_source" version="17.1" enabled="1"> |  <module name="clk_27" kind="clock_source" version="17.1" enabled="1"> | ||||||
|   <parameter name="clockFrequency" value="27000000" /> |   <parameter name="clockFrequency" value="27000000" /> | ||||||
|   <parameter name="clockFrequencyKnown" value="true" /> |   <parameter name="clockFrequencyKnown" value="true" /> | ||||||
| @ -618,104 +462,6 @@ | |||||||
|   <parameter name="simDrivenValue" value="0" /> |   <parameter name="simDrivenValue" value="0" /> | ||||||
|   <parameter name="width" value="32" /> |   <parameter name="width" value="32" /> | ||||||
|  </module> |  </module> | ||||||
|  <module name="pio_2" kind="altera_avalon_pio" version="17.1" enabled="1"> |  | ||||||
|   <parameter name="bitClearingEdgeCapReg" value="false" /> |  | ||||||
|   <parameter name="bitModifyingOutReg" value="false" /> |  | ||||||
|   <parameter name="captureEdge" value="false" /> |  | ||||||
|   <parameter name="clockRate" value="27000000" /> |  | ||||||
|   <parameter name="direction" value="Input" /> |  | ||||||
|   <parameter name="edgeType" value="RISING" /> |  | ||||||
|   <parameter name="generateIRQ" value="false" /> |  | ||||||
|   <parameter name="irqType" value="LEVEL" /> |  | ||||||
|   <parameter name="resetValue" value="0" /> |  | ||||||
|   <parameter name="simDoTestBenchWiring" value="false" /> |  | ||||||
|   <parameter name="simDrivenValue" value="0" /> |  | ||||||
|   <parameter name="width" value="32" /> |  | ||||||
|  </module> |  | ||||||
|  <module name="pio_3" kind="altera_avalon_pio" version="17.1" enabled="1"> |  | ||||||
|   <parameter name="bitClearingEdgeCapReg" value="false" /> |  | ||||||
|   <parameter name="bitModifyingOutReg" value="false" /> |  | ||||||
|   <parameter name="captureEdge" value="false" /> |  | ||||||
|   <parameter name="clockRate" value="27000000" /> |  | ||||||
|   <parameter name="direction" value="Output" /> |  | ||||||
|   <parameter name="edgeType" value="RISING" /> |  | ||||||
|   <parameter name="generateIRQ" value="false" /> |  | ||||||
|   <parameter name="irqType" value="LEVEL" /> |  | ||||||
|   <parameter name="resetValue" value="0" /> |  | ||||||
|   <parameter name="simDoTestBenchWiring" value="false" /> |  | ||||||
|   <parameter name="simDrivenValue" value="0" /> |  | ||||||
|   <parameter name="width" value="32" /> |  | ||||||
|  </module> |  | ||||||
|  <module name="pio_4" kind="altera_avalon_pio" version="17.1" enabled="1"> |  | ||||||
|   <parameter name="bitClearingEdgeCapReg" value="false" /> |  | ||||||
|   <parameter name="bitModifyingOutReg" value="false" /> |  | ||||||
|   <parameter name="captureEdge" value="false" /> |  | ||||||
|   <parameter name="clockRate" value="27000000" /> |  | ||||||
|   <parameter name="direction" value="Output" /> |  | ||||||
|   <parameter name="edgeType" value="RISING" /> |  | ||||||
|   <parameter name="generateIRQ" value="false" /> |  | ||||||
|   <parameter name="irqType" value="LEVEL" /> |  | ||||||
|   <parameter name="resetValue" value="0" /> |  | ||||||
|   <parameter name="simDoTestBenchWiring" value="false" /> |  | ||||||
|   <parameter name="simDrivenValue" value="0" /> |  | ||||||
|   <parameter name="width" value="32" /> |  | ||||||
|  </module> |  | ||||||
|  <module name="pio_5" kind="altera_avalon_pio" version="17.1" enabled="1"> |  | ||||||
|   <parameter name="bitClearingEdgeCapReg" value="false" /> |  | ||||||
|   <parameter name="bitModifyingOutReg" value="false" /> |  | ||||||
|   <parameter name="captureEdge" value="false" /> |  | ||||||
|   <parameter name="clockRate" value="27000000" /> |  | ||||||
|   <parameter name="direction" value="Output" /> |  | ||||||
|   <parameter name="edgeType" value="RISING" /> |  | ||||||
|   <parameter name="generateIRQ" value="false" /> |  | ||||||
|   <parameter name="irqType" value="LEVEL" /> |  | ||||||
|   <parameter name="resetValue" value="0" /> |  | ||||||
|   <parameter name="simDoTestBenchWiring" value="false" /> |  | ||||||
|   <parameter name="simDrivenValue" value="0" /> |  | ||||||
|   <parameter name="width" value="32" /> |  | ||||||
|  </module> |  | ||||||
|  <module name="pio_6" kind="altera_avalon_pio" version="17.1" enabled="1"> |  | ||||||
|   <parameter name="bitClearingEdgeCapReg" value="false" /> |  | ||||||
|   <parameter name="bitModifyingOutReg" value="false" /> |  | ||||||
|   <parameter name="captureEdge" value="false" /> |  | ||||||
|   <parameter name="clockRate" value="27000000" /> |  | ||||||
|   <parameter name="direction" value="Output" /> |  | ||||||
|   <parameter name="edgeType" value="RISING" /> |  | ||||||
|   <parameter name="generateIRQ" value="false" /> |  | ||||||
|   <parameter name="irqType" value="LEVEL" /> |  | ||||||
|   <parameter name="resetValue" value="0" /> |  | ||||||
|   <parameter name="simDoTestBenchWiring" value="false" /> |  | ||||||
|   <parameter name="simDrivenValue" value="0" /> |  | ||||||
|   <parameter name="width" value="32" /> |  | ||||||
|  </module> |  | ||||||
|  <module name="pio_7" kind="altera_avalon_pio" version="17.1" enabled="1"> |  | ||||||
|   <parameter name="bitClearingEdgeCapReg" value="false" /> |  | ||||||
|   <parameter name="bitModifyingOutReg" value="false" /> |  | ||||||
|   <parameter name="captureEdge" value="false" /> |  | ||||||
|   <parameter name="clockRate" value="27000000" /> |  | ||||||
|   <parameter name="direction" value="Input" /> |  | ||||||
|   <parameter name="edgeType" value="RISING" /> |  | ||||||
|   <parameter name="generateIRQ" value="false" /> |  | ||||||
|   <parameter name="irqType" value="LEVEL" /> |  | ||||||
|   <parameter name="resetValue" value="0" /> |  | ||||||
|   <parameter name="simDoTestBenchWiring" value="false" /> |  | ||||||
|   <parameter name="simDrivenValue" value="0" /> |  | ||||||
|   <parameter name="width" value="32" /> |  | ||||||
|  </module> |  | ||||||
|  <module name="pio_8" kind="altera_avalon_pio" version="17.1" enabled="1"> |  | ||||||
|   <parameter name="bitClearingEdgeCapReg" value="false" /> |  | ||||||
|   <parameter name="bitModifyingOutReg" value="false" /> |  | ||||||
|   <parameter name="captureEdge" value="false" /> |  | ||||||
|   <parameter name="clockRate" value="27000000" /> |  | ||||||
|   <parameter name="direction" value="Input" /> |  | ||||||
|   <parameter name="edgeType" value="RISING" /> |  | ||||||
|   <parameter name="generateIRQ" value="false" /> |  | ||||||
|   <parameter name="irqType" value="LEVEL" /> |  | ||||||
|   <parameter name="resetValue" value="0" /> |  | ||||||
|   <parameter name="simDoTestBenchWiring" value="false" /> |  | ||||||
|   <parameter name="simDrivenValue" value="0" /> |  | ||||||
|   <parameter name="width" value="32" /> |  | ||||||
|  </module> |  | ||||||
|  <module name="pulpino_0" kind="pulpino" version="1.0" enabled="1"> |  <module name="pulpino_0" kind="pulpino" version="1.0" enabled="1"> | ||||||
|   <parameter name="AUTO_INTERRUPT_RECEIVER_INTERRUPTS_USED" value="31" /> |   <parameter name="AUTO_INTERRUPT_RECEIVER_INTERRUPTS_USED" value="31" /> | ||||||
|   <parameter name="AXI_ADDR_WIDTH" value="32" /> |   <parameter name="AXI_ADDR_WIDTH" value="32" /> | ||||||
| @ -728,6 +474,7 @@ | |||||||
|   <parameter name="ZERO_RV32E" value="true" /> |   <parameter name="ZERO_RV32E" value="true" /> | ||||||
|   <parameter name="ZERO_RV32M" value="true" /> |   <parameter name="ZERO_RV32M" value="true" /> | ||||||
|  </module> |  </module> | ||||||
|  |  <module name="sc_config_0" kind="sc_config" version="1.0" enabled="1" /> | ||||||
|  <module name="timer_0" kind="altera_avalon_timer" version="17.1" enabled="1"> |  <module name="timer_0" kind="altera_avalon_timer" version="17.1" enabled="1"> | ||||||
|   <parameter name="alwaysRun" value="false" /> |   <parameter name="alwaysRun" value="false" /> | ||||||
|   <parameter name="counterSize" value="32" /> |   <parameter name="counterSize" value="32" /> | ||||||
| @ -758,6 +505,15 @@ | |||||||
|   <parameter name="baseAddress" value="0x00020020" /> |   <parameter name="baseAddress" value="0x00020020" /> | ||||||
|   <parameter name="defaultConnection" value="false" /> |   <parameter name="defaultConnection" value="false" /> | ||||||
|  </connection> |  </connection> | ||||||
|  |  <connection | ||||||
|  |    kind="avalon" | ||||||
|  |    version="17.1" | ||||||
|  |    start="pulpino_0.avalon_master_lsu" | ||||||
|  |    end="sc_config_0.avalon_s"> | ||||||
|  |   <parameter name="arbitrationPriority" value="1" /> | ||||||
|  |   <parameter name="baseAddress" value="0x00022000" /> | ||||||
|  |   <parameter name="defaultConnection" value="false" /> | ||||||
|  |  </connection> | ||||||
|  <connection |  <connection | ||||||
|    kind="avalon" |    kind="avalon" | ||||||
|    version="17.1" |    version="17.1" | ||||||
| @ -830,69 +586,6 @@ | |||||||
|   <parameter name="baseAddress" value="0x000210d0" /> |   <parameter name="baseAddress" value="0x000210d0" /> | ||||||
|   <parameter name="defaultConnection" value="false" /> |   <parameter name="defaultConnection" value="false" /> | ||||||
|  </connection> |  </connection> | ||||||
|  <connection |  | ||||||
|    kind="avalon" |  | ||||||
|    version="17.1" |  | ||||||
|    start="pulpino_0.avalon_master_lsu" |  | ||||||
|    end="pio_2.s1"> |  | ||||||
|   <parameter name="arbitrationPriority" value="1" /> |  | ||||||
|   <parameter name="baseAddress" value="0x000210c0" /> |  | ||||||
|   <parameter name="defaultConnection" value="false" /> |  | ||||||
|  </connection> |  | ||||||
|  <connection |  | ||||||
|    kind="avalon" |  | ||||||
|    version="17.1" |  | ||||||
|    start="pulpino_0.avalon_master_lsu" |  | ||||||
|    end="pio_3.s1"> |  | ||||||
|   <parameter name="arbitrationPriority" value="1" /> |  | ||||||
|   <parameter name="baseAddress" value="0x000210b0" /> |  | ||||||
|   <parameter name="defaultConnection" value="false" /> |  | ||||||
|  </connection> |  | ||||||
|  <connection |  | ||||||
|    kind="avalon" |  | ||||||
|    version="17.1" |  | ||||||
|    start="pulpino_0.avalon_master_lsu" |  | ||||||
|    end="pio_4.s1"> |  | ||||||
|   <parameter name="arbitrationPriority" value="1" /> |  | ||||||
|   <parameter name="baseAddress" value="0x000210a0" /> |  | ||||||
|   <parameter name="defaultConnection" value="false" /> |  | ||||||
|  </connection> |  | ||||||
|  <connection |  | ||||||
|    kind="avalon" |  | ||||||
|    version="17.1" |  | ||||||
|    start="pulpino_0.avalon_master_lsu" |  | ||||||
|    end="pio_5.s1"> |  | ||||||
|   <parameter name="arbitrationPriority" value="1" /> |  | ||||||
|   <parameter name="baseAddress" value="0x00021090" /> |  | ||||||
|   <parameter name="defaultConnection" value="false" /> |  | ||||||
|  </connection> |  | ||||||
|  <connection |  | ||||||
|    kind="avalon" |  | ||||||
|    version="17.1" |  | ||||||
|    start="pulpino_0.avalon_master_lsu" |  | ||||||
|    end="pio_6.s1"> |  | ||||||
|   <parameter name="arbitrationPriority" value="1" /> |  | ||||||
|   <parameter name="baseAddress" value="0x00021080" /> |  | ||||||
|   <parameter name="defaultConnection" value="false" /> |  | ||||||
|  </connection> |  | ||||||
|  <connection |  | ||||||
|    kind="avalon" |  | ||||||
|    version="17.1" |  | ||||||
|    start="pulpino_0.avalon_master_lsu" |  | ||||||
|    end="pio_7.s1"> |  | ||||||
|   <parameter name="arbitrationPriority" value="1" /> |  | ||||||
|   <parameter name="baseAddress" value="0x00021070" /> |  | ||||||
|   <parameter name="defaultConnection" value="false" /> |  | ||||||
|  </connection> |  | ||||||
|  <connection |  | ||||||
|    kind="avalon" |  | ||||||
|    version="17.1" |  | ||||||
|    start="pulpino_0.avalon_master_lsu" |  | ||||||
|    end="pio_8.s1"> |  | ||||||
|   <parameter name="arbitrationPriority" value="1" /> |  | ||||||
|   <parameter name="baseAddress" value="0x00021060" /> |  | ||||||
|   <parameter name="defaultConnection" value="false" /> |  | ||||||
|  </connection> |  | ||||||
|  <connection |  <connection | ||||||
|    kind="avalon" |    kind="avalon" | ||||||
|    version="17.1" |    version="17.1" | ||||||
| @ -923,14 +616,7 @@ | |||||||
|  <connection kind="clock" version="17.1" start="clk_27.clk" end="jtag_uart_0.clk" /> |  <connection kind="clock" version="17.1" start="clk_27.clk" end="jtag_uart_0.clk" /> | ||||||
|  <connection kind="clock" version="17.1" start="clk_27.clk" end="pio_0.clk" /> |  <connection kind="clock" version="17.1" start="clk_27.clk" end="pio_0.clk" /> | ||||||
|  <connection kind="clock" version="17.1" start="clk_27.clk" end="pio_1.clk" /> |  <connection kind="clock" version="17.1" start="clk_27.clk" end="pio_1.clk" /> | ||||||
|  <connection kind="clock" version="17.1" start="clk_27.clk" end="pio_2.clk" /> |  | ||||||
|  <connection kind="clock" version="17.1" start="clk_27.clk" end="pio_3.clk" /> |  | ||||||
|  <connection kind="clock" version="17.1" start="clk_27.clk" end="pio_4.clk" /> |  | ||||||
|  <connection kind="clock" version="17.1" start="clk_27.clk" end="timer_0.clk" /> |  <connection kind="clock" version="17.1" start="clk_27.clk" end="timer_0.clk" /> | ||||||
|  <connection kind="clock" version="17.1" start="clk_27.clk" end="pio_5.clk" /> |  | ||||||
|  <connection kind="clock" version="17.1" start="clk_27.clk" end="pio_6.clk" /> |  | ||||||
|  <connection kind="clock" version="17.1" start="clk_27.clk" end="pio_7.clk" /> |  | ||||||
|  <connection kind="clock" version="17.1" start="clk_27.clk" end="pio_8.clk" /> |  | ||||||
|  <connection kind="clock" version="17.1" start="clk_27.clk" end="master_0.clk" /> |  <connection kind="clock" version="17.1" start="clk_27.clk" end="master_0.clk" /> | ||||||
|  <connection |  <connection | ||||||
|    kind="clock" |    kind="clock" | ||||||
| @ -962,6 +648,11 @@ | |||||||
|    version="17.1" |    version="17.1" | ||||||
|    start="clk_27.clk" |    start="clk_27.clk" | ||||||
|    end="epcq_controller_0.clock_sink" /> |    end="epcq_controller_0.clock_sink" /> | ||||||
|  |  <connection | ||||||
|  |    kind="clock" | ||||||
|  |    version="17.1" | ||||||
|  |    start="clk_27.clk" | ||||||
|  |    end="sc_config_0.clock_sink" /> | ||||||
|  <connection |  <connection | ||||||
|    kind="interrupt" |    kind="interrupt" | ||||||
|    version="17.1" |    version="17.1" | ||||||
| @ -1027,21 +718,6 @@ | |||||||
|    version="17.1" |    version="17.1" | ||||||
|    start="clk_27.clk_reset" |    start="clk_27.clk_reset" | ||||||
|    end="pio_1.reset" /> |    end="pio_1.reset" /> | ||||||
|  <connection |  | ||||||
|    kind="reset" |  | ||||||
|    version="17.1" |  | ||||||
|    start="clk_27.clk_reset" |  | ||||||
|    end="pio_2.reset" /> |  | ||||||
|  <connection |  | ||||||
|    kind="reset" |  | ||||||
|    version="17.1" |  | ||||||
|    start="clk_27.clk_reset" |  | ||||||
|    end="pio_3.reset" /> |  | ||||||
|  <connection |  | ||||||
|    kind="reset" |  | ||||||
|    version="17.1" |  | ||||||
|    start="clk_27.clk_reset" |  | ||||||
|    end="pio_4.reset" /> |  | ||||||
|  <connection |  <connection | ||||||
|    kind="reset" |    kind="reset" | ||||||
|    version="17.1" |    version="17.1" | ||||||
| @ -1052,26 +728,6 @@ | |||||||
|    version="17.1" |    version="17.1" | ||||||
|    start="clk_27.clk_reset" |    start="clk_27.clk_reset" | ||||||
|    end="timer_0.reset" /> |    end="timer_0.reset" /> | ||||||
|  <connection |  | ||||||
|    kind="reset" |  | ||||||
|    version="17.1" |  | ||||||
|    start="clk_27.clk_reset" |  | ||||||
|    end="pio_5.reset" /> |  | ||||||
|  <connection |  | ||||||
|    kind="reset" |  | ||||||
|    version="17.1" |  | ||||||
|    start="clk_27.clk_reset" |  | ||||||
|    end="pio_6.reset" /> |  | ||||||
|  <connection |  | ||||||
|    kind="reset" |  | ||||||
|    version="17.1" |  | ||||||
|    start="clk_27.clk_reset" |  | ||||||
|    end="pio_7.reset" /> |  | ||||||
|  <connection |  | ||||||
|    kind="reset" |  | ||||||
|    version="17.1" |  | ||||||
|    start="clk_27.clk_reset" |  | ||||||
|    end="pio_8.reset" /> |  | ||||||
|  <connection |  <connection | ||||||
|    kind="reset" |    kind="reset" | ||||||
|    version="17.1" |    version="17.1" | ||||||
| @ -1087,6 +743,11 @@ | |||||||
|    version="17.1" |    version="17.1" | ||||||
|    start="clk_27.clk_reset" |    start="clk_27.clk_reset" | ||||||
|    end="hw_crc32_0.reset_sink" /> |    end="hw_crc32_0.reset_sink" /> | ||||||
|  |  <connection | ||||||
|  |    kind="reset" | ||||||
|  |    version="17.1" | ||||||
|  |    start="clk_27.clk_reset" | ||||||
|  |    end="sc_config_0.reset_sink" /> | ||||||
|  <interconnectRequirement for="$system" name="qsys_mm.clockCrossingAdapter" value="HANDSHAKE" /> |  <interconnectRequirement for="$system" name="qsys_mm.clockCrossingAdapter" value="HANDSHAKE" /> | ||||||
|  <interconnectRequirement for="$system" name="qsys_mm.insertDefaultSlave" value="false" /> |  <interconnectRequirement for="$system" name="qsys_mm.insertDefaultSlave" value="false" /> | ||||||
|  <interconnectRequirement for="$system" name="qsys_mm.maxAdditionalLatency" value="1" /> |  <interconnectRequirement for="$system" name="qsys_mm.maxAdditionalLatency" value="1" /> | ||||||
|  | |||||||
							
								
								
									
										6930
									
								
								sys.sopcinfo
									
									
									
									
									
								
							
							
						
						
									
										6930
									
								
								sys.sopcinfo
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
		Loading…
	
		Reference in New Issue
	
	Block a user
	 marqs
						marqs