commit-gnuradio
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[Commit-gnuradio] r11063 - in gnuradio/trunk/grc: data/platforms/python


From: jblum
Subject: [Commit-gnuradio] r11063 - in gnuradio/trunk/grc: data/platforms/python data/platforms/python/blocks src/grc_gnuradio/blks2
Date: Tue, 19 May 2009 19:06:55 -0600 (MDT)

Author: jblum
Date: 2009-05-19 19:06:55 -0600 (Tue, 19 May 2009)
New Revision: 11063

Added:
   gnuradio/trunk/grc/data/platforms/python/blocks/blks2_tcp_sink.xml
   gnuradio/trunk/grc/data/platforms/python/blocks/blks2_tcp_source.xml
   gnuradio/trunk/grc/src/grc_gnuradio/blks2/tcp.py
Modified:
   gnuradio/trunk/grc/data/platforms/python/block_tree.xml
   gnuradio/trunk/grc/data/platforms/python/blocks/Makefile.am
   gnuradio/trunk/grc/src/grc_gnuradio/blks2/Makefile.am
   gnuradio/trunk/grc/src/grc_gnuradio/blks2/__init__.py
Log:
Added custom grc_blks2 tcp source and sink blocks + wrappers.



Modified: gnuradio/trunk/grc/data/platforms/python/block_tree.xml
===================================================================
--- gnuradio/trunk/grc/data/platforms/python/block_tree.xml     2009-05-19 
23:56:09 UTC (rev 11062)
+++ gnuradio/trunk/grc/data/platforms/python/block_tree.xml     2009-05-20 
01:06:55 UTC (rev 11063)
@@ -16,6 +16,7 @@
                <block>gr_glfsr_source_x</block>
                <block>gr_null_source</block>
                <block>gr_file_source</block>
+               <block>blks2_tcp_source</block>
                <block>gr_udp_source</block>
                <block>audio_source</block>
                <block>gr_wavfile_source</block>
@@ -27,6 +28,7 @@
                <block>gr_vector_sink_x</block>
                <block>gr_null_sink</block>
                <block>gr_file_sink</block>
+               <block>blks2_tcp_sink</block>
                <block>gr_udp_sink</block>
                <block>audio_sink</block>
                <block>gr_wavfile_sink</block>

Modified: gnuradio/trunk/grc/data/platforms/python/blocks/Makefile.am
===================================================================
--- gnuradio/trunk/grc/data/platforms/python/blocks/Makefile.am 2009-05-19 
23:56:09 UTC (rev 11062)
+++ gnuradio/trunk/grc/data/platforms/python/blocks/Makefile.am 2009-05-20 
01:06:55 UTC (rev 11063)
@@ -52,6 +52,8 @@
        blks2_standard_squelch.xml \
        blks2_stream_to_vector_decimator.xml \
        blks2_synthesis_filterbank.xml \
+       blks2_tcp_sink.xml \
+       blks2_tcp_source.xml \
        blks2_valve.xml \
        blks2_variable_sink_x.xml \
        blks2_wfm_rcv.xml \

Copied: gnuradio/trunk/grc/data/platforms/python/blocks/blks2_tcp_sink.xml 
(from rev 11059, 
gnuradio/trunk/grc/data/platforms/python/blocks/gr_udp_sink.xml)
===================================================================
--- gnuradio/trunk/grc/data/platforms/python/blocks/blks2_tcp_sink.xml          
                (rev 0)
