Personal Information

English Fluent, French Conversational
Contact Information
Address: 470 Dawson Avenue, Ottawa, Ontario, K1Z 5V7
Phone (mobile): +1 613 276-6809
Resume: (PDF)

Work Experience

Sandelman Software Works Corporation

IETF ANIMA implementation

2016 to 2018

With partial support from a major router vendor, co-led IETF ANIMA WG secure bootstrap design team, resulting in draft-ietf-anima-voucher, draft-ietf-anima-bootstrapping-keyinfra, as well as open source reference implementation at: Minerva ANIMA reference implementation. Proactively sought cross-working group review, providing leadership in the IOT-Directorate to collect all enrollment efforts into a live roadmap and document.
Worked with RPL implementation in Contiki-OS.

IETF Roll implemenator

2009 to 2016

Wrote an open source implementation of the IETF ROLL RPL protocol for the Linux platform, called unstrung. Release 1.0 is yet to come, but have collaboration from one UK company.
Worked with RPL implementation in Contiki-OS.

IETF Roll co-chair

2012 to 2016

Was asked in 2011 to become the IETF ROLL working group co-chair. Was given a mandate to finish off the security aspects of the ROLL protocol, and many of the related security problems. Trained a new co-chair in late 2013. As part of this work, liased with the Zigbee IP specification writers, became involved with 802.15.4e mode of 802.15.4, leading the security design team of the IETF 6tisch working group, and co-lead for the IETF ANIMA secure bootstrap design team.


1996 to present

Formed Sandelman Software Works as a contract programming and internet security consulting firm. Projects include: device driver development, embedded Linux (PowerPC405, x86, ARM), VPN/IPsec internals /kernel architecture (FreeS/WAN project), BGP setup (both IPv4 and IPv6) and configuration, gForge/Savannah deployment, corporate security policy creation, network design and architecture, firewall evaluation, securing web servers, secure database replication, Virtual Private Network design, project management, Unix systems management, and cryptographic programming (IPsec).

CREDIL: Founder and Managing Editor

YARN project

July 2013 to 2016

Michael updated a Linux-based PPPoE appliance to include IPv6 functionality: DHCPv6 (RFC3315), Prefix-Delegation (RFC3633), packaging, security updates, specification and evaluation of target hardware, customer support, performance testing using SPIRENT system.
Michael worked with the DHCP WG RFC3315bis design team to revise RFC3315.


October 2012 to January 2014

Michael lead a team of two to work on an automated and computer-assisted scheduling system for IETF conferences. This involved in django (1.2), javascript (jQuery, JQUnit) and MySQL.

Sombrero/Heart-of-Gold project

August 2011 to May 2012

Michael worked on the embedded Contiki operating system on two projects. Both used the MSP430F54F38 processor; one used the GNU gcc tool-chain, the other used the IAR MSP tool-chain. Network protocols were involved in both cases: TCP/HTTP/HTML in one, and I2C in the other.

Hydra project

March 2010 to March 2014

Michael worked on a virtual desktop solution for translation students and professional. Managed by a Rails system (see wiki (php5, tikiwiki) and portal), with agents written in perl, visual basic, and powershell, a series of XEN servers provides computing services to 150 students simultaneously.

GAP project

December 2009 to October 2013

Michael brought IPv6 expertise to a number of CREDIL sponsor members, including managing a project to bring fiber-optic Internet (IPv4 and IPv6) to an industrial park in Montreal. This included deploying and debugging routing equipment from multiple vendors to run: STP, BGP4, OSPF, SIP. Michael continues to act as Network Architect, having successfully hired and trained operational staff.

SG1 project

Fall 2011 to October 2013, March 2015 to October 2017

Create customer facing front end (django) and support focused back-end (rails) system to process and present Call Detail Records (CDRs) for VoIP telco. The system has to process 100K records/day, and guaranteeing that one client will not see the other client's records. Extensive postgresql database tuning while managing a team of 3 programmers.

Thomas Watson project

December 2009 to Summer 2010

worked on a new Android phone. Bring up of phone (embedded Linux), debugging, project management. The CREDIL team worked on an H.264 video calling application requiring real time embedded Linux programming, and working with hardware encoders.

Internet Software Consortium

Operations Developer: Solid Name Service (SNS)

January 2014 to October 2014

