Pressuponho que a VPN já esteja funcionando e que as máquinas já estejam se comunicando pelo IP da VPN (o servidor com 10.0.0.11 e o cliente com 10.0.0.1).
Supondo que a rede do servidor seja 192.168.1.0/24 e a do cliente 192.168.100.0/24, o esquema é simples, adicionar as seguintes linhas em algum arquivo que inicia junto com o
Linux.
No servidor:
/sbin/route add -net 192.168.100.0 netmask 255.255.255.0 gw 10.0.0.11
No cliente:
/sbin/route add -net 192.168.1.0 netmask 255.255.255.0 gw 10.0.0.1
A partir dessa configuração estará definido que todo pacote enviado para um IP que está na outra rede irá passar pelo túnel, ou seja, se na rede do servidor, algum micro da rede do 192.168.100.0 tentar 'pingar' algum da rede 192.168.1.0, irá conseguir.
Ok, vamos para a parte que nos "enche o saco". Se as duas redes usarem faixa de IP 192.168.1.0/24, não temos como pingar um IP da outra rede, pois qualquer pacote enviado para a rede 192.168.1.0/24 não irá passar pelo túnel, ou se você preferir configurar para passar pelo túnel, o micro não conseguirá se comunicar com a própria rede (isso muitas vezes inclui o próprio gateway, então nem vou começar a falar dos problemas que isso irá custar).
A solução por mim encontrada foi mascarar via iptables as redes e "enganar as rotas". Um exemplo disso, quando a rede do servidor tentar pingar o IP 192.168.5.50, ele irá pingar o micro com IP 192.168.1.50, que está na rede do cliente. Vamos às regras.
Rede A (não importa se é cliente ou servidor):
# route add -net 192.168.5.0 netmask 255.255.255.0 gw 10.0.0.11
(através dessa regra definimos que tudo que vai para a rede 192.168.5.0/24 passará pelo túnel)
Rede B (não importa se é cliente ou servidor):
# iptables -t nat -A PREROUTING -d 192.168.5.0/24 -j NETMAP --to 192.168.1.0/24
(através dessa regra todo pacote que vier com destino à rede 192.168.5.0/24 será destinado à rede 192.168.1.0/24)
E é assim que a coisa funciona. Pessoal, esse foi meu primeiro artigo, me perdoem pela falta de didática, espero que tenham entendido, mas para quem não tiver entendido, ou se algum procedimento falhar, estou à disposição para tirar dúvidas.