KR950033803A - 다중 비트 시프트 장치, 이것을 이용한 데이타 프로세서, 및 다중 비트 시프트 방법 - Google Patents
다중 비트 시프트 장치, 이것을 이용한 데이타 프로세서, 및 다중 비트 시프트 방법 Download PDFInfo
- Publication number
- KR950033803A KR950033803A KR1019950013720A KR19950013720A KR950033803A KR 950033803 A KR950033803 A KR 950033803A KR 1019950013720 A KR1019950013720 A KR 1019950013720A KR 19950013720 A KR19950013720 A KR 19950013720A KR 950033803 A KR950033803 A KR 950033803A
- Authority
- KR
- South Korea
- Prior art keywords
- shift
- signal
- operand
- output
- input
- Prior art date
Links
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F7/00—Methods or arrangements for processing data by operating upon the order or content of the data handled
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F5/00—Methods or arrangements for data conversion without changing the order or content of the data handled
- G06F5/01—Methods or arrangements for data conversion without changing the order or content of the data handled for shifting, e.g. justifying, scaling, normalising
- G06F5/015—Methods or arrangements for data conversion without changing the order or content of the data handled for shifting, e.g. justifying, scaling, normalising having at least two separately controlled shifting levels, e.g. using shifting matrices
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Complex Calculations (AREA)
- Executing Machine-Instructions (AREA)
Abstract
데이타 프로세서(40)의 다중비트 시프트 장치(50)는 정규곱셈 연산에 사용하기위한 수정 부쓰 레코딩된 멀티플라이어(modified Booths recorded multplier)와 같은 멀티플라이어(55)를 포함한다. 상기 다중 비트시프트 장치(50)는 또한 회로 면적을 절약하기 위해 프로그램가능 좌·우 시프트를 실행하는데 상기 멀티플라이어(55)를 사용한다. 시프트 연산동안, 재사상(remapping)회로(54)는 시프트 카운트를 수신하여 재사상된 신호를 제공하도록 시프트 방향에 따라서 상기 시프트 카운트를 재사상한다. 상기 멀티플라이어(55)는 자체 입력에서 시프트 피연산자 및 재사상된 신호 모두를 수신한다. 상기 멀티플라이어(55)는 자체 출력에서 제1시프트 결과를 제공한다. 한 실시예에서, 출력 시프트(57)는 제1시프트 결과를 상기 시프트 방향에 따라 선택적으로 고정량만큼 시프트 하므로써 제2시프트 결과를 제공한다. 상기 제2시프트 결과는 공통 비트 위치에서 좌·우 시프트 모두의 출력을 포함한다.
Description
본 내용은 요부공개 건이므로 전문내용을 수록하지 않았음
제2도는 본 발명에 따른 데이타 프로세서를 포함하는 데이타 처리 시스템을 도시한 도면, 제5도는 본 발명의 제2실시예에 따른 ALU를 블럭도 형태로 도시한 도면.
Claims (4)
- 시프트 및 곱셈 연산을 실행하는 장치(50)로, 제1피연산자 (operand)를 수신하는 제1레지스터(51)와; 제2피연산자를 수신하는 제2레지스터(52)와; 제2레지스터(52)에 연결된 입력, 시프트 방향 신호를 수신하는 제1 제어 입력, 모드 신호를 수신하는 제2제어 입력, 및 출력을 가지며, 곱셈 연산 또는 시프트 연산을 나타내는 상기 모드 신호에 응답하여 상기 출력에 재사상된(remapped) 신호 또는 상기 제2피연산자를 선택적으로 제공하고, 상기 재사상된 신호는 상기 시프트 방향 신호에 의해 결정된 상기 제2피연산자로부터 디코딩되는 재사상 회로(52); 및 상기 제1레지스터(51)에 연결된 제1입력, 상기 재사상 회로(54)의 상기 출력에 연결된 제2입력, 및 상기 제1 및 제2입력의 곱을 제공하는 출력을 가지며, 상기 곱은 상기 곱셈 연산동안 상기 제1 및 제2피연산자의 곱이거나 또는 상기 시프트 연산동안 상기 내사상된 신호와 상기 제1피연산자의 곱에 일치하는 제1시프트 결과인 멀티플라이어(55)를 구비하는 것을 특징으로 하는 시프트/곱셈 연산 실행장치.
- 다중 비트(multibit)시프트 장치를 가진 데이타 프로세서(40)로써, 명령을 인출(fetch)하는 어드레스(46) 및 데이타(45)와; 상기 데이타 경로(45)에 연결되어, 이 데이타 경로를 거쳐 시프트 및 곱셈 명령을 포함한 다수의 명령을 수신하며, 상기 다수의 명령에 응답하여 다수의 제어 신호를 제공하고, 시프트 명령에 응답하여 실행될 시프트 연산 또는 곱셈 명령에 응답하여 실행될 곱셈 연산을 나타내는 모드 신호를 제공하며, 상기 시프트 명령에 응답하여 시프트 방향 신호를 제공하는 명령 디코더(41); 및 상기 명령 디코더(41)에 연결되어, 제1피연산자를 수신하는 제1레지스터(51)와; 제2피연산자를 수신하는 제2레지스터(52)와; 제2레지스터(52)에 연결된 입력, 시프트 방향 신호를 수신하는 제1제어 입력, 상기 모드 신호를 수신하는 제2제어 입력, 및 출력을 가지며, 상기 곱셈 명령 또느 시프트 명령을 각각 나타내는 상ㅊ기 모드 신호에 응답하여 상기 출력에 재사상된 신호 또는 상기 제2피연산자를 선택적으로 제공하고, 상기 재사상된 신호는 상기 시프트 방향 신호에 의해 결정된 상기 제2피연산자로부터 디코딩되는 재사상 회로(52); 및 상기 제1레지스터(51)에 연결된 제1입력, 상기 재사상 회로(54)의 상기 출력에 연결된 제2입력, 및 상기 제1 및 제2입력의 곱을 제공하는 출력을 가지며, 상기 곱은 상기곱셈 연산동안 상기 제1 및 제2피연산자의 곱이거나 또는 상기 시프트 연산동안 제1시프트 결과인 멀티플라이어(55)를 포함한 ALU(50)를 구비하는 것을 특징으로 하는 데이타 프로세서.
- 다중 비트 시프트 방법으로, 제1입력으로 시프트 연산자(shift operand)를 수신하는 단계와; 제2입력으로 시프트 카운트(shift count)를 수신하는 단계와; 시프트 방향 신호로써 결정된 상기 시프트 카운트로 부터 디코딩된 재사상된 신호를 제공하도록 상기 시프트 방향 신호에 의해 결정된 바와 같이 상기 시프트 카운트를 재사상하는 단계와; 상기 시프트 피연산자를 멀티플라이어 회로(55)의 제1입력에 제공하는 단계와; 상기 재사상된 신호를 상기 멀티플라이어 회로(55)의 제2입력에 제공하는 단계; 및 시프트 결과로써 상기 멀티플라이어 회로(55)의 출력을 제공하는 단계를 포함하는 것을 특징으로 하는 다중 비트 시프트 방법.
- 다중 비트 시프트 방법으로, 시프트 피연산자를 수신하는 단계와; 시프트 카운트 n를 수신하는 단계와; 시프트 방향 신호를 수신하는 단계와; 상기 시프트 방향 신호가 제1방향을 나타내는 경우에는 2k-1(이때, k는 상기 시프트 피연산자-1의 비트수를 나타냄)에 일치하는 제1재사상된 신호에 대해 상기 시프트 카운트 n를 재사상하는 단계와; 상기 시프트 카운트 n가 제로에 일치하지 않는 경우에는 2n-1에 일치하는 제2재사상된 신호에 대해서, n이 제로에 일치하는 경우, 즉 상기 시프트 방향 신호가 제2방향을 나타내는 경우에는 제로에 일치하는 제2재사상된 신호에 대해 상기 시프트 카운트 n을 재사상하는 단계와; 상기 시프트 피연산자를 멀티프라이어 회로(55)의 제1입력에 제공하는 단계와; 상기 시프트 방향 신호가 상기 제1방향을 나타내는 경우에는 상기 제1재사상된 신호를, 상기 시프트 방향 신호가 제2방향을 나타내는 경우는 상기 제2재사상된 신호를 상기 멀티프라이어 회로(55)의 제2입력에 제공하는 단계; 및 상기 멀티플라이어 회로(55)의 출력을 제1시프트 결과로써 제공하는 단계를 구비하며, 그에 따라 상기 시프트 피연산자의 시프팅이 전용 시프팅회로 없이도 상기 멀티플라이어 회로(55)를 통한 지연 시간보다 조금 긴 시간량 이내에 발생하게 되는 것을 특징으로 하는 다중 비트 시프트 방법.※ 참고사항 : 최초출원 내용에 의하여 공개하는 것임.
Applications Claiming Priority (3)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US249,505 | 1994-05-26 | ||
US249505 | 1994-05-26 | ||
US08/249,505 US5442576A (en) | 1994-05-26 | 1994-05-26 | Multibit shifting apparatus, data processor using same, and method therefor |
Publications (2)
Publication Number | Publication Date |
---|---|
KR950033803A true KR950033803A (ko) | 1995-12-26 |
KR100365059B1 KR100365059B1 (ko) | 2003-03-06 |
Family
ID=22943742
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
KR1019950013720A KR100365059B1 (ko) | 1994-05-26 | 1995-05-25 | 다중비트시프트장치,이것을이용한데이타프로세서,및다중비트시프트방법 |
Country Status (5)
Country | Link |
---|---|
US (1) | US5442576A (ko) |
EP (1) | EP0685787A1 (ko) |
JP (1) | JP3756967B2 (ko) |
KR (1) | KR100365059B1 (ko) |
CN (1) | CN1145877C (ko) |
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100618247B1 (ko) * | 1997-06-16 | 2006-10-24 | 마츠시타 덴끼 산교 가부시키가이샤 | 코드크기의축소화를지원하는정수복원형프로세서 |
Families Citing this family (37)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US5781457A (en) * | 1994-03-08 | 1998-07-14 | Exponential Technology, Inc. | Merge/mask, rotate/shift, and boolean operations from two instruction sets executed in a vectored mux on a dual-ALU |
US5751614A (en) * | 1994-03-08 | 1998-05-12 | Exponential Technology, Inc. | Sign-extension merge/mask, rotate/shift, and boolean operations executed in a vectored mux on an ALU |
NL9400607A (nl) * | 1994-04-15 | 1995-11-01 | Arcobel Graphics Bv | Dataverwerkingscircuit, vermenigvuldigingseenheid met pijplijn, ALU en schuifregistereenheid ten gebruike bij een dataverwerkingscircuit. |
US5687102A (en) * | 1995-05-26 | 1997-11-11 | National Semiconductor Corp. | Double precision (64 bit) shift operations using a 32 bit data path |
US5978822A (en) * | 1995-12-29 | 1999-11-02 | Atmel Corporation | Circuit for rotating, left shifting, or right shifting bits |
US5844827A (en) * | 1996-10-17 | 1998-12-01 | Samsung Electronics Co., Ltd. | Arithmetic shifter that performs multiply/divide by two to the nth power for positive and negative N |
US6185670B1 (en) * | 1998-10-12 | 2001-02-06 | Intel Corporation | System for reducing number of opcodes required in a processor using an instruction format including operation class code and operation selector code fields |
US6345286B1 (en) * | 1998-10-30 | 2002-02-05 | International Business Machines Corporation | 6-to-3 carry-save adder |
US6336113B1 (en) * | 1998-12-30 | 2002-01-01 | Kawasaki Steel Corporation | Data management method and data management apparatus |
KR100325430B1 (ko) * | 1999-10-11 | 2002-02-25 | 윤종용 | 상이한 워드 길이의 산술연산을 수행하는 데이터 처리장치 및 그 방법 |
US6529924B1 (en) * | 2000-03-27 | 2003-03-04 | International Business Machines Corporation | Method and apparatus for generating shift amount signals for an alignment shifter |
US7315879B2 (en) * | 2001-02-16 | 2008-01-01 | Texas Instruments Incorporated | Multiply-accumulate modules and parallel multipliers and methods of designing multiply-accumulate modules and parallel multipliers |
US6877022B1 (en) * | 2001-02-16 | 2005-04-05 | Texas Instruments Incorporated | Booth encoding circuit for a multiplier of a multiply-accumulate module |
US7181484B2 (en) * | 2001-02-21 | 2007-02-20 | Mips Technologies, Inc. | Extended-precision accumulation of multiplier output |
US7296049B2 (en) * | 2002-03-22 | 2007-11-13 | Intel Corporation | Fast multiplication circuits |
US7441104B2 (en) * | 2002-03-30 | 2008-10-21 | Hewlett-Packard Development Company, L.P. | Parallel subword instructions with distributed results |
EP1387257B1 (en) * | 2002-07-31 | 2017-08-23 | Texas Instruments Inc. | System to dispatch multiple instructions to available hardware resources |
JP2004258141A (ja) * | 2003-02-24 | 2004-09-16 | Fujitsu Ltd | モンゴメリ乗算剰余の多倍長演算のための演算装置 |
US7343388B1 (en) * | 2003-03-05 | 2008-03-11 | Altera Corporation | Implementing crossbars and barrel shifters using multiplier-accumulator blocks |
US7277990B2 (en) | 2004-09-30 | 2007-10-02 | Sanjeev Jain | Method and apparatus providing efficient queue descriptor memory access |
US7555630B2 (en) | 2004-12-21 | 2009-06-30 | Intel Corporation | Method and apparatus to provide efficient communication between multi-threaded processing elements in a processor unit |
US7418543B2 (en) * | 2004-12-21 | 2008-08-26 | Intel Corporation | Processor having content addressable memory with command ordering |
US7467256B2 (en) * | 2004-12-28 | 2008-12-16 | Intel Corporation | Processor having content addressable memory for block-based queue structures |
US7797364B2 (en) * | 2006-06-27 | 2010-09-14 | International Business Machines Corporation | Booth decoder apparatus and method |
US7797365B2 (en) * | 2006-06-27 | 2010-09-14 | International Business Machines Corporation | Design structure for a booth decoder |
US7877430B2 (en) * | 2007-03-26 | 2011-01-25 | Analog Devices, Inc. | Method and apparatus for accelerating processing of adaptive finite impulse response filtering |
US8549055B2 (en) | 2009-03-03 | 2013-10-01 | Altera Corporation | Modular digital signal processing circuitry with optionally usable, dedicated connections between modules of the circuitry |
US8805916B2 (en) * | 2009-03-03 | 2014-08-12 | Altera Corporation | Digital signal processing circuitry with redundancy and bidirectional data paths |
US9612795B2 (en) | 2013-03-14 | 2017-04-04 | Semiconductor Energy Laboratory Co., Ltd. | Data processing device, data processing method, and computer program |
CN106197295B (zh) * | 2016-07-20 | 2017-10-24 | 华中科技大学 | 一种激光测厚仪 |
US10409604B2 (en) | 2017-04-24 | 2019-09-10 | Arm Limited | Apparatus and method for performing multiply-and-accumulate-products operations |
US10409592B2 (en) * | 2017-04-24 | 2019-09-10 | Arm Limited | Multiply-and-accumulate-products instructions |
CN108255463B (zh) * | 2017-12-28 | 2020-12-22 | 深圳市紫光同创电子有限公司 | 一种数字逻辑运算方法、电路和fpga芯片 |
KR102182299B1 (ko) * | 2019-07-24 | 2020-11-24 | 에스케이텔레콤 주식회사 | 시프트 연산 장치 및 그의 동작 방법 |
CN112422979B (zh) * | 2019-08-23 | 2022-12-13 | 瑞昱半导体股份有限公司 | 应用于离散及逆离散正弦余弦变换的运算电路 |
CN111694544B (zh) * | 2020-06-02 | 2022-03-15 | 杭州知存智能科技有限公司 | 多位复用乘加运算装置、神经网络运算系统以及电子设备 |
US11789701B2 (en) | 2020-08-05 | 2023-10-17 | Arm Limited | Controlling carry-save adders in multiplication |
Family Cites Families (13)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
JPS5668833A (en) * | 1979-11-09 | 1981-06-09 | Fujitsu Ltd | Shift process system by multiplier |
US4396994A (en) * | 1980-12-31 | 1983-08-02 | Bell Telephone Laboratories, Incorporated | Data shifting and rotating apparatus |
US4575812A (en) * | 1984-05-31 | 1986-03-11 | Motorola, Inc. | X×Y Bit array multiplier/accumulator circuit |
JPS6152741A (ja) * | 1984-08-22 | 1986-03-15 | Nec Corp | シフト機能付乗算回路 |
JPS6297062A (ja) * | 1985-10-23 | 1987-05-06 | Mitsubishi Electric Corp | デイジタルシグナルプロセツサ |
JPS62127941A (ja) * | 1985-11-29 | 1987-06-10 | Fujitsu Ltd | 乗算装置におけるシフト方式 |
JPH0650462B2 (ja) * | 1986-02-18 | 1994-06-29 | 日本電気株式会社 | シフト数制御回路 |
US4887232A (en) * | 1987-05-15 | 1989-12-12 | Digital Equipment Corporation | Apparatus and method for performing a shift operation in a multiplier array circuit |
US4884232A (en) * | 1987-12-14 | 1989-11-28 | General Dynamics Corp., Pomona Div. | Parallel processing circuits for high speed calculation of the dot product of large dimensional vectors |
US5099445A (en) * | 1989-12-26 | 1992-03-24 | Motorola, Inc. | Variable length shifter for performing multiple shift and select functions |
US5128890A (en) * | 1991-05-06 | 1992-07-07 | Motorola, Inc. | Apparatus for performing multiplications with reduced power and a method therefor |
US5218564A (en) * | 1991-06-07 | 1993-06-08 | National Semiconductor Corporation | Layout efficient 32-bit shifter/register with 16-bit interface |
US5309382A (en) * | 1992-10-01 | 1994-05-03 | Silicon Graphics, Inc. | Binary shifter |
-
1994
- 1994-05-26 US US08/249,505 patent/US5442576A/en not_active Expired - Fee Related
-
1995
- 1995-05-18 EP EP95107582A patent/EP0685787A1/en not_active Withdrawn
- 1995-05-24 CN CNB951065963A patent/CN1145877C/zh not_active Expired - Fee Related
- 1995-05-24 JP JP14835895A patent/JP3756967B2/ja not_active Expired - Fee Related
- 1995-05-25 KR KR1019950013720A patent/KR100365059B1/ko not_active IP Right Cessation
Cited By (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
KR100618247B1 (ko) * | 1997-06-16 | 2006-10-24 | 마츠시타 덴끼 산교 가부시키가이샤 | 코드크기의축소화를지원하는정수복원형프로세서 |
Also Published As
Publication number | Publication date |
---|---|
EP0685787A1 (en) | 1995-12-06 |
KR100365059B1 (ko) | 2003-03-06 |
US5442576A (en) | 1995-08-15 |
CN1120696A (zh) | 1996-04-17 |
JPH07325704A (ja) | 1995-12-12 |
JP3756967B2 (ja) | 2006-03-22 |
CN1145877C (zh) | 2004-04-14 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
KR950033803A (ko) | 다중 비트 시프트 장치, 이것을 이용한 데이타 프로세서, 및 다중 비트 시프트 방법 | |
KR910010301A (ko) | 명령 지정방법 및 실행장치 | |
KR930018378A (ko) | 캐쉬 메모리 시스템의 성능최적화 방법 및 장치 | |
KR830006741A (ko) | 오페란드(被演算函數 : Operand)간 파이프라인 제어를 행하는 데이터 처리장치 | |
JPS6351287B2 (ko) | ||
KR850004680A (ko) | 집적 프로세서 | |
KR970016953A (ko) | Risc형 마이크로 프로세서 및 정보처리 장치 | |
KR950033804A (ko) | 결합 멀티플라이어/시프터 및 이를 위한 방법 | |
KR830006739A (ko) | 데이터 처리장치 | |
US3958221A (en) | Method and apparatus for locating effective operand of an instruction | |
KR890002756A (ko) | 데이타 처리가속기 | |
US4954947A (en) | Instruction processor for processing branch instruction at high speed | |
JP3237858B2 (ja) | 演算装置 | |
KR900006853A (ko) | 마이크로 프로세서 | |
US3997771A (en) | Apparatus and method for performing an arithmetic operation and multibit shift | |
KR860700300A (ko) | 입력 기억 회로 수단 및 그 분배 사용방법 | |
US4812970A (en) | Microprogram control system | |
EP1634163A1 (en) | Result partitioning within simd data processing systems | |
KR920002573B1 (ko) | 데이타 처리기 | |
KR970705075A (ko) | x86 명령어 세트와 x86 세그먼트 어드레싱을 지원하기 위한 실행 장치 아키텍처(Execution Unit Architecture to Support x86 Instruction Set and x86 Segmented Addressing) | |
JPS6265133A (ja) | 命令先取り装置 | |
JP2557629B2 (ja) | 割込方式 | |
KR860009421A (ko) | 논리기능을 가진 기억회로 | |
KR100471137B1 (ko) | 단축된 레지스터 클리어 인스트럭션 실행 사이클을 갖는 데이터처리 장치 | |
JPH0352092B2 (ko) |
Legal Events
Date | Code | Title | Description |
---|---|---|---|
A201 | Request for examination | ||
E902 | Notification of reason for refusal | ||
E701 | Decision to grant or registration of patent right | ||
GRNT | Written decision to grant | ||
FPAY | Annual fee payment |
Payment date: 20121123 Year of fee payment: 11 |
|
FPAY | Annual fee payment |
Payment date: 20131122 Year of fee payment: 12 |
|
LAPS | Lapse due to unpaid annual fee |