+++ gnuradio/trunk/grc/data/platforms/python/blocks/blks2_tcp_sink.xml  
2009-05-20 01:06:55 UTC (rev 11063)
@@ -0,0 +1,89 @@
+<?xml version="1.0"?>
+<!--
+###################################################
+##TCP Sink: Custom blks2 block
+###################################################
+ -->
+<block>
+       <name>TCP Sink</name>
+       <key>blks2_tcp_sink</key>
+       <import>from grc_gnuradio import blks2 as grc_blks2</import>
+       <make>grc_blks2.tcp_sink(
+       itemsize=$type.size*$vlen,
+       addr=$addr,
+       port=$port,
+       server=$server,
+)</make>
+       <param>
+               <name>Input Type</name>
+               <key>type</key>
+               <type>enum</type>
+               <option>
+                       <name>Complex</name>
+                       <key>complex</key>
+                       <opt>size:gr.sizeof_gr_complex</opt>
+               </option>
+               <option>
+                       <name>Float</name>
+                       <key>float</key>
+                       <opt>size:gr.sizeof_float</opt>
+               </option>
+               <option>
+                       <name>Int</name>
+                       <key>int</key>
+                       <opt>size:gr.sizeof_int</opt>
+               </option>
+               <option>
+                       <name>Short</name>
+                       <key>short</key>
+                       <opt>size:gr.sizeof_short</opt>
+               </option>
+               <option>
+                       <name>Byte</name>
+                       <key>byte</key>
+                       <opt>size:gr.sizeof_char</opt>
+               </option>
+       </param>
+       <param>
+               <name>Address</name>
+               <key>addr</key>
+               <value>127.0.0.1</value>
+               <type>string</type>
+       </param>
+       <param>
+               <name>Port</name>
+               <key>port</key>
+               <value>0</value>
+               <type>int</type>
+       </param>
+       <param>
+               <name>Mode</name>
+               <key>server</key>
+               <value>False</value>
+               <type>enum</type>
+               <option>
+                       <name>Server</name>
+                       <key>True</key>
+               </option>
+               <option>
+                       <name>Client</name>
+                       <key>False</key>
+               </option>
+       </param>
+       <param>
+               <name>Vec Length</name>
+               <key>vlen</key>
+               <value>1</value>
+               <type>int</type>
+       </param>
+       <check>$vlen &gt; 0</check>
+       <sink>
+               <name>in</name>
+               <type>$type</type>
+               <vlen>$vlen</vlen>
+       </sink>
+               <doc>
+In client mode, we attempt to connect to a server at the given address and 
port. \
+In server mode, we bind a socket to the given address and port and accept the 
first client.
+       </doc>
+</block>


Property changes on: 
gnuradio/trunk/grc/data/platforms/python/blocks/blks2_tcp_sink.xml
___________________________________________________________________
Added: svn:mergeinfo
   + 
/gnuradio/branches/developers/eb/t348/grc/data/platforms/python/blocks/gr_udp_sink.xml:10638-10648
/gnuradio/branches/developers/eb/t364/grc/data/platforms/python/blocks/gr_udp_sink.xml:11016-11017
/gnuradio/branches/developers/eb/t367/grc/data/platforms/python/blocks/gr_udp_sink.xml:11021-11025
/gnuradio/branches/developers/eb/t371/grc/data/platforms/python/blocks/gr_udp_sink.xml:10958-10971
/gnuradio/branches/developers/eb/t378/grc/data/platforms/python/blocks/gr_udp_sink.xml:10683-10688
/gnuradio/branches/developers/jblum/grc/grc/data/platforms/python/blocks/gr_udp_sink.xml:10680-10938
/gnuradio/branches/developers/jblum/gui_guts/grc/data/platforms/python/blocks/gr_udp_sink.xml:10464-10658
/gnuradio/branches/developers/jblum/vlen/grc/data/platforms/python/blocks/gr_udp_sink.xml:10667-10677
/gnuradio/branches/developers/jcorgan/cpphier/grc/data/platforms/python/blocks/gr_udp_sink.xml:10818-10858
/gnuradio/branches/developers/jcorgan/deb/grc/data/platforms/python/blocks/gr_udp_sink.xml:10949-10959,11013-11022
/gnuradio/branches/developers/jcorgan/fw-optimize/grc/data/platforms/python/blocks/gr_udp_sink.xml:10428-10429
/gnuradio/branches/developers/jcorgan/gpio2/grc/data/platforms/python/blocks/gr_udp_sink.xml:10713-10765
/gnuradio/branches/developers/jcorgan/iad2/grc/data/platforms/python/blocks/gr_udp_sink.xml:10771-10887
/gnuradio/branches/developers/jcorgan/t161/grc/data/platforms/python/blocks/gr_udp_sink.xml:10876-10880
/gnuradio/branches/developers/michaelld/am_swig_4/grc/data/platforms/python/blocks/gr_udp_sink.xml:10555-10595
/gnuradio/branches/developers/michaelld/two_mods/grc/data/platforms/python/blocks/gr_udp_sink.xml:10540-10546

Copied: gnuradio/trunk/grc/data/platforms/python/blocks/blks2_tcp_source.xml 
(from rev 11059, 
gnuradio/trunk/grc/data/platforms/python/blocks/gr_udp_source.xml)
===================================================================
--- gnuradio/trunk/grc/data/platforms/python/blocks/blks2_tcp_source.xml        
                        (rev 0)
