summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--readme.md27
-rw-r--r--src/createKicadLibrary.py1
-rw-r--r--src/model_generation.py326
3 files changed, 148 insertions, 206 deletions
diff --git a/readme.md b/readme.md
index f2e9a02..b8d3754 100644
--- a/readme.md
+++ b/readme.md
@@ -3,8 +3,8 @@ Ngspice Ghdl Interfacing Documentation
It contains all the documenation for Ngspice and Ghdl related work.
-Note: This project is still in alpha version and has been tested for basic digital components.
-====
+> Note: This project is in beta version and has been tested for rings, counters and PWM controllers.
+
## What exactly interfacing of ngspice ghdl do?
Ngspice support mixed mode simulation. It can simulate both digital and analog component.
@@ -18,7 +18,7 @@ for that model it will actually call the ghdl to get the result.
##Pre-requisites
-1. Ubuntu 12.04 (You can try it on other version and let us know)
+1. Ubuntu 12.04-16.04 (You can try it on other version and let us know)
2. Python 2.7
3. PyQt4
@@ -26,26 +26,23 @@ for that model it will actually call the ghdl to get the result.
##How to install?
1. Clone this repository.
2. Run `./install-nghdl.sh` It will install ngspice from source code and put it in $HOME.
-3. Set ngspice path in `.bashrc` file. Add `export PATH=/home/{your-username}/ngspice-26/install_dir/bin:$PATH` line in .bashrc
+3. Set ngspice path in `.bashrc` file. Add `export PATH=/home/{your-username}/ngspice-nghdl/install_dir/bin:$PATH` line in .bashrc
+
##Few words about installed code structure.
-1. Ngspice will be installed in home directory $HOME. If you already have ngspice-26 directory there it will take its backup.
+1. Ngspice will be installed in home directory $HOME. If you already have ngspice-31 directory there it will take its backup.
2. Source code for all other file will be present in ~/.esim-nghdl
3. symlink nghdl is stored in /usr/local/bin
+
##How to use?
1. Run nghdl in command terminal.
2. Upload your vhdl file.
-3. Model will be created with name of your vhdl file. It can be seen under (~ngspice-26/src/xspice/icm/ghdl/)
+3. Model will be created with name of your vhdl file. It can be seen under (~/ngspice-nghdl/src/xspice/icm/ghdl/)
4. You can use this model in your netlist.
-##LIMITATION:
-1. You can use only one output port in your file.
-2. All the port should be std_logic_vector only.
-3. We can use only one instance of code model in netlist.
-
-##FUTURE WORK
-1. Make changes to have more than one output.
-2. Making changes to include use of more than one instance of code models.
-3. Interfacing it with eSim formely known as Oscad so that we can use it in our schematic.
+##FEATURES:
+1. Support for 512 digital models.
+2. Support for digital models upto 64 output ports/pins.
+3. Multiple instances of same digital model.
diff --git a/src/createKicadLibrary.py b/src/createKicadLibrary.py
index b66d487..49c298e 100644
--- a/src/createKicadLibrary.py
+++ b/src/createKicadLibrary.py
@@ -74,7 +74,6 @@ class AutoSchematic(QtGui.QWidget):
ET.SubElement(param ,"fall_delay", default ="1.0e-9").text = "Enter Fall Delay (default=1.0e-9)"
ET.SubElement(param ,"input_load", default ="1.0e-12").text = "Enter Input Load (default=1.0e-12)"
ET.SubElement(param ,"instance_id", default ="1").text = "Enter Instance ID (Between 0-99)"
- ET.SubElement(param ,"stop_time", default ="90e-9").text = "Enter the stop time to end the simulation (default=90e-9)"
tree = ET.ElementTree(root)
tree.write(str(self.modelname) + '.xml')
print "Leaving the directory ", (xmlDestination)
diff --git a/src/model_generation.py b/src/model_generation.py
index dffd690..5bfa960 100644
--- a/src/model_generation.py
+++ b/src/model_generation.py
@@ -168,19 +168,18 @@ for item in output_port:
var_section='''
- // Declaring components of Client
- static int flag=0;
- FILE *log_client = NULL;
- log_client=fopen("client.log","a");
- int socket_fd, bytes_recieved;
- char send_data[1024];
+ // Declaring components of Client
+ FILE *log_client = NULL;
+ log_client=fopen("client.log","a");
+ int socket_fd, bytes_recieved;
+ char send_data[1024];
char recv_data[1024];
char *key_iter;
- struct hostent *host;
- struct sockaddr_in server_addr;
- double time_limit = PARAM(stop_time);
+ struct hostent *host;
+ struct sockaddr_in server_addr;
int sock_port = 5000+PARAM(instance_id);
'''
+
temp_input_var=[]
for item in input_port:
temp_input_var.append("char temp_"+item.split(':')[0]+"[1024];")
@@ -229,9 +228,9 @@ els_evt_ptr=[]
els_evt_count1=0
els_evt_count2=0
for item in output_port:
- els_evt_ptr.append("_op_"+item.split(":")[0]+" = cm_event_get_ptr("+str(els_evt_count1)+","+str(els_evt_count2)+");")
+ els_evt_ptr.append("_op_"+item.split(":")[0]+" = (Digital_State_t *) cm_event_get_ptr("+str(els_evt_count1)+","+str(els_evt_count2)+");")
els_evt_count2=els_evt_count2+1
- els_evt_ptr.append("_op_"+item.split(":")[0]+"_old"+" = cm_event_get_ptr("+str(els_evt_count1)+","+str(els_evt_count2)+");")
+ els_evt_ptr.append("_op_"+item.split(":")[0]+"_old"+" = (Digital_State_t *) cm_event_get_ptr("+str(els_evt_count1)+","+str(els_evt_count2)+");")
els_evt_count1=els_evt_count1+1
@@ -275,87 +274,80 @@ client_setup_ip='''
'''
client_fetch_ip='''
- /* Client Fetch IP Addr */
+ /* Client Fetch IP Addr */
- char* my_ip = STATIC_VAR(my_ip);
+ char* my_ip = STATIC_VAR(my_ip);
- host = gethostbyname(my_ip);
- printf("\\n\\nClient-Creating Socket \\n");
- fprintf(log_client,"Creating client socket \\n");
+ host = gethostbyname(my_ip);
+ printf("\\n\\nClient-Creating Socket \\n");
+ fprintf(log_client,"Creating client socket \\n");
'''
create_socket='''
- //Creating socket for client
- if ((socket_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1)
- {
- perror("Client-Error while creating client Socket \\n");
- fprintf(log_client,"Error while creating client socket \\n");
- exit(1);
- }
-
- printf("Client-Client Socket created successfully \\n");
- printf("Client- Socket Id : %d \\n",socket_fd);
- fprintf(log_client,"Client-Client Socket created successfully \\n");
- fprintf(log_client,"Client- Socket Id : %d \\n",socket_fd);
-
- // memset(&server_addr, 0, sizeof(server_addr));
- server_addr.sin_family = AF_INET;
- server_addr.sin_port = htons(sock_port);
- server_addr.sin_addr = *((struct in_addr *)host->h_addr);
- bzero(&(server_addr.sin_zero),8);
+ //Creating socket for client
+ if ((socket_fd = socket(AF_INET, SOCK_STREAM, 0)) == -1)
+ {
+ perror("Client-Error while creating client Socket \\n");
+ fprintf(log_client,"Error while creating client socket \\n");
+ exit(1);
+ }
+
+ printf("Client-Client Socket created successfully \\n");
+ printf("Client- Socket Id : %d \\n",socket_fd);
+ fprintf(log_client,"Client-Client Socket created successfully \\n");
+ fprintf(log_client,"Client- Socket Id : %d \\n",socket_fd);
+
+ // memset(&server_addr, 0, sizeof(server_addr));
+ server_addr.sin_family = AF_INET;
+ server_addr.sin_port = htons(sock_port);
+ server_addr.sin_addr = *((struct in_addr *)host->h_addr);
+ bzero(&(server_addr.sin_zero),8);
'''
connect_server='''
- printf("Client-Connecting to server \\n");
- fprintf(log_client,"Client-Connecting to server \\n");
- //Conneting to server
-
- int try_limit=10;
- while(try_limit>0)
- {
- if (connect(socket_fd, (struct sockaddr*)&server_addr,sizeof(struct sockaddr)) == -1)
- {
- sleep(1);
- try_limit--;
- if(try_limit==0)
- {
- fprintf(stderr,"Connect- Error:Tried to connect server on port , failed..giving up \\n");
- fprintf(log_client,"Connect- Error:Tried to connect server on port , failed..giving up \\n");
- exit(1);
- }
- }
- else
- {
- printf("Client-Connected to server \\n");
- fprintf(log_client,"Client-Connected to server \\n");
- break;
- }
- }
+ printf("Client-Connecting to server \\n");
+ fprintf(log_client,"Client-Connecting to server \\n");
+
+ //Connecting to server
+ int try_limit=10;
+ while(try_limit>0)
+ {
+ if (connect(socket_fd, (struct sockaddr*)&server_addr,sizeof(struct sockaddr)) == -1)
+ {
+ sleep(1);
+ try_limit--;
+ if(try_limit==0)
+ {
+ fprintf(stderr,"Connect- Error:Tried to connect server on port , failed..giving up \\n");
+ fprintf(log_client,"Connect- Error:Tried to connect server on port , failed..giving up \\n");
+ exit(1);
+ }
+ }
+ else
+ {
+ printf("Client-Connected to server \\n");
+ fprintf(log_client,"Client-Connected to server \\n");
+ break;
+ }
+ }
'''
-time_limit ='''
- if(TIME < time_limit)
- {
- //Formating data for sending it to client
- int Ii;
-
-'''
#Assign bit value to every input
assign_data_to_input=[]
for item in input_port:
- assign_data_to_input.append("\t\t\tfor(Ii=0;Ii<PORT_SIZE("+item.split(':')[0]+");Ii++)\n\
-\t\t\t{\n\t\t\t\tif( INPUT_STATE("+item.split(':')[0]+"[Ii])==ZERO )\n\
-\t\t\t\t{\n\t\t\t\t\ttemp_"+item.split(':')[0]+"[Ii]='0';\n\t\t\t\t}\n\
-\t\t\t\telse\n\t\t\t\t{\n\t\t\t\t\ttemp_"+item.split(':')[0]+"[Ii]='1';\n\
-\t\t\t\t}\n\t\t\t}\n\t\t\ttemp_"+item.split(':')[0]+"[Ii]='\\0';\n\n")
+ assign_data_to_input.append("\tfor(Ii=0;Ii<PORT_SIZE("+item.split(':')[0]+");Ii++)\n\
+\t{\n\t\tif( INPUT_STATE("+item.split(':')[0]+"[Ii])==ZERO )\n\
+\t\t{\n\t\t\ttemp_"+item.split(':')[0]+"[Ii]='0';\n\t\t}\n\
+\t\telse\n\t\t{\n\t\t\ttemp_"+item.split(':')[0]+"[Ii]='1';\n\
+\t\t}\n\t}\n\ttemp_"+item.split(':')[0]+"[Ii]='\\0';\n\n")
snprintf_stmt=[]
snprintf_count=0
-snprintf_stmt.append("\t\t\t//Sending and receiving data to-from server \n")
-snprintf_stmt.append('\t\t\tsnprintf(send_data,sizeof(send_data),"')
+snprintf_stmt.append("\t//Sending and receiving data to-from server \n")
+snprintf_stmt.append('\tsnprintf(send_data,sizeof(send_data),"')
for item in input_port:
snprintf_count=snprintf_count+1
snprintf_stmt.append(item.split(':')[0]+":%s")
@@ -376,37 +368,37 @@ for item in input_port:
else:
snprintf_stmt.append(",")
-snprintf_stmt.append('\n\t\t\tprintf("Client-Value of buffer string is %s \\n",send_data);')
-snprintf_stmt.append('\n\t\t\tprintf("Client-Sending data to server from client \\n");')
+snprintf_stmt.append('\n\tprintf("Client-Value of buffer string is %s \\n",send_data);')
+snprintf_stmt.append('\n\tprintf("Client-Sending data to server from client \\n");')
send_data='''
- if ( send(socket_fd,send_data,sizeof(send_data),0)==-1)
- {
- fprintf(stderr, "Client-Failure Sending Message \\n");
- close(socket_fd);
- exit(1);
- }
- else
- {
- printf("Client-Message being sent: %s \\n",send_data);
- fprintf(log_client,"Socket Id : %d & Message sent : %s \\n",socket_fd,send_data);
- }
+ if ( send(socket_fd,send_data,sizeof(send_data),0)==-1)
+ {
+ fprintf(stderr, "Client-Failure Sending Message \\n");
+ close(socket_fd);
+ exit(1);
+ }
+ else
+ {
+ printf("Client-Message being sent: %s \\n",send_data);
+ fprintf(log_client,"Socket Id : %d & Message sent : %s \\n",socket_fd,send_data);
+ }
'''
recv_data='''
- bytes_recieved=recv(socket_fd,recv_data,sizeof(recv_data),0);
- if ( bytes_recieved <= 0 )
- {
- printf("Client-Either Connection Closed or Error \\n");
- exit(1);
- }
- recv_data[bytes_recieved] = '\\0';
+ bytes_recieved=recv(socket_fd,recv_data,sizeof(recv_data),0);
+ if ( bytes_recieved <= 0 )
+ {
+ printf("Client-Either Connection Closed or Error \\n");
+ exit(1);
+ }
+ recv_data[bytes_recieved] = '\\0';
- printf("Client-Message Received From Server - %s\\n",recv_data);
- fprintf(log_client,"Message Received From Server- %s\\n",recv_data);
+ printf("Client-Message Received From Server - %s\\n",recv_data);
+ fprintf(log_client,"Message Received From Server- %s\\n",recv_data);
'''
@@ -415,66 +407,33 @@ recv_data='''
sch_output_event=[]
for item in output_port:
- sch_output_event.append("\t\t\t/* Scheduling event and processing them */\n\
-\t\t\tif((key_iter=strstr(recv_data, "+'"'+item.split(':')[0]+':"'")) != NULL)\n\
-\t\t\t{\n\
-\t\t\twhile(*key_iter++ != ':');\n\
-\t\t\tfor(Ii=0;*key_iter != ';';Ii++,key_iter++)\n\
-\t\t\t{\n\
-\t\t\t\tprintf(\"Client- Bit val is %c \\n\",*key_iter);\n\
-\t\t\t\tfprintf(log_client,\"Client-Bit val is %c \\n\",*key_iter);\n\
-\t\t\t\tif(*key_iter=='0')\n\t\t\t\t{\n\
-\t\t\t\t\tprintf(\"Client-Zero Received \");\n\
-\t\t\t\t\t_op_"+item.split(':')[0]+"[Ii]=ZERO;\n\t\t\t\t}\n\
-\t\t\t\telse if(*key_iter=='1')\n\t\t\t\t{\n\
-\t\t\t\t\tprintf(\"Client-One Received \\n\");\n\
-\t\t\t\t\t_op_"+item.split(':')[0]+"[Ii]=ONE;\n\
-\t\t\t\t}\n\t\t\t\telse\t\t\t\t{\n\
-\t\t\t\t\tfprintf(log_client,\"Unknow value return from server \\n\");\n\
-\t\t\t\t\tprintf(\"Client-Unknown value return \\n\");\n\t\t\t\t}\n\
-\t\t\t\tif(ANALYSIS == DC)\n\t\t\t\t{\n\
-\t\t\t\t\tOUTPUT_STATE("+item.split(':')[0]+"[Ii]) = _op_"+item.split(':')[0]+"[Ii];\n\
-\t\t\t\t}\n\t\t\t\telse\n\t\t\t\t{\n\
-\t\t\t\t\tif(_op_"+item.split(':')[0]+"[Ii] != _op_"+item.split(':')[0]+"_old[Ii])\n\
-\t\t\t\t\t{\n\
-\t\t\t\t\t\tOUTPUT_STATE("+item.split(':')[0]+"[Ii]) = _op_"+item.split(':')[0]+"[Ii];\n\
-\t\t\t\t\t\tOUTPUT_DELAY("+item.split(':')[0]+"[Ii]) = ((_op_"+item.split(':')[0]+"[Ii] == ZERO) ? PARAM(fall_delay) : PARAM(rise_delay));\n\
-\t\t\t\t\t}\n\t\t\t\t\telse\n\t\t\t\t\t{\n\
-\t\t\t\t\t\tOUTPUT_CHANGED("+item.split(':')[0]+"[Ii]) = FALSE;\n\t\t\t\t\t}\n\
-\t\t\t\t}\n\t\t\t\tOUTPUT_STRENGTH("+item.split(':')[0]+"[Ii]) = STRONG;\n\
-\t\t\t}\n\
-\t\t\t}\n")
-
-
-els_time_limit='''
-
- else
- {
- char *end_signal="END";
- printf("Closing Ngspice Simulation \\n");
- printf("current time = %g\\n",TIME);
- fprintf(log_client,"Times : Closing Socket \\n");
- snprintf(send_data,sizeof(send_data),"%s",end_signal);
- printf("Client-Value of buffer string is for END signal is %s \\n",send_data);
- printf("Client-Sending data to server from client for end signal \\n");
-
- if ( send(socket_fd,send_data,sizeof(send_data),0)==-1)
- {
- printf("Client-Failure Sending Message for END signal \\n");
- close(socket_fd);
- exit(1);
- }
- else
- {
- printf("Client-Message being sent for END signal : %s\\n",send_data);
- fprintf(log_client,"Socket Id : %d & Message sent : %s for END signal \\n",socket_fd,send_data);
- }
- flag++;
- }
-
- close(socket_fd);
-'''
-
+ sch_output_event.append("\t/* Scheduling event and processing them */\n\
+\tif((key_iter=strstr(recv_data, "+'"'+item.split(':')[0]+':"'")) != NULL)\n\
+\t{\n\
+\t\twhile(*key_iter++ != ':');\n\
+\t\tfor(Ii=0;*key_iter != ';';Ii++,key_iter++)\n\
+\t\t{\n\
+\t\t\tprintf(\"Client- Bit val is %c \\n\",*key_iter);\n\
+\t\t\tfprintf(log_client,\"Client-Bit val is %c \\n\",*key_iter);\n\
+\t\t\tif(*key_iter=='0')\n\t\t\t{\n\
+\t\t\t\tprintf(\"Client-Zero Received \");\n\
+\t\t\t\t_op_"+item.split(':')[0]+"[Ii]=ZERO;\n\t\t\t}\n\
+\t\t\telse if(*key_iter=='1')\n\t\t\t{\n\
+\t\t\t\tprintf(\"Client-One Received \\n\");\n\
+\t\t\t\t_op_"+item.split(':')[0]+"[Ii]=ONE;\n\
+\t\t\t}\n\t\t\telse\n\t\t\t{\n\
+\t\t\t\tfprintf(log_client,\"Unknow value return from server \\n\");\n\
+\t\t\t\tprintf(\"Client-Unknown value return \\n\");\n\t\t\t}\n\n\
+\t\t\tif(ANALYSIS == DC)\n\t\t\t{\n\
+\t\t\t\tOUTPUT_STATE("+item.split(':')[0]+"[Ii]) = _op_"+item.split(':')[0]+"[Ii];\n\
+\t\t\t}\n\t\t\telse if(_op_"+item.split(':')[0]+"[Ii] != _op_"+item.split(':')[0]+"_old[Ii])\n\
+\t\t\t{\n\t\t\t\tOUTPUT_STATE("+item.split(':')[0]+"[Ii]) = _op_"+item.split(':')[0]+"[Ii];\n\
+\t\t\t\tOUTPUT_DELAY("+item.split(':')[0]+"[Ii]) = ((_op_"+item.split(':')[0]+"[Ii] == ZERO) ? PARAM(fall_delay) : PARAM(rise_delay));\n\
+\t\t\t}\n\t\t\telse\n\t\t\t{\n\
+\t\t\t\tOUTPUT_CHANGED("+item.split(':')[0]+"[Ii]) = FALSE;\n\t\t\t}\n\
+\t\t\tOUTPUT_STRENGTH("+item.split(':')[0]+"[Ii]) = STRONG;\n\
+\t\t}\n\
+\t}\n")
#Writing content in cfunc.mod file
cfunc.write(comment)
@@ -529,11 +488,13 @@ for item in els_evt_ptr:
cfunc.write("\n")
cfunc.write("\t}")
cfunc.write("\n\n")
-cfunc.write("\tif(flag==0)\n\t{")
+
cfunc.write(client_fetch_ip)
cfunc.write(create_socket)
cfunc.write(connect_server)
-cfunc.write(time_limit)
+
+cfunc.write("\t//Formating data for sending it to client\n")
+cfunc.write("\tint Ii;\n\n")
for item in assign_data_to_input:
cfunc.write(item)
@@ -546,14 +507,9 @@ cfunc.write(recv_data)
for item in sch_output_event:
cfunc.write(item)
-#End of if statement of time limit
-cfunc.write(2*"\t"+"}")
-
-#Else part of time limit -sending END signal
-cfunc.write(els_time_limit)
-#Close if of flag==0
-cfunc.write("\t}\n\n")
+#Close socket fd
+cfunc.write("\tclose(socket_fd);\n\n")
#close log_client file
cfunc.write("\tfclose(log_client);")
@@ -613,34 +569,24 @@ for item in output_port:
parameter_table='''
PARAMETER_TABLE:
-Parameter_Name: instance_id
-Description: "instance_id"
-Data_Type: real
-Default_Value: 0
-Limits: -
-Vector: no
-Vector_Bounds: -
-Null_Allowed: yes
-
-PARAMETER_TABLE:
-Parameter_Name: rise_delay fall_delay
-Description: "rise delay" "fall delay"
-Data_Type: real real
-Default_Value: 1.0e-9 1.0e-9
-Limits: [1e-12 -] [1e-12 -]
-Vector: no no
-Vector_Bounds: - -
-Null_Allowed: yes yes
+Parameter_Name: instance_id input_load
+Description: "instance_id" "input load value (F)"
+Data_Type: real real
+Default_Value: 0 1.0e-12
+Limits: - -
+Vector: no no
+Vector_Bounds: - -
+Null_Allowed: yes yes
PARAMETER_TABLE:
-Parameter_Name: input_load stop_time
-Description: "input load value (F)" "time at which to shut-down (seconds)"
-Data_Type: real real
-Default_Value: 1.0e-12 1.0
-Limits: - [0.0 -]
-Vector: no no
-Vector_Bounds: - -
-Null_Allowed: yes no
+Parameter_Name: rise_delay fall_delay
+Description: "rise delay" "fall delay"
+Data_Type: real real
+Default_Value: 1.0e-9 1.0e-9
+Limits: [1e-12 -] [1e-12 -]
+Vector: no no
+Vector_Bounds: - -
+Null_Allowed: yes yes
'''