Vivek, Thank you for your detailed reply. I think I did not give you enough description of what I need. The following is a simplied situation: Basically, it's a standard cluster configuration: 1 normal PC as frontend, and 3 backends. When a TCP packet arrives at the frontend, the frontend will forward it to 2 of the 3 backends after examines the packet. I want this forwarding to be done using MAC multicast. I cannot use ip multicast because this require IP tunnelling (original IP header has to be keep intact). What I can think of the forwarding pseudo-code is like this: when packet comes in 1) validity check and other work 2) decide which connection it belongs to. 3) decide which backend this packet will be forwarded, i.e. which MAC multicast address will be used 4) invoke ip_send() to send out the packet. So how can tell the underneath protocol to use the choosed MAC multicast address without changing the code. I guess it must have something to do with the routing table, since this is how IP multicast is done. but I just don't have any clue. Thanks. Ronghua On Fri, 16 May 2003, Vivek wrote: > --=_IS_MIME_Boundary > > > Group multicast addresses are there i.e. mac address with the first bit > set > > to one. example: 11:22:33:44:55:66 is a group multicast address. > > for details, look at tcp/ip illustrated(stevens n wright) pg 341. > > > What I think is that there are no such thing as MAC multicast, correct > me > > if I am wrong , thanks. I think when MAC address of a packet with a > > multicast address is sent to a physical subnet, it should be > > FF:FF:FF:FF:FF:FF , ie. for all to receive. > > this is a special case of multicast MAC address > > > >I want to implement packet forwarding using MAC multicast. Basically, > what > > >I want to acheive is the following: a frontend machine accept packets > from > > >client side and forwards the packets to more than one backend machines. > > You need to have hardware switching capability for best results. I guess u > probably have a data switch as ur frontend, with backends directly > connected to its different interfaces. Look into the switch manuals to > understand how to enable it to perform the hardware multicast forwarding. > > If, instead, you have a regular multihomed host, I'd suggest following > choices:- > > 1. Use IP multicasting instead. Matter of fact I think that's the easiest > possibility. > > 2. Or maybe you have a single driver controlling all the interfaces. Then > this driver could have the added functionality to forward between these > interfaces based on the multicast MAC address. Normally such is not the > case. Drivers generally leave the forwarding capability to the network stack > or the hardware switch. > > 3. Use vlans. Let all your backends be on a single vlan. Broadcast to this > vlan. > > Vivek. > -- > ********************************************************* > What is evil to thee does not subsist in the ruling principle of another; > nor yet in any turning and mutation of thy corporeal covering. > Where is it then? or is it really there?...it? what?? > - Marcus Aurelius and Vivek in The Meditations and My Interpretations > :-) > ********************************************************* > "atul" <atul.gupta@wipro.com> wrote in message > NHBBJCIOGDENKEIHCAJGEEJNCDAA.atul.gupta@wipro.com">news:NHBBJCIOGDENKEIHCAJGEEJNCDAA.atul.gupta@wipro.com... > > Group multicast addresses are there i.e. mac address with the first bit > set > > to one. example: 11:22:33:44:55:66 is a group multicast address. > > To send the packet to more than one backend machines (which are hidden > from > > client either through router/server frontend machine in your case) you > have > > to run some application at your frontend machine which can retrieve the > > header information from the client and forwards the packet to all machines > > in any particular group. > > You can take some idea how ARP packets are sent, ARP cache is built. > > -----Original Message----- > > From: linux-net-owner@vger.kernel.org > > [mailto:linux-net-owner@vger.kernel.org]On Behalf Of Tace > > Sent: Thursday, May 15, 2003 5:56 PM > > To: linux-net@vger.kernel.org; Ronghua Zhang > > Cc: kernelnewbies@nl.linux.org > > Subject: Re: packet forwarding using MAC multicast > > > > > > Hi, > > What I think is that there are no such thing as MAC multicast, correct > me > > if I am wrong , thanks. I think when MAC address of a packet with a > > multicast address is sent to a physical subnet, it should be > > FF:FF:FF:FF:FF:FF , ie. for all to receive. > > > > Tace > > > > On Thu, 15 May 2003 16:58:01 > > Ronghua Zhang wrote: > > >I want to implement packet forwarding using MAC multicast. Basically, > what > > >I want to acheive is the following: a frontend machine accept packets > from > > >client side and forwards the packets to more than one backend machines. > > >The easiest way is simply forwarding packet once for each backend. But > > >this will consume too much bandwidth, that's why I resort to multicast. > > >But I have no idea how to let the MAC layer send a packet to a multicast > > >address, Anybody can shed some light on this? Thanks. > > > > > >ronghua > > >- > > >To unsubscribe from this list: send the line "unsubscribe linux-net" in > > >the body of a message to majordomo@vger.kernel.org > > >More majordomo info at http://vger.kernel.org/majordomo-info.html > > > > > > > > > ____________________________________________________________ > > Get advanced SPAM filtering on Webmail or POP Mail ... Get Lycos Mail! > > http://login.mail.lycos.com/r/referral?aid=27005 > > - > > To unsubscribe from this list: send the line "unsubscribe linux-net" in > > the body of a message to majordomo@vger.kernel.org > > More majordomo info at http://vger.kernel.org/majordomo-info.html > > > > -- > > Kernelnewbies: Help each other learn about the Linux kernel. > > Archive: http://mail.nl.linux.org/kernelnewbies/ > > FAQ: http://kernelnewbies.org/faq/ > > > > > --=_IS_MIME_Boundary > Content-Type: text/plain;charset=us-ascii > Content-Transfer-Encoding: 7bit > Content-Disposition: inline > > ************************************************************************ > > SASKEN BUSINESS DISCLAIMER > > This message may contain confidential, proprietary or legally Privileged information. In case you are not the original intended Recipient of the message, you must not, directly or indirectly, use, Disclose, distribute, print, or copy any part of this message and you are requested to delete it and inform the sender. Any views expressed in this message are those of the individual sender unless otherwise stated. Nothing contained in this message shall be construed as an offer or acceptance of any offer by Sasken Communication Technologies Limited ("Sasken") unless sent with that express intent and with due authority of Sasken. Sasken has taken enough precautions to prevent the spread of viruses. However the company accepts no liability for any damage caused by any virus transmitted by this email. > > *********************************************************************** > > --=_IS_MIME_Boundary-- > -- > Kernelnewbies: Help each other learn about the Linux kernel. > Archive: http://mail.nl.linux.org/kernelnewbies/ > FAQ: http://kernelnewbies.org/faq/ > -- Kernelnewbies: Help each other learn about the Linux kernel. Archive: http://mail.nl.linux.org/kernelnewbies/ FAQ: http://kernelnewbies.org/faq/