diff options
| -rw-r--r-- | sound/sound.srcs/sources_1/ip/BertErnie44Audio/BertErnie44Audio.xci | 52 | ||||
| -rw-r--r-- | sound/sound.xpr | 23 | ||||
| -rw-r--r-- | src/AudioOut.vhd | 2 | ||||
| -rw-r--r-- | src/PlayAudio.vhd | 10 | ||||
| -rw-r--r-- | src/SampleOut.vhd | 4 | ||||
| -rwxr-xr-x | src/wav2coe | 2 | 
6 files changed, 43 insertions, 50 deletions
| diff --git a/sound/sound.srcs/sources_1/ip/BertErnie44Audio/BertErnie44Audio.xci b/sound/sound.srcs/sources_1/ip/BertErnie44Audio/BertErnie44Audio.xci index 1f464b9..04a828f 100644 --- a/sound/sound.srcs/sources_1/ip/BertErnie44Audio/BertErnie44Audio.xci +++ b/sound/sound.srcs/sources_1/ip/BertErnie44Audio/BertErnie44Audio.xci @@ -13,8 +13,8 @@          "AXI_Slave_Type": [ { "value": "Memory_Slave", "resolve_type": "user", "usage": "all" } ],          "Use_AXI_ID": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],          "AXI_ID_Width": [ { "value": "4", "resolve_type": "user", "format": "long", "enabled": false, "usage": "all" } ], -        "Memory_Type": [ { "value": "Single_Port_RAM", "resolve_type": "user", "usage": "all" } ], -        "PRIM_type_to_Implement": [ { "value": "BRAM", "resolve_type": "user", "usage": "all" } ], +        "Memory_Type": [ { "value": "Single_Port_ROM", "value_src": "user", "resolve_type": "user", "usage": "all" } ], +        "PRIM_type_to_Implement": [ { "value": "BRAM", "resolve_type": "user", "enabled": false, "usage": "all" } ],          "Enable_32bit_Address": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],          "ecctype": [ { "value": "No_ECC", "resolve_type": "user", "enabled": false, "usage": "all" } ],          "ECC": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ], @@ -27,15 +27,15 @@          "RD_ADDR_CHNG_B": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],          "Use_Error_Injection_Pins": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],          "Error_Injection_Type": [ { "value": "Single_Bit_Error_Injection", "resolve_type": "user", "enabled": false, "usage": "all" } ], -        "Use_Byte_Write_Enable": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ], +        "Use_Byte_Write_Enable": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],          "Byte_Size": [ { "value": "9", "resolve_type": "user", "enabled": false, "usage": "all" } ],          "Algorithm": [ { "value": "Minimum_Area", "resolve_type": "user", "usage": "all" } ],          "Primitive": [ { "value": "8kx2", "resolve_type": "user", "enabled": false, "usage": "all" } ],          "Assume_Synchronous_Clk": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],          "Write_Width_A": [ { "value": "8", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ], -        "Write_Depth_A": [ { "value": "65536", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ], -        "Read_Width_A": [ { "value": "8", "resolve_type": "user", "usage": "all" } ], -        "Operating_Mode_A": [ { "value": "WRITE_FIRST", "resolve_type": "user", "usage": "all" } ], +        "Write_Depth_A": [ { "value": "200000", "value_src": "user", "resolve_type": "user", "format": "long", "usage": "all" } ], +        "Read_Width_A": [ { "value": "8", "resolve_type": "user", "enabled": false, "usage": "all" } ], +        "Operating_Mode_A": [ { "value": "WRITE_FIRST", "resolve_type": "user", "enabled": false, "usage": "all" } ],          "Enable_A": [ { "value": "Always_Enabled", "value_src": "user", "resolve_type": "user", "usage": "all" } ],          "Write_Width_B": [ { "value": "8", "resolve_type": "user", "enabled": false, "usage": "all" } ],          "Read_Width_B": [ { "value": "8", "resolve_type": "user", "enabled": false, "usage": "all" } ], @@ -51,9 +51,9 @@          "register_portb_output_of_softecc": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],          "Pipeline_Stages": [ { "value": "0", "resolve_type": "user", "enabled": false, "usage": "all" } ],          "Load_Init_File": [ { "value": "true", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ], -        "Coe_File": [ { "value": "../../../../../copyright/bijlagen/berternie44k.coe", "value_src": "user", "resolve_type": "user", "usage": "all" } ], -        "Fill_Remaining_Memory_Locations": [ { "value": "true", "value_src": "user", "resolve_type": "user", "format": "bool", "usage": "all" } ], -        "Remaining_Memory_Locations": [ { "value": "80", "value_src": "user", "resolve_type": "user", "usage": "all" } ], +        "Coe_File": [ { "value": "../../../../../copyright/rick.coe", "value_src": "user", "resolve_type": "user", "usage": "all" } ], +        "Fill_Remaining_Memory_Locations": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ], +        "Remaining_Memory_Locations": [ { "value": "0", "resolve_type": "user", "enabled": false, "usage": "all" } ],          "Use_RSTA_Pin": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],          "Reset_Memory_Latch_A": [ { "value": "false", "resolve_type": "user", "format": "bool", "enabled": false, "usage": "all" } ],          "Reset_Priority_A": [ { "value": "CE", "resolve_type": "user", "enabled": false, "usage": "all" } ], @@ -65,12 +65,12 @@          "Reset_Type": [ { "value": "SYNC", "resolve_type": "user", "enabled": false, "usage": "all" } ],          "Additional_Inputs_for_Power_Estimation": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],          "Port_A_Clock": [ { "value": "100", "resolve_type": "user", "format": "long", "usage": "all" } ], -        "Port_A_Write_Rate": [ { "value": "50", "resolve_type": "user", "format": "long", "usage": "all" } ], +        "Port_A_Write_Rate": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "all" } ],          "Port_B_Clock": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "all" } ],          "Port_B_Write_Rate": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "all" } ],          "Port_A_Enable_Rate": [ { "value": "100", "resolve_type": "user", "format": "long", "usage": "all" } ],          "Port_B_Enable_Rate": [ { "value": "0", "resolve_type": "user", "format": "long", "usage": "all" } ], -        "Collision_Warnings": [ { "value": "ALL", "resolve_type": "user", "usage": "all" } ], +        "Collision_Warnings": [ { "value": "ALL", "resolve_type": "user", "enabled": false, "usage": "all" } ],          "Disable_Collision_Warnings": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],          "Disable_Out_of_Range_Warnings": [ { "value": "false", "resolve_type": "user", "format": "bool", "usage": "all" } ],          "use_bram_block": [ { "value": "Stand_Alone", "resolve_type": "user", "usage": "all" } ], @@ -92,15 +92,15 @@          "C_CTRL_ECC_ALGO": [ { "value": "NONE", "resolve_type": "generated", "usage": "all" } ],          "C_HAS_AXI_ID": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_AXI_ID_WIDTH": [ { "value": "4", "resolve_type": "generated", "format": "long", "usage": "all" } ], -        "C_MEM_TYPE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ], +        "C_MEM_TYPE": [ { "value": "3", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_BYTE_SIZE": [ { "value": "9", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_ALGORITHM": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_PRIM_TYPE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_LOAD_INIT_FILE": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_INIT_FILE_NAME": [ { "value": "BertErnie44Audio.mif", "resolve_type": "generated", "usage": "all" } ],          "C_INIT_FILE": [ { "value": "BertErnie44Audio.mem", "resolve_type": "generated", "usage": "all" } ], -        "C_USE_DEFAULT_DATA": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ], -        "C_DEFAULT_DATA": [ { "value": "80", "resolve_type": "generated", "usage": "all" } ], +        "C_USE_DEFAULT_DATA": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ], +        "C_DEFAULT_DATA": [ { "value": "0", "resolve_type": "generated", "usage": "all" } ],          "C_HAS_RSTA": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_RST_PRIORITY_A": [ { "value": "CE", "resolve_type": "generated", "usage": "all" } ],          "C_RSTRAM_A": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ], @@ -112,9 +112,9 @@          "C_WRITE_MODE_A": [ { "value": "WRITE_FIRST", "resolve_type": "generated", "usage": "all" } ],          "C_WRITE_WIDTH_A": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_READ_WIDTH_A": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ], -        "C_WRITE_DEPTH_A": [ { "value": "65536", "resolve_type": "generated", "format": "long", "usage": "all" } ], -        "C_READ_DEPTH_A": [ { "value": "65536", "resolve_type": "generated", "format": "long", "usage": "all" } ], -        "C_ADDRA_WIDTH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ], +        "C_WRITE_DEPTH_A": [ { "value": "200000", "resolve_type": "generated", "format": "long", "usage": "all" } ], +        "C_READ_DEPTH_A": [ { "value": "200000", "resolve_type": "generated", "format": "long", "usage": "all" } ], +        "C_ADDRA_WIDTH": [ { "value": "18", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_HAS_RSTB": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_RST_PRIORITY_B": [ { "value": "CE", "resolve_type": "generated", "usage": "all" } ],          "C_RSTRAM_B": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ], @@ -126,9 +126,9 @@          "C_WRITE_MODE_B": [ { "value": "WRITE_FIRST", "resolve_type": "generated", "usage": "all" } ],          "C_WRITE_WIDTH_B": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_READ_WIDTH_B": [ { "value": "8", "resolve_type": "generated", "format": "long", "usage": "all" } ], -        "C_WRITE_DEPTH_B": [ { "value": "65536", "resolve_type": "generated", "format": "long", "usage": "all" } ], -        "C_READ_DEPTH_B": [ { "value": "65536", "resolve_type": "generated", "format": "long", "usage": "all" } ], -        "C_ADDRB_WIDTH": [ { "value": "16", "resolve_type": "generated", "format": "long", "usage": "all" } ], +        "C_WRITE_DEPTH_B": [ { "value": "200000", "resolve_type": "generated", "format": "long", "usage": "all" } ], +        "C_READ_DEPTH_B": [ { "value": "200000", "resolve_type": "generated", "format": "long", "usage": "all" } ], +        "C_ADDRB_WIDTH": [ { "value": "18", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_HAS_MEM_OUTPUT_REGS_A": [ { "value": "1", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_HAS_MEM_OUTPUT_REGS_B": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_HAS_MUX_OUTPUT_REGS_A": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ], @@ -153,9 +153,9 @@          "C_EN_SHUTDOWN_PIN": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_EN_SAFETY_CKT": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ],          "C_DISABLE_WARN_BHV_RANGE": [ { "value": "0", "resolve_type": "generated", "format": "long", "usage": "all" } ], -        "C_COUNT_36K_BRAM": [ { "value": "16", "resolve_type": "generated", "usage": "all" } ], +        "C_COUNT_36K_BRAM": [ { "value": "49", "resolve_type": "generated", "usage": "all" } ],          "C_COUNT_18K_BRAM": [ { "value": "0", "resolve_type": "generated", "usage": "all" } ], -        "C_EST_POWER_SUMMARY": [ { "value": "Estimated Power for IP     :     18.569202 mW", "resolve_type": "generated", "usage": "all" } ] +        "C_EST_POWER_SUMMARY": [ { "value": "Estimated Power for IP     :     2.3264 mW", "resolve_type": "generated", "usage": "all" } ]        },        "project_parameters": {          "ARCHITECTURE": [ { "value": "artix7" } ], @@ -186,9 +186,7 @@      "boundary": {        "ports": {          "clka": [ { "direction": "in", "driver_value": "0" } ], -        "wea": [ { "direction": "in", "size_left": "0", "size_right": "0", "driver_value": "0" } ], -        "addra": [ { "direction": "in", "size_left": "15", "size_right": "0", "driver_value": "0" } ], -        "dina": [ { "direction": "in", "size_left": "7", "size_right": "0", "driver_value": "0" } ], +        "addra": [ { "direction": "in", "size_left": "17", "size_right": "0", "driver_value": "0" } ],          "douta": [ { "direction": "out", "size_left": "7", "size_right": "0" } ]        },        "interfaces": { @@ -231,9 +229,7 @@            "port_maps": {              "ADDR": [ { "physical_name": "addra" } ],              "CLK": [ { "physical_name": "clka" } ], -            "DIN": [ { "physical_name": "dina" } ], -            "DOUT": [ { "physical_name": "douta" } ], -            "WE": [ { "physical_name": "wea" } ] +            "DOUT": [ { "physical_name": "douta" } ]            }          }        }, diff --git a/sound/sound.xpr b/sound/sound.xpr index f02c84f..94fb553 100644 --- a/sound/sound.xpr +++ b/sound/sound.xpr @@ -66,13 +66,13 @@      <Option Name="WTVcsLaunchSim" Val="0"/>      <Option Name="WTRivieraLaunchSim" Val="0"/>      <Option Name="WTActivehdlLaunchSim" Val="0"/> -    <Option Name="WTXSimExportSim" Val="2"/> -    <Option Name="WTModelSimExportSim" Val="2"/> -    <Option Name="WTQuestaExportSim" Val="2"/> +    <Option Name="WTXSimExportSim" Val="3"/> +    <Option Name="WTModelSimExportSim" Val="3"/> +    <Option Name="WTQuestaExportSim" Val="3"/>      <Option Name="WTIesExportSim" Val="0"/> -    <Option Name="WTVcsExportSim" Val="2"/> -    <Option Name="WTRivieraExportSim" Val="2"/> -    <Option Name="WTActivehdlExportSim" Val="2"/> +    <Option Name="WTVcsExportSim" Val="3"/> +    <Option Name="WTRivieraExportSim" Val="3"/> +    <Option Name="WTActivehdlExportSim" Val="3"/>      <Option Name="GenerateIPUpgradeLog" Val="TRUE"/>      <Option Name="XSimRadix" Val="hex"/>      <Option Name="XSimTimeUnit" Val="ns"/> @@ -108,7 +108,7 @@            <Attr Name="UsedIn" Val="simulation"/>          </FileInfo>        </File> -      <File Path="$PPRDIR/../copyright/bijlagen/berternie44k.coe"> +      <File Path="$PPRDIR/../copyright/rick.coe">          <FileInfo>            <Attr Name="UsedIn" Val="synthesis"/>            <Attr Name="UsedIn" Val="simulation"/> @@ -134,6 +134,7 @@        </Config>      </FileSet>      <FileSet Name="sim_1" Type="SimulationSrcs" RelSrcDir="$PSRCDIR/sim_1" RelGenDir="$PGENDIR/sim_1"> +      <Filter Type="Srcs"/>        <Config>          <Option Name="DesignMode" Val="RTL"/>          <Option Name="TopModule" Val="PlayAudio"/> @@ -201,9 +202,7 @@    <Runs Version="1" Minor="19">      <Run Id="synth_1" Type="Ft3:Synth" SrcSet="sources_1" Part="xc7a35tcpg236-1" ConstrsSet="constrs_1" Description="Vivado Synthesis Defaults" AutoIncrementalCheckpoint="true" IncrementalCheckpoint="$PSRCDIR/utils_1/imports/synth_1/PlayAudio.dcp" WriteIncrSynthDcp="false" State="current" Dir="$PRUNDIR/synth_1" IncludeInArchive="true" IsChild="false" AutoIncrementalDir="$PSRCDIR/utils_1/imports/synth_1" AutoRQSDir="$PSRCDIR/utils_1/imports/synth_1">        <Strategy Version="1" Minor="2"> -        <StratHandle Name="Vivado Synthesis Defaults" Flow="Vivado Synthesis 2022"> -          <Desc>Vivado Synthesis Defaults</Desc> -        </StratHandle> +        <StratHandle Name="Vivado Synthesis Defaults" Flow="Vivado Synthesis 2022"/>          <Step Id="synth_design"/>        </Strategy>        <GeneratedRun Dir="$PRUNDIR" File="gen_run.xml"/> @@ -225,9 +224,7 @@      </Run>      <Run Id="impl_1" Type="Ft2:EntireDesign" Part="xc7a35tcpg236-1" ConstrsSet="constrs_1" Description="Default settings for Implementation." AutoIncrementalCheckpoint="false" WriteIncrSynthDcp="false" State="current" Dir="$PRUNDIR/impl_1" SynthRun="synth_1" IncludeInArchive="true" IsChild="false" GenFullBitstream="true" AutoIncrementalDir="$PSRCDIR/utils_1/imports/impl_1" AutoRQSDir="$PSRCDIR/utils_1/imports/impl_1">        <Strategy Version="1" Minor="2"> -        <StratHandle Name="Vivado Implementation Defaults" Flow="Vivado Implementation 2022"> -          <Desc>Default settings for Implementation.</Desc> -        </StratHandle> +        <StratHandle Name="Vivado Implementation Defaults" Flow="Vivado Implementation 2022"/>          <Step Id="init_design"/>          <Step Id="opt_design"/>          <Step Id="power_opt_design"/> diff --git a/src/AudioOut.vhd b/src/AudioOut.vhd index c19a19a..d7a6b37 100644 --- a/src/AudioOut.vhd +++ b/src/AudioOut.vhd @@ -6,7 +6,7 @@ use IEEE.NUMERIC_STD.ALL;  entity AudioOut is      generic(          INPUT_DEPTH: integer := 256; -        INPUT_SAMPLE_SIZE: integer := 36984; +        INPUT_SAMPLE_SIZE: integer := 200000;          INPUT_AUDIO_HZ: integer := 44100;          INPUT_CLK_HZ: integer := 100000000      ); diff --git a/src/PlayAudio.vhd b/src/PlayAudio.vhd index 1af4a12..932f2a3 100644 --- a/src/PlayAudio.vhd +++ b/src/PlayAudio.vhd @@ -13,21 +13,21 @@ architecture Behavioral of PlayAudio is      component SampleOut is          generic(              INPUT_DEPTH: integer := 256; -            INPUT_SAMPLE_SIZE: integer := 36984; +            INPUT_SAMPLE_SIZE: integer := 200000;              INPUT_AUDIO_HZ: integer := 44100;              INPUT_CLK_HZ: integer := 100000000          );          Port ( 	reset, clk : in STD_LOGIC;                  inCOEData : in STD_LOGIC_VECTOR(7 downto 0);  			    outCOEData : out STD_LOGIC_VECTOR(7 downto 0); -                outCOEAddress : out STD_LOGIC_VECTOR(15 downto 0) +                outCOEAddress : out STD_LOGIC_VECTOR(17 downto 0)                  );      end component;      component AudioOut is          generic(              INPUT_DEPTH: integer := 256; -            INPUT_SAMPLE_SIZE: integer := 36984; +            INPUT_SAMPLE_SIZE: integer := 200000;              INPUT_AUDIO_HZ: integer := 44100;              INPUT_CLK_HZ: integer := 100000000          ); @@ -39,13 +39,13 @@ architecture Behavioral of PlayAudio is      component BertErnie44Audio IS          PORT (              clka : IN STD_LOGIC; -            addra : IN STD_LOGIC_VECTOR(15 DOWNTO 0); +            addra : IN STD_LOGIC_VECTOR(17 DOWNTO 0);              douta : OUT STD_LOGIC_VECTOR(7 DOWNTO 0)          );      END component; -signal COEAddress :STD_LOGIC_VECTOR(15 DOWNTO 0); +signal COEAddress :STD_LOGIC_VECTOR(17 DOWNTO 0);  signal COEData :STD_LOGIC_VECTOR(7 DOWNTO 0);  signal MusicLevel:STD_LOGIC_VECTOR(7 DOWNTO 0); diff --git a/src/SampleOut.vhd b/src/SampleOut.vhd index 53e3f1a..63b6159 100644 --- a/src/SampleOut.vhd +++ b/src/SampleOut.vhd @@ -6,14 +6,14 @@ use IEEE.NUMERIC_STD.ALL;  entity SampleOut is      generic(          INPUT_DEPTH: integer := 256; -        INPUT_SAMPLE_SIZE: integer := 36984; +        INPUT_SAMPLE_SIZE: integer := 200000;          INPUT_AUDIO_HZ: integer := 44100;          INPUT_CLK_HZ: integer := 100000000      );      Port ( 	reset, clk : in STD_LOGIC;  			inCOEData : in STD_LOGIC_VECTOR(7 downto 0);  			outCOEData : out STD_LOGIC_VECTOR(7 downto 0); -			outCOEAddress : out STD_LOGIC_VECTOR(15 downto 0) +			outCOEAddress : out STD_LOGIC_VECTOR(17 downto 0)  			);  end SampleOut; diff --git a/src/wav2coe b/src/wav2coe index 22fadf8..764ae61 100755 --- a/src/wav2coe +++ b/src/wav2coe @@ -2,7 +2,7 @@  INFILE="$1"  OUTFILE="$2" -rm "$OUTFILE" +rm -f "$OUTFILE"  echo "memory_initialization_radix=16;" >> "$OUTFILE"  echo "memory_initialization_vector=" >> "$OUTFILE"  ffmpeg -y -hide_banner -loglevel warning -i "$INFILE" -ac 1 -f u8 -acodec pcm_u8 - | cut -c1-200000 | hexdump -ve '16/1 "%02x " "\n"' >> "$OUTFILE" |