mirror of
https://github.com/marqs85/ossc.git
synced 2024-11-11 12:09:07 +00:00
9e81fb5922
* Enable overlay pattern customization * Fix non-alternating mode with line4x interlace sources * Add alternate interval option for pre-linedoubled sources
180 lines
6.4 KiB
Systemverilog
180 lines
6.4 KiB
Systemverilog
//
|
|
// 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
|