+++ gnuradio/trunk/grc/data/platforms/python/blocks/blks2_tcp_source.xml        
2009-05-20 01:06:55 UTC (rev 11063)
@@ -0,0 +1,89 @@
+<?xml version="1.0"?>
+<!--
+###################################################
+##TCP Source: Custom blks2 block
+###################################################
+ -->
+<block>
+       <name>TCP Source</name>
+       <key>blks2_tcp_source</key>
+       <import>from grc_gnuradio import blks2 as grc_blks2</import>
+       <make>grc_blks2.tcp_source(
+       itemsize=$type.size*$vlen,
+       addr=$addr,
+       port=$port,
+       server=$server,
+)</make>
+       <param>
+               <name>Output Type</name>
+               <key>type</key>
+               <type>enum</type>
+               <option>
+                       <name>Complex</name>
+                       <key>complex</key>
+                       <opt>size:gr.sizeof_gr_complex</opt>
+               </option>
+               <option>
+                       <name>Float</name>
+                       <key>float</key>
+                       <opt>size:gr.sizeof_float</opt>
+               </option>
+               <option>
+                       <name>Int</name>
+                       <key>int</key>
+                       <opt>size:gr.sizeof_int</opt>
+               </option>
+               <option>
+                       <name>Short</name>
+                       <key>short</key>
+                       <opt>size:gr.sizeof_short</opt>
+               </option>
+               <option>
+                       <name>Byte</name>
+                       <key>byte</key>
+                       <opt>size:gr.sizeof_char</opt>
+               </option>
+       </param>
+       <param>
+               <name>Address</name>
+               <key>addr</key>
+               <value>127.0.0.1</value>
+               <type>string</type>
+       </param>
+       <param>
+               <name>Port</name>
+               <key>port</key>
+               <value>0</value>
+               <type>int</type>
+       </param>
+       <param>
+               <name>Mode</name>
+               <key>server</key>
+               <value>True</value>
+               <type>enum</type>
+               <option>
+                       <name>Server</name>
+                       <key>True</key>
+               </option>
+               <option>
+                       <name>Client</name>
+                       <key>False</key>
+               </option>
+       </param>
+       <param>
+               <name>Vec Length</name>
+               <key>vlen</key>
+               <value>1</value>
+               <type>int</type>
+       </param>
+       <check>$vlen &gt; 0</check>
+       <source>
+               <name>out</name>
+               <type>$type</type>
+               <vlen>$vlen</vlen>
+       </source>
+       <doc>
+In client mode, we attempt to connect to a server at the given address and 
port. \
+In server mode, we bind a socket to the given address and port and accept the 
first client.
+       </doc>
+</block>


Property changes on: 
gnuradio/trunk/grc/data/platforms/python/blocks/blks2_tcp_source.xml
___________________________________________________________________
Added: svn:mergeinfo
   + 
/gnuradio/branches/developers/eb/t348/grc/data/platforms/python/blocks/gr_udp_source.xml:10638-10648
/gnuradio/branches/developers/eb/t364/grc/data/platforms/python/blocks/gr_udp_source.xml:11016-11017
/gnuradio/branches/developers/eb/t367/grc/data/platforms/python/blocks/gr_udp_source.xml:11021-11025
/gnuradio/branches/developers/eb/t371/grc/data/platforms/python/blocks/gr_udp_source.xml:10958-10971
/gnuradio/branches/developers/eb/t378/grc/data/platforms/python/blocks/gr_udp_source.xml:10683-10688
/gnuradio/branches/developers/jblum/grc/grc/data/platforms/python/blocks/gr_udp_source.xml:10680-10938
/gnuradio/branches/developers/jblum/gui_guts/grc/data/platforms/python/blocks/gr_udp_source.xml:10464-10658
/gnuradio/branches/developers/jblum/vlen/grc/data/platforms/python/blocks/gr_udp_source.xml:10667-10677
/gnuradio/branches/developers/jcorgan/cpphier/grc/data/platforms/python/blocks/gr_udp_source.xml:10818-10858
/gnuradio/branches/developers/jcorgan/deb/grc/data/platforms/python/blocks/gr_udp_source.xml:10949-10959,11013-11022
/gnuradio/branches/developers/jcorgan/fw-optimize/grc/data/platforms/python/blocks/gr_udp_source.xml:10428-10429
/gnuradio/branches/developers/jcorgan/gpio2/grc/data/platforms/python/blocks/gr_udp_source.xml:10713-10765
/gnuradio/branches/developers/jcorgan/iad2/grc/data/platforms/python/blocks/gr_udp_source.xml:10771-10887
/gnuradio/branches/developers/jcorgan/t161/grc/data/platforms/python/blocks/gr_udp_source.xml:10876-10880
/gnuradio/branches/developers/michaelld/am_swig_4/grc/data/platforms/python/blocks/gr_udp_source.xml:10555-10595
/gnuradio/branches/developers/michaelld/two_mods/grc/data/platforms/python/blocks/gr_udp_source.xml:10540-10546

