Sabtu, 23 Oktober 2010

Tulisan FPGA 2

MULTIPLEXER

Multiplexer berfungsi untuk memilih output dari beberapa input berdasarkan input pada kaki selectornya. Multiplexer memiliki rangkaian logika sebagai berikut :



Logika Programmer : 

library ieee;
use ieee.std_logic_1164.all;

entity kepletex is     -- mendefinisikan entity "kepletex"
port(             
a,b,c,d,s1,s2: in bit; -- terdapat 4 port input, 2 selector, dan 1 output
y:out bit);
end kepletex;

architecture mux_arch of kepletex is
begin
proc: process is
begin
if (s1='0' and s2='0') then y <= a;
else if (s1='0' and s2='1') then y <= b;
else if (s1='1' and s2='0') then y <= c;
else if (s1='1' and s2='1') then y <= d;
end if;
end process proc;
end mux_arch;


---------------------------------------------------------------------------------------------------------------------------------------------------------------------


Paket yang terdapat pada Library IEEE dan STD 

LIBRARY ieee;
USE ieee.std_logic_1164.ALL;

PACKAGE my_package IS
CONSTANT ADDER_WIDTH : integer := 5;
CONSTANT RESULT_WIDTH : integer := 6;

SUBTYPE ADDER_VALUE IS integer RANGE 0 TO 2 ** 

ADDER_WIDTH - 1;
SUBTYPE RESULT_VALUE IS integer RANGE 0 TO 2 ** 

RESULT_WIDTH - 1;
END my_package;

LIBRARY ieee;
USE ieee.std_logic_1164.ALL;
USE work.my_package.ALL;

ENTITY addsub IS
PORT
(
a: IN ADDER_VALUE;
b: IN ADDER_VALUE;
addnsub: IN STD_LOGIC;
result: OUT RESULT_VALUE
);
END addsub;

ARCHITECTURE rtl OF addsub IS
BEGIN
PROCESS (a, b, addnsub)
BEGIN
IF (addnsub = ‘1′) THEN
result ELSE
result END IF;
END PROCESS;
END rtl;


---------------------------------------------------------------------------------------------------------------------------------------------------------------------


Paket Library WORK 


LIBRARY IEEE;
USE IEEE.std_logic_1164.all;
USE IEEE.std_logic_arith.all;
USE IEEE.std_lodic_unsigned.all;
LIBRARY lpm;
USE lpm.lpm_components.all;
USE WORK.sigdec1.ALL



Minggu, 17 Oktober 2010

FPGA ( Field Programmable Gate Array )

Field Programmable Gate Array adalah IC digital yang sering digunakan untuk mengimplementasikan rangkaian digital. FPGA merupakan sebuah IC digital yang bersifat Programmable, yang artinya user dapat memakai IC digital secara berulang-ulang untuk menyesuaikan program apa yang akan ingin di download kedalam FPGA. FPGA bersifat Volatile, yang artinya jika listrik mati maka secara otomatis fungsi FPGA akan hilang, Artinya data yang telah kita proses dan kita download akan hilang semuanya. FPGA mempunyai kelebihan diantaranya jenis dan jumlah gerbangnya sangat banyak, kecepatannya sangat tinggi, mudah diprogram berkali-kali. Kekurangan FPGA adalah sifat Programnya masih bersifat Volatile.

FPGA berkembang pada tahun 1980-an dan baru di kembangkan pada tahun 1984 oleh perusahaan Xilinc yang berbasis di San Jose CA. terdapat 5 perusahaan besar yang memproduksikan FPGA diantaranya Xilinx, Altera, Lattice, Actel, Quicklogic.  Hanya 2 perusahaan yang memiliki nama tingkat tinggi yang memproduksikan FPGA yaitu Xilinx dan Altera, perusahaan Xilinx terkenal dengan software miliknya yang bernama ISE WebPack, dan perusahaan Altera terkenal dengan software bernama Quartus II Web Edition. 

Isi dari FPGA pada umunya : 

1. Configure Logic Blocks (CLB), bagian ini yang akan memproses segala bentuk rangkaian logika yang   dibuat oleh user/pemakai. 
2. I/O, sebagai interface antara external pin dari device dan internal user logic
3. Programmable Interconnect, bagian ini menghubungkan antara CLB satu dengan CLB lainnya. 

FPGA terbagi kedalam 2 kondisi yaitu, Kondisi Awal dan Kondisi Pemakai, ketika pertama kali FPGA dihidupkan, maka FPGA masih dalam keadaan awal, masih dalam keadaan kosong belum terprogram software apapun. bila pada kondisi pemakai, maka otomatis di dalam FPGA telah terdapat program. 

3 cara yang biasa digunakan untuk mendownload program ke dalam FPGA yaitu : 
1. Pemakai dapat mendownload langsung program ke dalam FPGA menggunakan kabel yang disambungkan     ke PC. 
2. Pemakai dapat menggunakan microkontroller pada board yang ada
3. Pemakai dapat menggunakan "boot-PROM" pada board yang ada