Took over development and maintenance of anycast based DNS service called SNS. Care and feeding of FreeBSD and Linux based infrastructure, with sh, perl, awk, javascript, Catalyst, PostgresQL and MongoDB components. Took system from all-in-one physical server to easily replicatable and testable VMware vSphere based virtual machines in a more typical front/middle/backend stack.
Updated the DNSSEC Lookaside Validator (, from a ruby 1.8/rails 2/postgresql 8 system, running on FreeBSD 7 hardware, to a ruby 1.9/rails 3/bundler/capistrano/postgresql 9 platform, based upon Linux and FreeBSD 10 virtual platforms.
Participated in some day-to-day activities around f-root server operation and planning.

SIMtone Corporation

Director, Consumer Desktop Development

April 2007 to August 2009

Consumer Desktop Unit (CDU), In charge of overall technical direction for the business unit. Manage people, projects, schedules, and write code. The CDU unit provides virtualized desktops to end-customers using XEN and VMware machine virtualization. Backend management was done by IPv6. Custom software provides provisioning, monitoring, and sign up. Software is written in C, Ruby (on Rails), PHP5/Drupal5, Perl, Java and Visual Basic, using XEN, VMware-server and ESXi APIs.

Xelerance Corporation

VP Research and Development

August 2003 to 2007

Formed Xelerance Corporation. Xelerance Corporation is the Open Source security specialists. Xelerance was the home of Openswan: IPsec for Linux (and continuation of Linux FreeS/WAN). Xelerance also dealt with DNSSEC, producing a product, dnsX. Xelerance practiced Test Driven Development, and geographically dispersed agile methods. As a hands-on VP of R&D, I was in charge of all software development, costing and scheduling for projects. Worked with a number of partners to bring hardware accelerated cryptographic operations to IPsec.

Solidum Systems Corporation

Chief Software Designer

February 1998 to October 2000

Responsible for for multiplatform development environment. Consulting with hardware designers and product managers on appropriate design of multi-gigabit packet classification ASSP. PCI device driver work for Linux, NetBSD and VxWorks for multiple products, including network adapters. Technical liason with partners, including most major NPU vendors, lookup engine vendors, and operating system vendors. Worked on all major layer 2, layer 3+ protocols: MPLS, Ethernet, Packet-over-SONET, IPv4, IPv6, TCP, L2TP, PPPoE, ATM/LANE, SSL, HTTP.

Field Application Engineer

October 2000 to August 2001

Given superior communications skills, was asked to join salesforce. Responsible for technical presentation to prospective customers, customization of solution to customer need, specification of product requirements, and delivery of technical solutions to customers.
Solidum was acquired by IDT in the fall of 2001.

Milkyway Networks Corporation

Technical manager, System Software

October 1994 to October 1996

Responsible for multiplatform development environment, project schedule, functional specification and assignment of work. Majority of Unix kernel work. C/CVS/Perl under Unix (BSDI/386 and SunOS). Maintenance of ongoing product. Porting to SVR4. Liason to IETF, advanced product research: IPsec, Kerberos, customization. Some VxWorks and ObjecTime. Milkyway Networks (now defunct) made the world's first transparent application layer firewall, originally called the BlackHole.

Bell Northern Research (BNR)

April to October 1994

Work group administrator in FiberWorld Products division. Internal telephone support for computing environment including day-to-day system management, and problem resolution. 1000+ user population on heterogeneous Unix networks (NCD,Sun,HP,Apollo,Mac).
(BNR + Northern Telecom merged to become Nortel and then Nortel Networks)

Achilles Networking

parttime 1992 to 1996

System administrator in startup internet services company. Set up and support for email (DNS, SMTP, UUCP, etc..) and news (INN: NNTP and UUCP). Security auditing.

Carleton University, Ottawa

August 1993 to 1994

Publisher and technical support for a new electronic journal: Conservation Ecology: a peer reviewed journal. Experience with World-Wide-Web (NCSA Mosaic), gopher, anonymous ftp and email servers.

Carp Systems International/Enterprise Planning Systems


Full time Unix network administrator responsable for smooth operation of a dozen Unix hosts (RS/6000 running AIX, HP running HP-UX, SVR4, SCO and Windows on 386, X terminals, Macintosh, others) in an R&D environment of 30+ people. Numerous upgrades and enhancements performed including portions of a platform independant environment for source and binaries.

Fountain Technical Services

1989 to 1991

This job entailed many day to day elements of system administration and system configuration combined with evaluation of various hardware and software products prior to installation at customer sites. Configuration and change management tools were created and prototyped in a variety of languages and environments including: Foxbase, Prolog, Smalltalk.

Cadence Design Automation (formally SDA systems)

summer 1986, summer 1987, and summer 1992

Use of Sun 4 based VLSI design tools including Tangate's Cell-3C, Cadence Framework (Edge) versions 2 - 4.0. Experience writting high level user interfaces in the LISP/C-like language Skill, and writing of analytical geometry programs in C within a large CAD database environment.

Academic Experience


Interpersonal Skills

Entrepreneurial Experience

Personal Interests