Modified: gnuradio/trunk/grc/src/grc_gnuradio/blks2/Makefile.am
===================================================================
--- gnuradio/trunk/grc/src/grc_gnuradio/blks2/Makefile.am       2009-05-19 
23:56:09 UTC (rev 11062)
+++ gnuradio/trunk/grc/src/grc_gnuradio/blks2/Makefile.am       2009-05-20 
01:06:55 UTC (rev 11063)
@@ -29,4 +29,5 @@
        packet.py \
        probe.py \
        selector.py \
+       tcp.py \
        variable_sink.py

Modified: gnuradio/trunk/grc/src/grc_gnuradio/blks2/__init__.py
===================================================================
--- gnuradio/trunk/grc/src/grc_gnuradio/blks2/__init__.py       2009-05-19 
23:56:09 UTC (rev 11062)
+++ gnuradio/trunk/grc/src/grc_gnuradio/blks2/__init__.py       2009-05-20 
01:06:55 UTC (rev 11063)
@@ -25,3 +25,4 @@
 from error_rate import error_rate
 from probe import probe_function, probe_avg_mag_sqrd_c, probe_avg_mag_sqrd_f, 
probe_density_b, probe_mpsk_snr_c
 from variable_sink import variable_sink_b, variable_sink_s, variable_sink_i, 
variable_sink_f, variable_sink_c
+from tcp import tcp_source, tcp_sink

Added: gnuradio/trunk/grc/src/grc_gnuradio/blks2/tcp.py
===================================================================
--- gnuradio/trunk/grc/src/grc_gnuradio/blks2/tcp.py                            
(rev 0)
+++ gnuradio/trunk/grc/src/grc_gnuradio/blks2/tcp.py    2009-05-20 01:06:55 UTC 
(rev 11063)
@@ -0,0 +1,66 @@
+#
+# Copyright 2009 Free Software Foundation, Inc.
+#
+# This file is part of GNU Radio
+#
+# GNU Radio is free software; you can redistribute it and/or modify
+# it under the terms of the GNU General Public License as published by
+# the Free Software Foundation; either version 3, or (at your option)
+# any later version.
+#
+# GNU Radio is distributed in the hope that it will be useful,
+# but WITHOUT ANY WARRANTY; without even the implied warranty of
+# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
+# GNU General Public License for more details.
+#
+# You should have received a copy of the GNU General Public License
+# along with GNU Radio; see the file COPYING.  If not, write to
+# the Free Software Foundation, Inc., 51 Franklin Street,
+# Boston, MA 02110-1301, USA.
+#
+
+from gnuradio import gr
+import socket
+import os
+
+def _get_sock_fd(addr, port, server):
+       """
+       Get the file descriptor for the socket.
+       As a client, block on connect, dup the socket descriptor.
+       As a server, block on accept, dup the client descriptor.
+       @param addr the ip address string
+       @param port the tcp port number
+       @param server true for server mode, false for client mode
+       @return the file descriptor number
+       """
+       sock = socket.socket(socket.AF_INET, socket.SOCK_STREAM)
+       if server:
+               sock.bind((addr, port))
+               sock.listen(1)
+               clientsock, address = sock.accept()
+               return os.dup(clientsock.fileno())
+       else:
+               sock.connect((addr, port))
+               return os.dup(sock.fileno())
+
+class tcp_source(gr.hier_block2):
+       def __init__(self, itemsize, addr, port, server=True):
+               #init hier block
+               gr.hier_block2.__init__(
+                       self, 'tcp_source',
+                       gr.io_signature(0, 0, 0),
+                       gr.io_signature(1, 1, itemsize),
+               )
+               fd = _get_sock_fd(addr, port, server)
+               self.connect(gr.file_descriptor_source(itemsize, fd), self)
+
+class tcp_sink(gr.hier_block2):
+       def __init__(self, itemsize, addr, port, server=False):
+               #init hier block
+               gr.hier_block2.__init__(
+                       self, 'tcp_sink',
+                       gr.io_signature(1, 1, itemsize),
+                       gr.io_signature(0, 0, 0),
+               )
+               fd = _get_sock_fd(addr, port, server)
+               self.connect(self, gr.file_descriptor_sink(itemsize, fd))





reply via email to

[Prev in Thread] Current Thread [Next in Thread]