summaryrefslogtreecommitdiff
path: root/sim/ucsim/s51.src/test/mdu88x.h
blob: 65d41b2b3ede538b7a0445fa942f335cdfa999cb (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
#ifndef MDU88X_HEADER
#define MDU88X_HEADER

#include <stdint.h>

/* unsigned OPs */

extern uint8_t mdu_32udiv16(uint32_t op1, uint16_t op2,
			    uint32_t *res, uint16_t *rem)
  __reentrant;
extern uint8_t mdu_16udiv16(uint16_t op1, uint16_t op2,
			    uint16_t *res, uint16_t *rem)
    __reentrant;
extern uint8_t mdu_16umul16(uint16_t op1, uint16_t op2,
			    uint32_t *res)
    __reentrant;

/* signed OPs */

extern uint8_t mdu_32sdiv16(int32_t op1, int16_t op2,
			    int32_t *res, int16_t *rem)
  __reentrant;
extern uint8_t mdu_16sdiv16(int16_t op1, int16_t op2,
			    int16_t *res, int16_t *rem)
    __reentrant;
extern uint8_t mdu_16smul16(int16_t op1, int16_t op2,
			    int32_t *res)
    __reentrant;

/* normalize */

extern uint8_t mdu_norm(uint32_t op,
			uint32_t *res, uint8_t *nuof_shifts)
    __reentrant;

/* logical shifts */

extern uint8_t mdu_lshift(uint32_t op, uint8_t shifts, uint8_t right,
			  uint32_t *res)
    __reentrant;
extern uint8_t mdu_lshift_left(uint32_t op, uint8_t shifts,
			       uint32_t *res)
    __reentrant;
extern uint8_t mdu_lshift_right(uint32_t op, uint8_t shifts,
				uint32_t *res)
    __reentrant;

/* arithmetic shifts */

extern uint8_t mdu_ashift(int32_t op, int8_t shifts, int8_t right,
			  int32_t *res)
    __reentrant;
extern uint8_t mdu_ashift_left(int32_t op, int8_t shifts,
			       int32_t *res)
    __reentrant;
extern uint8_t mdu_ashift_right(int32_t op, int8_t shifts,
				int32_t *res)
    __reentrant;

#endif