System Software Lab Manual

Download as doc, pdf, or txt
Download as doc, pdf, or txt
You are on page 1of 31

SYSTEM SOFTWARE LAB MANUAL

1. IMPLEMENTATION OF A SYMBOL TABLE

#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#include<string.h>
Struct table
{
char var[10]; int value;
};
struct table tb1[20];
int i,j,n; void create(); void modify();
int search(char variable[],int n); void insert(); void display();
void main()
{ int ch,result=0;
char v[10];
clrscr();
do
{
printf("\n\n1.CREATE\n2.INSERT\n3.MODIFY\n4.SEARCH\n5.DISPLAY\n6.EXIT:\t");
scanf("%d",&ch);
switch(ch)
{
case 1:create(); break;
case 2:insert(); break;
case 3:modify(); break;
case 4:printf("\nEnter the variable to be searched:");
scanf("%s",&v);
result=search(v,n);
if(result==0)
printf("\nThe variable is not present\n");
else
printf("\nThe location of the variable is %d \n The value of %s is
%d.",result,tb1[result].var,tb1[result].value);
break;
case 5:display(); break;
case 6:exit(1);
}
}while(ch!=6);
getch();
}
void create()
{ printf("\nEnter the no. of entries:");
scanf("%d",&n);
printf("\nEnter the variable and the values:-\n");

for(i=1;i<=n;i++)
{ scanf("%s%d",tb1[i].var,&tb1[i].value);
check:
if(tb1[i].var[0]>='0' && tb1[i].var[0]<='9')
{ printf("\nVariable should start with alphabet\nEnter correct name\n");
scanf("%s%d",tb1[i].var,&tb1[i].value);
goto check;
}
check1:
for(j=1;j<i;j++)
{ if(strcmp(tb1[i].var,tb1[j].var)==0)
{ printf("\nThe variable already present. Enter another:");
scanf("%s%d",&tb1[i].var,&tb1[i].value);
goto check1;
}}}
printf("\nThe table after creation is:\n");
display();
}
void insert()
{
if(i>=20)
printf("\nCannot insert.table is full\n");
else
{
n++;
printf("\nEnter the variable and the value:");
scanf("%s%d",&tb1[n].var,&tb1[n].value);
check:
if(tb1[i].var[0]>='0' && tb1[i].var[0]<='9')
{
printf("\nVariable should start with alphabet\nEnter correct name\n");
scanf("%s%d",tb1[i].var,&tb1[i].value);
goto check;
}
check1:
for(j=1;j<n;j++)
{
if(strcmp(tb1[j].var,tb1[i].var)==0)
{
printf("\nThe variable already present. Enter another:");
scanf("%s%d",&tb1[i].var,&tb1[i].value);
goto check1;
}
}
printf("\nThe table after insertion is:");
display();

}
}
void modify()
{
char variable[10];
int result=0;
printf("\nEnter the variable to be modified:");
scanf("%s",&variable);
result=search(variable,n);
if(result==0)
printf("%s not present\n",variable);
else
{
printf("\nThe current value of the variable %s is %d.\nEnter the new variable and its
value",tb1[result].var,tb1[result].value);
scanf("%s%d",tb1[result].var,&tb1[result].value);
check:
if(tb1[i].var[0]>='0' && tb1[i].var[0]<='9')
{
printf("\nVariable should start with alphabet\nEnter correct name\n");
scanf("%s%d",tb1[i].var,&tb1[i].value);
goto check;
}
}
printf("\nThe table after modification is:");
display();
}
int search(char variable[],int n)
{
int flag;
for(i=1;i<=n;i++)
if(strcmp(tb1[i].var,variable)==0)
{
flag=1;
break;
}
if(flag==1)
return i;
else
return 0;
}
void display()
{
printf("\nVariable\tvalue\n");
for(i=1;i<=n;i++)
printf("%s\t\t%d\n",tb1[i].var,tb1[i].value);

Output:
1.CREATE
2.INSERT
3.MODIFY
4.SEARCH
5.DISPLAY
6.EXIT:1
Enter the no. of entries:2
Enter the variable and the values:a 23
c 45
The table after creation is:
Variable value
a 23
c 45
1.CREATE 2.INSERT 3.MODIFY 4.SEARCH 5.DISPLAY 6.EXIT:2
Enter the variable and the value:b 34
The table after insertion is:
Variable value
a 23
c 45
b 34
1.CREATE 2.INSERT 3.MODIFY 4.SEARCH 5.DISPLAY 6.EXIT: 3
Enter the variable to be modified:c
The current value of the variable c is 45.
Enter the new variable and its valuec 44
The table after modification is:
Variable value
a 23
c 44
b 34
1.CREATE 2.INSERT 3.MODIFY 4.SEARCH 5.DISPLAY 6.EXIT: 4
Enter the variable to be searched:a
The location of the variable is 1
The value of a is 23.
1.CREATE 2.INSERT 3.MODIFY 4.SEARCH 5.DISPLAY 6.EXIT: 5
Variable value
a 23
c 44
b 34
1.CREATE 2.INSERT 3.MODIFY 4.SEARCH 5.DISPLAY 6.EXIT: 6

2. IMPLEMENTATION OF PASS ONE OF A TWO PASS

ASSEMBLER
#include<stdio.h>
#include<conio.h>
#include<string.h>
void main()
{
char opcode[10],mnemonic[3],operand[10],label[10],code[10];
int locctr,start,length;
FILE *fp1,*fp2,*fp3,*fp4;
clrscr();
fp1=fopen("input.txt","r");
fp2=fopen("symtbl.txt","w");
fp3=fopen("out.txt","w");
fp4=fopen("optab.txt","r");
fscanf(fp1,"%s%s%s",label,opcode,operand);
if(strcmp(opcode,"START")==0)
{
start=atoi(operand);
locctr=start;
fprintf(fp3,"\t%s\t%s\t%s\n",label,opcode,operand);
fscanf(fp1,"%s%s%s",label,opcode,operand);
}
else
locctr=0;
while(strcmp(opcode,"END")!=0)
{
fprintf(fp3,"%d\t",locctr);
if(strcmp(label,"**")!=0)
fprintf(fp2,"%s\t%d\n",label,locctr);
fscanf(fp4,"%s%s",code,mnemonic);
while(strcmp(code,"END")!=0)
{
if(strcmp(opcode,code)==0)
{
locctr+=3;
break;
}
fscanf(fp4,"%s%s",code,mnemonic);
}
if(strcmp(opcode,"WORD")==0)
locctr+=3;
else if(strcmp(opcode,"RESW")==0)
locctr+=(3*(atoi(operand)));
else if(strcmp(opcode,"RESB")==0)
locctr+=(atoi(operand));

else if(strcmp(opcode,"BYTE")==0)
++locctr;
fprintf(fp3,"%s\t%s\t%s\t\n",label,opcode,operand);
fscanf(fp1,"%s%s%s",label,opcode,operand);
}
fprintf(fp3,"%d\t%s\t%s\t%s\n",locctr,label,opcode,operand);
length=locctr-start;
printf("The length of the program is %d",length);
fclose(fp1);
fclose(fp2);
fclose(fp3);
fclose(fp4);
getch();
}

Output:
INPUT FILES:
input.txt
** START 2000
** LDA FIVE
** STA ALPHA
** LDCH CHARZ
** STCH C1
ALPHA RESW 1
FIVE WORD 5
CHARZ BYTE C'Z'
C1 RESB 1
** END **
optab.txt
START *
LDA 03
STA 0f
LDCH 53
STCH 57
END *
OUTPUT FILES:
The length of the program is 20
symtab.txt
ALPHA 2012
FIVE 2015
CHARZ 2018
C1 2019
ouput.txt
** START 2000
2000 ** LDA FIVE
2003 ** STA ALPHA

2006 ** LDCH CHARZ


2009 ** STCH C1
2012 ALPHA RESW 1
2015 FIVE WORD 5
2018 CHARZ BYTE C'Z'
2019 C1 RESB 1
2020 ** END **
3. IMPLEMENTATION OF PASS TWO OF A TWO PASS
ASSEMBLER
#include<stdio.h> #include<conio.h> #include<string.h>
void main()
{
char
opcode[10],operand[10],symbol[10],label[10],code[10],mnemonic[5],character,add[10],objectco
de[10];
int flag,flag1,locctr,location,loc;
FILE *fp1,*fp2,*fp3,*fp4;
clrscr();
fp1=fopen("out.txt","r"); fp2=fopen("twoout.txt","w");
fp3=fopen("optab.txt","r"); fp4=fopen("symtbl.txt","r");
fscanf(fp1,"%s%s%s",label,opcode,operand);
if(strcmp(opcode,"START")==0)
{ fprintf(fp2,"%s\t%s\t%s\n",label,opcode,operand);
fscanf(fp1,"%d%s%s%s",&locctr,label,opcode,operand);
}
while(strcmp(opcode,"END")!=0)
{ flag=0;
fscanf(fp3,"%s%s",code,mnemonic);
while(strcmp(code,"END")!=0)
{ if((strcmp(opcode,code)==0) && (strcmp(mnemonic,"*"))!=0)
{ flag=1;
break;
}
fscanf(fp3,"%s%s",code,mnemonic);
}
if(flag==1)
{ flag1=0; rewind(fp4);
while(!feof(fp4))
{
fscanf(fp4,"%s%d",symbol,&loc);
if(strcmp(symbol,operand)==0)
{
flag1=1; break;
}}
if(flag1==1)

{
itoa(loc,add,10);
strcpy(objectcode,strcat(mnemonic,add));
}}
else if(strcmp(opcode,"BYTE")==0 || strcmp(opcode,"WORD")==0)
{
if((operand[0]=='C') || (operand[0]=='X'))
{
character=operand[2];
itoa(character,add,16);
strcpy(objectcode,add);
}
else
{
itoa(atoi(operand),add,10);
strcpy(objectcode,add);
}}
else
strcpy(objectcode,"\0");
fprintf(fp2,"%s\t%s\t%s\t%d\t%s\n",label,opcode,operand,locctr,objectcode);
fscanf(fp1,"%d%s%s%s",&locctr,label,opcode,operand);
}
fprintf(fp2,"%s\t%s\t%s\t%d\n",label,opcode,operand,locctr);
fclose(fp1); fclose(fp2);
fclose(fp3); fclose(fp4);
getch();
}
INPUT FILES:
out.txt
** START 2000
2000 ** LDA FIVE
2003 ** STA ALPHA
2006 ** LDCH CHARZ
2009 ** STCH C1
2012 ALPHA RESW 1
2015 FIVE WORD 5
2018 CHARZ BYTE C'Z'
2019 C1 RESB 1
2020 ** END **

optab.txt
START *

LDA 03
STA 0f
LDCH 53
STCH 57
END *
symtbl.txt
ALPHA 2012
FIVE 2015
CHARZ 2018
C1 2019
OUTPUT FILES:
twoout.txt
** START 2000
** LDA FIVE 2000 032015
** STA ALPHA 2003 0f2012
** LDCH CHARZ 2006 532018
** STCH C1 2009 572019
ALPHA RESW 1 2012
FIVE WORD 5 2015 5
CHARZ BYTE C'Z' 2018 5a
C1 RESB 1 2019
** END ** 2020
4. IMPLEMENTATION OF A SINGLE PASS ASSEMBLER
#include<stdio.h> #include<conio.h>
#include<string.h> #include<stdlib.h> #define MAX 10
struct input
{
char label[10],opcode[10],operand[10],mnemonic[5]; int loc;
};
struct input table[MAX];
struct symtab
{
char sym[10]; int f,val,ref;
};
struct symtab symtbl[MAX];
void main()
{
int f1,i=1,j=1,flag,locctr,x;
char add[10],code[10],mnemcode[5];
FILE *fp1,*fp2,*fp3;
clrscr();
fp1=fopen("input1.txt","r"); fp2=fopen("optab1.txt","r"); fp3=fopen("spout.txt","w");
fscanf(fp1,"%s%s%s",table[i].label,table[i].opcode,table[i].operand);
if(strcmp(table[i].opcode,"START")==0)
{

locctr=atoi(table[i].operand);
i++;
fscanf(fp1,"%s%s%s",table[i].label,table[i].opcode,table[i].operand);
}
else
locctr=0;
while(strcmp(table[i].opcode,"END")!=0)
{ if(strcmp(table[i].label,"**")!=0)
{
for(x=1;x<j;x++)
{ f1=0;
if((strcmp(symtbl[x].sym,table[i].label)==0) && (symtbl[x].f==1))
{
symtbl[x].val=locctr; symtbl[x].f=0;
table[symtbl[x].ref].loc=locctr; f1=1;
break;
}
}
if(f1==0)
{
strcpy(symtbl[j].sym,table[i].label); symtbl[j].val=locctr; symtbl[j].f=0;
j++;
}
}
fscanf(fp2,"%s%s",code,mnemcode);
while(strcmp(code,"END")!=0)
{ if(strcmp(table[i].opcode,code)==0)
{ strcpy(table[i].mnemonic,mnemcode);
locctr+=3;
for(x=1;x<=j;x++)
{
flag=0;
if(strcmp(table[i].operand,symtbl[x].sym)==0)
{
flag=1;
if(symtbl[x].f==0)
table[i].loc=symtbl[x].val;
break;
}
}
if(flag!=1)
{
strcpy(symtbl[j].sym,table[i].operand);
symtbl[j].f=1;
symtbl[j].ref=i;
j++;

}
}
fscanf(fp2,"%s%s",code,mnemcode);
}
rewind(fp2);
if(strcmp(table[i].opcode,"WORD")==0)
{
locctr+=3;
strcpy(table[i].mnemonic,'\0');
table[i].loc=atoi(table[i].operand);
}
else if(strcmp(table[i].opcode,"RESW")==0)
{
locctr+=(3*(atoi(table[i].operand)));
strcpy(table[i].mnemonic,'\0');
table[i].loc=atoi('\0');
}
else if(strcmp(table[i].opcode,"RESB")==0)
{
locctr+=(atoi(table[i].operand));
strcpy(table[i].mnemonic,'\0');
table[i].loc=atoi('\0');
}
else if(strcmp(table[i].opcode,"BYTE")==0)
{
++locctr;
if((table[i].operand[0]=='C') || (table[i].operand[0]=='X'))
table[i].loc=(int)table[i].operand[2];
else
table[i].loc=locctr;
}
i++;
fscanf(fp1,"%s%s%s",table[i].label,table[i].opcode,table[i].operand);
}
for(x=1;x<=i;x++)
fprintf(fp3,"%s\t%s\t%s\t%s\n",table[x].label,table[x].opcode,table[x].operand,strcat(table[x].mn
emonic,itoa(table[x].loc,add,10)));
for(x=1;x<j;x++)
printf("%s\t%d\n",symtbl[x].sym,symtbl[x].val);
getch();
}

Output:
INPUT FILES:
input1.txt
** START 6000
** JSUB CLOOP

** JSUB RLOOP
ALPHA WORD 23
BETA RESW 3
GAMMA BYTE C'Z'
DELTA RESB 4
CLOOP LDA ALPHA
RLOOP STA BETA
** LDCH GAMMA
** STCH DELTA
** END **
optab1.txt
START *
JSUB 48
LDA 14
STA 03
LDCH 53
STCH 57
END *
OUTPUT FILES:
CLOOP 6023
RLOOP 6026
ALPHA 6006
BETA 6009
GAMMA 6018
DELTA 6019
spout.txt
** START 6000 0
** JSUB CLOOP 486023
** JSUB RLOOP 486026
ALPHA WORD 23 23
BETA RESW 3 0
GAMMA BYTE C'Z' 90
DELTA RESB 4 0
CLOOP LDA ALPHA 146006
RLOOP STA BETA 036009
** LDCH GAMMA 536018
** STCH DELTA 576019
** END ** 0
5. IMPLEMENTATION OF A MACRO PROCESSOR
#include<stdio.h> #include<conio.h>
#include<stdlib.h> #include<string.h>
void main()
{
char n1,n,c1,i;

char fn[10][10],ilab[20],iopd[20],m[20][3],oper[20],opd[20];
FILE *fp1,*fp2,*p[5]; clrscr(); n=0;
fp1=fopen("macin.txt","r");
while(!feof(fp1))
{ fscanf(fp1,"%s%s%s",ilab,iopd,oper);
if(strcmp(iopd,"macro")==0)
n++;
}
printf("No. of macros=%d\n",n);
n1=n;
printf("Enter the text filename\n");
for(i=0;i<n;i++)
{ scanf("%s",fn[i]);
p[i]=fopen(fn[i],"w");
}
n=0;
rewind(fp1);
while(!feof(fp1))
{ fscanf(fp1,"%s%s%s",ilab,iopd,oper);
if(strcmp(iopd,"macro")==0)
{ strcpy(m[n],oper);
fscanf(fp1,"%s%s%s",ilab,iopd,oper);
while(strcmp(iopd,"mend")!=0)
{ fprintf(p[n],"%s %s %s\n",ilab,iopd,oper);
fscanf(fp1,"%s%s%s",ilab,iopd,oper);
}
fclose(p[n]);
n++;
}
}
for(i=0;i<n1;i++)
p[i]=fopen(fn[i],"r"); fp2=fopen("outmac.txt","w"); rewind(fp1);
fscanf(fp1,"%s%s%s",ilab,iopd,oper);
while(!feof(fp1))
{ if(strcmp(iopd,"call")==0)
{ for(i=0;i<n1;i++)
{ if(strcmp(m[i],oper)==0)
{ rewind(p[i]);
fscanf(p[i],"%s%s%s",ilab,iopd,oper);
while(!feof(p[i]))
{ fprintf(fp2,"%s %s %s\n",ilab,iopd,oper);
c1=1;
fscanf(p[i],"%s%s%s",ilab,iopd,oper);
}
break;
}}}

if(c1!=1)
fprintf(fp2,"%s %s %s\n",ilab,iopd,oper);
c1=0;
fscanf(fp1,"%s%s%s",ilab,iopd,oper);
}
fprintf(fp2,"%s %s %s\n",ilab,iopd,oper);
}

Output:
INPUT FILE:
macin.txt
** macro m1
** move a,b
** mend --** macro m2
** lda b
** mend --** start 1000
** lda a
** call m1
** call m2
** add a,b
OUPUT FILE:
No. of macros=2
Enter the text filename
outmac
macin
outmac.txt
** macro m1
** move a,b
** mend --** macro m2
** lda b
** mend --** start 1000
** lda a
** move a,b
** lda b
** add a,b
6. IMPLEMENTATION OF AN ABSOLUTE LOADER
#include<stdio.h>
#include<conio.h>
#include<string.h>
#include<stdlib.h>
struct object_code
{
int locctr;

char byte[5];
};
struct object_code code[200];
void main()
{
FILE *fp1,*fp2;
char input[15];
int i,len,n=0,count=0,inc=0,textloc,tlen,tloc=0,num=0,loc;
clrscr();
fp1=fopen("loadin.txt","r");
fp2=fopen("loadout.txt","w");
rewind(fp1);
rewind(fp2);
fscanf(fp1,"%s",input);
if(strcmp(input,"H")==0)
{
for(i=0;i<4;i++)
{
if(i==1)
fscanf(fp1,"%x",&loc);
else
fscanf(fp1,"%s",input);
}
}
tloc=loc;
while(strcmp(input,"E")!=0)
{
if(strcmp(input,"T")==0)
{
fscanf(fp1,"%x",&textloc);
for(i=0;i<(textloc-(tloc+tlen));i++)
{
strcpy(code[inc].byte,"xx");
code[inc++].locctr=loc++;
}
fscanf(fp1,"%x",&tlen);
tloc=textloc;
}
else
{
len=strlen(input);
for(i=0;i<len;i++)
{
code[inc].byte[num++]=input[i];
if(num > 1)
{

code[inc].locctr=loc;
loc++;
inc++;
num=0;
}
}
}
fscanf(fp1,"%s",input);
}
n=0;
i=0;
count=0;
fprintf(fp2,"%x\t",code[i].locctr);
for(i=0;i<inc;i++)
{
fprintf(fp2,"%s",code[i].byte);
n++;
if(n > 3)
{
fprintf(fp2,"\t");
n=0;
count++;
}
if(count > 3)
{
fprintf(fp2,"\n%x\t",code[i+1].locctr);
count=0;
}
}
getch();
}

Output:
INPUT FILE:
loadin.txt
H COPY 002000 00107a
T 002000 1e 142033 483039 102036 282030 302015
483061 3c2003 00202a 0c2039 00202d
T 00201e 15 2C2036 483062 182033 4C0000 454f46
200003 100000
T 002039 1e 242030 302030 e0305d 30303f d8305d
282030 303057 53a039 2c305e 38303f
T 002057 a 102036 4c0000 F1 201000
T 002071 19 342030 e03079 303064 4fa039 dc3079
2c2036 383064 4c0000 15
E 002000
OUTPUT FILE:

loadout.txt
2000 14203348 30391020 36282030 30201548
2010 30613c20 0300202a 0c203900 202d2C20
2020 36483062 1820334C 0000454f 46200003
2030 100000xx xxxxxxxx xx242030 302030e0
2040 305d3030 3fd8305d 28203030 305753a0
2050 392c305e 38303f10 20364c00 00F12010
2060 00xxxxxx xxxxxxxx xxxxxxxx xxxxxxxx
2070 xx342030 e0307930 30644fa0 39dc3079
2080 2c203638 30644c00 0015
7. IMPLEMENTATION OF A RELOCATING LOADER
#include<stdio.h> #include<conio.h> #include<string.h> #include<stdlib.h>
struct object_code
{
int locctr; char add[10]; }obcode[300];
void main()
{ char input[100][16],output[100][16],binary[20],address[20],stloc[10];
int len,bitmask,loc,tlen=0,tloc,textloc,i=0,location,j,k,count=0,start,n,num=0,inc=0;
FILE *fp1,*fp2; clrscr();
fp1=fopen("relin.txt","r"); fp2=fopen("relout.txt","w");
printf("Enter the location where the present program has to be loaded:");
scanf("%s",stloc); start=atoi(stloc);
location=start;
tloc=start;
fscanf(fp1,"%s",input[i]);
while(strcmp(input[i],"T")!=0)
{
strcpy(output[i],input[i]);
i++;
fscanf(fp1,"%s",input[i]);
strcpy(output[i],input[i]);
}
itoa(start,output[2],10);
while(strcmp(input[i],"E")!=0)
{
strcpy(output[i],input[i]);
if(strcmp(input[i],"T")==0)
{
for(j=0;j<3;j++)
{
i++;
fscanf(fp1,"%s",input[i]);
strcpy(output[i],input[i]);
}

bitmask=atoi(output[i]);
itoa(bitmask,binary,2);
strcpy(output[i],NULL);
textloc=atoi(output[i-2]);
textloc=textloc+start;
itoa(textloc,output[i-2],10);
for(n=0;n<(textloc-(tloc+tlen));n++)
{
strcpy(obcode[inc].add,"xx");
obcode[inc++].locctr=location++;
}
tlen=atoi(output[i-1]);
tloc=textloc;
k=0;
}
else
{
if(binary[k]=='1')
{
num=0;
len=strlen(output[i]);
strcpy(address,NULL);
for(j=2;j<len;j++)
{
address[num]=output[i][j];
output[i][j]='\0';
num++;
}
loc=atoi(address); loc=loc+start; itoa(loc,address,10);
strcat(output[i],address);
}
k++;
len=strlen(output[i]); num=0;
for(n=0;n<len;n++)
{obcode[inc].add[num++]=output[i][n];
if(num>1)
{obcode[inc++].locctr=location++;
num=0;
}}}
i++;
fscanf(fp1,"%s",input[i]);
}
strcpy(output[i],input[i]);
i++;
fscanf(fp1,"%s",input[i]);
loc=atoi(input[i]);

loc=loc+start;
strcpy(output[i],itoa(loc,address,10));
count=0;
i=0;
n=0;
fprintf(fp2,"%d\t",obcode[n].locctr);
for(n=0;n<inc;n++)
{
fprintf(fp2,"%s",obcode[n].add);
i++;
if(i > 3)
{
fprintf(fp2,"\t"); i=0; count++;
}
if(count > 3)
{
fprintf(fp2,"\n%d\t",obcode[n+1].locctr); count=0;
}
}
getch();
}

Output:
INPUT FILE:
relin.txt
H COPY 000000 001073
T 000000 10 015 140033 481039 100036 280030 300015 481061 311003
200030 211033 200033
T 000011 19 045 412036 481061 380033 412000 454196 100003 200000
T 000031 15 135 140030 430030 141013 301044 241064 210030 301057
543039 212064 381045
T 000058 05 056 100036 520000 151 301000
T 000065 19 080 340030 141079 301064 503039 152079 220036 381064
430000 25
E 000000
OUTPUT FILE:
relout.txt
3000 14303348 40391030 36283030 30001548
3016 10613110 03200030 21103320 0033xx41
3032 50364810 61383033 41500045 41961030
3048 03200000 xx143030 43003014 10133010
3064 44241064 21303030 40575460 39212064
3080 381045xx xxxxxxxx xxxxxxxx xxxxxx10
3096 30365230 00154000 301000xx xx343030
3112 14107930 40645030 39152079 22003638
3128 10644300 0025

8. IMPLEMENTATION OF PASS 1 OF A DIRECT LINKING


LOADER
#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#include<string.h>
#define MAX 10
struct estab
{
char csect[10];
char sym_name[10];
long int add;
int length;
}table[MAX];
void main()
{
FILE *fp1,*fp2;
char input[10];
long int i,count=0,start,length,loc;
clrscr();
fp1=fopen("dlinkin.txt","r");
fp2=fopen("dlinkout.txt","w");
printf("\nEnter the location where the program has to be loaded:");
scanf("%lx",&start);
fprintf(fp2,"CSECT\tSymname\tAddress\tLength\n");
rewind(fp1);
while(!feof(fp1))
{
fscanf(fp1,"%s",input);
if(strcmp(input,"H")==0)
{
fscanf(fp1,"%s",input);
strcpy(table[count].csect,input);
strcpy(table[count].sym_name,"\0");
fscanf(fp1,"%s",input);
table[count].add=atoi(input)+start;
fscanf(fp1,"%s",input);
length=atoi(input);
table[count++].length=atoi(input);
fscanf(fp1,"%s",input);
}
if(strcmp(input,"D")==0)
{
fscanf(fp1,"%s%lx",input,&loc);
while((strcmp(input,"R")!=0))
{

strcpy(table[count].csect,"\0");
strcpy(table[count].sym_name,input);
table[count].add=loc+start;
table[count++].length=0;
fscanf(fp1,"%s%lx",input,&loc);
}
while(strcmp(input,"T")!=0)
fscanf(fp1,"%s",input);
}
if(strcmp(input,"T")==0)
while(strcmp(input,"E")!=0)
fscanf(fp1,"%s",input);
fscanf(fp1,"%s",input);
start=start+length;
}
for(i=0;i<count;i++)
fprintf(fp2,"%s\t%s\t%lx\t%d\n",table[i].csect,table[i].sym_name,table[i].add,table[i].length);
getch();
}

Output:
INPUT FILE:
dlinkin.txt
H PROGA 000000 000070
D LISTA 000040 ENDA 000054
R LISTB ENDB LISTC ENDC
T 000020 10 03201D 77100004 150014
T 000054 16 100014 15100006 00002F 100014 FFFFC0
M 000024 05 +LISTB
M 000054 06 +LISTC
M 000058 06 +ENDC
M 000064 06 +LISTB
E 000000
H PROGB 000000 000088
D LISTB 000060 ENDB 000070
R LISTA ENDA LISTC ENDC
T 000036 11 03100000 772027 05100000
T 000070 18 100000 05100006 05100020 05100030 100000
M 000037 05 +LISTA
M 000044 05 +ENDA
M 000070 06 +ENDA
M 000074 06 +ENDC
M 000078 06 +ENDC
M 000082 06 +ENDA
E 000000
H PROGC 000000 000057
D LISTC 000030 ENDC 000042

R LISTA ENDA LISTB ENDB


T 000018 12 03100000 77100004 05100000
T 000042 15 100030 100008 100011 100000 100000
M 000019 05 +LISTA
M 000023 05 +LISTB
M 000027 05 +ENDA
M 000048 06 +LISTA
M 000051 06 +ENDA
M 000054 06 +LISTB
E 000000
OUTPUT FILE:
dlinkout.txt
CSECT Symname Address Length
PROGA 2000 70
LISTA 2040 0
ENDA 2054 0
PROGB 2046 88
LISTB 20a6 0
ENDB 20b6 0
PROGC 209e 57
LISTC 20ce 0
ENDC 20e0 0
9. IMPLEMENTATION OF PASS 2 OF A DIRECT LINKING
LOADER
#include<stdio.h> #include<conio.h>
#include<string.h> #include<stdlib.h>
struct ext_table
{char csect[10]; char sname[10]; int padd; int plen;
}estab[20];
struct object_code
{
char code[15]; int add;
}obcode[500];
void main()
{
FILE *fp1,*fp2,*fp3;
int i,j,x,y,n=0,num=0,inc=0,count=0,record=0,pstart,exeloc,start,textloc;
int loc,mloc[30],textlen,mlen[30],length,location;
long int newadd;
char *add1,operation,lbl[10],input[10],label[30][10],
address[10];
clrscr();
printf("\n this is pass 2 of direct linking loader\n");
fp1=fopen("dlink2in.txt","r"); fp2=fopen("dlink1out.txt","r");

fp3=fopen("dlink2out.txt","w"); rewind(fp1);
rewind(fp2); rewind(fp3);
while(!feof(fp2))
{
fscanf(fp2,"%s%s%d
%d",estab[num].csect,estab[num].sname,&estab[num].padd,&estab[num].plen);
num++;
}
exeloc=estab[0].padd; loc=exeloc; start=loc;
while(!feof(fp1))
{
fscanf(fp1,"%s",input);
if(strcmp(input,"H")==0)
{
fscanf(fp1,"%s",input);
for(i=0;i<num;i++)
if(strcmp(input,estab[i].csect)==0)
{
pstart=estab[i].padd; break;
}
while(strcmp(input,"T")!=0)
fscanf(fp1,"%s",input);
}
do
{ if(strcmp(input,"T")==0)
{ fscanf(fp1,"%d",&textloc);
textloc=textloc+pstart;
for(i=0;i<(textloc-loc);i++)
{
strcpy(obcode[inc].code,"xx");
obcode[inc++].add=start++;
}
fscanf(fp1,"%d",&textlen);
loc=textloc+textlen;
}
else if(strcmp(input,"M")==0)
{
fscanf(fp1,"%d",&mloc[record]); mloc[record]=mloc[record]+pstart;
fscanf(fp1,"%d",&mlen[record]); fscanf(fp1,"%s",label[record++]);
}
else
{
length=strlen(input);
x=0;
for(i=0;i<length;i++)
{

obcode[inc].code[x++]=input[i];
if(x>1)
{
obcode[inc++].add=start++;
x=0;
}
}
}
fscanf(fp1,"%s",input);
}while(strcmp(input,"E")!=0);
if(strcmp(input,"E")==0)
fscanf(fp1,"%s",input);
}
for(n=0;n<record;n++)
{
operation=label[n][0];
length=strlen(label[n]);
for(i=1;i<length;i++)
lbl[i-1]=label[n][i];
lbl[length-1]='\0';
length=0;
strcpy(address,"\0");
location=mloc[n]-exeloc;
loc=location;
count=0;
while(length<mlen[n])
{
strcat(address,obcode[location++].code);
count++;
length+=2;
}
for(i=0;i<num;i++)
if(strcmp(lbl,estab[i].sname)==0)
break;
switch(operation)
{
case '+':newadd=strtol(address,&add1,10)+(long int)estab[i].padd; break;
case '-':newadd=strtol(address,&add1,10)-(long int)estab[i].padd; break;
}
ltoa(newadd,address,10);
x=0; y=0;
while(count > 0)
{ obcode[loc].code[x++]=address[y++];
if(x > 1)
{
x=0;

loc++;
count--;
}
}
}
count=0;
n=0;
fprintf(fp3,"%d\t",obcode[0].add);
for(i=0;i<inc;i++)
{
fprintf(fp3,"%s",obcode[i].code);
n++;
if(n>3)
{
fprintf(fp3,"\t");
n=0;
count++;
}
if(count>3)
{
fprintf(fp3,"\n%d\t",obcode[i+1].add);
count=0;
}
}
getch();
}

Output:
INPUT FILES:
dlink1in.txt
H PROGA 000000 000070
D LISTA 000040 ENDA 000054
R LISTB ENDB LISTC ENDC
T 000020 10 03201D 77100004 150014
T 000054 16 100014 15100006 00002F 100014 FFFFC0
M 000024 05 +LISTB
M 000054 06 +LISTC
M 000058 06 +ENDC
M 000064 06 +LISTB
E 000000
H PROGB 000000 000088
D LISTB 000060 ENDB 000070
R LISTA ENDA LISTC ENDC
T 000036 11 03100000 772027 05100000
T 000070 18 100000 05100006 05100020 05100030 100000
M 000037 05 +LISTA
M 000044 05 +ENDA

M 000070 06 +ENDA
M 000074 06 +ENDC
M 000078 06 +ENDC
M 000082 06 +ENDA
E 000000
H PROGC 000000 000057
D LISTC 000030 ENDC 000042
R LISTA ENDA LISTB ENDB
T 000018 12 03100000 7100004 05100000
T 000042 15 100030 100008 100011 100000 100000
M 000019 05 +LISTA
M 000023 05 +LISTB
M 000027 05 +ENDA
M 000048 06 +LISTA
M 000051 06 +ENDA
M 000054 06 +LISTB
E 000000
dlink1out.txt
PROGA ** 2000 70
** LISTA 2040 0
** ENDA 2054 0
PROGB ** 2070 88
** LISTB 2130 0
** ENDB 2140 0
PROGC ** 2158 57
** LISTC 2188 0
** ENDC 2200 0
OUTPUT FILE:
Dlink2out.txt
2000 xxxxxxxx xxxxxxxx xxxxxxxx xxxxxxxx
2016 xxxxxxxx 03201D77 10213415 0014xxxx
2032 xxxxxxxx xxxxxxxx xxxxxxxx xxxxxxxx
2048 xxxxxxxx xxxx1022 02151022 0600002F
2064 102144FF FFC0xxxx xxxxxxxx xxxxxxxx
2080 xxxxxxxx xxxxxxxx xxxxxxxx xxxxxxxx
2096 xxxxxxxx xxxxxxxx xxxx0310 20407720
2112 27051020 54xxxxxx xxxxxxxx xxxxxxxx
2128 xxxxxxxx xxxxxxxx xxxxxxxx 10205405
2144 10220605 10222005 10208410 0000xxxx
2160 xxxxxxxx xxxxxxxx xxxxxxxx xxxxxxxx
2176 03102040 77102134 05102054 xxxxxxxx
2192 xxxxxxxx xxxxxxxx 10003010 00081020
2208 51102054 102130

10. IMPLEMENTATION OF A SIMPLE TEXT EDITOR


#include<stdio.h> #include<conio.h>
#include<ctype.h> #include<dos.h>
#include<iostream.h> #include<fstream.h>
char filename[15];
char buff[1000];
int curx,cury,count;
void cur_pos()
{
curx=wherex();
cury=wherey();
textcolor(12);
textbackground(9);
gotoxy(35,20);
cout<<"\n";
cout<<"***********************************************************************
\n";
cout<<"\n";
cout<<" TEXT EDITOR \n";
cout<<"\n";
cout<<"***********************************************************************
\n";
cout<<"\n Type ur text and then press escape key\n";
gotoxy(100,100);
cprintf("%2d%2d",curx,cury);
gotoxy(curx,cury);
}
void main()
{
char ch,c;
ofstream outfile;
ifstream infile;
clrscr();
cur_pos();
curx=wherex();
cury=wherey();
while(c!=27)
{
c=getch();
switch(c)
{
case 80:gotoxy(curx,cury+1);
break;
case 77:gotoxy(curx+1,cury);
break;
case 72:gotoxy(curx,cury-1);

break;
case 75:gotoxy(curx-1,cury);
break;
case 32:printf(" ");
buff[count++]=' ';
break;
case 13:gotoxy(1,cury+1);
buff[count++]='\n';
break;
default:textcolor(13);
if((c >= 65) && (c <= 122) || (c >= 48 && c <= 57))
printf("%c",c);
break;
}
buff[count++]=c;
cur_pos();
}
cprintf("\n\nDo u want to save?");
scanf("%c",&c);
if(c == 'y')
{
cprintf("\n\nEnter the filename with extension in 8 char only: ");
scanf("%s",filename);
outfile.open(filename,ios::out);
outfile<<buff;
outfile.close();
cout<<"\nDo u want to open\n";
ch=getch();
{
if(ch=='y')
{
cprintf("\n\nEnter the filename to open: ");
scanf("%s",filename);
infile.open(filename,ios::in);
infile.get(buff,count,'*');
gotoxy(90,1);
printf("%s",buff);
getch();
infile.close();
}
}
}
}

Output:
hi welcome
This is a sample text editor program for IT SS lab

Do u want to save? y
Enter the filename with extension in 8 char only: sample.txt
Do u want to open
Enter the filename to open: sample.txt
hi welcome
This is a sample text editor program IT SS lab
***********************************************************
TEXT EDITOR
***********************************************************
Type ur text and then press escape key
28 5
11. MULTI PASS ASSEMBLERS

#include<stdlib.h>
#include<conio.h>
#include<stdio.h>
#include<string.h>
int search(char sym[10]);
char praddr[10];
int k,data[100],mem[100],i=0,q,d=0, value,j;
int csaddr,exaddr,cslth;
char type[10],addr[10],obj[10],mflag[10],op;
void main()
{
FILE *in,*address;
in=fopen("OBJECT.TXT","r");
address=fopen("ADDRESS.TXT","r");
clrscr();
fscanf(address,"%s",praddr);
fclose(address);
csaddr=atoi(praddr);
exaddr=atoi(praddr);
fscanf(in,"%s\t%s\t%s\t%s\t",type,addr,obj,mflag);
while(!feof(in))
{
cslth=atoi(obj);
while(strcmp(type,"E")!=0)
{
fscanf(in,"%s\t%s\t%s\t%s\t",type,addr,obj,mflag);
if(strcmp(type,"T")==0)
{
mem[i]=atoi(addr)+csaddr;
data[i]=atoi(obj);
i++;
}

else if(strcmp(type,"M")==0)
{
op=mflag[0];
for(j=1;j<strlen(mflag);j++)
mflag[j-1]=mflag[j];
mflag[j-1]='\0';
value=search(mflag);
q=d+atoi(addr)/3;
if(op=='+')
data[q]=data[q]+value;
else
data[q]=data[q]-value;
}
}
d=cslth/3;
exaddr=csaddr+atoi(addr);
csaddr=csaddr+cslth;
fscanf(in,"%s\t%s\t%s\t%s\n",type,addr,obj,mflag);
}
fclose(in);
q=(exaddr-(atoi(praddr)))/3;
printf("Program Loaded in memory is ready for execution\n");
printf("Execution Starting Address:%d\n",exaddr);
printf("ADDRESS\t DATA\n");
for(j=0;j<i;j++)
printf("%d\t%d\n",mem[j],data[j]);
gotoxy(1,q+4);
getch();
}
int search(char sym[10])
{
FILE *fp;
char s1[10],s2[10],s3[10],s4[10];
fp=fopen("ESTAB.TXT","r");
while(!feof(fp))
{
fscanf(fp,"%s\t%s\t%s\t%s\n",s1,s2,s3,s4);
if(strcmp(s2,sym)==0)
{
fclose(fp);
return(atoi(s3));
}
}
fclose(fp);
return 0;
}

Output:
Program Loaded in memory is ready for execution
Execution Starting Address:9009
ADDRESS DATA
9000 6
9003 10006
9006 9
9009 6
9012 10006
9015 9

You might also like